Real6410的NBL1.LSB和NBL2编译下载不能启动的问题
********************************LoongEmbedded********************************
作者:LoongEmbedded(kandi)
時間:2012.03.24
類別:WINCE系統開發
********************************LoongEmbedded********************************
?
Real6410開發板的NBL1.LSB和NBL2的這兩部分生成的鏡像合成為block0img.nb0,但利用SD卡更新的IROM_SD_EBOOT.nb0更新的第一階段的bootloader為block0.nb0,所以為了統一,我修改NBL1.LSB和NBL2的這兩部分生成為block0.nb0(72KB)。然后基于SD卡啟動的方式來燒錄這個block0.nb0,但是系統不能啟動,但如果基于Real6410開發板廠家提供的block0.nb0(68KB)來燒錄,確實可以正常啟動的。為了進一步明確問題,我基于usb的更新方式來更新我自己編譯生成的block0.nb0(72KB),確實可以正常啟動,而如果更新廠家提供的block0.nb0(68KB)卻不能正常啟動。
?
為了搞清楚這個問題,仔細查看了NBL1.LSB、NBL2、EBOOT.WHIMORY和Eboot.SDFuser這幾部分的代碼,發現是Real6410修改了三星原廠的代碼,下面我們來分析此問題,先看NBL1.LSB部分的main函數下面的部分:
圖1
可知nbl1部分是從第10個page開始讀取nbl2部分的,而我對比了Real6410提供Eboot.SDFuser和三星原廠此文件夾nand.cpp文件燒錄block0.的WriteRawImageToBootMedia函數相關部分,發現是Real6410做了下面的修改:
圖2
而Real6410采用的MLC NAND FLASH一個page的大小為2048,所以根據上面的內容可知Real6410把nbl2部分的鏡像文件寫到第6page開始的地址,而上面我們知道nbl1是從第10個page的地方去讀取nbl2,這樣肯定導致了nbl1只能拷貝nbl2的后大半部分,這樣就無法正常啟動了。所以還原回三星原廠的內容,經過測試,就不存在上面提到的問題了。
?
下面我們來看NBL1.LSB的bib文件
圖3
在來看NBL1.LSB的makefile文件包含的一個語句:
copy /y/b $(_PLATFORMROOT)\$(_TGTPLAT)\target\$(_TGTCPU)\$(WINCEDEBUG)\nbl1.nb1 $(_PLATFORMROOT)\$(_TGTPLAT)\target\$(_TGTCPU)\$(WINCEDEBUG)\nbl1.nb0
意思就是NBL1.nb0是由NBL1.nb1 Copy得到的,接下里看NBL2的makefile文件的相關部分:
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支持8KB的stepping stone,那么我嘗試了把圖3中的0x00001000(4KB)改為0x00002000(8KB),而且去掉NBL1.LSB的makefile上面的語句,同時把NBL2的makefile文件上面的部分改為:
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大小為8KB,nbl2.nb0大小為68KB,blcok.nb0大小72KB,然后基于sd卡和usb卡的方式來更新block.nb0,均可以正常啟動,這樣豈不是更容易理解。
?
總結
以上是生活随笔為你收集整理的Real6410的NBL1.LSB和NBL2编译下载不能启动的问题的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 基于WINCE6.0下载multiple
- 下一篇: WINCE6.0系统调用