MIT6.828_HW4_ XV6 Lazy Page Allocation

Homework4: xv6 lazy page allocation

Xv6应用程序使用sbrk()系统调用向内核请求堆内存,sbrk()分配物理内存并将其映射到进程的虚拟地址空间。 有些程序分配内存,但从不使用它,例如大型稀疏数组。 复杂的内核会延迟分配内存的每个页面,直到应用程序尝试使用该页面为止(产生缺页中断时),本练习中我们会将此延迟分配功能添加到xv6。

Part One: Eliminate allocation from sbrk()

第一个任务是删除sbrk(n)系统调用中分配内存的核心代码,sbrk(n)会根据参数n增加分配给进程的内存,
然后返回新分配内存区域的起始地址,原来的sbrk(n)做两个工作:分配内存,增加myproc()->sz,我们写的
新sbrk(n)函数只根据参数n增加myproc()->sz,不做实际的分配工作。修改后的代码如下图:
图片
修改后进行make qemu,进入xv6系统,当执行如下操作时,你会发现产生了某些错误:
图片
"pid 3 sh: trap…" 这行信息是trap.c中的处理trap的函数发出的,trap号14代表发生了页故障,为什么
会发生页故障呢?

答:sbrk()实际上并没有分配内存,所以可以猜测是某个地方调用了该函数,然后对未分配的内存区域进行

  • 6
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值