和内存不同的是,这个“页表”的级别是自定义的,原始的xv6的表有13项,前12项直接包含文件块的地址,第13项是二级表的地址,二级表包含256项,每项都是文件块的地址,所以单个文件最大为12+256个文件块,为了支持更大的文件,需要将直接包含文件块地址的表项中取一项支持三级表,这样单个文件就可以扩大到11+256+256*...
uint64handle_page(uint64 va,structproc *p){if(va < (1L<<37) || va >= (1L<<57))return-1;for(inti =0; i <16; i++)if(p->vmas[i].valid && va >= p->vmas[i].addr && va < p->vmas[i].addr + p->vmas[i].length) {intperm = PTE_U;if(p->vmas[i].prot & PR...
首先是对thread_schedule函数进行填空,只需要调用切换函数就行了,根据文档的说明,这个切换函数是保存当前线程用到的所有callee-saved寄存器,然后将这些寄存器全部赋值为下一个线程里保存的值,联想到xv6内核里的context结构体就是用来保存这些寄存器的,所以直接复制过来并作为thread结构体的一个属性,那么调用切换函数就会像这...
MIT-6.S081-2020实验(xv6-riscv64)一:util 实验文档 概述 实验一主要涉及调用系统调用函数,这些系统调用函数基本都是符合POSIX规范的,和操作系统本身关系较小,在调试的时候也可以先把程序在外部的Linux下跑通然后再放进xv6中运行。 内容 sleep 基本没什么特别的内容,按说明的做就行了。 #include "kernel/types...
实验文档 概述 这次实验主要实现Lazy allocation的功能,即进程在动态分配内存的时候先不分配,等到要用到发生缺页中断的时候再实际分配,核心是实现缺页中断的处理。xv6的文档介绍了三种缺页中断的应用,第一为Copy on write,即fork的时候先不复制内存,等到要用到发生缺
MIT-6.S081-2020实验(xv6-riscv64)六:cow 实验文档 概述 这次实验实现copy on write功能,和上次实验一样也是缺页中断的应用,但不同的是,这次实验涉及的物理内存和虚拟地址的操作要比上个实验多不少,因此难度也更大一些。 内容 首先是uvmcopy的部分,原来的操作是从老页表中获得虚拟地址对应的物理地址,创建一...
However, this scheme does limit the maximum size of a user process to be less than the kernel's lowest virtual address. After the kernel has booted, that address is0xC000000in xv6, the address of the PLIC registers; memlayout.h中CLINT对应的常数是0x2000000,比0xC000000小,按照文档的指示是可...
这次实验主要实现网卡驱动的一部分,文档内容非常长,实际实验不算难,跟着hint就行,但还是需要对整体框架有一定的了解。 内容 发送函数: inte1000_transmit(structmbuf *m){ acquire(&e1000_lock); uint32 index = regs[E1000_TDT];if((tx_ring[index].status & E1000_TXD_STAT_DD) ==0) { ...
MIT-6.S081-2020实验(xv6-riscv64)八:lock 实验文档 概述 这次实验主要涉及锁在内核的应用,没有用到什么特别的理论知识,但是编程的时候陷阱重重,要么资源竞争,要么死锁,和实验三差不多,非常考验耐心和细心。 内容 Memory allocator 这个任务要求给物理内存分配程序重新设计锁,使得等待锁时的阻塞尽量少。可以按CPU...
MIT-6.S081-2020实验(xv6-riscv64)六:cow 实验文档 概述 这次实验实现copy on write功能,和上次实验一样也是缺页中断的应用,但不同的是,这次实验涉及的物理内存和虚拟地址的操作要比上个实验多不少,因此难度也更大一些。 内容 首先是uvmcopy的部分,原来的操作是从老页表中获得虚拟地址对应的物理地址,创建一...