🐳
uCore OS(on RISC-V64)实验指导书
  • Introduction
  • LAB0:ready~go!
    • 实验目的
    • 实验内容
    • 前导知识
      • 了解uCore
      • 了解RISC-V
      • 了解OS实验
      • 了解实验环境
      • 了解开发调试基本工具
      • 了解硬件模拟器
    • 配置环境
      • 安装虚拟环境
      • 安装开发工具
      • 安装硬件模拟器
      • 安装调试工具
  • LAB0.5:最小可执行内核
    • 实验目的
    • 实验内容
    • 练习
    • 内存布局
    • 链接脚本
    • 真正的入口点
    • 从SBI到stdio
    • 编译运行
    • 项目组成与执行流
  • LAB1:中断机制
    • 实验目的
    • 实验内容
    • 练习
    • RISC-V中断相关
    • 上下文处理
    • 中断处理程序
    • 时钟中断
    • 项目组成与执行流
  • LAB2:物理内存管理
    • 实验目的
    • 实验内容
    • 练习
    • 地址与页表
    • 物理内存探测
    • 以页为单位管理物理内存
    • 页面分配算法
    • 项目组成与执行流
  • LAB3:虚拟内存管理
    • 实验目的
    • 实验内容
    • 练习
    • 页面置换
    • PageFault
    • 使用多级页表
    • 页面置换机制
    • FIFO置换算法
    • 项目组成与执行流
  • LAB4:进程管理
    • 实验目的
    • 实验内容
    • 练习
    • 进程与线程
    • 相关结构体
    • 进程模块初始化
    • 进程切换
    • 项目组成与执行流
  • LAB5:用户程序
    • 实验目的
    • 实验内容
    • 练习
    • 用户进程
    • 用户程序
    • 创建并执行用户进程
    • 系统调用
    • 用户进程的退出和等待
    • 项目组成与执行流
  • LAB6:进程调度
    • 实验目的
    • 实验内容
    • 练习
    • 进程状态
    • 再次认识进程切换
    • 调度算法框架
    • 项目组成与执行流
  • LAB7:同步互斥
    • 实验目的
    • 实验内容
    • 练习
    • 同步互斥的基本概念
    • 信号量
    • 条件变量与管程
    • 项目组成与执行流
  • LAB8:文件系统
    • 实验目的
    • 实验内容
    • 练习
    • 文件系统介绍
    • 文件系统抽象层VFS
    • 硬盘文件系统SFS
    • 设备即文件
    • 从中断到终端
    • 项目组成与执行流
由 GitBook 提供支持
在本页
  • 练习1:说明不会出现死锁的原因
  • 练习2:设计方案
  • 练习3:信号量实现条件变量
  • 练习4:禁用中断

这有帮助吗?

  1. LAB7:同步互斥

练习

练习1:说明不会出现死锁的原因

  1. 证明/说明为什么我们给出的信号量实现的哲学家问题不会出现死锁。不必特别严谨,但要能说服你自己/助教?

  2. 证明/说明为什么我们给出的条件变量实现的哲学家问题不会出现死锁。不必特别严谨,但要能说服你自己/助教?

练习2:设计方案

  1. 给出为用户态进程/线程提供信号量机制的设计方案,并比较说明给内核级提供信号量机制的异同。

  2. 给出为用户态进程/线程提供条件变量机制的设计方案,并比较说明给内核级提供条件变量机制的异同。

练习3:信号量实现条件变量

能否不基于信号量机制来完成条件变量?如果不能,请给出理由,如果能,请给出设计说明和具体实现。

练习4:禁用中断

kern/sync/sem.c的信号量实现中,出现了这样的暂时禁用中断的代码:

static __noinline uint32_t __down(semaphore_t *sem, uint32_t wait_state) {
    bool intr_flag;
    local_intr_save(intr_flag);
    /*some code*/
    local_intr_restore(intr_flag);
}

我们其实从正确的框架里删除了两句local_intr_restore(intr_flag)和一句local_intr_save(intr_flag);,请你找出是哪里删掉了,并举出删掉之后不能正常工作的一种情况。

上一页实验内容下一页同步互斥的基本概念

最后更新于4年前

这有帮助吗?