Android 编译出kernel的uImage无法正常载入

现象:硬件平台烧完机后,系统没有起来,通过串口看log是系统卡死在了kernel阶段

        一开始看这个问题的时候,bug的描述是kernel的两个配置项做了替换配置之后(CONFIG_USB_GADGET;CONFIG_USB_EHCI_ARC_OTG)出现了该问题,然后就分析到底这俩配置项(一个是将usb配置为debug模式,一个是配置为OTG模式)能有啥影响,会导致kernel的启动出现问题,后来发现方向错了,原来尝试添加其他的配置项(只要会导致uImage编译出来后变大)就会导致kernel无法起机,到此为止锁定了问题,不是具体配置项影响,很可能是kernel大小导致了该问题。

"nand_read_kernel=nand read ${loadaddr} 0x1000000 0x360000"	\
"nand_read_recovery_kernel=nand read ${loadaddr} 0x2CA00000 0x360000"	\

      问题的怀疑点到了uboot给kernel传的参数部分,在uboot/include/configs/mx53_**.h里边有上边两项的定义,发现nand read只从0x1000000读了0x360000大小的uImage,大小为3.35M左右,进一步锁定问题,大于3.35不能启动,小于3.35可以启动,因此将0x360000改为0x400000,问题解决~~~~


       这个问题拿出来做记录的原因是:bug的描述让我的解决方向出现了偏差,除了配置项的干扰外,还存在更改kernel的开机启动图片也出现不能起机,因此又拿着开机图片那块琢磨半天,好在最后灵光一闪,闪到了正题,虽然解决该问题的改动是那么的不起眼!看来大方向不能错啊!

你可能感兴趣的:(Android)