Skip to content
Redox: A Rust Operating System
Rust Shell Assembly Makefile C++ Nix
Find file
Pull request Compare This branch is 3 commits ahead, 106 commits behind master.
Latest commit 9ee9113 @jackpot51 jackpot51 Merge branch 'master' into higher-half
Conflicts:
	kernel/arch/x86_64/paging.rs
	kernel/asm/interrupts-i386.asm
Failed to load latest commit information.
crates Correct rendering of title
filesystem Update sodium
img Redox background
kernel Merge branch 'master' into higher-half
liballoc_system fix rustfmt on liballoc_system
libc @ 161e972 Add system, add -c to ion
libstd Add more doc comments in libstd with cleanup
rust @ 959af0c WIP: Redox target, fix build
setup Require i386-elf-gcc for mac homebrew
windows Add ar, gcc, objdump for i386 windows
.gitignore Automagically create initfs from initfs directory, update redoxfs
.gitmodules Add stdio locking (WIP), add some more duration functions
.travis.yml Reenable build for master
CONTRIBUTING.md Update Markdown formatting
LICENSE.md Sorry Charlie, all the original Rustboot code has been gone for sever…
Makefile Fix virtualbox booting, update redoxfs
README.md Installation script renamed
appveyor.yml Appveyor will build using make.bat
bochs.i386 Fix paths in bochs files, format ASM
bochs.x86_64 Fix paths in bochs files, format ASM
bootstrap.sh Download nasm from bootstrap.sh on Arch Linux
i386-unknown-redox.json Reorder switch_to
make.bat Added a batchfile for easier windows builds
x86_64-unknown-redox.json Disable float support for x86_64, until issues are fixed

README.md

Redox

Redox is an operating system written in pure Rust, designed to be modular and secure. The development blog can be found at http://www.redox-os.org.

Documentation can be found here.

Please make sure you use the latest nightly of rustc before building (for more troubleshooting, see "Help! Redox won't compile!").

Travis Build Status MIT licensed

Contents

What it looks like

Redox Redox Redox

Redox Redox Redox

Help! Redox won't compile!

Sometimes things go wrong when compiling. Try the following before opening an issue:

  1. Run make clean.
  2. Run git clean -X -f -d.
  3. Make sure you have the latest version of Rust nightly! (multirust is recommended for managing Rust versions).
  4. Update GNU Make, NASM and QEMU/VirtualBox.
  5. Pull the upstream master branch (git remote add upstream git@github.com:redox-os/redox.git; git pull upstream master).

and then rebuild!

Contributing to Redox

If you're interested in this project, and you'd like to help us out, here is a list of ways you can do just that.

Cloning, Building, and Running

Redox is big (even compressed)! So cloning Redox takes a lot bandwidth, and (depending on your data plan) can be costly, so clone at your own risk!

Quick Setup

$ cd path/to/your/projects/folder/

# Run bootstrap setup
$ curl -sf https://raw.githubusercontent.com/redox-os/redox/master/bootstrap.sh -o bootstrap.sh && bash -e bootstrap.sh

# Build Redox
$ make all

# Launch using QEMU
$ make qemu
# Launch using QEMU without using KVM (Kernel Virtual Machine). Try if QEMU gives an error.
$ make qemu kvm=no

QEMU with KVM

To use QEMU with KVM (kernel-based virtual Machine), which is faster than without KVM, you need a CPU with Intel® Virtualization Technology (Intel® VT) or AMD Virtualization™ (AMD-V™) support. Most systems have this disabled in the BIOS by default, so you may need to reboot and enable the feature in the BIOS.

Manual Setup

To manually clone, build and run Redox using a Linux host, run the following commands (with exceptions, be sure to read the comments):

$ cd path/to/your/projects/folder/

# HTTPS
$ git clone https://github.com/redox-os/redox.git --origin upstream --recursive
# SSH
$ git clone git@github.com:redox-os/redox.git --origin upstream --recursive

$ cd redox/

# Install/update dependencies
$ sudo <your package manager> install make nasm qemu

# Install multirust
$ curl -sf https://raw.githubusercontent.com/brson/multirust/master/quick-install.sh | sh

# Set override toolchain to nightly build
$ multirust override nightly

# Update git submodules
$ git submodule update --init

# Build Redox
$ make all

# Launch using QEMU
$ make qemu
# Launch using QEMU without using KVM (Kernel Virtual Machine). Try if QEMU gives an error.
$ make qemu kvm=no
Something went wrong with that request. Please try again.