这个问题同样经典,大意是说u-boot传递的machine id不正确。在网上看到的文章几乎如出一辙:有两种方法,一是修改内核的head.S(具体在./arch/arm/kernel目录下),二是修改u-boot代码。可惜,第二种方法中出现的源代码文件,在我移植的版本中没有发现。
我的提示信息是这样的:
(注:这里使用的内核是许久以前我第二次移植linux时使用的。——不禁想起那段奋斗的日子。)
在u-boot代码(./board/samsung/smdk2440/smdk2440.c)中,赋值machine ID的代码如下:
在linux内核(./arch/arm/mach-s3c2440/mach-smdk2440.c)中,代码是这样:
两者是一致的,都是1008(=0x3f0)。
而且,我在u-boot中打印板子信息也能看到这个machine id(第一行arch_number即是):
按理说,既然大家都一致了,能正常引导才是啊。可惜还是不行。
于是修改了head.S文件,可以了。但是,这个应该是不推荐的方法。
后来我在cmd_bootm.c文件中的do_bootm_linux函数中添加一行debug信息:
在启动时显示如下:
注意,Starting kernel ...这行是u-boot打印的。
上面的信息证实了,在启动内核之前的那一刻,machine id还是0x3f0,是正常的。至于为什么就是不能引导,我也不清楚。
这个问题搞了很久,不过今天下午却能引导起来了。就是不修改head.S文件,不修改u-boot关键代码(加个Debug信息而已),就可以了。
下面是启动信息:
这个诡异的问题到底是怎么回事,山人也不明白。