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

原创 2012年03月24日 11:26:30

********************************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函数下面的部分:

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文件

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,均可以正常启动,这样岂不是更容易理解。

 

相关文章推荐

nbl2r,htmlspecialchars

定义和用法 nl2br() 函数在字符串中的每个新行 (\n) 之前插入 HTML 换行符 ()。
  • amberom
  • amberom
  • 2014年06月04日 10:19
  • 441

Real6410移植linux-2.6.39.1记录(1)-启动cramfs根文件系统

// 主题:Real6410移植linux-2.6.39.1// 作者:kevinjz2010@gmail.com// 版权:kevinjz原创// 平台:linux-2.39.1 real6410 ...

real6410移植linux2.6.39.4内核(2)-添加nand flash驱动及启动cramfs文件系统

real6410移植linux2.6.39.4内核(2)-添加nand flash驱动及启动cramfs文件系统 又经过了一天的奋战,搜索了无数资料,今天终于VFS: Mounted roo...
  • heyong_
  • heyong_
  • 2012年03月23日 18:50
  • 1277

real6410移植linux2.6.39.4内核(1)-内核移植环境的搭建及测试

经过几天的失败经历,以及逐渐对内核移植步骤的了解,现在我想实现的内容很简单,就是仅仅把一个 新的内核(我这里是官网下载的2.6.39.4内核)在开发板上面跑起来,也可以叫他裸跑,意思就是说什么驱 ...
  • heyong_
  • heyong_
  • 2012年03月22日 12:07
  • 831

real6410开发板和主机的网络连接问题

这两天想试试UBOOT下的tftp下载功能,所以要建立开发板和ubuntu的网络连接,中间遇到一些问题,现记录下来,以免忘记。 1.刚开始时无论是PC机ping开发板还是开发板ping电脑,都ping...

文件下载不能使用ajax的替代解决方案

前天我们决定优化一下之前使用系统的导出excel和pdf文件功能,由于有时候数据量比较大,服务器查询数据和生成文件的事件可能会比较长,于是我们决定在前台页面加一个”数据处理中”的提示,在此期间不让用户...

Real6410移植linux-2.6.39.1记录(2)-LCD驱动移植

// 主题:Real6410移植linux-2.6.39.1// 作者:kevinjz2010@gmail.com// 版权:kevinjz原创// 平台:linux-2.39.1 real6410 ...

Linux DNW2 For Real6410

  • 2011年11月22日 12:10
  • 23.38MB
  • 下载

交叉编译tslib和qt4.7.3 并在real6410上测试通过。

交叉编译4.7.3的应该有很多,qt交叉编译的资料也很多。我对自己编译过程中的心得体会和一些看法。 整个过程,应该是tslib --配置--qt---配置---测试。 (1)下载qt q...

S3C6410的Bootloader的两个阶段BL1和BL2编译相关学习

********************************LoongEmbedded********************************作者:LoongEmbedded(kandi)...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Real6410的NBL1.LSB和NBL2编译下载不能启动的问题
举报原因:
原因补充:

(最多只允许输入30个字)