5.0下的中断:感觉上就一个字“乱”,主要是这些代码分别放在不同的地方,或许这样更合理化吧,谁知道MS怎么想的。主要分布在以下几个地方:(A1)platform\common\src\common\intr;(A2)platform\common\src\xxx(type of cpu)\yyy(intel or samsung or …)\zzz\intr;(A3)platform\zzz\src\kernel\oal\intr.c。
5.0下中断初始化流程:从时间上来看先是OEMInit(oal\init.c)->OALIntrInit(A2中实现)->BSPIntrInit(A3中实现,这个地方比较关键了,因为要添加或修改中断就要在这里来做,主要实现SYSINTR_XXX与IRQ_XXX的映射)。OK中断初始化完毕。
5.0下中断的enable流程:在5.0下面没有找到SC_InterruptInitialize,或者类似的实现,不过我想5.0下面的应该和4.2下面的一样。由驱动的InterruptInitialize终调用到OEMInterruptEnable(在A1\common\oem.c中实现)->OALIntrEnableIrqs(在A3中实现)->BSPIntrEnableIrq(在A3中实现)。至此enable完成。对应的disbale和done也是在相应的文件中实现。
从名字上也可以看出来A1提供了一个对内核开放的中断层,由它再去调用对应的oal层的代码A2,A2再在其中调用A3中的代码;则A3中主要的就是提供一个给程序员注册的一个接口BSPIntrInit。
4.2下的中断:InterruptInitialize(具体的驱动中注册中断与事件)->SC_InterruptInitialize(系统的函数,可以根据private\winceos\coreos\nk\kernel\kwin32.c中的const PFNVOID Win32Methods[]数组得知这是一个系统函数。这一步为猜测,该函数在private\winceos\coreos\nk\kernel\intrapi.c中实现。enable中断-通过调用下面的函数,之后将相应的事件放入中断事件队列)->DoInterruptEnable(在private\winceos\coreos\nk\kernel\intrapi.c中实现,先调用pfnOEMTranslateSysIntr映射一下,不过我没有找到这个函数指针的原型。之后才是OEMInterruptEnable)->OEMInterruptEnable(在platform\xxx\kernel\hal\cfw.c中,地球人都知道。在这个文件中有个static void OEMInitInterrupts(void),是在oeminit中被调用的,差点被忽悠了。)这只是enable(也包含初始化),相应的disable和done也在相应的文件中实现。可能用4.2用多了,感觉这些中断的处理一气呵成,很容易理解,就是修改或者增加比较麻烦。要分别处理OEMInterruptXXX中相应的各个中断。
免责声明: 凡注明来源本网的所有作品,均为本网合法拥有版权或有权使用的作品,欢迎转载,注明出处。非本网作品均来自互联网,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责。