You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

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
  • 让用户程序能够操作文件系统
    • 使文件系统线程安全
    • 实现文件描述符
    • 实现相关系统调用