当进程需要更多的内存的时候,调用malloc申请更多的堆内存,而系统调用sbrk()完成该工作。sbrk系统调用分配物理内存,并映射到进程的虚拟地址。但是有的进程会一次申请大量的内存,但是又可能根本用不到,比如说sparse array。所以说复杂的内核涉及会将实际的allocation的工作推迟到实际用的时候,发生了page fault了,然后再进行实际的分配。
第1部分:Eliminate allocation from sbrk()
对系统调用sbrk的实际实现sys_sbrk进行修改,只将进程的内存空间大小增加n,而不进行实际的分配。代码修改如下
//sysproc.c
int
sys_sbrk(void)
{
int addr, newsz;
int n;
if(argint(0, &n) < 0)
return -1;
addr = proc->sz;
newsz = addr + n;
if (newsz >= KERNBAS