DAVINCI DM36x 之——RBL→UBL→U-BOOT内存变换图

嵌入式技术

1378人已加入

描述

summery:1)位于cpuMemoryMap的0x8000~0xBFFF中的RBL初始化0x7FFC~0x8000作为RBL堆栈;2)

summery:

1)位于cpu Memory Map 的0x8000~0xBFFF中的RBL 初始化 0x7FFC~0x8000 作为RBL堆栈;

2)读取NAND 的 DEVICE ID 号,然后在RBL中的NAND DEVICE ID fomat中查找相应ID ,以达到对应控制的目的;

3)从NAND中的1th block 的 0th page 中查找UBL描述符,如果没有查到相应的MagicNum则next block中查找;如果查到正确的幻数,则记录UBL的描述符,包括MAGICNUM ,BLOCKNUM,,,加载地址位IARM最后24byte 中;

4)查找描述符完毕后,从描述符后的1th page 开始copy 到 IRAM中,IARM中的加载地址是0x20;

5)RBL程序跳入IRAM中的0x20地址开始执行UBL代码;

6)UBL代码会将位于nand中的UBL last block后的1th code(u-boot) copy 到 DDR2上;

7)启动U-BOOT代码;

下面是具体内存操作MAP:


还有些不明白的地方:

1)DDR2中的 U-BOOT分布,上图只是反汇编U-BOOT出来的地址;

2)烧写是为什么还要tftp   0x80700000 ;然后从nandwrite 0x80700000 0xXXXXXXXX  0xXXXXXXXX,此时的0x80700000代表究竟;

烦请知道的大牛给指点下;

提醒:显示的图片窗口有限,可以右击图片另存为后,可以看到全图;

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 相关推荐

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分