Building Redox
Congrats on making it this far! Now you will build Redox. This process is for x86-64 machines (Intel/AMD). There are also similar processes for i686 and AArch64/ARM64.
The build process fetches files from the Redox Gitlab server. From time to time, errors may occur which may result in you being asked to provide a username and password during the build process. If this happens, first check for typos in the git
URL. If that doesn't solve the problem and you don't have a Redox GitLab login, try again later, and if it continues to happen, you can let us know through the chat.
To avoid bugs from different build environments (operating systems) we are using Rootless Podman for major parts of the build. Podman is invoked automatically and transparently within the Makefiles.
The TL;DR version is here. More details are available in the Advanced Podman Build page.
You can find out more about Podman on the Podman documentation.
(Don't forget to read the Build System page to know our build system organization and how it works)
Podman Build Overview
Podman is a container manager that creates containers to execute a Linux distribution image. In our case, we are creating an Debian image, with a Rust installation and all the dependencies needed to build the system and programs.
The build process is performed in your normal working directory, e.g., ~/tryredox/redox
. Compilation of the Redox components is performed in the container, but the final Redox image (build/$ARCH/$CONFIG/harddrive.img
or build/$ARCH/$CONFIG/livedisk.iso
) is constructed using FUSE running directly on your host machine.
Setting PODMAN_BUILD
to 1 in .config, on the make
command line (e.g., make PODMAN_BUILD=1 all
) or in the environment (e.g., export PODMAN_BUILD=1; make all
) will enable Podman.
First, a base image called redox_base
will be constructed, with all the necessary packages for the build system. A "home" directory will also be created in build/podman
. This is the home directory of your container alter ego, poduser
. It will contain the rustup
install, and the .bashrc
. This takes some time, but is only done when necessary. The tag file build/container.tag is also created at this time to prevent unnecessary image builds.
Then, various make
commands are executed in containers built from the base image. The files are constructed in your working directory tree, just as they would for a non-Podman build. In fact, if all necessary packages are installed on your host system, you can switch Podman on and off relatively seamlessly, although there is no benefit of doing so.
The build process is using Podman's keep-id
feature, which allows your regular User ID to be mapped to poduser
in the container. The first time a container is built, it takes some time to set up this mapping. After the first container is built, new containers can be built almost instantly.
TL;DR - New or Existing Working Directory
New Working Directory
If you have already read the Building Redox instructions, but you wish to use Podman Build, follow these steps:
-
Ensure you have the
curl
program installed. e.g., for Pop!_OS/Ubuntu/Debian:which curl || sudo apt-get install curl
-
Create a new directory and run
podman_bootstrap.sh
inside of it. This will clone the repository and install Podman.mkdir -p ~/tryredox
cd ~/tryredox
curl -sf https://gitlab.redox-os.org/redox-os/redox/raw/master/podman_bootstrap.sh -o podman_bootstrap.sh
time bash -e podman_bootstrap.sh
You may be asked which QEMU installation you want. Please select
full
.You may be asked which Podman container runtime you want to use,
crun
orrunc
. Choosecrun
, butrunc
will also work. -
Update your path to include
cargo
and the Rust compiler.source ~/.cargo/env
-
Navigate to the
redox
directory.cd ~/tryredox/redox
-
Build the system. This will take some time.
time make all
Existing Working Directory
If you already have the build system, simply perform the following steps:
-
Change to your working directory
cd ~/tryredox/redox
-
Update the build system and wipe all binaries
make pull clean
-
Install Podman. If your Linux distribution is not supported, check the installation instructions to determine which dependencies are needed. Or, run the following in your
redox
base` directory:./podman_bootstrap.sh -d
-
Enable Podman.
nano .config
PODMAN_BUILD?=1
📝 Note: the initial container setup for the Podman build can take 15 minutes or more, but it is comparable in speed to native build after that.
-
Build the Redox image.
make all
Run in a virtual machine
You can immediately run the new image (build/x86_64/desktop/harddrive.img
) in a virtual machine with the following command:
make qemu
📝 Note: if you are building the system using
build.sh
to change the CPU architecture or filesystem contents, you can also provide theqemu
option to run the virtual machine:./build.sh -a i686 -c demo qemu
This will build
build/i686/demo/harddrive.img
(if it doesn't already exist) and run it in the QEMU emulator.
The emulator will display the Redox GUI (Orbital). See Using the emulation for general instructions and Trying out Redox for things to try.
Run without a GUI
To run the virtual machine without a GUI, use:
make qemu gpu=no
If you want to capture the terminal output, read the Debug Methods section.
💡 Tip: if you encounter problems running the virtual machine, try turning off various virtualization features with
make qemu kvm=no
ormake qemu iommu=no
. These same arguments can also be used withbuild.sh
.
QEMU Tap For Network Testing
Expose Redox to other computers within a LAN. Configure QEMU with a "TAP" which will allow other computers to test Redox client/server/networking capabilities.
Please join the chat if this is something you are interested in pursuing.
Building A Redox Bootable Image
Read the Testing on Real Hardware section.
Contributor Note
If you intend to contribute to Redox or its subprojects, please read the CONTRIBUTING document to understand how the Redox build system works, and how to set up your repository fork appropriately. You can use ./bootstrap.sh -d
in the redox
folder to install the prerequisite packages if you have already done a git clone
of the sources.
If you encounter any bugs, errors, obstructions, or other annoying things, please join the chat or report the issue to the build system repository or a proper repository for the component. Thanks!
build.sh
build.sh
is a shell script for quickly invoking make
for a specified variant, CPU architecture, and output file.
💡 Tip: for doing Redox development, such settings should usually be configured in the
.config
file (see the Configuration Settings page). But for users who are just trying things out, thebuild.sh
script can be used to runmake
for you.
Example 1
The following builds the server
variant of Redox for the i686
(32-bit Intel/AMD) CPU architecture (defined in config/i686/server.toml
):
./build.sh -a i686 -c server live
The resulting image is build/i686/server/livedisk.iso
, which can be used to install Redox from a USB device.
Example 2
The following builds the desktop
variant of Redox for the aarch64
(64-bit ARM) CPU architecture (defined in config/aarch64/desktop.toml
).
./build.sh -f config/aarch64/desktop.toml qemu
The resulting image is build/aarch64/desktop/harddrive.img
, which is then run in the QEMU emulator upon completion of the build.
💡 Tip: if you are going to use
build.sh
repeatedly, it's recommended that you do so consistently. The script's underlyingmake
command doesn't keep any record of the build settings used betweenbuild.sh
runs.
Details of build.sh
and other settings are described in the Configuration Settings page.