网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
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对应的物理地址
如下图所示。
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**