共2条
1/1 1 跳转至页

问
CP15的寄存器C2中存放了用来进行从虚拟地址到物理地址转换的页表的地址。但问题是页表本身也是存放在存储器中的,要找到页表的物理地址首先要通过页表,这岂不是“鸡生蛋还是蛋生鸡”的问题了?难道C2中存放的页表地址就是物理地址?
另外,即使ARM带有MMU,在刚BOOT的时候,其实MMU还是没有使能的,那么岂不是ROM的地址一定要在系统的0地址,而实际并非如此,这是怎么回事?
请大家指点!谢谢! 答 1: mmu访问页表是通过物理地址访问的 答 2: REC2中存放的是页表的基地址,MMU使能后系统访问页表时是不需要软件干涉的,软件指令只要一访问某一地址,MMU机构就会找到这个页表查表。因此不存在你所谓的问题。如果对页表定位也需要软件来完成,那么就存在楼主说的这个问题。不知道楼主是否明白了。
BOOT时的启动地址和MMU无关,不是一个概念,通常ARM芯片BOOT的启动地址可以通过跳线来选择。另外有些系统片内有ROM,启动时总是从ROM的LOADER代码开始运行,再引导到您所需要的任何地址启动OS。 答 3: 谢谢楼上两位的回答!caluova,我认为MMU在执行的时候可能是不需要软件干预的,但是在使能MMU之前,设置C2里面的内容应该还是要软件吧?
ARM假如是上电,PC必然是为0。就向caluova说的,有些系统片内集成了ROM,启动时总是从ROM的代码开始执行,我觉得要么是片内ROM本身编址为0,要么是ARM系统利用REMAP功能,将片内ROM映射到0地址。
不知道我的理解对否?
另外,即使ARM带有MMU,在刚BOOT的时候,其实MMU还是没有使能的,那么岂不是ROM的地址一定要在系统的0地址,而实际并非如此,这是怎么回事?
请大家指点!谢谢! 答 1: mmu访问页表是通过物理地址访问的 答 2: REC2中存放的是页表的基地址,MMU使能后系统访问页表时是不需要软件干涉的,软件指令只要一访问某一地址,MMU机构就会找到这个页表查表。因此不存在你所谓的问题。如果对页表定位也需要软件来完成,那么就存在楼主说的这个问题。不知道楼主是否明白了。
BOOT时的启动地址和MMU无关,不是一个概念,通常ARM芯片BOOT的启动地址可以通过跳线来选择。另外有些系统片内有ROM,启动时总是从ROM的LOADER代码开始运行,再引导到您所需要的任何地址启动OS。 答 3: 谢谢楼上两位的回答!caluova,我认为MMU在执行的时候可能是不需要软件干预的,但是在使能MMU之前,设置C2里面的内容应该还是要软件吧?
ARM假如是上电,PC必然是为0。就向caluova说的,有些系统片内集成了ROM,启动时总是从ROM的代码开始执行,我觉得要么是片内ROM本身编址为0,要么是ARM系统利用REMAP功能,将片内ROM映射到0地址。
不知道我的理解对否?
共2条
1/1 1 跳转至页
回复
有奖活动 | |
---|---|
【EEPW电子工程师创研计划】技术变现通道已开启~ | |
发原创文章 【每月瓜分千元赏金 凭实力攒钱买好礼~】 | |
【EEPW在线】E起听工程师的声音! | |
“我踩过的那些坑”主题活动——第001期 | |
高校联络员开始招募啦!有惊喜!! | |
【工程师专属福利】每天30秒,积分轻松拿!EEPW宠粉打卡计划启动! | |
送您一块开发板,2025年“我要开发板活动”又开始了! | |
打赏了!打赏了!打赏了! |
打赏帖 | |
---|---|
电流检测模块MAX4080S被打赏10分 | |
【我踩过的那些坑】calloc和malloc错误使用导致跑飞问题排查被打赏50分 | |
多组DCTODC电源方案被打赏50分 | |
【我踩过的那些坑】STM32cubeMX软件的使用过程中的“坑”被打赏50分 | |
新手必看!C语言精华知识:表驱动法被打赏50分 | |
【我踩过的那些坑】杜绑线问题被打赏50分 | |
【我踩过的那些坑】STM32的硬件通讯调试过程的“坑”被打赏50分 | |
【我踩过的那些坑】晶振使用的问题被打赏100分 | |
【我踩过的那些坑】电感选型错误导致的处理器连接不上被打赏50分 | |
【我踩过的那些坑】工作那些年踩过的记忆深刻的坑被打赏10分 |