###关于写时复制 父进程创建子进程之后,并不是将自己的数据段、堆和栈完全复制一份给子进程,而是将这些区域的访问权限设置为只读,如果父进程或者子进程的中的任一个试图修改这些区域,则内核将为修改区域的那块内存制作一个副本。在此之前,内核仅为子进程分配虚拟地址,父子进程共享同一段物理地址。
但是在内核空间创建进程时没有写时复制。在mm/memory.c中,
copy_page_tables函数中有这样一段代码:
if (this_page > LOW_MEM) {
*from_page_table = this_page;
this_page -= LOW_MEM;
this_page >>= 12;
mem_map[this_page]++;
}
LOW_MEM是1M,对于位于 1MB 以下的页面,说明 是内核页面,因此不需要对 mem_map[]进行设置。因为 mem_map[]仅用于管理主内存区中的页面使用 情况。因此,对于内核移动到任务 0 中并且调用 fork()创建任务 1 时(用于运行 init()),由于此时复制的页面还在内核区域,所以下面判断中的语句不会执行。这就是在内核空间中创建进程时没有写时复制的原因。