1
0
mirror of https://github.com/rcore-os/rCore.git synced 2024-11-25 09:26:17 +04:00
Rust version of THU uCore OS. Linux compatible.
Go to file
Chen 2a4747abaa
Merge pull request #46 from Jackey-Huo/dev
HTIF interface read enabled for rocket-chip
2019-05-03 14:09:12 +08:00
bootloader Merge remote-tracking branch 'origin/master' into mipsel 2019-04-01 23:32:30 +08:00
crate Automatically enlarge heap when kernel heap is about to run out 2019-05-01 18:33:55 +08:00
docs add figure for some important rcore structures 2019-04-28 00:11:54 +08:00
kernel remove the fxxk words.... 2019-05-03 14:06:00 +08:00
tests Change travis test arch from riscv64 to riscv32 2019-03-27 07:28:18 +08:00
tools stage debug code for output 2019-05-02 21:32:19 +08:00
user@b6a3477505 update fs. add BlockCache 2019-05-03 00:35:00 +08:00
.gitignore .gitignore updated. 2019-04-12 13:10:34 +08:00
.gitmodules replace riscv-pk by OpenSBI ! 2019-04-20 00:15:55 +08:00
.travis.yml replace gnu binutils with cargo-binutils 2019-04-12 00:23:34 +08:00
Cargo.toml move bit-allocator and rcore-thread crate to remote 2019-04-04 12:45:55 +08:00
LICENSE update README. add LICENSE 2018-12-02 22:19:32 +08:00
README.md Add Rocket Chip platform in README 2019-04-27 23:04:10 +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, MIPS32

Tested boards: QEMU, HiFive Unleashed, x86_64 PC (i5/i7), Raspberry Pi 3B+, Kendryte K210 and FPGA running Rocket Chip

demo

Building

Environment

See Travis script for details.

How to run

$ rustup component add rust-src llvm-tools-preview
$ cargo install cargo-binutils
$ cargo install cargo-xbuild --force
$ cargo install bootimage --version 0.5.7 --force
$ git clone https://github.com/rcore-os/rCore.git --recursive
$ cd rCore/user
$ make sfsimg arch={riscv32,riscv64,x86_64,aarch64,mipsel} # requires $(arch)-linux-musl-gcc
$ cd ../kernel
$ make run arch={riscv32,riscv64,x86_64,aarch64,mipsel} 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

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

History

This is a project of THU courses:

Reports and Dev docs (in Chinese)

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