内存管理 -- 快表 TLB (Translation Look-aside Buffers)

一、页表

因为虚拟内存的存在,它最终还是要去访问物理内存,中间就需要通过映射,来达到获取内存中数据的目的。而映射就需要建立虚拟内存与物理内存的关系,这就有了页表的存在。
页表存在于进程的内存之中,MMU收到虚拟地址之后查询Page Table来获取物理地址。
内存管理 -- 快表 TLB (Translation Look-aside Buffers)_第1张图片

1、单级页表

处理器把虚拟地址给到MMU,然后MMU通过查表的方法找到与虚拟地址对应的物理地址。此时问题就出现了,如果只有一级的页表查找速度是会非常快,但会占去很大一部分内存,

如:对于4GB的虚拟地址且大小为4KB页,一级页表将有2^20个表项,页表占有连续内存并且存储空间大
内存管理 -- 快表 TLB (Translation Look-aside Buffers)_第2张图片

2、多级页表

多级页表把需要的用到的页复制到内存中,而不需要的则放在辅存中,这样就能省去很大一部分内存。但问题又来了,因为是多级页表,就需要一步一步的检索,带来了查询效率的问题。
以2级页表为例,MMU要先进行两次页表查询确定物理地址,在确认了权限等问题后,MMU再将这个物理地址发送到总线,内存收到之后开始读取对应地址的数据并返回。

这就像在地

你可能感兴趣的:(arm,linux,从入门到精通,linux,嵌入式硬件)