PB5.0 features/sysgen参数和ceconfig.h中宏定义的对应关系

SYSGEN,就编译BSP,就会出现Failed to initialize from CECONFIG.H 错误。

使用PB建立一个wince image之前先要建立一个workspace来控制除OEM BSP之外的所有的image的属性,包括的内容等等。这些内容主要是通过PBcatalog来管理的,通过PBviewàcatalog打开的视窗,我们从全部的window ce的可选组件中选择我们需要的加入到workspace中,这样的话我们sysgen出来的image就具备了相应的功能。从catalog的视窗中,我们可以通过查询任意一个组件的属性来获得它唯一对应的一个sysgen_开头的变量。但是这些变量并不能直接用来在runtime的情况下用于判断image具备哪些组件。在实际的运用中,AP可以#include一个名为“ceconfig.h”的头文件,这个头文件里面都是类似”CE_MOULDLE_***SHELL_MODULES_***COREDLL_****”之类的宏定义,这些宏定义可以直接被AP用来判定image内是否具备其需要的一些组件,比如MFCAYGSHELL等等。Ceconfig.h是在sysgen的阶段自动由系统的批处理生成的,由于ceconfig.h的重要性,所以有必要搞清楚通过PBcatalog生成的sysgen_环境变量是如何和ceconfig.h内部的宏对应起来的。


首先从PB开发环境的OSDesignView中修改的feature将直接反映到以sysgen_开头的环境变量中,为了验证有哪些sysgen_已经被设置,可以执行Build OSàOpen release directory进入命令行模式,然后执行“set sysgen”命令,就可以看到所有的sysgen_XXX的环境变量了。这些环境变量是属于桌面windows的,可以dos下或是bat批处理文件中使用。由于dos下的命令也是支持一些条件判断语法,如IF ELSE等指令,所以利用dos批处理文件就可以根据既有的环境变量做进一步的处理了。


现在来介绍微软是如何利用bat批处理对sysgen_环境变量做转换,变成cecongfig.h中的宏定义的。

首先来看cesysgen.bat,这个批处理文件每次在Build OsàSysgen的时候会被调用,其位于“D:/WINCE500/PUBLIC/CEBASE/OAK/MISC”(假设wince500安装在D盘)。

在这个目录下你可以看到很多bat文件:

D:/WINCE500/PUBLIC/CEBASE/OAK/MISC的目录

2004-07-0112:00744 cebase.bat

2007-10-3111:257,362 cesysgen.bat

2004-07-0112:003,743 datasync.bat

2004-07-0112:006,081 dcom.bat

2004-07-0112:0026,594 directx.bat

2004-07-0112:004,091 gdiex.bat

2004-07-0112:0013,610 ie.bat

2004-10-1507:152,841 netcf.bat

2006-05-0413:489,245 netcfv2.bat

2004-07-0112:005,133 rdp.bat

2004-07-0112:002,632 script.bat

2004-07-0112:0020,954 servers.bat

2004-07-0112:002,253 shell.bat

2004-07-0112:001,721 shellsdk.bat

2004-07-0112:001,136 speech.bat

2004-07-0112:001,730 sqlce.bat

2005-12-1502:201,762 sqlmobile.bat

2004-07-0112:003,906 viewers.bat

2004-07-0112:005,242 voip.bat

2004-07-0112:003,025 wceappsfe.bat

2004-07-0112:0015,167 wceshellfe.bat

2006-08-3115:26100,533 winceos.bat

后面我们会知道,其他的bat批处理文件都会被cesysgen.bat调用到的。

调用“D:/WINCE500/PUBLIC/CEBASE/OAK/MISC>cesysgen report”的时候,你可以看到一些类似ceconfig.h中的宏定义的字符串:

Report:

SYSGEN_ASYNCMAC=1

SYSGEN_AS_BASE=1

SYSGEN_AUDIO=1

…….. 省略

CE_MODULES=coredllnk msim commctrl commdlg rsaenh ….. 省略 (ceconfig.h中的CE_MODULES_XXX一一对应――config.hmctrlcommdlg rsaenh ...

COREDLL_COMPONENTS=coremainlmem showerr thunks correct ….. 省略(ceconfig.h中的COREDLL _XXX一一对应――config.hmctrl commdlg rsaenh ...

……


这说明,在这个批处理里面已经有了sysgen->宏定义的转换了。

ultraedit打开cesysgen.bat,跟踪report参数,可以走到113行,看到下面的命令:

113:doReport#标号

114 echoReport:#语句显示Report

115 setSYSGEN#显示所有的sysgen_环境变量

116 if"%__IN_BLD_RECURS%"=="1" set SYSGEN>%_WINCEROOT%/__BLD_RECURS_DEP.txt

117 set SYSGEN>%_WINCEROOT%/public/%_TGTPROJ%/__CEBASE_FEATURES.txt

117 for %%f in(%_DEPTREES%) do call :CallProjFile %%f report

主要看117行,这里是一个for循环,f是变量,%_DEPTREES%f可以取值的范围,这个语句将%_DEPTREES%中的每个字符串作为参数传递给CallProjFile子函数(批处理标号)。为了了解%_DEPTREES%中有那些字符串,可以执行echo %_DEPTREES%,你会看到类似下面的一串字符:

winceos dcomgdiex ie script servers shellsdk shell rdp wceshellfe wceappsfe viewers directxvoip datasync netcf SQLCE ostest speech NETCFV2 SQLMOBILE PROJECTNAME

基本上,上面的字符串和D:/WINCE500/PUBLIC/CEBASE/OAK/MISC目录下的每一个bat文件是一一对应的。而且大致可以看出,它们的名字就是wince所有组件归类之后的组名。

跟踪到:CallProjFile标号,大概在156行,有如下内容:

:CallProjFile

if not exist %__CESYSGEN_PATH%/%1.bat goto:CPF_NotCE

call %__CESYSGEN_PATH%/%1.bat %2 %3 %4%5 %6 %7 %8 %9

goto :EOF

:CPF_NotCE


if not exist%_PUBLICROOT%/cebase/oak/misc/%1.bat goto :CPF_NotCE2

call %_PUBLICROOT%/cebase/oak/misc/%1.bat%2 %3 %4 %5 %6 %7 %8 %9

goto :EOF

:CPF_NotCE2


if not exist%_PUBLICROOT%/%1/cebasecesysgen.bat goto :CPF_Unknown

call%_PUBLICROOT%/%1/cebasecesysgen.bat %2 %3 %4 %5 %6 %7 %8 %9

goto :EOF

:CPF_Unknown

if /i"%___PUBLICPROJECT%"=="common" if"%_ECHOON%"=="1" echo WARNING: Unable to find project file%1, args %2 %3 %4 %5 %6 %7 %8 %9

goto :EOF


大致的功能就是到三个路径去寻找参数1.bat“ 的批处理文件,如果找到并执行之,首先根据%_DEPTREES%可知,第一个参数是winceos,所以我们在D:/WINCE500/PUBLIC/CEBASE/OAK/MISC下面的winceos.bat会被执行。依次类推,dcom.bat gdiex.bat ie.batscript.bat servers.bat ….这些批处理会顺序执行。

接下来就到了揭开谜底的时候了,打开winceos.bat. 你可以发现有很多类似

if"%SYSGEN_XXX%"=="1" set CE_MODULES=%CE_MODULES% YYY的语句,这XXXYYY的对应关系就是sysgen_ceconfig的宏定义之间的关系。

所以类似的,打开其他的.bat文件可以分析其他类别的XXXàYYY的对应了。

这样你可以search到所有的,你想知道的对应关系。


你可能感兴趣的:(config,features,sysgen)