WinCE6.0 OAL的特点

简介: WinCE6.0的OAL跟WinCE5.0中的有较大差别。了解这些差别,对我们移植OAL部分很有帮助。本文将简要介绍WinCE6.0 OAL的特点。      WinCE5.0将内核、OAL和KITL链接成一个内核可执行文件NK.exe。

     WinCE6.0OALWinCE5.0中的有较大差别。了解这些差别,对我们移植OAL部分很有帮助。本文将简要介绍WinCE6.0 OAL的特点。

     WinCE5.0将内核、OALKITL链接成一个内核可执行文件NK.exe。而WinCE6.0将这三者分开,分别对应Kernel.dllOAL.exeKITL.dll。显而易见,这样做最大的好处是可以单独升级这三者中的任何一个,而先前的结构则是牵一发而动全身的。WinCE5.0OAL结构如图1所示: 

                            
                    图1

WinCE6.0OAL结构如图2所示: 

               图2
      对比图1和图2,可以看到CE6.0OAL在功能上和CE5.0的基本一致,主要包括初始化、中断管理和IOCTL等。在图2中增加了NKStub.libNKGLOBALOEMGLOBAL等内容。这对于WinCE6.0是至关重要的。在CE5.0中,由于内核、OALKITL最终链接到一个可执行程序中,所以可以直接相互调用彼此的函数。这看起来很方便,但存在安全隐患,甚至在更新内核代码的时候会影响到OAL的执行。KernelOALKITL相互独立,则消除了这个安全隐患。现在,它们之间的通讯是通过包涵函数指针和变量值的全局结构变量来实现的。每个模块编译一个函数指针列表以提供给其他模块使用,而列表中没有的函数将不能被别的模块调用。内核模块导出列表NKGLOBAL,主要包括虚拟内存操作、注册表访问和字符串处理等一些内核API以及共享的全局变量。OAL只能调用该列表中包括的内核API。为了方便OAL代码的移植,微软将函数指针列表封装到NKStub.lib中。所以,我们在移植OAL代码时没有必要通过结构中的函数指针去调用内核APIOAL代码保持原来的函数调用方式。简单看一下NKStub.c的代码实现,下面是部分代码:

       BOOL INTERRUPTS_ENABLE (BOOL fEnable)

{

    return g_pNKGlobal->pfnINT_ENABLE (fEnable);

}

       可以看到,OAL中调用相应的内核API时,NKStub将执行对应的结构中的函数指针。所以在编译OAL时,添加NKStub.lib后就可以跟以前一样使用这些内核函数。当然NKStub也包括了KITL中的相应函数列表,所以OAL也能使用KITL中的函数。

       OAL导出了列表OEMGLOBAL,其中包括了OAL函数指针和全局变量。其中有很多函数指针是必须的,如果缺少,系统将不能正常工作。而另外有些函数指针则是可选的。具体内容可查看PB帮助的相应部分。OEMGLOBAL的定义在文件:C:\WINCE600\PRIVATE\WINCEOS\COREOS\NK\OEMMAIN\oemglobal.c中。

       总结一下,CE6.0OAL从内核中独立出来,这样方便OAL的单独升级,也提高了安全性。由于内核、OALKITL相互独立,所以引入了NKGLOBALOEMGLOBAL这两个结构以支持模块间的函数调用。为了方便代码的移植,CE6.0提供了NKStub.libOEMStub.lib,他们做了从函数指针到函数的转换工作。所以,在移植BSP时,原来的代码可保持不变。

到这里,我们已经知道了WinCE6.0OAL的特点。实际移植时,还需要注意OAL的目录组织。这里将5.06.0 OAL部分的目录组织做一个对比。

CE5.0 OAL目录组织

对应文件

%_WINCEROOT%\platform\BSPNAME\src\kernel\oal

oal.lib

%_WINCEROOT%\platform\BSPNAME\src\kernel\kern

kern.exe

%_WINCEROOT%\platform\BSPNAME\src\kernel\kernkitl

kernkitl.exe

%_WINCEROOT%\platform\BSPNAME\src\kernel\kernkitlprof

kernkitlprof.exe

CE6.0 OAL目录组织

Builds

%_WINCEROOT%\platform\BSPNAME\src\oal\oallib

oal.lib

%_WINCEROOT%\platform\BSPNAME\src\oal\oalexe

oal.exe

%_WINCEROOT%\platform\BSPNAME\src\kitl

kitl.dll

其中,6.0OALLIB对应5.0OALOALEXE对应KernKITL对应Kernkitl。而5.0kernkitlprof6.0中一般放在oallib的目录下。在移植BSP时可参照该对应关系进行目录组织。

       本文从功能结构和目录组织上介绍了 WinCE6.0 OAL 的特点,在移植 BSP 时可作参考。 有关 OAL 移植的具体实现,后文将详细介绍。另外,文中有不贴切的地方欢迎您指正。
目录
相关文章
|
存储 数据可视化 安全
ucgui在嵌入式linux下的移植
ucgui在嵌入式linux下的移植
|
Linux 程序员 Android开发
快了!基于ARM架构的Windows10又要来了!
快了!基于ARM架构的Windows10又要来了!
快了!基于ARM架构的Windows10又要来了!
WinCE下的任务管理器
这里给大家推荐一款WinCE下有用的小软件,WinCE任务管理器。不用多介绍了,它的界面如下图所示。             WinCE下任务管理器的下载地址:http://files.cnblogs.com/we-hjb/WinCE_TaskManager.rar
826 0
WinCE常用调试工具汇总
WinCE驱动调试助手V2.9 http://www.cnblogs.com/we-hjb/archive/2009/05/17/1458725.html WinCE串口调试助手V2.1 http://www.
1640 0
Wince 中的图形编程
  图形编程程序当中,笔者主要要和大家讨论的是画刷的创建和使用以及绘图函数,比如2D图像的绘制等等。  *画刷的定义:   HBRUSH hBrush;  *画刷的类型:   1. 系统内置画刷:GetStockObject()   2.
|
API
Wince下蓝牙开发的问题
这几天在做wince下的蓝牙开发,经过一番资料搜索之后发现了很多有用的帖子和经验,但是经过实际验证发现问题多多,首先就是一个wince和mobile不分的误区,很多API和库wince上有而mobile上没有,而大多数则是mobile上有winc...
960 0
|
索引
WinCE下流驱动的一点说明
一般情况下,WinCE流驱动的索引为0~9。应用程序中,通过CreateFile(_T("XXXN:"),…)打开对应的驱动,N也为0~9。这样看来,似乎在WinCE下同名流驱动个数被限制在10个以内。
884 0
|
Windows
WinCE6.0实现TexFAT的注意点
TexFAT(Transaction-safe Extended FAT)与TFAT功能一样,在WinCE6.0之前,包括Windows Mobile6.5使用的是TFAT,WinCE6.0和WP7则使用TexFAT。
1089 0
|
Android开发 内存技术
关于WinCE6.0补丁包的一点说明
以前整理过一篇《WinCE6.0 R3的安装步骤》,后来本本装了Win7后,按照这个步骤安装R3,又验证了一遍。当然,这个步骤是个人总结出的,未必是最优的方案。       这两天在论坛里又看到有人在问R3的安装步骤,实际上R3的安装就是PB6.0补丁的安装,只是在安装的时候要注意各个补丁的安装顺序。
875 0