首先切换pgtbl分支
git checkout pgtbl make clean
Print a page table
定义一个vmprint()函数,应当接受一个pagetable_t作为参数,会按照如下的格式进行打印页表
在exec.c中的return argc之前插入if(p->pid == 1) vmprint(p->pagetable)
,以打印第一个进程的页表
当启动xv6时,那么就会打印输出来描述第一个进程刚刚完成exec()->init时的页表:
-
第一行
page table 0x0000000087f64000
显示vmprint的参数 -
之后每一行对应一个PTE,包含树中所指的页表页的PTE
-
每个PTE行都有一些 . ,表示其在树中的深度
-
每一行显示其在页表页面中的PTE索引,PTE比特位以及PTE所对应的物理地址
1.首先根据提示在exec.c中的return argc之前插入if(p->pid==1) vmprint(p->pagetable)
2.看kernel/vm.c中有freewalk方法,用来释放页表页面内存的
根据这个逻辑可以仿照出来一个vmprint(pagetable_t pagetable)
函数,
pagetable_t是一个页面指针,xv6使用三级页表,每个页面大小为4096字节,在kernel/riscv.h中规定
不过由于要打印 .. 所以考虑递归需要多传入一个参数用来记录层级
所以另外实现一个递归函数_vmprint(pagetable_t pagetable, int level)
3.添加vmprint函数定义放到kernel/defs.h里面
void vmprint(pagetable_t);
mak