2019-03-17 21:09:12 +04:00
# rCore
2017-04-11 21:44:44 +04:00
2019-03-26 21:40:47 +04:00
[![Build Status ](https://travis-ci.org/rcore-os/rCore.svg?branch=master )](https://travis-ci.org/rcore-os/rCore)
2018-07-06 19:14:51 +04:00
2019-01-05 08:58:11 +04:00
Rust version of THU [uCore OS Plus ](https://github.com/chyyuu/ucore_os_plus ).
2018-11-19 21:29:44 +04:00
Going to be the next generation teaching operating system.
2019-04-11 20:23:34 +04:00
Supported architectures: x86_64, RISCV32/64, AArch64, MIPS32
2018-12-02 18:19:32 +04:00
2019-03-20 07:36:41 +04:00
Tested boards: QEMU, HiFive Unleashed, x86_64 PC (i5/i7), Raspberry Pi 3B+
2018-07-06 19:14:51 +04:00
2018-12-16 07:47:33 +04:00
![demo ](./docs/2_OSLab/os2atc/demo.png )
2017-04-11 21:44:44 +04:00
## Building
2017-04-18 17:21:11 +04:00
2018-08-07 12:48:34 +04:00
### Environment
2019-04-11 20:23:34 +04:00
* [Rust ](https://www.rust-lang.org ) toolchain at nightly-2019-03-05
2019-01-03 15:20:02 +04:00
* Cargo tools: [cargo-xbuild ](https://github.com/rust-osdev/cargo-xbuild )
2019-01-06 07:25:48 +04:00
* [QEMU ](https://www.qemu.org ) >= 3.1.0
2019-01-03 15:20:02 +04:00
* [bootimage ](https://github.com/rust-osdev/bootimage ) (for x86_64)
* [RISCV64 GNU toolchain ](https://www.sifive.com/boards ) (for riscv32/64)
2019-02-15 12:10:12 +04:00
* [AArch64 GNU toolchain ](https://cs140e.sergio.bz/assignments/0-blinky/ ) (for aarch64)
2019-03-26 04:28:10 +04:00
* [musl-cross-make ](https://github.com/richfelker/musl-cross-make ) (for userland musl, or download prebuilt toolchain from [musl.cc ](https://musl.cc/ ))
2019-03-23 14:23:02 +04:00
* [libfuse-dev ](https://github.com/libfuse/libfuse ) (for userland image generation)
2019-02-15 12:10:12 +04:00
See [Travis script ](./.travis.yml ) for details.
2017-04-11 21:44:44 +04:00
2018-08-07 12:48:34 +04:00
### How to run
2018-09-19 16:43:49 +04:00
```bash
2019-04-11 20:23:34 +04:00
$ rustup component add rust-src llvm-tools-preview
$ cargo install cargo-binutils
2019-04-10 09:12:26 +04:00
$ cargo install cargo-xbuild --force
$ cargo install bootimage --version 0.5.7 --force
2018-09-19 16:43:49 +04:00
```
2018-08-07 12:48:34 +04:00
```bash
2019-03-20 07:36:41 +04:00
$ git clone https://github.com/rcore-os/rCore.git --recursive
2019-03-20 20:12:33 +04:00
$ cd rCore/user
2019-04-11 20:23:34 +04:00
$ make sfsimg arch={riscv32,riscv64,x86_64,aarch64,mipsel} # requires $(arch)-linux-musl-gcc
2019-03-20 20:12:33 +04:00
$ cd ../kernel
2019-04-11 20:23:34 +04:00
$ make run arch={riscv32,riscv64,x86_64,aarch64,mipsel} mode=release
2019-03-23 21:09:58 +04:00
$ make run arch=x86_64 mode=release pci_passthru=0000:00:00.1 # for ixgbe real nic, find its pci (bus, dev, func) first
2018-08-07 12:48:34 +04:00
```
2017-04-11 21:44:44 +04:00
2019-04-21 10:32:24 +04:00
## Maintainers
| Module | Maintainer |
|--------|-----------------------|
| x86_64 | @wangrunji0408 |
| RISCV | @jiegec |
| ARM (Raspi3) | @equation314 |
| MIPS | @HarryChen @miskcoo |
| Memory, Process, File System | @wangrunji0408 |
| Network with drivers | @jiegec |
| GUI | @equation314 |
2019-01-03 15:20:02 +04:00
## History
This is a project of THU courses:
2019-04-21 10:32:24 +04:00
* [Operating System (2018 Spring) ](http://os.cs.tsinghua.edu.cn/oscourse/OS2018spring/projects/g11 )
* [Comprehensive Experiment of Computer System (2018 Summer) ](http://os.cs.tsinghua.edu.cn/oscourse/csproject2018/group05 )
* [Operating System Train (2018 Autumn) ](http://os.cs.tsinghua.edu.cn/oscourse/OsTrain2018 )
* [Operating System (2019 Spring) ](http://os.cs.tsinghua.edu.cn/oscourse/OS2019spring/projects )
2019-01-03 15:20:02 +04:00
2019-04-21 10:32:24 +04:00
[Reports ](./docs ) and [Dev docs ](https://rucore.gitbook.io/rust-os-docs/ ) (in Chinese)
2019-01-03 15:20:02 +04:00
It's based on [BlogOS ](https://github.com/phil-opp/blog_os ) , a demo project in the excellent tutorial [Writing an OS in Rust (First Edition) ](https://os.phil-opp.com/first-edition/ ).
2017-04-11 21:44:44 +04:00
## License
2018-04-02 11:28:32 +04:00
2017-04-11 21:44:44 +04:00
The source code is dual-licensed under MIT or the Apache License (Version 2.0).