Add support for virtual console TTY mode management ioctls required by Xorg and other display servers. The implementation includes: - KDGETMODE: Query the current virtual console mode - KDSETMODE: Switch between text and graphics modes Virtual consoles utilize the framebuffer with two distinct modes: - Text mode (default): Kernel renders text characters to framebuffer - Graphics mode: User space applications gain full framebuffer control Xorg requires KDSETMODE during initialization to switch to graphics mode, preventing conflicts where both the kernel and Xorg would simultaneously attempt to write to the framebuffer. This ensures proper display handling and eliminates rendering artifacts. Co-authored-by: Ruihan Li <lrh2000@pku.edu.cn> |
||
|---|---|---|
| .github | ||
| .vscode | ||
| book | ||
| kernel | ||
| osdk | ||
| ostd | ||
| test | ||
| tools | ||
| .code-workspace | ||
| .dockerignore | ||
| .gitignore | ||
| .licenserc.yaml | ||
| .typos.toml | ||
| CODEOWNERS | ||
| COPYRIGHT | ||
| Cargo.lock | ||
| Cargo.toml | ||
| Components.toml | ||
| DOCKER_IMAGE_VERSION | ||
| LICENSE-MPL | ||
| Makefile | ||
| OSDK.toml | ||
| README.md | ||
| README_CN.md | ||
| README_JP.md | ||
| RELEASES.md | ||
| VERSION | ||
| rust-toolchain.toml | ||
| rustfmt.toml | ||
| triagebot.toml | ||
README.md
A secure, fast, and general-purpose OS kernel written in Rust and compatible with Linux
News:
- 2025-10-17: ICSE 2026 accepted yet another paper about Asterinas: RusyFuzz: Unhandled Exception Guided Fuzzing for Rust OS Kernel.
- 2025-10-14: CortenMM: Efficient Memory Management with Strong Correctness Guarantees received the Best Paper Award at SOSP 2025.
- 2025-07-23: SOSP 2025 accepted another Asterinas paper: CortenMM: Efficient Memory Management with Strong Correctness Guarantees.
- 2025-06-18: USENIX ;login: magazine published Asterinas: A Rust-Based Framekernel to Reimagine Linux in the 2020s.
- 2025-04-30: USENIX ATC 2025 accepted two Asterinas papers:
Congratulations to the Asterinas community🎉🎉🎉
Introducing Asterinas
Asterinas is a secure, fast, and general-purpose OS kernel that provides Linux-compatible ABI. It can serve as a seamless replacement for Linux while enhancing memory safety and developer friendliness.
-
Asterinas prioritizes memory safety by employing Rust as its sole programming language and limiting the use of unsafe Rust to a clearly defined and minimal Trusted Computing Base (TCB). This innovative approach, known as the framekernel architecture, establishes Asterinas as a more secure and dependable kernel option.
-
Asterinas surpasses Linux in terms of developer friendliness. It empowers kernel developers to (1) utilize the more productive Rust programming language, (2) leverage a purpose-built toolkit called OSDK to streamline their workflows, and (3) choose between releasing their kernel modules as open source or keeping them proprietary, thanks to the flexibility offered by MPL.
While the journey towards a production-grade OS kernel is challenging, we are steadfastly progressing towards this goal. Over the course of 2024, we significantly enhanced Asterinas's maturity, as detailed in our end-year report. In 2025, our primary goal is to make Asterinas production-ready on x86-64 virtual machines and attract real users!
Getting Started
Get yourself an x86-64 Linux machine with Docker installed. Follow the three simple steps below to get Asterinas up and running.
- Download the latest source code.
git clone https://github.com/asterinas/asterinas
- Run a Docker container as the development environment.
docker run -it --privileged --network=host --device=/dev/kvm -v $(pwd)/asterinas:/root/asterinas asterinas/asterinas:0.16.1-20250922
- Inside the container, go to the project folder to build and run Asterinas.
make build
make run
If everything goes well, Asterinas is now up and running inside a VM.
The Book
See The Asterinas Book to learn more about the project.
License
Asterinas's source code and documentation primarily use the Mozilla Public License (MPL), Version 2.0. Select components are under more permissive licenses, detailed here. For the rationales behind the choice of MPL, see here.