i386的页机制

i386CPU不仅有段机制,而且支持页机制。一个32位的逻辑地址经过段机制映射成线性地址后,还要经过页机制映射成32位的逻辑地址。

与页机制有关的寄存器有:CR3,CR0

CR0的最高位PG是页映射机制的总开关,如果PG位是1则开启页映射机制。

CR3寄存器用来存放页面目录的首地址。

32位的线性地址分成如下3个部分:

页面目录dir,10bits页面表page,10bits页内偏移offset,12bits
i386把地址分成许多页面,每个页面大小为4k字节(12位)。

容易看出,页面目录里共有1k个页面表的地址,由于每个地址是32位的,所以一个页面目录占用4k字节的空间,正好一个页面。

同样,1个页面表里共有1k个页面的地址,占用4k字节,也是一个页面。

页机制的工作过程如下:

把32位线性地址的dir部分加上CR3,得到相应页面表的首地址。

把页面表的首地址加上线性地址中的page部分,得到页面的首地址。

把页面首地址加上线性地址的offset部分,得到逻辑地址。

由于每个页面表大小正好位4k字节,因此每个页面表会正好放在一个页面里面。也就是说页面表的首地址是4k的倍数。因此页面目录中每项的低12位都没用到,因此i386把页面目录项的低12位移做他用。

同样,对页面表中的每个地址,低12位也有其他用途。


NOTES:

1 对内核空间,从虚拟地址上看,内核空间是分配在4G空间中的最高的1G,而物理地址是分配在最低的1G空间。他们之间存在一个简单的关系,即内核空间的线性地址减去3G就是物理地址。虽然他们也要通过页机制来映射,但页机制映射内核空间地址时,保证它们之间存在如上的关系。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值