1
0
mirror of https://github.com/rcore-os/rCore.git synced 2024-11-25 01:16:18 +04:00
rCore/README.md

91 lines
2.7 KiB
Markdown
Raw Normal View History

2019-03-17 21:09:12 +04:00
# rCore
2017-04-11 21:44:44 +04:00
2020-01-29 15:52:18 +04:00
[![CI](https://github.com/rcore-os/rCore/workflows/CI/badge.svg?branch=master)](https://github.com/rcore-os/rCore/actions)
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.
Supported architectures and boards:
2018-12-02 18:19:32 +04:00
2020-06-30 08:27:29 +04:00
* x86_64(Tier 1): QEMU, PC (i5/i7)
* RISCV32/64(Tier 2): QEMU, HiFive Unleashed
* AArch64(Tier 2): QEMU, Raspberry Pi 3B+
* MIPS32(Tier 3): QEMU, [TrivialMIPS](https://github.com/Harry-Chen/TrivialMIPS)
2018-07-06 19:14:51 +04:00
2018-12-16 07:47:33 +04:00
![demo](./docs/2_OSLab/os2atc/demo.png)
## What's included
rCore has the following features:
* Linux compatible syscall interface: run Linux userspace programs
* Network stack
* Simple file system
* Signal system
* Async IO
* Kernel module
2017-04-11 21:44:44 +04:00
## Building
2018-08-07 12:48:34 +04:00
### Environment
* [Rust](https://www.rust-lang.org) toolchain
* [QEMU](https://www.qemu.org) >= 4.1.0
2019-10-05 10:38:43 +04:00
* [musl-based GCC toolchains](https://musl.cc/) (only for building [user programs](https://github.com/rcore-os/rcore-user))
2019-02-15 12:10:12 +04:00
2019-10-05 10:38:43 +04:00
Setup on Linux or macOS:
2018-08-07 12:48:34 +04:00
2018-09-19 16:43:49 +04:00
```bash
$ rustup component add rust-src llvm-tools-preview
2019-10-05 10:38:43 +04:00
```
Or use Docker container:
```bash
$ docker run -it -v $PWD:$PWD -w $PWD wangrunji0408/rcore
2018-09-19 16:43:49 +04:00
```
2019-10-05 10:38:43 +04:00
### How to run
2018-08-07 12:48:34 +04:00
```bash
$ git clone https://github.com/rcore-os/rCore.git --recursive
2019-03-20 20:12:33 +04:00
$ cd rCore/user
2020-06-22 07:41:27 +04:00
$ make sfsimg PREBUILT=1 ARCH=x86_64
2019-03-20 20:12:33 +04:00
$ cd ../kernel
2020-02-01 09:19:10 +04:00
$ make run ARCH=x86_64 LOG=info
2018-08-07 12:48:34 +04:00
```
2017-04-11 21:44:44 +04:00
2020-02-01 09:19:10 +04:00
See [Makefile](kernel/Makefile) for more usages.
2019-04-16 09:11:29 +04:00
## Maintainers
| Module | Maintainer |
|--------|-----------------------|
| x86_64 | @wangrunji0408 |
| RISC-V | @jiegec |
2020-06-22 07:41:27 +04:00
| AArch64 (Raspi3) | @equation314 |
| MIPS | @Harry_Chen @miskcoo |
2019-04-16 09:11:29 +04:00
| Memory, Process, File System | @wangrunji0408 |
| Network with drivers | @jiegec |
| GUI | @equation314 |
## History
This is a project of THU courses:
2020-06-30 08:27:29 +04:00
* [Operating System (2018 Spring)](http://os.cs.tsinghua.edu.cn/oscourse/OS2018spring/projects/g11)
2019-04-16 09:11:29 +04:00
* [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)
* [Operating System Train (2019 Autumn)](http://os.cs.tsinghua.edu.cn/oscourse/OsTrain2019)
2020-06-15 08:26:23 +04:00
* [Operating System (2020 Spring)](http://os.cs.tsinghua.edu.cn/oscourse/OS2020spring/projects)
2019-04-16 09:11:29 +04:00
[Reports](./docs) and [Dev docs](https://rucore.gitbook.io/rust-os-docs/) (in Chinese)
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).