最新通知

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

最后更新日期:2020-04-25

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 进度已经达到第八章第二小节的同学,在 练习题的主页 提供了一种修改原版代码的方式,以通过评测脚本测试 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 设定为

Introduction - 图1

在练习六中增加了测试文件需要用到的 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 分支)为:

  1. <!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!----
  2. Language files blank comment code
  3. <!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!----
  4. Rust 42 315 21 2178
  5. D 120 256 0 633
  6. Assembly 4 16 2 185
  7. JSON 116 0 0 116
  8. Markdown 1 4 0 55
  9. make 2 17 0 54
  10. TOML 2 5 2 22
  11. Bourne Shell 1 0 0 1
  12. <!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!----
  13. SUM: 288 613 25 3244
  14. <!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!---<!----

代码仓库

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

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

阅读在线文档并进行实验