A monolithic kernel based on ArceOS.
Install Docker in your system.
Then build all dependencies through provided dockerfile:
./scripts/get_deps.sh
cd .arceos
docker build -t starry -f Dockerfile .
Create a container and build/run app:
# back to the root directory of the project
cd ..
docker run --privileged --rm -it -v $(pwd):/starry -w /starry starry bash
# Now build/run app in the container
make user_apps
make defconfig
make run
cargo install cargo-binutils axconfig-gen
sudo apt install libclang-dev cmake dosfstools build-essential
Download & install musl toolchains:
# download
wget https://musl.cc/aarch64-linux-musl-cross.tgz
wget https://musl.cc/riscv64-linux-musl-cross.tgz
wget https://musl.cc/x86_64-linux-musl-cross.tgz
wget https://github.com/LoongsonLab/oscomp-toolchains-for-oskernel/releases/download/loongarch64-linux-musl-cross-gcc-13.2.0/loongarch64-linux-musl-cross.tgz
# install
tar zxf aarch64-linux-musl-cross.tgz
tar zxf riscv64-linux-musl-cross.tgz
tar zxf x86_64-linux-musl-cross.tgz
tar zxf loongarch64-linux-musl-cross.tgz
# exec below command in bash OR add below info in ~/.bashrc
export PATH=`pwd`/x86_64-linux-musl-cross/bin:`pwd`/aarch64-linux-musl-cross/bin:`pwd`/riscv64-linux-musl-cross/bin:`pwd`/loongarch64-linux-musl-cross/bin:$PATH
# for Debian/Ubuntu
sudo apt-get install qemu-system
# for macos
brew install qemu
Notice: The version of qemu
should be no less than 8.2.0.
Other systems, arch and version please refer to Qemu Download
# Clone the base repository
./scripts/get_deps.sh
# Run riscv64 example
make ARCH=riscv64 AX_TESTCASE=nimbos user_apps
# When running on a new architecture, you need to generate the configuration file again.
make ARCH=riscv64 defconfig
make ARCH=riscv64 AX_TESTCASE=nimbos BLK=y NET=y ACCEL=n run
# Run x86_64 example
make ARCH=x86_64 AX_TESTCASE=nimbos user_apps
# When running on a new architecture, you need to generate the configuration file again.
make ARCH=x86_64 defconfig
make ARCH=x86_64 AX_TESTCASE=nimbos BLK=y NET=y ACCEL=n run
# Run aarch64 example
make ARCH=aarch64 AX_TESTCASE=nimbos user_apps
make ARCH=aarch64 defconfig
make ARCH=aarch64 AX_TESTCASE=nimbos BLK=y NET=y FEATURES=fp_simd ACCEL=n run
# Run Loongarch64 example
make ARCH=loongarch64 AX_TESTCASE=nimbos user_apps
make ARCH=loongarch64 defconfig
make ARCH=loongarch64 AX_TESTCASE=nimbos BLK=y NET=y ACCEL=n run
# Run another example (libc testcases)
make ARCH=riscv64 AX_TESTCASE=libc user_apps
make ARCH=riscv64 defconfig
# When running libc testcases, you need to enable `fp_simd` feature.
make ARCH=riscv64 AX_TESTCASE=libc BLK=y NET=y FEATURES=fp_simd ACCEL=n run
# Clone the base repository
./scripts/get_deps.sh
# Build user applications
make ARCH=<arch> AX_TESTCASE=<testcases> user_apps
# Build kernel
make ARCH=<arch> LOG=<log> AX_TESTCASE=<testcases> build
# Run kernel
make ARCH=<arch> LOG=<log> AX_TESTCASE=<testcases> run
Where testcases
are shown under the apps/
folder.
<arch>
should be one of riscv64
, aarch64
, x86_64
, loongarch64
.
<log>
should be one of off
, error
, warn
, info
, debug
, trace
.
More arguments and targets can be found in Makefile.
For example, to run the nimbos testcases on qemu-system-x86_64
with log level info
:
make ARCH=x86_64 LOG=info AX_TESTCASE=nimbos run
Note: Arguments like NET
, BLK
, and GRAPHIC
enable devices in QEMU, which take effect only at runtime, not at build time. More features can be found in the Cargo.toml of arceos.
Since ArceOS relies on special build scripts and some environment variables, this usually causes rust-analyzer
to prompt some annoying errors. You may want to put the following configuration into .vscode/settings.json
(ie workspace settings):
{
"rust-analyzer.cargo.extraEnv": {
"AX_CONFIG_PATH": "${workspaceFolder}/.axconfig.toml"
}
}
We can run testcases of the OS competition with StarryOS. Guidence can be found in Starry-Tutorial.
And you can run the testcases with the following commands:
# Clone the base repository
./scripts/get_deps.sh
# run the testcases of oscomp on x86_64
$ make oscomp_run ARCH=x86_64 # If it reports an error: -accel kvm: failed to initialize kvm: Permission denied, please add `ACCEL=n` argument.
# run the testcases of oscomp on riscv64
$ make oscomp_run ARCH=riscv64
# run the testcases of oscomp on aarch64
$ make oscomp_run ARCH=aarch64
# run the testcases of oscomp on loongarch64
$ make oscomp_run ARCH=loongarch64
To run more testcases from oscomp, you can refer to the oscomp README.
To allow the kernel to run user-written test cases, temporary test cases can be created.
If you want to add source codes of the testcases, you can refer to the libc testcases and add your source codes in the c testcase folder, and append the testcase_list with your testcase name. Then you can run the testcases with the following commands:
make AX_TESTCASE=libc user_apps ARCH=$(YOUR_ARCH)
make AX_TESTCASE=libc BLK=y NET=y FEATURES=fp_simd ACCEL=n run ARCH=$(YOUR_ARCH)
If you want to add executable file directly, the specific steps are as follows:
-
Create a temporary test case folder
cd apps && mkdir custom && cd custom
-
Create a
Makefile
in the current directory and fill in the following content:all: build build: clean: rm -rf *.out
The reason for creating an empty build
Makefile
is that when Starry packages test case images, it will first execute the test case's build program by default. However, since our temporary test case does not currently have a defined build program,make all
does not need to perform any operations. -
Copy your executable file into the current directory.
-
Create a
testcase_list
file in the current directory and add the relative path of the executable file that needs to be executed. Note that this path should be relative toapps/custom
(i.e., the current directory). In our example, the content should be:hello
-
Return to the project root directory and run the following command:
sudo ./build_img.sh -fs ext4 -file apps/custom cp disk.img .arceos/disk.img make defconfig make AX_TESTCASE=custom ARCH=x86_64 BLK=y NET=y FEATURES=fp_simd,lwext4_rs LOG=off ACCEL=n run
This completes the execution of the custom test case.