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

  WinCE5读核笔记(一) exception vector到底在哪里?_第1张图片

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空间。

你可能感兴趣的:(c,exception,vector,struct,WinCE)