进程创建使用do_fork函数,其中重要的部分如子进程的地址空间的建立,进程空间的建立主要包括线性地址空间和物理地址空间两个方面。其中线性地址空间使用VMA的方式管理,在dup_mmap函数中进行复制和初始化,而物理地址空间使用页目录,页表来管理。
下面分析进程物理地址空间的初始化过程。
整个调用流程:do_fork -> copy_process -> copy_mm -> dup_mm ->
其中进程的页表分为两段,0G-3G用户页表,3G-4G内核页表
内核页表
内核页表的创建 :~/ ->mm_init -> mm_alloc_pgd -> pgd_alloc