關(guān)于WinCE系統(tǒng)的編譯過程
發(fā)布時(shí)間:2008/9/11 0:00:00 訪問次數(shù):493
過程如圖:
從圖中可以看出,整個(gè)編譯都是通過調(diào)用blddemo.bat來實(shí)現(xiàn)的,實(shí)際上也是這樣,編譯wince就是用blddemo.bat,只不過后面可以跟不同的參數(shù)。編譯階段和系統(tǒng)產(chǎn)生階段由cebuild.bat完成,文件拷貝階段由buildrel.bat完成,最后的生成映像階段由makeimg.exe完成。下面介紹一下各個(gè)階段。
1. 編譯階段(compile phase)
這個(gè)過程指對(duì)wince路徑下的private和public目錄進(jìn)行編譯,將里面的源代碼編譯成庫文件等,這個(gè)過程可能會(huì)花費(fèi)幾個(gè)小時(shí)。除非改動(dòng)了private或public目錄下的源碼,否則是不需要編譯的。一般我們編譯自己的工程的時(shí)候,不需要這個(gè)步驟。
2. 系統(tǒng)產(chǎn)生階段(sysgen phase)
在這個(gè)過程中,系統(tǒng)會(huì)根據(jù)你在pb中catalog中的選項(xiàng),刪除和設(shè)置相應(yīng)的sysgen環(huán)境變量,鏈接相應(yīng)的靜態(tài)庫,過濾頭文件,為sdk創(chuàng)建所需的導(dǎo)入庫,同時(shí)還會(huì)為wince系統(tǒng)創(chuàng)建一些配置文件。最后會(huì)編譯當(dāng)前的bsp和應(yīng)用程序。
3. 文件拷貝階段(release copy phase)
拷貝所有所需的文件到工程的release目錄下面,主要是前面系統(tǒng)產(chǎn)生階段所產(chǎn)生的所有文件。
4. 生成映像階段(make run-time image phase)
該過程首先調(diào)用cenlscmp.exe根據(jù)國際語系與地區(qū)設(shè)定生成wince.nls文件。然后調(diào)用fmerge.exe合并一些配置文件,合并所有bib文件為ce.bib,合并所有的reg文件為reginit.ini,合并所有的dat文件為initobj.dat,合并所有的db文件為initdb.ini。之后調(diào)用regcomp.exe壓縮reginit.ini為default.fdf。根據(jù)local環(huán)境變量的設(shè)置調(diào)用res2exe.exe更新所有的dll,exe和cpl文件中的資源文件,主要是更新其中的語言部分。再調(diào)用txt2ucde.exe轉(zhuǎn)換所有ascii碼字符串為unicode。最后調(diào)用romimage.exe合并所有文件為nk.bin。
在整個(gè)編譯過程中有時(shí)會(huì)遇到編譯錯(cuò)誤,這個(gè)可以通過察看build.log,build.err和build.wrn文件來分析問題,這三個(gè)文件應(yīng)該是位于”\wince600”目錄下面。編譯錯(cuò)誤可能在不同的編譯階段產(chǎn)生,我們也可以根據(jù)這一點(diǎn)來分析問題。
一般在系統(tǒng)產(chǎn)生階段(sysgen phase)出現(xiàn)錯(cuò)誤很可能是由于丟失組件或文件造成的,這時(shí)候build.log會(huì)提供更多信息幫助分析問題。在這個(gè)階段產(chǎn)生錯(cuò)誤,很可能是由于在當(dāng)前工程中添加或者刪除wince組件造成的,其中有些組件的更改是需要進(jìn)行”clean sysgen”的,而不能只使用”sysgen”命令。所以我的建議是每次添加或刪除組件都做”clean sysgen”。
如上面介紹系統(tǒng)產(chǎn)生階段(sysgen phase)也會(huì)編譯bsp和部分應(yīng)用。所以如果錯(cuò)誤出現(xiàn)在系統(tǒng)產(chǎn)生階段的編譯過程中,一般一種可能就是你的代碼有語法錯(cuò)誤,當(dāng)然這種錯(cuò)誤很好查。還有一種可能出現(xiàn)的錯(cuò)誤是連接錯(cuò)誤,有可能是丟失了lib庫文件或者鏈接錯(cuò)了庫文件,也有可能是調(diào)用了錯(cuò)誤的api函數(shù),還有就是設(shè)置了錯(cuò)誤的環(huán)境變量,這些查起來相對(duì)困難一點(diǎn)。
如果錯(cuò)誤產(chǎn)生在文件拷貝階段(release copy phase),一種常見的問題就是和硬盤驅(qū)動(dòng)器有關(guān),檢查一下release目錄所在磁盤的磁盤空間。
如果問題出現(xiàn)在生成映像階段(make run-time image phase),根據(jù)編譯的輸出窗口的輸出信息判斷問題出在哪個(gè)子階段。一種可能是你的bib文件或者reg文件中存在語法錯(cuò)誤導(dǎo)致合并文件時(shí)出錯(cuò),還有就是注意你的image的大小是否超過了config.bib文件中的設(shè)定,還有就是可能丟失了某個(gè)或者某些文件,這些丟失的文件很可能是由于在前面的編譯過程中出現(xiàn)錯(cuò)誤導(dǎo)致的。
當(dāng)然,也有時(shí)候會(huì)遇到一些奇怪的問題,這些問題可能是由于沒有正確的安裝wince造成的,比如在安裝wince的時(shí)候,路徑中不要有中文或者空格或者其他比較奇怪的字符。補(bǔ)丁要按照順序來打,要不也可能會(huì)出現(xiàn)問題。
歡迎轉(zhuǎn)載,信息來自維庫電子市場(chǎng)網(wǎng)(www.dzsc.com)
過程如圖:
從圖中可以看出,整個(gè)編譯都是通過調(diào)用blddemo.bat來實(shí)現(xiàn)的,實(shí)際上也是這樣,編譯wince就是用blddemo.bat,只不過后面可以跟不同的參數(shù)。編譯階段和系統(tǒng)產(chǎn)生階段由cebuild.bat完成,文件拷貝階段由buildrel.bat完成,最后的生成映像階段由makeimg.exe完成。下面介紹一下各個(gè)階段。
1. 編譯階段(compile phase)
這個(gè)過程指對(duì)wince路徑下的private和public目錄進(jìn)行編譯,將里面的源代碼編譯成庫文件等,這個(gè)過程可能會(huì)花費(fèi)幾個(gè)小時(shí)。除非改動(dòng)了private或public目錄下的源碼,否則是不需要編譯的。一般我們編譯自己的工程的時(shí)候,不需要這個(gè)步驟。
2. 系統(tǒng)產(chǎn)生階段(sysgen phase)
在這個(gè)過程中,系統(tǒng)會(huì)根據(jù)你在pb中catalog中的選項(xiàng),刪除和設(shè)置相應(yīng)的sysgen環(huán)境變量,鏈接相應(yīng)的靜態(tài)庫,過濾頭文件,為sdk創(chuàng)建所需的導(dǎo)入庫,同時(shí)還會(huì)為wince系統(tǒng)創(chuàng)建一些配置文件。最后會(huì)編譯當(dāng)前的bsp和應(yīng)用程序。
3. 文件拷貝階段(release copy phase)
拷貝所有所需的文件到工程的release目錄下面,主要是前面系統(tǒng)產(chǎn)生階段所產(chǎn)生的所有文件。
4. 生成映像階段(make run-time image phase)
該過程首先調(diào)用cenlscmp.exe根據(jù)國際語系與地區(qū)設(shè)定生成wince.nls文件。然后調(diào)用fmerge.exe合并一些配置文件,合并所有bib文件為ce.bib,合并所有的reg文件為reginit.ini,合并所有的dat文件為initobj.dat,合并所有的db文件為initdb.ini。之后調(diào)用regcomp.exe壓縮reginit.ini為default.fdf。根據(jù)local環(huán)境變量的設(shè)置調(diào)用res2exe.exe更新所有的dll,exe和cpl文件中的資源文件,主要是更新其中的語言部分。再調(diào)用txt2ucde.exe轉(zhuǎn)換所有ascii碼字符串為unicode。最后調(diào)用romimage.exe合并所有文件為nk.bin。
在整個(gè)編譯過程中有時(shí)會(huì)遇到編譯錯(cuò)誤,這個(gè)可以通過察看build.log,build.err和build.wrn文件來分析問題,這三個(gè)文件應(yīng)該是位于”\wince600”目錄下面。編譯錯(cuò)誤可能在不同的編譯階段產(chǎn)生,我們也可以根據(jù)這一點(diǎn)來分析問題。
一般在系統(tǒng)產(chǎn)生階段(sysgen phase)出現(xiàn)錯(cuò)誤很可能是由于丟失組件或文件造成的,這時(shí)候build.log會(huì)提供更多信息幫助分析問題。在這個(gè)階段產(chǎn)生錯(cuò)誤,很可能是由于在當(dāng)前工程中添加或者刪除wince組件造成的,其中有些組件的更改是需要進(jìn)行”clean sysgen”的,而不能只使用”sysgen”命令。所以我的建議是每次添加或刪除組件都做”clean sysgen”。
如上面介紹系統(tǒng)產(chǎn)生階段(sysgen phase)也會(huì)編譯bsp和部分應(yīng)用。所以如果錯(cuò)誤出現(xiàn)在系統(tǒng)產(chǎn)生階段的編譯過程中,一般一種可能就是你的代碼有語法錯(cuò)誤,當(dāng)然這種錯(cuò)誤很好查。還有一種可能出現(xiàn)的錯(cuò)誤是連接錯(cuò)誤,有可能是丟失了lib庫文件或者鏈接錯(cuò)了庫文件,也有可能是調(diào)用了錯(cuò)誤的api函數(shù),還有就是設(shè)置了錯(cuò)誤的環(huán)境變量,這些查起來相對(duì)困難一點(diǎn)。
如果錯(cuò)誤產(chǎn)生在文件拷貝階段(release copy phase),一種常見的問題就是和硬盤驅(qū)動(dòng)器有關(guān),檢查一下release目錄所在磁盤的磁盤空間。
如果問題出現(xiàn)在生成映像階段(make run-time image phase),根據(jù)編譯的輸出窗口的輸出信息判斷問題出在哪個(gè)子階段。一種可能是你的bib文件或者reg文件中存在語法錯(cuò)誤導(dǎo)致合并文件時(shí)出錯(cuò),還有就是注意你的image的大小是否超過了config.bib文件中的設(shè)定,還有就是可能丟失了某個(gè)或者某些文件,這些丟失的文件很可能是由于在前面的編譯過程中出現(xiàn)錯(cuò)誤導(dǎo)致的。
當(dāng)然,也有時(shí)候會(huì)遇到一些奇怪的問題,這些問題可能是由于沒有正確的安裝wince造成的,比如在安裝wince的時(shí)候,路徑中不要有中文或者空格或者其他比較奇怪的字符。補(bǔ)丁要按照順序來打,要不也可能會(huì)出現(xiàn)問題。
歡迎轉(zhuǎn)載,信息來自維庫電子市場(chǎng)網(wǎng)(www.dzsc.com)
熱門點(diǎn)擊
- 貼片電容的精度表示方法
- 利用ISE中的Tcl功能控制版本
- RC低通濾波器的響應(yīng)特性
- Tcl工具語言和ISE開發(fā)工具中草的Tcl功
- 同步復(fù)位及異步復(fù)位設(shè)計(jì)
- π形阻抗匹配電路
- 粉紅噪聲發(fā)生用一3dB/oct濾波器
- 測(cè)定阻抗匹配的重要性…l段π形濾波器
- PCB飛針測(cè)試幾個(gè)有效的方法
- 從圖形界面方式轉(zhuǎn)換到Tcl命令行方式
推薦技術(shù)資料
- 羅盤誤差及補(bǔ)償
- 造成羅盤誤差的主要因素有傳感器誤差、其他磁材料干擾等。... [詳細(xì)]
- 電源管理 IC (PMIC)&
- I2C 接口和 PmBUS 以及 OTP/M
- MOSFET 和柵極驅(qū)動(dòng)器單
- 數(shù)字恒定導(dǎo)通時(shí)間控制模式(CO
- Power Management Buck/
- 反激變換器傳導(dǎo)和輻射電磁干擾分析和抑制技術(shù)
- 多媒體協(xié)處理器SM501在嵌入式系統(tǒng)中的應(yīng)用
- 基于IEEE802.11b的EPA溫度變送器
- QUICCEngine新引擎推動(dòng)IP網(wǎng)絡(luò)革新
- SoC面世八年后的產(chǎn)業(yè)機(jī)遇
- MPC8xx系列處理器的嵌入式系統(tǒng)電源設(shè)計(jì)
- dsPIC及其在交流變頻調(diào)速中的應(yīng)用研究