# RustOS
## Port to RISCV (WIP)
2018年THU计算机系统综合实验
[Project Wiki ](http://os.cs.tsinghua.edu.cn/oscourse/csproject2018/group05 )
[Documents ](./docs/RISCV.md )
### Environment
[Dockerfile ](./riscv-env/Dockerfile ) (Can not build directly. Just for reference)
Available on DockerHub: `wangrunji0408/riscv-rust`
### How to run
```bash
git clone https://github.com/wangrunji0408/RustOS.git -b riscv --recursive
cd RustOS
# Pull docker image and enter docker interactive shell
make docker_riscv
# Inside docker ...
cd kernel
# Patch the atomic mod of core lib
make patch-core
make run
```
## Summary
[![Build Status ](https://travis-ci.org/wangrunji0408/RustOS.svg?branch=master )](https://travis-ci.org/wangrunji0408/RustOS)
A project of THU OS2018 spring.
[Project Wiki ](http://os.cs.tsinghua.edu.cn/oscourse/OS2018spring/projects/g11 )
[MidReport ](./docs/MidReport.md )
[FinalReport ](./docs/FinalReport.md )
The goal is to write a mini OS in Rust with multicore supporting.
It will start from the post of the [Writing an OS in Rust ](http://os.phil-opp.com ) series. Then reimplement [xv6-x86_64 ](https://github.com/jserv/xv6-x86_64 ) in Rust style.
## Building
You need to have `nasm` , `grub-mkrescue` , `xorriso` , `qemu` , a nightly Rust compiler, and `xargo` installed. Then you can run it using `make run` .
A docker image is available and recommanded. Read [this ](docker/README.md ) for details.
## License
The source code is dual-licensed under MIT or the Apache License (Version 2.0).