WinCE5.0/6.0下,通过command line实现自动化编译

news/2024/7/10 3:49:50 标签: wince, command, 脚本, path, 平台, 产品

好久没写Blog了,实在觉得说不过去了,今天介绍一下WinCE的自动化编译。

 先来解释一下:一般我们要编译WinCE都是先创建工程,然后再IDE的开发环境中进行编译。对于WinCE5.0来说,是用Platform Builder5.0;对于WinCE6.0来说,就是用VS2005,因为PB6.0已经集成到VS2005里面了。这样有个问题,就是每次都要人来手动编译。让我来举个例子,这是我在做项目中遇到的。公司基于ARM的平台开发BSP,而且已经release了,但是公司有很多产品都基于这个平台,每个平台根据功能不同对WinCE进行了不同程度的裁剪,所以每个产品对应一个工程。这样问题就出现了,如果要进行测试,我们就需要有人手动的把每一个工程都编译出来,然后才能进行测试,这样会很耽误时间。如果是用自动化编译,只需要通过脚本命令把要编译的工程输入,然后运行,到了第二天早上,所有产品的image就都编译出来了,这样会很节省时间。  

 

现在就开始介绍如何实现,有个前提是你已经创建了一个WinCE工程并且在里面为这个工程创建了SDK,当然如果你不需要导出SDK的话,你就不需要创建SDK了。WinCE5.0和WinCE6.0的命令有些小的区别,我会分开介绍:  

 

对于WinCE5.0:  

 

1. pbxmlutils.exe

 在“/Windows CE Platform Builder/5.00/CEPB/BIN”下面可以找到,这个命令可以从PB的文档中查到。主要作用是通过解析你的工程文件<OS Design Name>.pbxml来获得与该工程相关的环境变量,并产生一个脚本来设置这些环境变量。格式如下: 

pbxmlutils /getbuildenv /workspace "%_WINCEROOT%/PBWorkspaces/<OS design name>/<OS design name>.pbxml" /config "<BSP>: <Target device>" > SetEnv.bat

看着可能有点晕,我来举个例子:

pbxmlutils /getbuildenv /workspace "%_WINCEROOT%/PBWorkspaces/MyWorkspace/MyWorkspace.pbxml" /config "CEPC: x86_Release" > SetEnv.bat

其实就两个参数,第一个参数很多人都知道如何设置,第二个参数config可能有些人不太了解,你可以打开你的工程,然后查环境变量PBCONFIG的值,用这个值就可以了。

2. Blddemo.exe

这个应该比较熟悉。编译WinCE的时候,实际上就是调用Blddemo -q,不多说了。

3. buildsdk.exe

这个是用来编译SDK的。格式如下;

buildsdk [MyOSDesign.pbxml]

很简单,不过还是给个例子:

buildsdk "%_WINCEROOT%/PBWorkspaces/MyWorkspace/MyWorkspace.pbxml"    

 

对于WinCE6.0:  

 

1. pbxmlutils.exe

在“/Microsoft Platform Builder/6.00/cepb/IdeVS”下面可以找到,这个命令可以从PB的文档中查到。主要作用是通过解析你的工程文件<OS Design Name>.pbxml来获得与该工程相关的环境变量,并产生一个脚本来设置这些环境变量。格式如下: 

pbxmlutils /getbuildenv /workspace "%_WINCEROOT%/OSDesigns/<OS design name>/<OS design name>/<OS design name>.pbxml" /config "<BSP> <Target device>" > SetEnv.bat

来举个例子:

pbxmlutils /getbuildenv /workspace "C:/WINCE600/OSDesigns/MyWorkspace/MyWorkspace/MyWorkspace.pbxml" /config "CEPC x86 Release" > SetEnv.bat

和WinCE5.0有些小的区别,要注意一下。同样如果不知道第二个参数config如何设置,可以打开工程,查环境变量PBCONFIG的值,用这个值就可以。

2. Blddemo.exe

这个和WinCE5.0用法一样。编译WinCE的时候,实际上就是调用Blddemo -q。

3. buildsdk.exe

这个是用来编译SDK的。格式如下;

buildsdk [MyOSDesign.pbxml] [MySdkConfig.sdkcfg]

很简单,不过还是给个例子:

buildsdk "/OSDesigns/MyWorkspace/MyWorkspace/MyWorkspace.pbxml" "/OSDesigns/MyWorkspace/MyWorkspace/SDKs/SDK1/SDK1.sdkcfg"  

 

基本上,自动化编译所需的主要命令都已经介绍完了,下面介绍如何使用上面的命令实现:  

 

对于WinCE5.0:

@echo off

@set _WINCEROOT=c:/wince500
@set _PBROOT="c:/Program Files/Windows CE Platform Builder/5.00"
@set PATH=%PATH%;c:/Program Files/Windows CE Platform Builder/5.00/cepb/bin

cd /D %_WINCEROOT%
if exist build.log del build.log
if exist build.wrn del build.wrn
if exist build.err del build.err

