定位一个问题,从uboot启动initrd时,内核挂死,串口无打印。之前一直ok的,随着rootfs增加了一些应用程序,initrd尺寸变得庞大后,出现了该现象。
定位下来后,原因是initrd覆盖了uboot的参数内存。
因为uboot将commandline的参数传送到linux内核是通过uboot的堆栈传过去的。由于initrd尺寸变大后,linux内核初始化后,将uboot的堆栈给覆盖了,导致死机。
一开始定位这个问题的时候考虑过这个原因,不过只是看了initrd的文件大小,觉得不会覆盖uboot的内存位置的。后来细想了一下,initrd的文件大小和kernel的实际尺寸是不同的,实际上kernel的尺寸远大于initrd文件的大小。对于这个问题,kernel的大小是21M(看内核的 System.map文件),而initrd的文件大小为11.7M。
将uboot的内存位置从0x81000000搬移到 0x82000000问题解决。
阅读(2208) | 评论(0) | 转发(0) |