i386CPU不仅有段机制,而且支持页机制。一个32位的逻辑地址经过段机制映射成线性地址后,还要经过页机制映射成32位的逻辑地址。
与页机制有关的寄存器有:CR3,CR0
CR0的最高位PG是页映射机制的总开关,如果PG位是1则开启页映射机制。
CR3寄存器用来存放页面目录的首地址。
32位的线性地址分成如下3个部分:
页面目录dir,10bits | 页面表page,10bits | 页内偏移offset,12bits |
容易看出,页面目录里共有1k个页面表的地址,由于每个地址是32位的,所以一个页面目录占用4k字节的空间,正好一个页面。
同样,1个页面表里共有1k个页面的地址,占用4k字节,也是一个页面。
页机制的工作过程如下:
把32位线性地址的dir部分加上CR3,得到相应页面表的首地址。
把页面表的首地址加上线性地址中的page部分,得到页面的首地址。
把页面首地址加上线性地址的offset部分,得到逻辑地址。
由于每个页面表大小正好位4k字节,因此每个页面表会正好放在一个页面里面。也就是说页面表的首地址是4k的倍数。因此页面目录中每项的低12位都没用到,因此i386把页面目录项的低12位移做他用。
同样,对页面表中的每个地址,低12位也有其他用途。
NOTES:
1 对内核空间,从虚拟地址上看,内核空间是分配在4G空间中的最高的1G,而物理地址是分配在最低的1G空间。他们之间存在一个简单的关系,即内核空间的线性地址减去3G就是物理地址。虽然他们也要通过页机制来映射,但页机制映射内核空间地址时,保证它们之间存在如上的关系。