内存管理重要的组成部分是虚拟地址和物理地址之间的映射关系。从物理设备上看这部分的功能由页表(page table)实现。
页表本身是存储在物理内存中的一块内存空间,操作系统按照硬件规范填写相应地址形成树状结构。而硬件则根据这个树状结构实现虚拟地址到物理地址的映射。
Intel的手册上写的非常详细,我就截取一张图做示例。
每个进程都有自己的页表,虽然用户空间的映射依赖进程自身,但所有进程都共享同样的内核页表空间。所以探究内核页表结构是加深内核页表运行机制的方式之一。
然而你知道么,内核页表并非一蹴而就,而是经过了几个步骤才最终成为我们想要的样子。就好像你得先飞升上仙,才能够飞升上神。这是一个道理。
内核页表经过了下面几个变化过程。
内核刚加载时,还是压缩后的状态。这时候内核就有一张非常简陋的页表。直接映射了4G空间。