3.7 KiB
Rust OS多核移植与基于PARD框架的线程级Label管理 方案设计文档
2015011251 王纪霆
实验目标
- 完成RustOS在riscv32上的多核开启
- 使RustOS可在中科院计算所PARD RISCV硬件环境下运行
- 使RustOS能够在PARD上开启smp
- 添加控制功能,使得RustOS可以控制/查看PARD的寄存器
如果以上这些要全部实现,可以预料地将无法在八周内完成。
实验背景
LvNA/PARD是一个用于进行内存隔离的硬件系统。它基于rocket-chip实现,在通常的多核以外,在核与各存储设备间增加了寄存器和额外的模块,并且对总线访问添加了标签,两者相结合下,可以完成对总线访问的控制,即对各核能够使用的缓存大小、磁盘流量进行限制等。
但目前为止,这项工作还有一些问题。首先是作为控制流量的关键——control plane,并未暴露给各核,而需要通过硬件的JTAG机制与板子上的控制模块prm(内含一个linux系统)沟通,并且在prm上实现控制脚本。而prm又和各核无法直接沟通,这样,运行在各核上的OS不仅无法修改寄存器,也无法知晓自己所分配到的资源大小,与PARD系统完全隔离。
如此一来,这个系统仅能进行核间的隔离,而无法完成进程间的隔离。这是因为,为了区分进程、给两个进程打上不同的标签,就必须让OS可以主动修改和设置control plane。
解决这个问题,实现进程级的label管理就是这个项目的主要目的。
实验设计
实际上,本项目的两个方向,即多核移植和PARD移植,是可以独立完成的。因为也可以退而求其次,考虑在PARD上只运行单核的线程级标签管理。但最终的目的还是让RustOS接手PARD的所有核,作为一个多核OS运行,对整个系统的运行进行管理。
最理想的方法是让硬件把control plane映射到内存,作为各核的一个设备。但硬件非常复杂,并且中科院方也没有实现这一功能。所以还是对硬件不做修改,依旧通过prm管理control plane,而将prm用串口等和各核连接,让其作为核的一个设备,在核的控制下修改底层配置。
为此,需要做的具体来说是:
- 让RustOS可以在核上运行;
- 在prm上写脚本(运行在完善的Linux环境,且有现成范例),控制control plane;
- 在RustOS上写驱动,使其可以与prm交互完成控制;
- 在RustOS中添加系统调用等,使得操作系统可以管理驱动;
另一边,多核移植所要做的是:
- 开启多核,实现原子操作等,为内核中可能的竞争加锁(Rust已经帮我们做了很多);
- 核间进程调度,load balance;
多核这边打算做的简单一些,基本照搬uCore+ on rv64来做,因为主要的设计和优化工作应该交给wrj同学。
目前进度
PARD端:
- 完成了实现机理的调研
- 正在服务器上编译复现(工程太大,本地vivado编译不了)
多核端:
- 完成了ucore+ smp的初步学习
- 学习了bbl,完成了RustOS on rv32的多核开启
暂时计划
如果必须前八周结束,估计是无法做完的。
根据能否在前八周过后继续做,有以下远近期的计划:
短期
- 完成rv32 on smp的移植(第5-6周)
- 完成多核Rust OS在PARD上的运行(第7-8周)
长期
- 完成RustOS与PARD的交互协议构建(第9-11周)
- 实现基于RustOS的进程级标签管理(第12周后)
以上均基于只有本人一人工作的前提,若有其他人协助/加入则根据实际情况而定。