Rust
Rust is a systems language sponsored by Mozilla, focused on three things: safety, speed, and concurrency. It accomplishes many of these goals through strong compile-time checks, allowing for very little overhead at runtime. Performance is comparable to C or C++, while being free of many of the problems caused by things like dangling pointers, buffer overflows, and iterator invalidation.
While Rust is very much a "curly-brace" language, it also takes many cues from ML. Almost everything is an expression, and there is a very strong type system including sum types and powerful generics.
Rust provides a mechanism to subvert its safety checks when necessary, by adding an 'unsafe' annotation to portions of your code. This allows you full access to raw pointers, while controlling exactly how they are used. Often, Rust code that uses unsafe will do so as an implementation detail, allowing for them to expose a safe interface.
Operating System Development
Rust has a comparable amount of runtime to C and C++, and has set up its standard library to be amenable towards OS development. Specifically, the standard library (std) consists of two smaller parts: core and alloc. Core consists of the primitive, platform-independent components of the standard library. It doesn't include things like allocation, threading, and other higher-level features. Alloc is used for managing heap allocations, smart pointers, and simple data collections. Std builds on top of core and alloc to add other OS dependent features, such as files and processes. Using only core and alloc instead of std is as easy as adding the no_std annotation to your main source file.
Every Rust compiler is a cross-compiler, which makes setup easier.
Active Projects
- A mature POSIX OS
- "Writing an OS in Rust"
- Tutorial: RISC-V OS using Rust
- Meaty Bare-Bones
- core-os-riscv
- An xv6-like operating system
- RISC-V based with multi-core support
- Tifflin
- Multiboot image for x86_64
- has VFS and userland
- Redox
- One of the largest and most active Rust OS projects
- Tock
- optimized for embedded devices
- isolates drivers and applications
- intermezzOS
- Small kernel + book, specifically for learning OSDev through Rust
- on hiatus indefinitely
- Ryanra's RustOS
- Uses libcore/collections/alloc
- QuiltOS
- Forked from Ryanra's RustOS
- Main goal is demoing OS Dev libraries written in Rust.
- Rux
- Nebulet
- Has an end goal of running WebAssembly in the kernel for a performance increase
- Theseus
- An experimental OS written in Rust
- MOROS
- A simple hobby OS with a text-based user interface
Past Projects
Rust went through a long and public development process and used to have a significantly larger runtime. There were lots of experiments pre-1.0, thus these projects are of historical interest, but aren't guaranteed to run or even build.
Libraries
- libx86: Library to program x86 hardware.
- x86_64: Library to program x86_64 hardware.
- bootloader: A rust bootloader.
libcpu: Library to program CPUs.Now absorbed into libx86.- slabmalloc: Low-level memory allocator for liballoc.
- multiboot: Library to read multiboot layout.
- spin: Various synchronization primitives implemented with spinning. Closely mimics `std::sync`'s interface.
- fringe: Context switching agnostic to how stacks are allocated.
See Also
- Rust Website
- Operating Systems Development in Rust
- Reenix: Implementing a Unix-like OS in Rust
- Writing an OS in Rust in tiny steps (Steps 1-5)
- Rust Bare Bones
- Blog Series: Writing an OS in Rust
- Retarget your compiler so interrupts are not evil
- BOOTBOOT loader has an example 64 bit higher half kernel in Rust
- rust-osdev on GitHub