通过MMU进行虚拟地址和物理地址的转化以及寻址的步骤.docVIP

通过MMU进行虚拟地址和物理地址的转化以及寻址的步骤.doc

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
通过MMU进行虚拟地址和物理地址的转化以及寻址的步骤

通过MMU进行虚拟地址和物理地址的转化以及寻址的步骤 先来看一个图: 当arm请求访问存储器时,现在TLB(快表)中查找虚拟地址,如果虚拟地址对应的地址变换条目不在TLB中,则从内存的页表中查找并添加到TLB中,方便下一次的快速查找,若TLB已经满了,则根据淘汰算法进行清除,从而增加变换的速度。 那么问题来了,什么是TLB?什么是页表?什么又是地址变换条目呢?首先虚拟地址到物理地址的转换是通过页表来实现的,而页表就是存储在内存中的表,它的每一行都是虚拟地址以及对应的物理地址,而每一行就叫做地址变换条目,当然每一行中还会有一些其他的信息,例如控制位、访问权限等,由于每次从内存中页表读取地址变换条目速度比较慢,且浪费cpu,于是就取了其中一小段的页表放在指定地存储器中,这个存储器和寄存器读取的速度相似,而这一小段的页表叫做快表——TLB。 说到页表,就会提到页表的基地址,这个地址放在cp15的c2寄存器中,是查找的入口(我认为)。当然cp15以及MMU的不同的寄存器作用不一样,有很多也是跟查找表相关的,例如TLB的清除,控制位等,具体的寄存器说明请查阅资料。 当MMU得到了地址变换条目之后,要进行以下的操作。 得到虚拟地址对应的物理地址(不用详细说) 根据变换条目中的C、B位,判断是否缓存该内存访问的结果 根据访问权限控制位以及以及域访问控制位,判断该内存是否可以被访问(MMU将整个存储空间分为16个域domain,通过寄存器可以进行控制权限等)。 缓存访问的说明:不允许缓存的时候,直接访问物理地址对应的内存空间;允许访问的时候,如果在cache命中,则忽略物理地址,直接读取缓存信息,不在cache中,则访问物理内存并把内容读取到cache中。 当然如果禁止了MMU,则虚拟地址 物理地址,也就是所谓的平板访问。 以上就是ARM的页式管理,说明:页式管理将虚拟地址分为不同的块——页,每一页物理内存也会分成同样大小的页,也就可以一一对应,从而实现虚拟地址到物理地址的映射。 对于页式管理的细致分析以及一些淘汰调度算法在此不作说明,具体参见linux内核的内存管理分析。

文档评论(0)

80219pm + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档