首页 > 代码库 > ARM基础:MMU 异常向量表 重映射
ARM基础:MMU 异常向量表 重映射
/******************************************************************************************************************
参考:
说明:在学习裸机中断时重新遇到这个几个词,这次就要搞明白了。
******************************************************************************************************************/
这个三个词好长时间都没有搞懂,今天略微有点明白就记下来。物理地址是主线,其它都是陪衬。CPU是只会沿着这条路走的,这路有什么是靠MMU来说的,在0x30000000处以后的地址是内存。只说一点:为什么中断要用MMU。
这是因为异常后,CPU会自动跑到0地址处运行,但是程序在内存中启动后,但是向量表没有在真正的0地址处,在0x30000000这个时候就要出现一个忽悠的,骗它0x30000000就是0地址处,这样才可以。MMU就是一个骗子,CPU是一个憨厚的一个人,它还会跑到0地址处,但是实质的内容其实是和0x30000000地址开始的一样的内容。这就是一个重映射的过程。中断后也有一个地址,8种不同异常类型对就8个地址,会自动跑到各个地址处执行,但是这个地址是什么代码要靠自己决定的,可以让它"Hello World",也可以什么都不做。
linux分用户态、核心态。两种状态;ARM处理器有7种运行模式。
这之间有什么联系吗?如果有,这两种状态和这7中运行模式是怎么对应的?切换的动作是怎么实现的?
答:
linux kernel只用到ARM的user和svc模式。 用户态 -- user 内核态 -- svc |
ARM基础:MMU 异常向量表 重映射
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。