Cortex-A7:内存管理单元(MMU)介绍

0 参考资料

ARM Cortex-A(armV7)编程手册V4.0.pdf

1 Cortex-A7:内存管理单元(MMU)介绍

1.0 相关名词解释

名词解释:
(1)内存管理单元。内存管理单元英文全称为Memory Management Unit,简称MMU。后文为了表示方便使用MMU表示内存管理单元。
(2)虚拟地址。虚拟地址英文全称为Virtual Address,简称VA。VA可以简单认为就是CPU访问内存时使用的地址,它需要经过MMU转换为真实存储器的内存地址。
(3)物理地址。物理地址英文全称为Physical Address,简称PA。PA可以简单认为就是真实存储器的内存地址。

1.1 MMU的功能

(1)虚拟存储空间到物理存储空间的映射(虚拟地址到物理地址的转换)。
(2)存储器访问权限控制,例如读、写、可执行权限。
(3)控制存储器属性。例如内存顺序(Memory Order,如Strongly-ordered(强序)和Device(设备)类型内存)、内存Cache策略。
页表(Translate Table)是实现上述功能的重要手段。页表存放在内存上,表中按一定规则存放了上述(1)、(2)、(3)中的信息。
(4)支持最多2级页表。

1.2 使用MMU的好处

MMU一个重要功能就是能够让任务在自己的私有虚拟内存空间独立运行,以Cortex-A7架构处理器来说,相当于每个任务都可以享有4GB的内存空间,而不必关心其它任务是否使用到了相同的内存地址。这种虚拟内存系统的一个关键特征就是对地址进行重定位,也就是将处理器访问的虚拟地址转换为存储器上的物理地址。开发者可以在不需要知道真实存储器的物理地址情况下编写任务或应用(这部分工作由操作系统完成),减轻了心智负担,开发者可以为每个任务/应用使用相同的虚拟内存地址空间。即使物理内存地址不是连续的,也能使用连续的虚拟内存地址空间,这是因为虚拟地址空间和实际物理地址空间映射关系不是直接映射。
下图演示了一个虚拟地址到物理地址的映射关系例子:
在这里插入图片描述
如果MMU被失能,虚拟地址将直接映射到相同的物理地址(也就是PA=VA)。如果MMU无法将虚拟地址转换为物理地址,则会生成一个异常(例如缺页异常),向处理器提供关于该异常的相关信息。

许多年以前,当人 们还在使用DOS或是更古老的操作系统的时候,计算机的内存还非常小,一般都是以K为单位进行计算,相应的,当时的程序规模也不大,所以内存容量虽然小, 但还是可以容纳当时的程序。但随着图形界面的兴起还用用户需求的不断增大,应用程序的规模也随之膨胀起来,终于一个难题出现在程序员的面前,那就是应用程 序太大以至于内存容纳不下该程序,通常解决的办法是把程序分割成许多称为覆盖块(overlay)的片段。覆盖块0首先运行,结束时他将调用另一个覆盖块。虽然覆盖块的交换是由OS完成的,但是必须先由程序员把程序先进行分割,这是一个费时费力的工作,而且相当枯燥。人们必须找到更好的办法从根本上解决这个问题。不久人们找到了一个办法,这就是虚拟存储器(virtual memory).虚拟存储器的基本思想是程序,数据,堆栈的总的大小可以超过物理存储器的大小,操作系统把当前使用的部分保留在内存中,而把其他未被使用的部分保存在磁盘上。比 如对一个16MB的程序和一个内存只有4MB的机器,OS通过选择,可以决定各个时刻将哪4M的内容保留在内存中,并在需要时在内存和磁盘间交换程序片 段,这样就可以把这个16M的程序运行在一个只具有4M内存机器上了。而这个16M的程序在运行前不必由程序员进行分割。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

NW嵌入式开发

感谢您的支持,让我们一起进步!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值