1. 程式人生 > >wince中BIB檔案的詳細介紹

wince中BIB檔案的詳細介紹

在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中。