4.5 KiB
Rust OS 教学lab实验的制作 基础功能完善
1 内存管理
1.0 尚未实现
- 页面置换Enhanced Clock算法实现: 主要需要修改和完善以适应新的接口, 可以考虑作为lab中的challenge
- 页面换出到磁盘而非堆内存中: ide无法挂载,目前是换入到堆内存中.
- Copy On Write: 之前框架中有Copy on write的部分实现,并未启用,正确性存疑. 可以考虑作为lab中的challenge
- 获取页表项方法中存在的bug修复: 该bug目前不会影响OS运行, 但是这显然是十分危险的(比如在多核时,或者被中断时). 可能的修复方式是fork一份riscv库并对其进行修改,提供对页表项的操作接口.
1.1 page fault 处理
Rust OS riscv32中之前并未实现page fault的异常处理, 目前已经加入page fault处理,目前的page fault能够处理的错误包括:
- 页面换出导致的page fault
- copy on write导致的page fault(由于目前尚未将copy on write机制接入框架,因此正确性有待验证)
1.2 页面置换
框架中原本的页面置换算法框架仅支持单页表, 且并未在RustOS中启用而只是在ucore-memory库中进行了测试. 此外之前部分swap in/out的底层支持尚未实现(set_swapped等等).
目前已经:
完成了swap in/out所需的底层支持: 由于目前框架中尚未启用copy on write, 因此实际上swap并未考虑到copy on write在page entry上所占用的标志位.不过swap标志位仅在not present时候有意义,因此通过略微修改现有框架是可以实现同时开启copy on write和swap 机制的.
修改页面置换的框架实现,使之支持多个用户进程: 这里主要的改动在于SwapManager除了需要记录可换出页的虚地址以为,还要记录虚地址所在的二级页表(InactivePageTable0). 在换入换出操作时可能需要短暂进行活跃页表的切换.
在RustOS中启用页面置换: 仅用户进程地址空间的用户页(MemorySet中所包含的地址)允许被换出.目前实现是在用户进程创建时将这些页设为swappable,在进程结束Context资源释放前先将这些页全部换入内存,然后进行unmap操作释放物理内存.
1.3 物理页帧延迟分配
实现了用户线程memory area部分(非内核部分)的物理内存延迟分配.实现方法是在map的时候对于上述内存区域仅建立页表项,target部分设置为0. 在page fault的时候对于这些页表项分配物理页帧.目前来说没有处理不合法虚地址的问题,但是目前memory set record记录了new user和fork的时候的临时memory的记录,因此理论上用裸指针是比较好实现虚地址合法性的判断(process.get_memory_set_mut()可以获取一般的memory set的可变引用).
2 进程管理
已经完成从王润基处的移植,目前的问题是依然会有out of memory.
3 同步互斥
修正了原本底层原子函数的bug并补全了底层原子函数的实现,但是目前的底层使用关中断实现,不支持多核,不过不影响lab实验的制作。
4 文件系统
由于文件系统的主体不在主仓库而是在 wangrunji0408/SimpleFileSystem-Rust 中,对文件系统的修改在 benpigchu/SimpleFileSystem-Rust 进行(ucore-fs-enhance
分支)。要在主仓库中预览目前进行的修改,可以在 kernel/Cargo.toml
中加入以下内容:
[patch."https://github.com/wangrunji0408/SimpleFileSystem-Rust"]
simple-filesystem = { git = "https://github.com/benpigchu/SimpleFileSystem-Rust", branch="ucore-fs-enhance" }
以下是目前的进度与在真正进入教学 Lab 划分与制作前的计划
- 修复原有实现的错误
- 正确维护和解释磁盘上的
inode
结构的size
项 - 正确维护磁盘上的
inode
结构的nlinks
项
- 正确维护和解释磁盘上的
- [-] 补充实现之前未实现的功能
unlink
link
mount
- 符号链接相关内容
- [-] 调整接口的定义
- 用只获得一个目录项的
get_entry
取代获得所有目录项的list
- 用单层查找的
find
取代多层查找的lookup
- 返回错误类型而非直接
panic!
- 将
vfs
device
等与具体文件系统无关的内容从SimpleFileSystem-Rust
仓库移动到主仓库的新包中(crate/vfs
)
- 用只获得一个目录项的
- 让用户程序能够操作文件系统
- 使文件系统线程安全
- 实现文件描述符
- 实现相关系统调用