1
0
mirror of https://github.com/rcore-os/rCore.git synced 2024-11-22 16:16:16 +04:00
Rust version of THU uCore OS. Linux compatible.
Go to file
2019-03-31 23:31:37 +08:00
bootloader update URL to new organization 2019-03-18 11:55:06 +08:00
crate Add interrupt for mips32 in crate::thread. 2019-03-31 23:31:37 +08:00
docs split Process and Thread 2019-01-25 23:28:48 +08:00
kernel Add interrupt for mips32 in crate::thread. 2019-03-31 23:31:37 +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 Remove m-mode and k210 support. 2019-03-26 08:28:10 +08:00
user@96548d0464 Fix bootloader build failure on aarch64 2019-03-27 12:08:02 +08:00
.gitignore add aarch64 bootloader framework 2019-03-04 15:22:19 +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).