注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

男儿当自强的博客

每天进步一点

 
 
 

日志

 
 
 
 

NK.bin和NK.nb0学习  

2010-10-17 17:22:43|  分类: wince操作系统 |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |

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) 
记录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的组织格式:

NK.bin和NK.nb0学习 - 男儿当自强 - 男儿当自强的博客

 

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

NK.bin和NK.nb0学习 - 男儿当自强 - 男儿当自强的博客

 

可以知道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)指定的大小一致的。

NK.bin和NK.nb0学习 - 男儿当自强 - 男儿当自强的博客

而如果把ROMSIZE=00800000时,生成的文件如下:

NK.bin和NK.nb0学习 - 男儿当自强 - 男儿当自强的博客

 

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,见下图:

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

4.        

  评论这张
 
阅读(1239)| 评论(0)
推荐 转载

历史上的今天

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2017