一、页表
因为虚拟内存的存在,它最终还是要去访问物理内存,中间就需要通过映射,来达到获取内存中数据的目的。而映射就需要建立虚拟内存与物理内存的关系,这就有了页表的存在。
页表存在于进程的内存之中,MMU
收到虚拟地址之后查询Page Table
来获取物理地址。
1、单级页表
处理器把虚拟地址给到MMU
,然后MMU
通过查表的方法找到与虚拟地址对应的物理地址。此时问题就出现了,如果只有一级的页表查找速度是会非常快,但会占去很大一部分内存,
如:对于4GB的虚拟地址且大小为4KB页,一级页表将有2^20个表项,页表占有连续内存并且存储空间大
2、多级页表
多级页表把需要的用到的页复制到内存中,而不需要的则放在辅存中,这样就能省去很大一部分内存。但问题又来了,因为是多级页表,就需要一步一步的检索,带来了查询效率的问题。
以2级页表为例,MMU
要先进行两次页表查询确定物理地址,在确认了权限等问题后,MMU
再将这个物理地址发送到总线,内存收到之后开始读取对应地