DAVINCI DM36x 之——RBL→UBL→U-BOOT内存变换图
![Rank: 8](images/default/star_level3.gif) ![Rank: 8](images/default/star_level3.gif)
- UID
- 872235
|
DAVINCI DM36x 之——RBL→UBL→U-BOOT内存变换图
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:
提醒:显示的图片窗口有限,可以右击图片另存为后,可以看到全图; |
|
|
|
|
|