最新通知
由于本文档还不稳定,有时会有更新,更新信息会第一时间放在这里。由于文档不稳定引起的问题不会导致扣分。
最后更新日期: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 设定为;
在练习六中增加了测试文件需要用到的 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 保存其完整的状态以供出现问题时参考。
与章节相对应的代码可以很容易的找到。章节标题下提供了指向下一个存档点代码状态的链接。