CurMSec += SYSTEM_TICK_MS; /////SYSTEM_TICK_MS = 1
然后根据下列语句判断应该返回什么值:
if ((int) (dwReschedTime – CurMSec) >= 0)
return SYSINTR_RESCHED; ///重新调度
else
return SYSINTR_NOP; ///不再执行任何操作
上述代码中全局变量dwReschedTime在schedule.c中定义,也就是由内核的调度模块决定在何时开始重新调度线程。CurMSec累计了从WindowsCE启动到当前总共产生了多少个system tick。实现系统时钟后还要实现OEMIdle函数,当没有线程准备运行时OEMIdle被调用,OEMIdle函数将CPU置于空闲模式,但在空闲模式下仍然要累计系统时钟。
三、I/O控制代码
1. I/O控制代码作用
应用软件或者驱动程序可以调用KernelIoControl函数与OAL层通信,而KernelIoControl在内部调用OEMIoControl函数。OEMIoControl是一个OAL API,OEM可以在OEMIoControl中编写自己的I/O控制代码实现一些功能,或者说与应用软件通信。I/O控制代码常用的例子如重启计算机、得到系统信息、设置RTC、得到设备ID等。还有一些系统程序使用的特殊的I/O控制代码。在这里说明一下,我经过实验证实CE提供的得到设备ID方法并非有效。
2. 编写自己的I/O控制代码步骤
1) 在pkfuncs.h或者新编写一个.h文件中按如下格式定义:
#define IOCTL_MY_CONTROL CTL_CODE(FILE_DEVICE_HAL, 3000, METHOD_NEITHER, FILE_ANY_ACCESS)
2) 在oemioctl.c中修改OEMIoControl函数,添加如下代码:
case IOCTL_MY_CONTROL:
......
3) 在应用程序中调用KernelIoControl函数,具体参数参见帮助文档。
四、结束语:
OAL所有接口函数和全局变量说明请参见标题为“Supported OAL APIs”的帮助文档。以前的文章《加密Windows CE系统》里介绍的 OEMLoadInit_t pOEMLoadInit 和 OEMLoadModule_t pOEMLoadModule 就是OAL暴露的用于创建可信任环境的全局变量,我们编写好了函数后就可以把函数地址赋给这两个变量。OAL的确很复杂,当实际需要时我们才会具体研究某一部分,因为带着问题研究是最有效率的。希望这两篇文章能够抛砖引玉,让更熟悉OAL的开发者能够公开自己的研究成果,和大家分享。
文章来源于领测软件测试网 https://www.ltesting.net/