中断代码结构比较之WinCE4.2 VS WinCE5.0

发 布 时 间 : 2009-01-17 来 源 : http://bluefish.blog.51cto.com/214870/58125 作 者 : bluefish 浏 览 :
现在项目要从wince4.2下port到wince5.0下,今天将sd卡的驱动加到wince5下。用的是现有的也就是wince4.2下的驱动程序,几个dll文件:SDBusDriver.dll;SDCSDCard.dll;SDMemory.dll。这个工作主要就是将相应的中断加上就好了。
      下面进入正题。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中相应的各个中断。
      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。


上一篇:wince5.0中断的详细解释 下一篇:Windows CE内核启动分析