You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
Harry Chen a57a22a26b
Fix VGA initialization with correct PCI address
7 years ago
bootloader Merge remote-tracking branch 'origin/master' into mipsel 7 years ago
crate Merge remote-tracking branch 'origin/master' into mipsel 7 years ago
docs split Process and Thread 7 years ago
kernel Fix VGA initialization with correct PCI address 7 years ago
riscv-pk@405ea59dd7 fix serial interrupt on HiFiveU 7 years ago
tests Change travis test arch from riscv64 to riscv32 7 years ago
tools Merge remote-tracking branch 'rcore/dev' 7 years ago
user@07619a48d4 Add VGA implementation for mipsel malta board 7 years ago
.gitignore Use gcc to pre-process mipsel assembly 7 years ago
.gitmodules update URL to new organization 7 years ago
.travis.yml Fix bootloader build failure on aarch64 7 years ago
Cargo.toml Fix bootloader build failure on aarch64 7 years ago
LICENSE update README. add LICENSE 7 years ago
README.md Change travis badge link, and fix allow_failures syntax 7 years ago
rust-toolchain Move to a newer rust toolchain with rls 7 years ago

README.md

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