WinCE系統(tǒng)的編譯過程
在WinCE系統(tǒng)中,當(dāng)我們完成了相關(guān)的開發(fā)和系統(tǒng)定制工作以后,會(huì)編譯WinCE系統(tǒng),最后生成NK.bin和NK.nb0。我現(xiàn)在用WinCE6.0在自己的PC上面編譯一次用時(shí)19分16秒(有一天無聊,就測了一下)。下面介紹一下WinCE系統(tǒng)的編譯過程,大致分為4個(gè)階段:編譯階段(Compile phase),系統(tǒng)產(chǎn)生階段(Sysgen phase),文件拷貝階段(Release copy phase)和生成映像階段(Make Run-time image phase)。
過程如圖:
從圖中可以看出,整個(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è)過程指對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)境變量,這些查起來相對困難一點(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)問題。