码迷,mamicode.com
首页 > 其他好文 > 详细

专题1-MMU-lesson2-深入剖析地址转化

时间:2016-08-23 11:40:34      阅读:197      评论:0      收藏:0      [点我收藏+]

标签:

1、地址转化总体分析

技术分享

 

                          技术分享

level one fetch和level two fetch分为一级转换和二级转换。

由上图右边可以看出,首先通过TTB(Translation Table Base)寄存器找到转换表基地址,该表有4096项,然后用虚拟地址的[31:20]位来找该表里面的表项,再检查该表项最后两位如果为00,则无效转换,如果为01,则是粗页转换,为10为段转换,为11为细页转换。

关于转换表的简单描述

首先,转换表是存放在内存当中的;然后,这张表是由工程师来编写的,工程师然后把该表的首地址放到TTB中,然后把TTB的值写入cp15寄存器中的c2寄存器,那么在MMU工作的时候,会直接去cp15的c2寄存器当中去取该地址,那么就可以找到转换表的首地址了。

2、段转换方式

当找到转换表中的表项之后,会取出该表项的高12位,

技术分享

技术分享

技术分享

3、细页转换

从转换表的表项中找到细页页表的基地址,然后从虚拟地址的[19:10]位来找到细页页表里面的表项,然后检测该表项的最后两位为00则无效,为01则找到大页基地址,然后用虚拟地址的[15:0]来找具体的表项,就是我们要找的物理内存;为10则找到小页基地址,然后用虚拟地址的[11:0]来找具体的表项,就是我们要找的物理内存,为11则找到极小页基地址,然后用虚拟地址的[9:0]来找具体的表项,就是我们要找的物理内存。

技术分享

专题1-MMU-lesson2-深入剖析地址转化

标签:

原文地址:http://www.cnblogs.com/gary-guo/p/5798441.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!