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. 练习题

lab7

本实验主要需要阅读代码和回答问题。

  1. 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分,每找出一处1分,举出不能正常工作的情况1分)

    • 注:现在还没删这几处。

    • 同学们其实可以轻松地找到正确框架的代码,然后通过对比得到哪里是删掉的。这是否对自己分析的同学不太公平?(这个分析的过程可能还比较恶心)。可行的方式是不是,我们直接告诉同学们正确框架在哪里,只要你不想自己分析我们就允许你直接diff不同文件来找bug, 如果你觉得我们的作业有意思,就自己分析哪里应该加?

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

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

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

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

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

上一页lab6下一页lab8

最后更新于5年前

这有帮助吗?