1 MMU是什么?有什么功能?
MMU是内存管理单元。MMU可以实现虚拟地址到物理地址的转换(映射)。
2 为什么要使用MMU
为了解决以下两个问题:
a)为了在小内存中运行大程序。实际情况中,程序容量大于内存容量。
b)系统中有很多的程序需要同时执行,它们要求的内存空间比实际的内存空间大。
3 MMU为什么就能解决以上2个问题呢?
MMU可以虚拟地址空间,将地址空间放大。作为32位系统,其虚拟地址空间可达到2的32次方,即地址空间为0~0xffffffff,共4G空间。这个空间就比实际内存空间要大得多了。
4 MMU怎么实现虚拟地址到物理地址的转换的呢?
映射。MMU将虚拟地址空间和物理地址空间划分为大小一样的小空间(称为段或页),然后在物理空间和虚拟空间之间建立一一对应的关系。建立过程如下:
5物理空间和虚拟空间如何建立映射关系?
简单来说就是CPU发出要寻址的地址后(该地址为一个虚拟地址),它经过MMU处理后(如何处理此处省略)得到一个描述符。该描述符通过存储控制器发送到SDRAM,然后在SDRAM中查找表中对应的描述符。这个表在SDRAM中,SDRAM已经开辟了16K的存储空间来存放这个表,每个描述符占4字节,每个描述符对应1M的虚拟空间。描述符的最低2位有4种结果,分别为00(无效)、01(粗页表)、10(段)及11(细页表)。
下面以段的方式为例说明转换过程。页表基址寄存器(用来存储映射表的首地址,被称作TTB,以jz2440开发板为例,他的页表基址为0x3000 0000)的[31:14]位与MVA的[31:20]位组成一个低2位为0的32位地址,这个就是段描述符。然后取出段描述符的[31:20]位,即段基址,它和MVA的[19:0]位组成一个32位的物理地址,这就是MVA对应的物理地址
如下图所示。