ucore step by step
tutorial
tutorial
  • 欢迎来到ucore step-by-step的世界
  • lab0: 预备起
    • 溯源: ucore的历史
    • 概览: 指导书的结构
    • 开搞: 实验环境搭建
  • lab0.5: 比麻雀更小的麻雀(最小可执行内核)
    • 内存布局,OpenSBI,elf和bin
    • 链接脚本和入口点
    • "真正的"入口点
    • 从SBI到stdio
    • Just make it
    • 项目组成和执行流
  • lab1: 断, 都可以断
    • 掉进兔子洞(中断入口点)
    • 中断处理程序
    • 滴答滴答(时钟中断)
    • 项目组成和执行流
  • lab2: 物理内存和页表
    • 内核初始映射
    • 物理内存管理
    • 页面分配算法
    • 项目组成和执行流
  • lab3: 缺页异常和页面置换
    • 扫清外围
    • 使用多级页表
    • 页面置换机制
    • FIFO置换算法
    • 项目组成和执行流
  • lab4: 进程管理
    • 进程与线程
    • 相关数据结构
    • 进程模块初始化
    • 进程切换
    • 项目组成和执行流
  • lab5: 用户程序
    • 用户程序
    • system call!
    • 中断处理
    • 项目组成和执行流
  • lab6: 进程调度
    • 再次认识进程切换
    • 调度算法框架
    • 项目组成和执行流
  • lab7: 同步互斥
    • 同步互斥的基本概念
    • 信号量
    • 条件变量与管程
    • 项目组成和执行流
  • lab8: 文件系统
    • 文件系统抽象层VFS
    • 硬盘文件系统SFS
    • 设备即文件
    • 从zhong duan 到 zhong duan
    • 项目组成和执行流
  • 练习题
    • lab1
    • lab2
    • lab3
    • lab4
    • lab5
    • lab6
    • lab7
    • lab8
  • 附录
    • makefile
由 GitBook 提供支持
在本页
  • 实验要求
  • 实验帮助
  • 思考题(不计分)

这有帮助吗?

  1. 练习题

lab1

上一页练习题下一页lab2

最后更新于4年前

这有帮助吗?

实验要求

阅读文档lab0-1,完成实验环境的搭建,并可以运行ucore。

  1. 回答:描述ucore中处理中断异常的流程(从异常的产生开始)。(2分)

  2. 回答:对于任何中断,__alltraps 中都需要保存所有寄存器吗?请说明理由。(2分)

  3. 编程:在任意位置触发一条非法指令异常(如:mret),在 kern/trap/trap.c的异常处理函数中捕获,并对其进行处理,简单输出异常类型和指令即可。(6分)

实验帮助

  • 参考资料

    • :重点第 10 章

  • 非法指令可以加在任意位置,比如在通过内联汇编加入,也可以直接修改汇编。但是要注意,什么时候时候异常触发了才会被处理?

  • 查阅参考资料,判断自己触发的异常属于什么类型的,在相应的情况下进行代码修改。

思考题(不计分)

  • ucore支持嵌套异常吗?如果不支持,可否通过一些方法使得ucore支持?

RV 硬件简要手册-中文
RV 硬件规范手册-英文