http://www.cnblogs.com/Efronc/archive/2012/03/01/2375578.html
1.内存分配图(引用网络图片)
2.u-boot映像的地址0并非指物理地址0,由不同的启动方式映射到不同的地址。例如v210是映射到0xD0000000处的irom。
3.TEXT_BASE等指向SDRAM的地址均为虚拟地址。
4.TEXT_BASE为顶层Makefile中定义的,例如三星官方BSP中定义的是0xC3E00000,它是程序实际的链接首地址。
5.SDRAM_BASE被MMU映射在0xC0000000。
6._end和__bss_start为链接脚本文件中最后定义的bss段,在链接时确定,并与u-boot映像编译在一起。
7.在bl1段运行时,u-boot映像被复制到TEXT_BASE开始的地址处。
8. u-boot分配用户栈顶的代码为:
ldr r0, _TEXT_BASE /* upper 128 KiB: relocated uboot */ 将0xc3e00000加载到r0
sub r0, r0, #CFG_MALLOC_LEN /* malloc area */ r0减去0x4000的malloc域
sub r0, r0, #CFG_GBL_DATA_SIZE /* bdinfo */ r0减去128字节的全局结构体
#if defined(CONFIG_USE_IRQ)
sub r0, r0, #(CONFIG_STACKSIZE_IRQ+CONFIG_STACKSIZE_FIQ) 如果用户有使用IRQ,再减去2*4*1024的中断栈空间
#endif
sub sp, r0, #12 /* leave 3 words for abort-stack */ 为取址终止异常预留3个字空间后设置好用户sp