Real6410的NBL1.LSB和NBL2编译下载不能启动的问题

********************************LoongEmbedded********************************

作者:LoongEmbedded(kandi)

时间:2012.03.24

类别:WINCE系统开发

********************************LoongEmbedded********************************

 

Real6410开发板的NBL1.LSBNBL2的这两部分生成的镜像合成为block0img.nb0,但利用SD卡更新的IROM_SD_EBOOT.nb0更新的第一阶段的bootloaderblock0.nb0,所以为了统一,我修改NBL1.LSBNBL2的这两部分生成为block0.nb0(72KB)。然后基于SD卡启动的方式来烧录这个block0.nb0,但是系统不能启动,但如果基于Real6410开发板厂家提供的block0.nb0(68KB)来烧录,确实可以正常启动的。为了进一步明确问题,我基于usb的更新方式来更新我自己编译生成的block0.nb0(72KB),确实可以正常启动,而如果更新厂家提供的block0.nb0(68KB)却不能正常启动。

 

为了搞清楚这个问题,仔细查看了NBL1.LSBNBL2EBOOT.WHIMORYEboot.SDFuser这几部分的代码,发现是Real6410修改了三星原厂的代码,下面我们来分析此问题,先看NBL1.LSB部分的main函数下面的部分:

Real6410的NBL1.LSB和NBL2编译下载不能启动的问题_第1张图片

1

可知nbl1部分是从第10page开始读取nbl2部分的,而我对比了Real6410提供Eboot.SDFuser和三星原厂此文件夹nand.cpp文件烧录block0.WriteRawImageToBootMedia函数相关部分,发现是Real6410做了下面的修改:

2

Real6410采用的MLC NAND FLASH一个page的大小为2048,所以根据上面的内容可知Real6410nbl2部分的镜像文件写到第6page开始的地址,而上面我们知道nbl1是从第10page的地方去读取nbl2,这样肯定导致了nbl1只能拷贝nbl2的后大半部分,这样就无法正常启动了。所以还原回三星原厂的内容,经过测试,就不存在上面提到的问题了。

 

下面我们来看NBL1.LSBbib文件

Real6410的NBL1.LSB和NBL2编译下载不能启动的问题_第2张图片

3

在来看NBL1.LSBmakefile文件包含的一个语句:

copy /y/b $(_PLATFORMROOT)\$(_TGTPLAT)\target\$(_TGTCPU)\$(WINCEDEBUG)\nbl1.nb1 $(_PLATFORMROOT)\$(_TGTPLAT)\target\$(_TGTCPU)\$(WINCEDEBUG)\nbl1.nb0

意思就是NBL1.nb0是由NBL1.nb1 Copy得到的,接下里看NBL2makefile文件的相关部分:

copy /b $(_PLATFORMROOT)\$(_TGTPLAT)\target\$(_TGTCPU)\$(WINCEDEBUG)\nbl1.nb1 + $(_PLATFORMROOT)\$(_TGTPLAT)\target\$(_TGTCPU)\$(WINCEDEBUG)\nbl1.nb2 + $(_PLATFORMROOT)\$(_TGTPLAT)\target\$(_TGTCPU)\$(WINCEDEBUG)\nbl2.nb0 $(_PLATFORMROOT)\$(_TGTPLAT)\target\$(_TGTCPU)\$(WINCEDEBUG)\block0.nb0

意思是block0.nb0= nbl1.nb1+nbl1.nb2+nbl2.nb0合成的,我觉得似乎没必要这样处理,既然S3C6410支持8KBstepping stone,那么我尝试了把图3中的0x00001000(4KB)改为0x00002000(8KB),而且去掉NBL1.LSBmakefile上面的语句,同时把NBL2makefile文件上面的部分改为:

copy /b $(_PLATFORMROOT)\$(_TGTPLAT)\target\$(_TGTCPU)\$(WINCEDEBUG)\nbl1.nb0 + $(_PLATFORMROOT)\$(_TGTPLAT)\target\$(_TGTCPU)\$(WINCEDEBUG)\nbl2.nb0 $(_PLATFORMROOT)\$(_TGTPLAT)\target\$(_TGTCPU)\$(WINCEDEBUG)\block0.nb0

这样修改编译生成的nbl1.nb0大小为8KBnbl2.nb0大小为68KBblcok.nb0大小72KB,然后基于sd卡和usb卡的方式来更新block.nb0,均可以正常启动,这样岂不是更容易理解。

 

你可能感兴趣的:(Real6410的NBL1.LSB和NBL2编译下载不能启动的问题)