把物理地址暴露给外部是一件非常危险的事情,因此采用虚拟内存作为线性地址与物理地址的中间层。
32位地址总线保存0x00000000到0xffffffff所有的地址,转换为二进制就是32个0到32个1,也就是2^32 = 4G,因此虚拟内存大小为4G,其布局如下图所示:
一个可执行文件在运行时被装载到虚拟内存,那么他是怎么装载的呢?首先,每个进程都有一个PCB(进程描述符)来描述这个进程的状态信息,其内部有一个struct mm_struct *mm指向了一个mm_struct结构体,该结构体被称为内存描述符,用来描述进程地址空间。如下图所示:
内存描述符有一个指针mmap指向一个链表,该链表节点类型为struct vm_area_struct,每个节点指向了虚拟内存中的一个段。内存描述符还有一个pgd_t *pgd指向页全局目录: