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...
xv6 lab uthread前置xv6 book章节 第四章、trap和syscall 有三种情况,CPU会把当前执行的执行指令流转让出去给相应的事件处理程序。 一种情况就是syscall系统调用,用户进程主动调用ecall指令让内核帮助其完成一些任务。 第二种情况就是exception异常,用户进程或者内核程序的非法指令导致当前执行流的让出,比如除0错误,或...
->RISC-V发出中断 ->trap handler ->调用devintr ->检查状态 ->调用uartintr处理输入 查看uartintr的源码, 可以看到它会循环不断的从UART硬件中读取等待的输入字符,并传递给consoleintr, 一旦读取完,uartgetc返回-1, 立刻退出循环, 结束这次中断的处理.并再次响应下一个像上面这样的流程产生的中断. void uartin...
OpenSCA CLI 是一款开源的软件成分分析工具,用来扫描项目的第三方开源组件依赖及漏洞信息。如何使用 了解详情 下载安装 OpenSCA-CLI: 访问https://gitee.com/XmirrorSecurity/OpenSCA-cli,通过发行版(Release)下载对应系统架构最新的OpenSCA-Cli工具。 使用说明: ...
xv6的特性:An Overview2. 启动xv6操作系统3. 自旋锁spin lock4.kalloc和内存管理5.参考:RISC-V指令...
/* 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. ...
课程参考资料: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 ...