进程控制块PCB,实际上指的是一个结构体task_struct。下面说说这个task_struct
Task_struct有一个指向mm_struct的指针,mm_struct结构体是该进程整个用户空间的抽象。包含着装入的可执行映像信息以及进程的页目录指针。Mm_struct结构体非常有意思,在一个进程控制块里,只含有一个指向mm_struct的指针,但是一个mm_struct能够被若干个进程指向。怎么指呢?通过的fork。fork后会创建子进程,子进程在写实拷贝之前,和父进程指向同一块物理页面,如图
父子进程所指向的物理内存是同一块内存,两个进程所映射的物理页面仍然是相同的,所以mm_struct被共享。Mm_struct里放着一个变量mm_count,用来统计被指了多少次。mm_struct有一个非常有名的指针,pgd。这个指针,就是放在CR3的指针。在切换进程的时候,会在切换函数的最末把当前进程的pgd放进CR3里,进而保持页目录的准确。
下面是mm_struct的源码
struct mm_struct
{
struct vm_area_struct *mmap; /* list of VMAs */
struct vm_area_struct *mmap_avl; /* tree of VMAs */
struct vm_area_struct *mmap_cache; /* last find_vma result */
pgd_t * pgd;
atomic_t mm_users; /*