An experimental monolithic OS based on ArceOS
- RISC-V 64
- LoongArch64
- AArch64
- x86_64 (work in progress)
TODO
git clone --recursive https://github.com/Starry-OS/StarryOS.git
cd StarryOSOr if you have already cloned it without --recursive option:
cd StarryOS
git submodule update --init --recursiveWe provide a prebuilt Docker image with all dependencies installed.
For users in mainland China, you can use the following image which includes optimizations like Debian packages mirrors and crates.io mirrors:
docker pull docker.cnb.cool/starry-os/arceos-build
docker run -it --rm -v $(pwd):/workspace -w /workspace docker.cnb.cool/starry-os/arceos-buildFor other users, you can use the image hosted on GitHub Container Registry:
docker pull ghcr.io/arceos-org/arceos-build
docker run -it --rm -v $(pwd):/workspace -w /workspace ghcr.io/arceos-org/arceos-buildNote: The --rm flag will destroy the container instance upon exit. Any changes made inside the container (outside of the mounted /workspace volume) will be lost. Please refer to the Docker documentation for more advanced usage.
This step may vary depending on your operating system. Here is an example based on Debian:
sudo apt update
sudo apt install -y build-essential cmake clang qemu-systemNote: Running on LoongArch64 requires QEMU 10. If the QEMU version in your Linux distribution is too old (e.g. Ubuntu), consider building QEMU from source.
-
Download files from setup-musl releases
-
Extract to some path, for example
/opt/riscv64-linux-musl-cross -
Add bin folder to
PATH, for example:export PATH=/opt/riscv64-linux-musl-cross/bin:$PATH
# Install rustup from https://rustup.rs or using your system package manager
# Automatically download components via rustup
cd StarryOS
cargo -V# Default target: riscv64
make rootfs
# Explicit target
make ARCH=riscv64 rootfs
make ARCH=loongarch64 rootfsThis will download rootfs image from Starry-OS/rootfs and set up the disk file for running on QEMU.
# Default target: riscv64
make build
# Explicit target
make ARCH=riscv64 build
make ARCH=loongarch64 build
# Run on QEMU (also rebuilds if necessary)
make ARCH=riscv64 run
make ARCH=loongarch64 runNote:
- Binary dependencies will be automatically built during
make build. - You don't have to rerun
buildevery time.runautomatically rebuilds if necessary. - The disk file will not be reset between each run. As a result, if you want to switch to another architecture, you must run
make rootfswith the new architecture beforemake run.
You can check out the GUI guide to set up a graphical environment, or explore other documentation in this folder.
If you're interested in contributing to the project, please see our Contributing Guide.
See more build options in the Makefile.
This project is now released under the Apache License 2.0. All modifications and new contributions in our project are distributed under the same license. See the LICENSE and NOTICE files for details.