当前位置:首页 > 单片机 > 单片机
[导读]1. 地址的分类 以前的程序很小,可以全部装入内存中运行,随着技术的发展,出现了如下两种情况:1)有的程序很大,它要求的内存空间超过了内存总容量,不能一次性装入内存中;2)多任务系统中有很多程序需要同时运行,它们要求

1. 地址的分类
以前的程序很小,可以全部装入内存中运行,随着技术的发展,出现了如下两种情况:
1)有的程序很大,它要求的内存空间超过了内存总容量,不能一次性装入内存中;
2)多任务系统中有很多程序需要同时运行,它们要求的内存空间超过了内存总容量,不能把所有的程序全部装入内存中。
实际上,一个程序在运行前,没有必要全部装入内存,而仅需要将那些当前要运行的部分先装入内存,其余部分在用到的时候再从磁盘调入,而当内存耗光时,再将暂时不用的部分调出到磁盘。这使得一个大程序可以在较小的内存空间中运行,也使得内存中可以同时装入更多的程序并发执行,从用户的角度看,该系统所具有的内存容量比实际的内存容量大得多,人们把这样的存储器称为虚拟存储器。
虚拟存储器从逻辑上对内存容量进行了扩充,用户看到的大容量只是一种感觉,是虚的。在32位的CPU系统中,这个虚拟内存的地址范围是0~0xffff_ffff,我们把这个地址范围称为虚拟地址空间,其中的某个地址称为虚拟地址。与虚拟地址空间、虚拟地址对应的是物理地址空间、物理地址,它们对应实际的内存。
虚拟地址最张需要转换为物理地址才能读写实际的数据,这通过将虚拟地址空间、物理地址空间划分为同样大小的一块块小空间(称为段或页),然后为这两类小空间建立映射关系。由于虚拟地址空间远大于物理空间,有可能多块虚拟地址空间映射到同一块物理地址空间,或者有些虚拟地址空间没有映射到具体的物理地址空间上去(可以在使用到时再映射)。ARM CPU的地址转换过程涉及到3个概念:虚拟地址(VA,Virtual Address)、变换后的虚拟地址(MVA,Modified Virtual Address)、物理地址(PA,Physical Address)。
没启动MMU时,CPU核、cache、MMU、外设等所有部件使用的都是物理地址。
启动MMU后,CPU核对外发出虚拟地址VA;VA被转换为MVA供cache、MMU使用,在这里MVA被转换为PA;最后使用PA读写实际设备(S3C2410/S3C2440内部寄存器或外接设备):
1)CPU核看到的、用到的都是虚拟地址VA,至于VA如何最终落实到物理地址PA上,CPU核是不理会的。
2)而cache和MMU也是看不到VA的,它们利用MVA转换得到的PA。
3)实际的设备看不到VA、MVA,读写它们时使用的是物理地址PA。
MVA是除CPU核外的其他部分看见的虚拟地址。
如果VA<32M,需要使用进程标识号PID(通过读CP15的C13来获得)来转换为MVA。VA与MVA的转换方法如下:
if (VA<32M) then
MVA=VA | (PID<<25) //VA<32M
else
MVA=VA //VA>=32M

利用PID生成MVA的目的是为了减少切换进程时的代价:不使用MVA而直接使用VA的话,当两个进程所用的虚拟地址空间(VA)有重叠时,在切换进程时为了把重叠的VA映射到不到的PA上去,需要重建页表、使无效caches和TLBS等,代价非常大。使用MVA后,进程切换就省事多了;假设两个进程1、2运行的VA都是0~(32M-1),但是它们的MVA并不重叠,分别是0x0200_0000~0x03ff_ffff、0x0400_0000~0x05ff_ffff,这样就不必进行重建页表等工作了。

2. 虚拟地址到物理地址的转换过程
将一个虚拟地址转换为一个物理地址,一般有两种方法:用一个确定的数学公式进行转换或用表格存储虚拟地址对应的物理地址。这类表格称为页表(Page table),页表由一个个条目(Entry)组成;每个条目存储了一段虚拟地址对应的物理地址及其访问权限,或者下一级页表的地址。
在ARM CPU中使用第二种方法。S3C2410/S3C2440最多会用到两级页表:以段(Section,1MB)的方式进行转换时只用到一级页表,以页(Page)的方式进行转换时用到两级页表。页的大小有3种:大页(64KB)、小页(4KB)、极小页(1KB)。条目也被称为“描述符”(Descriptor),有:段描述符、大页描述符、小页描述符、极小页描述符——它们保存段、大页、小页或极小页的起始物理地址;粗页表描述符、细页表描述符——它们保存二级页表的物理地址。
大概的转换过程如下:
1)根据给定的虚拟地址找到一级页表中的条目;
2)如果此描述符是段描述符,则返回物理地址,转换结束;
3)否则,如果此描述符是二级页表描述符,继续利用虚拟地址在此二级页表中找到下一个条目;
4)如果这第二个条目是页描述符,则返回物理地址,转换结束;
5)其他情况出错。


本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

9月2日消息,不造车的华为或将催生出更大的独角兽公司,随着阿维塔和赛力斯的入局,华为引望愈发显得引人瞩目。

关键字: 阿维塔 塞力斯 华为

加利福尼亚州圣克拉拉县2024年8月30日 /美通社/ -- 数字化转型技术解决方案公司Trianz今天宣布,该公司与Amazon Web Services (AWS)签订了...

关键字: AWS AN BSP 数字化

伦敦2024年8月29日 /美通社/ -- 英国汽车技术公司SODA.Auto推出其旗舰产品SODA V,这是全球首款涵盖汽车工程师从创意到认证的所有需求的工具,可用于创建软件定义汽车。 SODA V工具的开发耗时1.5...

关键字: 汽车 人工智能 智能驱动 BSP

北京2024年8月28日 /美通社/ -- 越来越多用户希望企业业务能7×24不间断运行,同时企业却面临越来越多业务中断的风险,如企业系统复杂性的增加,频繁的功能更新和发布等。如何确保业务连续性,提升韧性,成...

关键字: 亚马逊 解密 控制平面 BSP

8月30日消息,据媒体报道,腾讯和网易近期正在缩减他们对日本游戏市场的投资。

关键字: 腾讯 编码器 CPU

8月28日消息,今天上午,2024中国国际大数据产业博览会开幕式在贵阳举行,华为董事、质量流程IT总裁陶景文发表了演讲。

关键字: 华为 12nm EDA 半导体

8月28日消息,在2024中国国际大数据产业博览会上,华为常务董事、华为云CEO张平安发表演讲称,数字世界的话语权最终是由生态的繁荣决定的。

关键字: 华为 12nm 手机 卫星通信

要点: 有效应对环境变化,经营业绩稳中有升 落实提质增效举措,毛利润率延续升势 战略布局成效显著,战新业务引领增长 以科技创新为引领,提升企业核心竞争力 坚持高质量发展策略,塑强核心竞争优势...

关键字: 通信 BSP 电信运营商 数字经济

北京2024年8月27日 /美通社/ -- 8月21日,由中央广播电视总台与中国电影电视技术学会联合牵头组建的NVI技术创新联盟在BIRTV2024超高清全产业链发展研讨会上宣布正式成立。 活动现场 NVI技术创新联...

关键字: VI 传输协议 音频 BSP

北京2024年8月27日 /美通社/ -- 在8月23日举办的2024年长三角生态绿色一体化发展示范区联合招商会上,软通动力信息技术(集团)股份有限公司(以下简称"软通动力")与长三角投资(上海)有限...

关键字: BSP 信息技术
关闭
关闭