- 
                Notifications
    You must be signed in to change notification settings 
- Fork 426
Getting Started
New to cross? Cross-compilation? Container engines? Here's how to get up-and-running.
Table of Contents
cross requires a rustup installation of Rust. To do so, the recommended instructions are documented here, but might differ on some platforms. For UNIX-like systems, run the following command in a terminal and follow the instructions to install Rust and add Rust to the path:
curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | shOn Windows, download rustup-init.exe or following the other installation methods, say, to install from a package manager.
On some platforms, such as NixOS, you might need to use a package manager since the default rustup install will fail. On NixOS, you should run the following, which will install rustup and the latest stable release of Rust.
nix-env -i rustup
rustup toolchain install stableNote that you might need additional tools on some platforms to get rustc and cargo working. On UNIX-like systems, this generally means an install of GCC or Clang. For example, on NixOS you will likely need to install GCC via nix-env -i gcc and then go into a GCC and Rust shell (nix-shell -p gcc rustup). On Alpine, you'll need to run apk add libgcc gcc musl-dev. Exact instructions will differ by OS and Linux distro, feel free to ask on the discussion or our Matrix room if you have any questions.
Once cargo is installed via rustup, and the necessary additional tools are present, you can now install cross via cargo:
cargo install cross
# Optionally, if you have bininstall, you can install via pre-built binary
cargo bininstall crossOnce cross is installed, you need a container engine and you can start cross-compiling.
On Windows and macOS, we generally recommend you use Docker unless you know what you're doing. Docker Desktop install instructions can be found here. On Linux, you can either install via Docker Engine, Docker Desktop or Podman. We generally recommend Podman, since it runs rootless by default. If you choose to use Docker, make sure you add users to the docker group so it can be run without sudo (note that this has security implications) or use rootless Docker.
Once your container engine is installed, you can check that it is running via:
# or us podman, if installed
$ docker ps -aOnce both cross and the container engine are installed, you can build your first package: this is all that's required.
$ cargo init --bin hello
$ cd hello
$ cross run --target aarch64-unknown-linux-gnu
   Compiling hello v0.1.0 (/project)
    Finished dev [unoptimized + debuginfo] target(s) in 0.64s
     Running `/linux-runner aarch64 /target/aarch64-unknown-linux-gnu/debug/hello`
Hello, world!This will automatically install the Rust target required and the Docker image containing the toolchain to cross-compile your target.