内存管理单元-MMU

S3C2440MMU地址变换过程

1、运行时装入(程序在运行之前,只需要将那些当前要运行的部分先装入内存,其余部分在用到时再从磁盘调入,而当内存耗光时再将暂时不用的部分调出到磁盘)使得一个大程序可以在较小的内存空间中运行,也使得内存中可以同时装入更多的程序并发执行。
2、虚拟地址最终需要转换成物理地址才能读写实际的数据,下图是VA和MVA的关系
这里写图片描述
2.1、CPU核看到的VA,caches和MMU看到和使用的而是MVA,实际设备使用的是PA
3、虚拟地址到物理地址的转换过程
页表基址寄存器?
3.1、转换方法用表格存储虚拟地址对应的物理地址
3.2、下面是S3C2440地址转换图
这里写图片描述
3.3、一级页表使用4096个描述符来表示这4GB空间,每个描述符对应1MB虚拟地址,要么存储1MB物理地址空间的起始地址,要么存储下一级页表物理地址
3.4、下图就是一级页表描述符的格式
这里写图片描述
3.5、粗页表描述符,细页表描述符保存二级页表物理地址,共256个条目,一个条目表示4k大小的物理地址空间,一张粗页表表示1MB大小的物理地址空间
3.6、下图是段的地址转换过程
这里写图片描述
3.7、下图是二级页表描述符格式
这里写图片描述
3.8、下图是保存在粗页表中的大页描述符时,地址转换过程
这里写图片描述
3.9、下图是保存在粗页表中的小页描述符时,地址转换过程
这里写图片描述
3.10、下图是保存在粗页表中的极小页描述符时,地址转换过程
这里写图片描述
3.11、获得了地址转换的结论,如下图
这里写图片描述

MMU的内存访问权限检查

1、“域”决定是否对某块内存进行权限检查
1.1、下图展示了CP15寄存器C3的每两位对应一个域的情形,S3C2440总共16个域
这里写图片描述
下图是域访问控制寄存器C3每两位数据代表的含义
这里写图片描述
1.2、一级页表描述符bit[8:5]告诉了我们这1M内存属于哪个域,例如bit[8:5]=0b1111,则页面的该项指示的这1M内存属于域15,CP15寄存器C3的相应位bit[31:30]=0b11,权限检查的任务就会交给二级页表中的大页/小页描述符中的。位“AP3”,“AP2”,“AP1”,“AP0”。
2、“AP”决定如何对某块内存进行权限检查
下图是AP,S/R位的访问权限对照
这里写图片描述
3、下图是CPU核与协处理器数据传递指令的语法格式
这里写图片描述

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值