1
0
mirror of https://github.com/rcore-os/rCore.git synced 2024-11-25 01:16:18 +04:00
Rust version of THU uCore OS. Linux compatible.
Go to file
2020-06-12 08:50:07 +08:00
.github/workflows update Rust nightly to 2020-04-06 2020-04-06 17:19:05 +08:00
crate Merge branch 'master' of github.com:rcore-os/rCore 2020-05-22 23:10:54 +08:00
docs Revert part of changes 2020-06-12 08:50:07 +08:00
kernel Revert part of changes 2020-06-12 08:50:07 +08:00
modules/hello_rust Bugfix: x86_64 module compilation failure (#20) 2019-10-10 01:43:37 +08:00
rboot@048fa09b6b run make 2020-04-27 03:08:23 +08:00
slides week13 report 2020-05-16 09:14:19 +08:00
tests Fix riscv32 testing 2019-05-03 15:17:06 +08:00
tools Bump rboot and user commit, update Cargo.lock and fix addr2line.py 2020-01-29 10:59:39 +08:00
user@1bdaf05bb3 Revert part of changes 2020-06-12 08:50:07 +08:00
.gitignore add utimensat, fix touch 2020-04-25 23:05:40 +08:00
.gitmodules x86_64: switch from legacy BIOS to UEFI. use rboot as new bootloader 2019-09-04 10:37:31 +08:00
LICENSE update LICENSE 2020-02-01 13:26:38 +08:00
README.md update readme 2020-05-26 16:41:27 +08:00
rust-toolchain update Rust nightly to 2020-04-06 2020-04-06 17:19:05 +08:00

rCore

CI

Rust version of THU uCore OS Plus.

Going to be the next generation teaching operating system.

Supported architectures and boards:

demo

Building

Environment

Setup on Linux or macOS:

$ rustup component add rust-src llvm-tools-preview

Or use Docker container:

$ docker run -it -v $PWD:$PWD -w $PWD wangrunji0408/rcore

How to run

$ git clone https://github.com/rcore-os/rCore.git --recursive
$ cd rCore/user
$ make sfsimg prebuilt=1 arch=x86_64
$ cd ../kernel
$ make run ARCH=x86_64 LOG=info

See Makefile for more usages.

Maintainers

Module Maintainer
x86_64 @wangrunji0408
RISC-V @jiegec
ARM (Raspi3) @equation314
MIPS @Harry_Chen @miskcoo
Memory, Process, File System @wangrunji0408
Network with drivers @jiegec
GUI @equation314

History

This is a project of THU courses:

Reports and Dev docs (in Chinese)

It's based on BlogOS , a demo project in the excellent tutorial Writing an OS in Rust (First Edition).

License

The source code is dual-licensed under MIT or the Apache License (Version 2.0).

libc-test

安装

直接使用我们的 user 子模块即可。如果要自己设置,在 user 目录下执行

$ git clone git://repo.or.cz/libc-test
$ rm -r libc-test/.git

编译

考虑到在 rCore 中编译所有测例耗费时间过长,所以选择在本机用 musl-gcc 编译。请确保自己已经安装好了x86_64-linux-musl-gcc 工具链,且在 path 中,在 config.make 制定了 CC 的值。 在本机执行:

$ make
$ rm src/*/*.err

随后修改 user 目录下的 Makefile 文件,将 libc-test打包进入文件系统。

在 rCore 中测试

进入 libc-test 目录,执行脚本

$ ash runtest.sh

在测试测例前控制台会先打印当前测例名。若测试成功则顺次测试下一个测例,若失败则会打印额外信息,当遇到更严重的错误时可能导致 rCore 卡死或崩溃。例如在测试 math 库中的 sqrt 时,若测试失败,则输出为

run sqrt
sqrt failed

在结束后,可前往对应测例所在目录下,通过查看测例所对应的 .err 文件查看失败的原因。

当遇到使得 rCore 崩溃的测例时,手动记录当前测例在 runtest.sh 中的位置,手动更新 user 中的文件,使其从下一个测例开始测试,并记录中间若干测例的测试结果。如此反复,直到测试过所有测例。

目前测试的结果

  • 尚未通过的测例 (215/473)
    • pthread 相关:可能由于缺少相关信号
    • math 相关:由于缺少对 mxcsr 寄存器的支持,导致获取 FP Exceptions 失败,从而无法通过相关测例中对 FP Exceptions 的校验。极少数情况出现对于 bad cases 的计算错误。
    • sync 相关

具体的测试结果可参考 user/libc-test/ 目录下的三个 RECORD.txt 文件。