1
0
mirror of https://github.com/rcore-os/rCore.git synced 2024-11-23 08:26:17 +04:00
Rust version of THU uCore OS. Linux compatible.
Go to file
2019-04-06 19:26:14 +08:00
bootloader Merge remote-tracking branch 'origin/master' into mipsel 2019-04-01 23:32:30 +08:00
crate Merge remote-tracking branch 'origin/master' into mipsel 2019-04-01 23:32:30 +08:00
docs split Process and Thread 2019-01-25 23:28:48 +08:00
kernel Disable multi-CPU. 2019-04-06 19:26:14 +08:00
riscv-pk@405ea59dd7 fix serial interrupt on HiFiveU 2019-03-19 18:23:10 +08:00
tests Change travis test arch from riscv64 to riscv32 2019-03-27 07:28:18 +08:00
tools Merge remote-tracking branch 'rcore/dev' 2019-03-29 13:37:20 +08:00
user@67890aeb42 Update user app repo 2019-04-06 00:38:36 +08:00
.gitignore Use gcc to pre-process mipsel assembly 2019-04-06 00:24:01 +08:00
.gitmodules update URL to new organization 2019-03-18 01:14:30 +08:00
.travis.yml Fix bootloader build failure on aarch64 2019-03-27 12:08:02 +08:00
Cargo.toml Fix bootloader build failure on aarch64 2019-03-27 12:08:02 +08:00
LICENSE update README. add LICENSE 2018-12-02 22:19:32 +08:00
README.md Change travis badge link, and fix allow_failures syntax 2019-03-27 01:40:47 +08:00
rust-toolchain Move to a newer rust toolchain with rls 2019-03-25 13:00:09 +08:00

rCore

Build Status

Rust version of THU uCore OS Plus.

Going to be the next generation teaching operating system.

Supported architectures: x86_64, RISCV32/64, AArch64, MIPS (planned)

Tested boards: QEMU, HiFive Unleashed, x86_64 PC (i5/i7), Raspberry Pi 3B+

Dev docs (in Chinese)

demo

Building

Environment

See Travis script for details.

How to run

$ rustup component add rust-src
$ cargo install cargo-xbuild bootimage
$ git clone https://github.com/rcore-os/rCore.git --recursive
$ cd rCore/user
$ make sfsimg arch={riscv32,riscv64,x86_64,aarch64} # requires x86_64-linux-musl-gcc or musl-gcc
$ cd ../kernel
$ make run arch={riscv32,riscv64,x86_64,aarch64} mode=release
$ make run arch=x86_64 mode=release pci_passthru=0000:00:00.1 # for ixgbe real nic, find its pci (bus, dev, func) first

History

This is a project of THU courses:

  • Operating System (2018 Spring)
  • Comprehensive Experiment of Computer System (2018 Summer)
  • Operating System Train (2018 Autumn)
  • Operating System (2019 Spring)

Project wiki (internal access only): OS, CECS, OST

Reports (in Chinese): docs

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).