pbxmlutils /getbuildenv /workspace "%_WINCEROOT%/PBWorkspaces/MyDesign/MyDesign.pbxml" /config "Samsung SMDK2410: ARMV4I_Release" > buildenv.bat
call buildenv.bat
call %_TARGETPLATROOT%/%_TGTPLAT%.bat
call Blddemo -q

buildsdk "%_WINCEROOT%/PBWorkspaces/MyDesign/MyDesign.pbxml"

 

对于WinCE6.0:

@echo off

@set _WINCEROOT=d:/wince600
@set _PBROOT=C:/Program Files/Microsoft Platform Builder/6.00
@set PATH=%_PBROOT%/cepb/idevs;%PATH%

cd /D %_WINCEROOT%
if exist build.log del build.log
if exist build.wrn del build.wrn
if exist build.err del build.err

pbxmlutils /getbuildenv /workspace "%_WINCEROOT%/OSDesigns/MyDesign/MyDesign/MyDesign.pbxml" /config "CEPC x86 Release" > buildenv.bat
call buildenv.bat
call %_TARGETPLATROOT%/%_TGTPLAT%.bat
call Blddemo -q

call buildsdk "%_WINCEROOT%/OSDesigns/MyDesign/MyDesign/MyDesign.pbxml" "%_WINCEROOT%/OSDesigns/MyDesign/MyDesign/SDKs/SDK1/SDK1.sdkcfg"


上面针对WinCE5.0和WinCE6.0的两个命令略有不同,但是原理是一样的。只要有点Windows脚本命令的知识,了解WinCE的整个编译过程,看懂上面的代码应该没问题,这里就不作介绍了。

 

上面给出的只是例子,上面的代码,可以实现command line编译WinCE并且还可以导出SDK。如果想实现对多个工程进行编译,只需要对上面的脚本作些修改就可以了。上面的脚本完全可以改写成函数的形式,通过传递工程文件名和平台的config来编译WinCE,这样就可以对多个工程顺序进行编译,这里就不介绍了。


本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/gooogleman/archive/2008/08/06/2776411.aspx


http://www.niftyadmin.cn/n/1516558.html

相关文章

bootloader 开发,最郁闷前三步

在书市和网上溜达一圈&#xff0c;只发现两本关于Bootloader的开发资料。一个是电子工业出版社出版的《Windows CE.NET实用开发技术》&#xff1b;另一个是PB的HELP文件。其他大多为介绍Bootloader相关知识的&#xff0c;最多也就是修改一下官方的Bootloader源码。 觉得没什么…

windowsCE异常和中断服务程序初探

1。中断/异常相量的装入和执行方式。 中断和异常都是异步发生的事件&#xff0c;当该事件发生&#xff0c;系统将停止目前正在执行的代码转而执行事件响应的服务程序。而事件服务程序的入口点就是中断/异常向量所在的位置。arm的中断向量可以是0x0开始的低地址向量&…

献给为了知识执着的嵌入式初学者

谨献给为了知识执着的嵌入式初学者&#xff0c;欢迎高手补充讨论 实践当然是最锻炼人的方式&#xff0c;但是我想在校生很少有这样的机会&#xff0c;别说本科生&#xff0c;硕士生也未必有条件。所以我想学习嵌入式要从个人的知识背景和现实条件出发。订立合适的阶段目标&am…

Windows CE OAL层的结构与开发

Windows CE是微软针对嵌入式领域推出的一款全新的操作系统。之所以说它是一款全新的操作系统&#xff0c;是因为尽管Windows CE的UI非常接近其它的桌面版Windows操作系统&#xff0c;但是它的内核完全是重新写的&#xff0c;并不是任何一款桌面版Windows的精简版本。 Windows C…

Eboot启动代码分析

启动代码通常都是用处理器相应的汇编代码写成&#xff0c;比较晦涩&#xff0c;但是却包含了很多与平台相关的信息&#xff0c;对初始化代码进行分析有利于对平台的理解。本文将对Eboot的初始化代码进行分析&#xff0c;主要包含从Reset到进入C的main开始。mov r0, #0x4800…

WinCE中中断的处理过程(驱动开发人员角度)

中断是硬件与软件打交道的重要方法&#xff0c;因此&#xff0c;大多数驱动程序都涉及到对中断的处理&#xff0c;本文就驱动程序的开发人员以及BSP的开发人员的角度&#xff0c;来谈谈Windows CE中中断的处理过程。 如果一个驱动程序要处理一个中断&#xff0c;那么驱动程序需…

WinCE资源链接

http://blog.csdn.net/constantine/------------不错的博客&#xff0c;一些原创值得借鉴。 http://blog.csdn.net/yeyueyeyue/archive/2006/12.aspx----------此人的博客虽然不在更新&#xff0c;但是也比较有价值。 http://yzcyn.blog.163.com/blog/----------2440跑wince6…

wince5.0中断分析--精辟

原帖地址http://topic.csdn.net/u/20071008/11/D54DF4A6-09EF-4D7F-AADB-2F60FF3824FC.html 1 WinCE中第一次对中断的处理是在OAL的OEMInit()中,该函数调用OALIntrInit()完成对中断的初始化. 2 OALIntrInit()对中断的初始化做了如下工作: 2.1 通过配置IPR0-IPR33设置中断优…