NK.bin和NK.nb0詳解

1.       NK.bin

BinMicrosoft Windwos CE binary image data format(.bin)文件格式中包含若干個獨立的記錄(record),以記錄(record)爲單位來組織數據,每個record都包含了起始地址,長度,檢驗碼和這個record中包含的數據內容,Platform Builder調用工具RomImage.exeWINCE內核所有文件以bin格式合併成一個文件(至於RomImage.exe是怎麼合成NK.bin的,後面需要好好深入瞭解),默認文件名爲nk.binBootLoader又以同樣的格式將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地址

請注意,最後的recordjumpAddressOAL層的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.binimage start地址及image length,然後就是接下來以record的格式來讀取record的數據到RAM中。Bin文件格式可以使得映像文件最下,加載時間短,但需要bootloader給予解釋加載才能運行,這個解析的工作是在DownloadBin函數中進行的。

 

2.       NK.nb0

Nb0nb0文件就是可執行映像的原始Flash映像,它不包括頭,一般情況下將內核下載到設備的RAM中運行都採用nb0格式,nb0文件的尺寸比bin大,但是可以直接運行,要生產NK.nb0,就需要在congfig.bib中加入下面的內容

ROMSTART = 80200000

ROMWIDTH = 32

ROMSIZE = 02300000

ROMSTARTWINCE image在內存中的起始地址,ROMWIDTH指數據總線的寬度,ROMSIZEWINCE image的大小。現在我們的系統的NK.bin大小是26889KB,生成的NK.nb0大小爲

現在我們設置ROMSIZE=01A00000NK.bin=26889KB > 01A0000(26MB),也就是說如果WINCE image大小大於ROMSIZE指定的大小的時候,除了生成NK.nb0之外還會生成NK0.nb1NK.nb2….,下圖是ROMSIZE=01A00000設置時生成的NK.nb0NK.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.binNK.nb0的區別

NK.binNK.nb0的區別主要有以下這些區別:

NK.BIN中的內容是被壓縮過的,而NK.NB0中的內容是沒有壓縮的,兩者大小的區別是因爲在生成過程中BIN會將設定的後面的NULL自動去掉,而NB0就不會。由於NK.NB0是非壓縮的數據,裏面的數據就是NK.BIN展開以後在內存裏面的數據。而NK.BIN是有壓縮的數據,裏面的數據時壓縮以後類似於record的數據,被loader拷貝到內存以後沒有區別,由於BIN文件需要解壓,因而其下載方式也不一樣,通常,通過串口直接下載nb0pb下載用BIN

NK.BINNK.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
發佈了45 篇原創文章 · 獲贊 6 · 訪問量 7萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章