MMU的理解

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对应的物理地址

如下图所示。
在这里插入图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值