1. NK.bin
Bin:Microsoft Windwos CE binary image data format(.bin)文件格式中包含若干個獨立的記錄(record),以記錄(record)爲單位來組織數據,每個record都包含了起始地址,長度,檢驗碼和這個record中包含的數據內容,Platform Builder調用工具RomImage.exe將WINCE內核所有文件以bin格式合併成一個文件(至於RomImage.exe是怎麼合成NK.bin的,後面需要好好深入瞭解),默認文件名爲nk.bin。BootLoader又以同樣的格式將nk.bin分解成多個文件放到RAM中,NK.bin這個文件在存儲上是按照下面的結構來存儲的:
標記(7)
Image開始地址(1)+Image長度(1)
備註:上面前7個字節是標記:B000FF,後面00 00 1A 80(801A0000)是Image開始地址,C8 34 0D 02(020D34C8)這個是Image長度
在下圖用了紅色框,框出Record的起始、長度、檢查碼,緊跟的白色框,則是該Record的實際資料內容。
記錄0地址+記錄0長+記錄0校驗和+記錄0內容(文件內容)
記錄1地址+記錄1長+記錄1校驗和+記錄1內容(文件內容)
………………………..
也就是
"B000FF/x0A" //7字節大小
ImageStartAddress, ImageLength //8字節大小
RecordAddress, RecordLength, RecordChecksum, Data…….// module/file toc信息
RecordAddress, RecordLength, RecordChecksum, Data…// modulese信息
RecordAddress, RecordLength, RecordChecksum, Data…// files信息
RecordAddress, RecordLength, RecordChecksum, Data爲 0x43454345 // ROM signature
RecordAddress, RecordLength, RecordChecksum, Data爲 0x43454345 // TOC pointer
RecordAddress, RecordLength, RecordChecksum, Data爲 0x43454345 // copylist信息
RecordAddress, RecordLength, RecordChecksum, Data爲 0x43454345 // romhdr信息
………………………………
0x00000000 , JumpAddress , 0x00000000 //啓動地址startup地址
請注意,最後的record的jumpAddress是OAL層的startup函數的地址,這個函數在/Src/Oal/Oallib/startup.s中定義,通過viewbin –r nk.bin可以看到nk.bin的組織格式:
………………………………….
可以知道OAL層的startup函數的地址是0x802C1AF8
我們在download NK.bin的時候,先是讀取出magic number(也就是"B000FF/x0A"),用來判斷download的是什麼樣格式的NK(在這裏是bin格式的),接着讀取出NK.bin的image start地址及image length,然後就是接下來以record的格式來讀取record的數據到RAM中。Bin文件格式可以使得映像文件最下,加載時間短,但需要bootloader給予解釋加載才能運行,這個解析的工作是在DownloadBin函數中進行的。
2. NK.nb0
Nb0:nb0文件就是可執行映像的原始Flash映像,它不包括頭,一般情況下將內核下載到設備的RAM中運行都採用nb0格式,nb0文件的尺寸比bin大,但是可以直接運行,要生產NK.nb0,就需要在congfig.bib中加入下面的內容
ROMSTART = 80200000
ROMWIDTH = 32
ROMSIZE = 02300000
ROMSTART指WINCE image在內存中的起始地址,ROMWIDTH指數據總線的寬度,ROMSIZE指WINCE image的大小。現在我們的系統的NK.bin大小是26889KB,生成的NK.nb0大小爲
現在我們設置ROMSIZE=01A00000,NK.bin=26889KB > 01A0000(26MB),也就是說如果WINCE image大小大於ROMSIZE指定的大小的時候,除了生成NK.nb0之外還會生成NK0.nb1,NK.nb2,….,下圖是ROMSIZE=01A00000設置時生成的NK.nb0及NK.nb1的大小和ROMSIZE(01A00000)指定的大小一致的。
而如果把ROMSIZE=00800000時,生成的文件如下:
NK.nb0=NK.nb1=NK.nb2=NK.nb3=8192KB,也就是0x800000,所以從中可以看出NK.nbn的大小時由ROMSIZE來指定的。
如果把ROMSIZE=01B00000時,這時NK.bin=26889KB< 01B0000(27MB),所以只要生成的WINCE image大小小於ROMSIZE指定的大小的時候,就只會生成NK.nb0,見下圖:
3. NK.bin和NK.nb0的區別
NK.bin和NK.nb0的區別主要有以下這些區別:
⑴NK.BIN中的內容是被壓縮過的,而NK.NB0中的內容是沒有壓縮的,兩者大小的區別是因爲在生成過程中BIN會將設定的後面的NULL自動去掉,而NB0就不會。由於NK.NB0是非壓縮的數據,裏面的數據就是NK.BIN展開以後在內存裏面的數據。而NK.BIN是有壓縮的數據,裏面的數據時壓縮以後類似於record的數據,被loader拷貝到內存以後沒有區別,由於BIN文件需要解壓,因而其下載方式也不一樣,通常,通過串口直接下載nb0,pb下載用BIN。
⑵NK.BIN和NK.NB0都可下載到RAM中,如果下載到RAM的是NK.BIN文件,因爲是壓縮的,顯然需要先通過bootloader進行解壓才能往NAND Flash中燒寫。而如果下載到RAM中的NK.NB0就不需要解壓了,可以直接燒寫到NAND Flash即可。
⑶NK.NB0就是NK.BIN展開後的文件,bootloader可以支持下載NB0,也可支持下載BIN,一般的做法是對於NB0的文件下載到RAM後就直接燒寫到NAND Flash中,對於BIN的文件下載後先解壓然後再燒寫到NAND Flash上,其實也可以做成BIN燒寫到NAND Flash中,然後啓動的時候load出來後再解壓,但這樣會加長啓動時間,這種方法一般只會用在NAND Flash空間不夠的情況。
轉自:http://blog.csdn.net/zhengmeifu/article/details/7839492