Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/rcore-os/rCore_tutorial_doc

Tutorial doc for rCore OS step by step (2nd edition)
https://github.com/rcore-os/rCore_tutorial_doc

Last synced: 2 months ago
JSON representation

Tutorial doc for rCore OS step by step (2nd edition)

Awesome Lists containing this project

README

        

## **_最新通知_**

由于本文档还不稳定,有时会有更新,更新信息会第一时间放在这里。由于文档不稳定引起的问题不会导致扣分。

> **[info] 最后更新日期:2020-09-09**
>
> **2020-09-09**
>
> 本文档基本上已经停止维护,我们会将开发的重心放在[第三版 tutorial](https://rcore-os.github.io/rCore-Tutorial-deploy/) 上面,欢迎大家来围观!
>
> **2020-04-25**
>
> 将第九章中所引用的 rcore-fs 系列 crate 的版本更新为 7f5eeac 。
>
> **2020-04-08**
>
> 感谢 @LyricZhao 同学的帮助,更新了 lab5 的一些文字描述。
>
> **2020-03-26**
>
> github.io 疑似被和谐,目前在 rcore-tutorial-doc.netlify.com 维护自动更新的镜像。之后有时间的话更新配置文件。
>
> **2020-03-15**
>
> 对于 lab8 , 补充说明了 ``sys_read`` 的语义:即在管道为空的时候应阻塞调用它的进程。
>
> **2020-03-09**
>
> lab7 的题目终于出完了,大家可以去做了。。。QAQ
>
> **2020-03-08**
>
> 如果有 `dd` 命令报错的同学请注意:在第九章第四小节中,MacOS 平台的同学在通过 `dd` 命令将 `temp` 文件打包到用户镜像中的时候,应该使用 `bs=1k` 而非 `bs=1K` 。该问题已在 master 分支和文档中修改。
>
> 对于在做 lab2/3 而 tutorial 进度已经达到第八章第二小节的同学,在 [练习题的主页](./exercise/introduction.md) 提供了一种修改原版代码的方式,以通过评测脚本测试 lab2/3 。
>
> **2020-03-07**
>
> 将 rCore_tutorial 的 master 分支更新到第九章第四小节。
>
> 对于 lab2/3/5/6/8 以及即将完成的 lab7 新增了统一的评测脚本以及对应的使用说明,可以不必从 master 分支开始实验而是按照 tutorial 从零开始,只要评测脚本能得出正确的结果即会被认可。lab2/3/5/6/8 的评测方式以及测试程序的说明也在其自身的页面中更新了。
>
> 对于 lab2/3,不再统一使用一个 `init.rs` 而是拆分为两个内核态测试程序,移除了其中多余的初始化代码,只依赖中断和内存管理。
>
> **2020-03-06**
>
> 修复了第九章第四小节一些明显的错误,完善了文件读写测试程序 `write.rs`。
>
> 感谢 @Liurunda 同学提供的大量勘误。
>
> **2020-03-05**
>
> 为了显得很轻量级,在首页更新了目前的总代码行数。
>
> 正文方面:新增了第九章第四小节作为练习八的基础,同时在第九章 intro 部分上传了 rCore 和 xv6 文件系统的分析文档。
>
> 练习方面:
>
> 在练习五的描述中,将 `sys_fork` 的 syscall id 设定为 $$220$$;
>
> 在练习六中增加了测试文件需要用到的 syscall id;
>
> 重写了练习八,新增了练习八的测试程序。
>
> **2020-03-04**
>
> 调换了练习五和练习六的顺序。
>
> 修改了练习八的要求,强制要求实现 `sys_fork` 。
>
> 在 `exercise/introduction` 中增加了测评的详细说明。
>
> 删除了从零开始复现的要求,只对练习进行检察。
>
> **2020-03-03**
>
> 更新了第五章第一节的小节部分以及第二节的前半部分,指出了必要的链接脚本的改动,进行了更加流畅的衔接;
>
> 更新了第九章第一、二小节,使得记事本和用户终端两个应用程序支持退格键。
>
> **2020-03-02**
>
> 更新了实验报告的命名要求与放置位置。
>
> **2020-02-27**
>
> 修改了 `2. 物理内存管理` 章节中的 `实验要求 2(问答题)`。
>
> 优化了 `1. 中断异常` 章节中的 `实验要求 3(问答题)` 的描述。
>
> **2020-02-26**
>
> 简化了 `5. CPU 调度` 章节中的测试用例,删掉了对 `sys_wait` 等系统调用的要求,并且降低了对输出数据的的要求。
>
> **2020-02-20**
>
> 如果在编译 _buddy_system_allocator_ 时报错,可能是本地 crate 版本未更新,只需进入 _os/,usr/_ 文件夹下分别 `cargo update -p buddy_system_allocator` ,并重新编译即可。
>
> 如果内核在输出 `setup process!` 后 panic 报 page fault ,则很有可能将 `timer::init` 函数中的 `TICKS = 0;` 注释掉即可正常运行。

# rCore Tutorial

这是一个展示如何从零开始用 Rust 语言写一个基于 64 位 RISC-V 架构的操作系统的教程。完成这个教程后,你将可以在内核上运行用户态终端,并在终端内输入命令运行其他程序。

我们很轻量级!截至目前的代码行数分布(ch9-pa4 分支)为:

```
-------------------------------------------------------------------------------
Language files blank comment code
-------------------------------------------------------------------------------
Rust 42 315 21 2178
D 120 256 0 633
Assembly 4 16 2 185
JSON 116 0 0 116
Markdown 1 4 0 55
make 2 17 0 54
TOML 2 5 2 22
Bourne Shell 1 0 0 1
-------------------------------------------------------------------------------
SUM: 288 613 25 3244
-------------------------------------------------------------------------------
```

## 代码仓库

左侧章节目录中含有一对方括号"[ ]"的小节表示这是一个存档点,即这一节要对最近几节的代码进行测试。所以我们对每个存档点都设置了一个 commit 保存其完整的状态以供出现问题时参考。

与章节相对应的代码可以很容易的找到。章节标题下提供了指向下一个存档点代码状态的链接。

## 阅读在线文档并进行实验

- [实验 ppt:rcore step-by-step tutorial](https://rcore-os.github.io/rCore_tutorial_doc/os2atc2019/os2atc.html)
- [实验文档:rcore step-by-step tutorial](https://rcore-os.github.io/rCore_tutorial_doc/)
- [实验代码:rcore step-by-step code](https://github.com/rcore-os/rCore_tutorial/)

## 评论区

对于章节内容有任何疑问及建议,请在对应页面最下面的评论区中发表观点。注意需要用 Github ID 登录后才能评论。

好了,那就让我们正式开始!