WinCE5读核笔记(一) exception vector到底在哪里?

 

struct ARM_HIGH是被WinCE5 kernel安放在0xFFFD,0000地址的一个结构体。这个结构体非常大,我说它大不是因为它的 member很多,而是它的每个member都是一个非常大的数组。主要是为了对齐到一些特殊的地址。
我们知道在 core中0xFFFF,0000是high address exception vector的位置,而它就包含在struct ARM_HIGH中。对应于exVectors成员变量。
同时我们从这个结构体可以看出WinCE内核的一些精心安排。
0xFFFD,0000存放MMU第一级页表。第一级页表的地址要对齐到16KB,也就是[13~0]是零。0xFFFD,0000是满足这个要求的。
0xFFFF,2400是Interrupt processer mode用到的stack。
0xFFFF,4900是Abort processer mode用到的stack。
0xFFFF,6800是Fast interrupt processer mode用到的stack。
0xFFFF,C000是kernel mode用的stack。Kernel mode 其实也就是Supervisor processer mode。
值得注意的是stack是由高地址向低地址增长。经查证,上面4个stack地址。其实是stack的高地址。这些stack在使用时,stack会向reserved6这个member延伸。
我想问你的是:ARM processer mode中的undefined mode,他的stack为什么没有定义?
有的!既然kernel stack用的是的reserved6,那么kStack[0x800]这个空间就没人用了,它就是undefined mode的stack空间。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值