1、查看u-boot在ddr第一次运行前后,malloc区域中数据的差别
2、http://blog.youkuaiyun.com/bigapple88/article/details/5693489 malloc失败
3、查看u-boot源代码目录中,common/dlmalloc.c文件
4、u-boot env_relocate malloc 失败
env_relocate[257] malloced ENV at (null)
*** Warning - bad CRC, using default environment
就是说molloc函数返回NULL!就是没有分配到内存!google了下uboot的malloc函数,有大牛遇到像我这样经典的问题,以下引用他的:
而bss段的初始化由C在调用main程序前将其初始化。但是对于U-BOOT而言,这些只能由它自己去完成。
而s3c44b0 start.s中没有做这部分工作。结果便会导致所以依赖于bss段赋初值为0的函数发生问题。
比如前面的malloc函数,他的top_pad为一个随机数,如几个M/Gbytes,咱们系统中总共才那么点SDRAM,
哪够你这么挥霍的, 其结果必然是malloc分配堆失败,程序挂掉了;
原来如此,但是uboot1.1.1版本的start.S也没有对bss段初始化阿,这可能又是真的跟编译器有关了。哎呀,一个星期的折腾阿!最终的解决方案是在start.S里面添加bss段初始化代码: