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的實際資料內容。

NK.bin和NK.nb0详解_第1张图片
记录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的组织格式:

NK.bin和NK.nb0详解_第2张图片

………………………………….

可以知道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

NK.bin和NK.nb0详解_第3张图片

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空间不够的情况。

你可能感兴趣的:(image,Microsoft,Flash,存储,download,WinCE)