xv6 book risc-v 第八章 文件系统 文件系统的一个目标是组织和存储数据。文件系统通常支持在用户和应用之间共享数据,以及持久化它们以让重启后数据仍然可用。 xv6文件系统提供Unix风格的文件、目录以及路径名(查看第一章)并且将它的数据存储在virtio磁盘上以持久化(查看第四章)。文件系统面临多种挑战: 文件系统需要...
xv6 book risc-v 第六章 锁 包括xv6在内的大多数内核都会交错的执行多个活动,一个原因来自于多处理器硬件:计算机有多个独立运行的CPU,比如xv6的RISC-V,这些CPU共享物理内存,并且xv6利用这一点来维护被所有CPU共同读写的数据结构。这种共享提高了在一个CPU正在更新数据结构的过程中另一个CPU读取该数据结构的可能,...
P在sleep时保持着锁,所以V将永远阻塞在等待锁的过程中。 我们将通过改变sleep的接口来修正前面的方案:调用者必须将条件锁(condition lock)传递给sleep,这样在调用进程被标记为SLEEPING并在chan上等待后,它就可以释放锁。锁将强制并发的V等待直到P将自己置于SLEEPING状态,这样wakeup就会发现SLEEPING**的消费者并将其唤醒...
RISC-V的页表硬件通过将每个虚拟地址映射到一个物理地址将这两种地址联系起来。 xv6运行在Sv39 RISC-V上,这意味着只会使用64位虚拟地址的低39位,高25位没有被使用。在这种Sv39配置中,一个RISC-V页表在逻辑上是一个由2²⁷(134,217,728)个页表项(Page Table Entry, PTE)组成的数组。每个PTE包含一个44...
我们将这个物理页的起始地址放到 RISC-V 处理器指定的一个寄存器中(stap),接着打开启用虚拟地址的...
4.1 RISC-V的trap机制 每个RISC-V的CPU都有一些控制寄存器,内核可以通过写寄存器告诉CPU怎么处理trap,内核也可以通过读相应的控制寄存器来判断发生了哪种trap。 stvec(supervisor trap vector):内核将trap处理程序的地址写到此寄存器,RISC-V就会跳转到此处来处理trap ...
课程参考资料:xv6 book https://pdos.csail.mit.edu/6.828/2021/xv6/book-riscv-rev2.pdf 做每一章实验前都会要求阅读相关章节 网上参考笔记及代码: 1.B站UP的笔记: https://cactus-agenda-c84.notion.site/XV6-labs-2021-0894f931b3324edea30dca7826c01a97 ...
/* kernel/riscv.h */ ... // one beyond the highest possible virtual address. // MAXVA is actually one bit less than the max allowed by // Sv39, to avoid having to sign-extend virtual addresses // that have the high bit set. ...
使用IDEA 插件离线检测 将OpenSCA 扫描能力集成到 IntelliJ 平台 IDE 工具,随时随地保障组件依赖安全。如何使用 了解详情 使用OpenSCA CLI 扫描分析 OpenSCA CLI 是一款开源的软件成分分析工具,用来扫描项目的第三方开源组件依赖及漏洞信息。如何使用 了解详情
xv6是由麻省理工学院(MIT)开发的一个教学目的的操作系统,它是在x86处理器上用ANSI标准C重新实现的Unix第六版(即v6), 课程编号为6.828。2019年被移植到RISC-V之上,并设置了6.S081。 xv6的主要特征: 开源,精简,代码仅两万行左右; 功能完善,可全面理解操作系统的原理及实现; ...