首先先切换到lazy分支
git checkout lazy
make clean
Xv6应用程序使用sbrk()系统调用向内核请求堆内存。sbrk()分配物理内存并将其映射到进程的虚拟地址空间。内核为一个大请求分配和映射内存可能需要很长时间。为了提高效率,故采用懒分配的策略
Eliminate allocation from sbrk()
删除sbrk(n)系统调用中的页面分配代码(kernel/sysproc.c)

Lazy allocation
1.修改kernel/trap.c里面的usertrap()函数,根据r_scause()判断是否为页面错误,(p->sz代表进程的地址上限)然后分配物理内存并添加映射

2.修改kernel/vm.c中的uvmunmap()函数,lazy allacation中没有实际分配内存,那么解除映射关系的时候这部分内存也要略过

第一个continue而言,主要解决的问题是一二级页表中存在Lazy Alloction的pte还未建立映射关系,所以walk函数会返回0

最低0.47元/天 解锁文章
2364

被折叠的 条评论
为什么被折叠?



