作者:ARM-WinCE
在WinCE中使用的一個重要的文件就是BIB文件,全稱Binary Image Builder File。在WinCE的編譯過程中會用到BIB文件,應該是在最後的Makeimg階段。所有的BIB文件會被合併成CE.bib文件,然後Romimage.exe會根據BIB文件中的描述來決定哪些文件最終被包含到WinCE image中。當然,BIB文件還決定了WinCE設備內存的分配,其中定義了WinCE image佔用哪塊內存,Framebuffer佔用哪塊內存等。
在BIB文件中分爲4大項:MEMORY項,CONFIG項,MODULES項和FILES項。下面分別作個解釋:
MEMORY:定義了內存分配的相關設置,一般在BSP中的config.bib文件中。
CONFIG:在最後的Makeimg階段,爲Romimage.exe提供一些生成WinCE image的配置屬性。該項是可選的,一般也在BSP中的config.bib文件中定義。
MODULES:定義了一些會被打包到WinCE image中的模塊或者文件,比如dll,exe等。這些文件會被Romimage.exe標記爲加載到RAM中或者XIP。我們可以在這裏添加自己的WinCE應用程序或者模塊,但是不要添加Managed Binaries,一般指.NET的程序。
FILES:定義了一些操作系統會用到的其他的文件,比如字體文件,圖片等。這些文件也會在WinCE運行的時候被加載到RAM中。
下面會詳細介紹上面的4大項:
1. MEMORY項
一般都在config.bib文件中定義,開頭會有MEMORY的字樣。這裏定義了爲WinCE image以及其他模塊預留的RAM,同時也定義了WinCE可以使用的RAM。具體格式如下:
MEMORY
NAME Start Address Memory Size Type
NAME:該內存區域的名字,必須是唯一的。
Start Address:該內存區域的起始地址,用十六進制表示。
Memory Size:該內存區域的大小,用十六進制表示。
Type:內存區域的類型。包涵的多種類型如下。
類型值 |
描述 |
FIXUPVAR |
用於在WinCE編譯的Makeimg階段,就初始化一個內核中的全局變量。 |
NANDIMAGE |
當創建了一個使用BinFS的image的時候,NAND設備上的WinCE kernel重定向到RAM中的區域,當系統訪問該區域的時候,BinFS會負責訪問Nand設備上相應的位置,並返回數據給系統,實際上就是在Nand設備上面實現了XIP的功能。 |
RAM |
定義了被WinCE系統使用的RAM區域,這塊內存必須是連續的,這裏有一點要注意就是從硬件的角度來說,這塊內存不能跨越兩片SDRAM,也就是說整個區域空間必須在一片硬件SDRAM上。 |
RAMIMAGE |
定義了一塊內存區域用於加載WinCE image,實際上WinCE啓動以後,image會被拷貝到這塊內存區域上面運行。一個image只能有一個連續的RAMIMAGE區域。 |
RESERVED |
這塊內存區域會被預留出來,一般用於Frambuffer或者是DMA Buffer,或者是一塊共享內存用於EBOOT傳遞參數給WinCE系統。 |
EXTENSION |
定義了一塊WinCE image中的區域作爲ROMHDR extension的數據區域。 |
2.CONFIG項
一般在config.bib文件中定義,定義了一些額外的配置參數,其中一些對於WinCE image來說也很重要。具體格式如下;
CONFIG
ITEM=Parameter
ITEM |
描述 |
AUTOSIZE |
允許未被使用的WinCE image的RAM被用作WinCE系統的RAM。默認值爲ON。 |
COMPRESSION |
允許Romimage.exe壓縮WinCE image中的可寫入部分。默認值爲ON。 |
BOOTJUMP |
定義了跳轉跳轉頁在RAMIMAGE空間的地址。而不是默認情況下的RAMIMAGE的首地址。默認值爲NONE。 |
FSRAMPERCENT |
定義了文件系統使用的內存的百分比。默認值爲0x80808080。 Byte 0:第一個2MB中,每1MB所包含的4KB的倍數。 Byte 1:第二個2MB中,每1MB所包含的4KB的倍數。 Byte 2:第三個2MB中,每1MB所包含的4KB的倍數。 Byte 3:剩下的內存中,每1MB所包含的4KB的倍數。 |
KERNELFIXUPS |
定義了Romimage.exe是否重新定向內核的可寫入區域。默認值爲ON,內核的可寫入區域被重新定向到RAMIMAGE的起始位置。 |
OUTPUT |
定義了最終生成的image存放的路徑。默認爲%_FLATRELEASEDIR%。 |
PROFILE |
定義了是否在WinCE image中包含profiler的結構和符號。默認值爲OFF。 |
RESETVECTOR |
重新指定跳轉頁的位置,一般針對MIPS芯片從0x9FC00000開始引導的問題。 |
ROMFLAGS |
內核標記位,可以進行組合: 0x01表示禁用按需分頁。 0x02表示禁用完全內核模式,完全內核模式表示所有的線程都運行在內核模式。 0x10表示只信任ROM MODULES中的模塊。 0x20表示停止刷新TLB。 0x40表示按照/base鏈接選項中的地址加載DLL。 |
ROMSTART |
指WinCE image在內存中的起始地址。 |
ROMSIZE |
指WinCE image的大小。 |
ROMWIDTH |
指數據總線的寬度。 |
ROMOFFSET |
指定一個偏移量來修改.bin文件中的每一個記錄的地址。一般用於ROM中的.bin文件加載到RAM來運行的情況,主要是表示存儲.bin的位置和運行.bin的位置不一樣。 |
SRE |
使Romimage.exe產生一個.sre文件。默認值爲OFF。 |
X86BOOT |
定義是否插入一條跳轉指令,在x86復位向量地址的時候。 |
3.MODULES項和FILES項
該項列出了所有被包含在WinCE image中的模塊以及文件,以及這些模塊和文件以什麼方式被加載到內存中。具體格式如下:
MODULES
Name Path Memory Type
Name:模塊的名字,比如一個dll或者exe文件的文件名。
Path:路徑,一般都是WinCE的工程的Release目錄。
Memory:指定該模塊被放在哪個區域,一般都是NK區域。
Type:定義了文件的類型。具體如下:
類型 |
描述 |
S |
系統文件。 |
H |
隱藏文件。 |
R |
只壓縮模塊的資源部分。 |
C |
壓縮模塊的所有部分。 |
D |
禁止調試。 |
N |
模塊是不可信任的。 |
P |
告訴Romimage.exe不需要檢查CPU的類型。 |
K |
告訴Romimage.exe必需固定該模塊的內核地址。有該標記的模塊只能被LoadKernelLibrary函數加載。 |
X |
告訴Romimage.exe對該模塊簽名。 |
M |
運行時加載整個模塊,不要按需分頁。 |
L |
告訴Romimage.exe不要分離ROM DLL。 |
一般FILES項的Type只支持S,H,N,D幾個類型,而MODULES項的Type是都支持的。
舉個例子吧:
INIT.EXE %_WINCEROOT%/RELEASE/INIT.EXE NK SH
MYDLL.DLL %_WINCEROOT%/RELEASE/MYDLL.DLL NK SHC
對於BIB文件來說同樣支持“條件編譯”,我們可以通過設置環境變量來選擇性地將某些模塊打包到WinCE image中。一般在BSP中,對於一些驅動模塊的環境變量我們IF來進行條件判斷。而對於WinCE的系統模塊來說,一般都是SYSGEN變量,應該使用@CESYSGEN IF來判斷。
我們在BSP的開發中最常見的主要就是eboot.bib,config.bib,platform.bib和project.bib。下面簡單介紹一下:
project.bib:該文件主要自創建的WinCE工程中所需的一些文件。
platform.bib:該文件包含了和硬件平臺相關的文件,主要以驅動程序爲主。
config.bib:該文件描述了WinCE系統的內存的配置。
eboot.bib:該文件描述了WinCE的eboot的內存的配置。
還有其他的一些bib文件,在WinCE系統編譯後都會背拷貝到工程的release目錄下面。比如common.bib,ie.bib等。這些文件列出了WinCE的組件相關的文件,根據用戶訂製的系統,會被選擇性的打包到WinCE image中。