uboot启动Linux内核时undefined instruction错误

错误描述

U-Boot 1.1.6 (Oct 18 2011 - 15:23:51) for FriendlyARM MINI6410


CPU:     S3C6410@532MHz
         Fclk = 532MHz, Hclk = 133MHz, Pclk = 66MHz, Serial = CLKUART (SYNC Mode) 
Board:   MINI6410
DRAM:    256 MB
Flash:   0 kB
NAND:    256 MB 
In:      serial
Out:     serial
Err:     serial
MAC: 08:90:90:90:90:90
Hit any key to stop autoboot:  0 

NAND read: device 0 offset 0x80000, size 0x500000
........................................ 5242880 bytes read: OK
## Booting image at c0008000 ...
Boot with Image

Starting kernel ...

undefined instruction
pc : [<50008004>]	   lr : [<c7e209c8>]
sp : c7fffe14  ip : 000000ff	 fp : 00000000
r10: c7e609a3  r9 : 00000000	 r8 : 7a176bfd
r7 : c7e442c0  r6 : 00000000	 r5 : c7e5ffb8  r4 : 00000000
r3 : 50008000  r2 : 50000100	 r1 : 000009d8  r0 : 00000000
Flags: nZCv  IRQs off  FIQs off  Mode SVC_32
Resetting CPU ...

reset... 

  

解决办法

  导致这个错误的原因是烧入Uboot的时候没有重新烧入linux内核,导致uboot启动的时候找不到Linux内核,烧入uboot的时候重新烧入Linux内核就可以了。但是坑爹的我在查找问题的时候修改了Linux内核的启动参数,导致在Linux启动到init进程的时候启动失败了。现在先看一下uboot相关的选项和参数:

U-Boot 1.1.6 (Oct 18 2011 - 15:23:51) for FriendlyARM MINI6410


CPU:     S3C6410@532MHz
         Fclk = 532MHz, Hclk = 133MHz, Pclk = 66MHz, Serial = CLKUART (SYNC Mode) 
Board:   MINI6410
DRAM:    256 MB
Flash:   0 kB
NAND:    256 MB 
In:      serial
Out:     serial
Err:     serial
MAC: 08:90:90:90:90:90
Hit any key to stop autoboot:  0 
##### FriendlyARM U-Boot(2011-10, NAND) for 6410 #####
[f] Format the nand flash
[v] Download u-boot.bin
[k] Download Linux/Android kernel
[y] Download root yaffs2 image
[u] Download root ubifs image
[a] Download Absolute User Application
[n] Download Nboot.nb0 for WinCE
[w] Download WinCE NK.nb0
[s] Set the boot parameter of Linux 
[b] Boot Linux
[q] Quit to shell
NAND(SLC): 256 MiB, RAM: 256 MiB
Enter your Selection:


##s这个选项是设置Linux启动的参数,一旦选中它,输入的任何字符都会被当做Linux参数保存哦,就算输入一个字符q,然后按回车,你认为想退出,其实它已经把q当做Linux的参数保存了,再次启动Linux的时候就可能出问题,除非只是单独的按回车。这是可以输入q,进入Quit to shell选项,在这里输入help,可以看到帮助命令,还可以在这里看到Linux的输入选项呢。

  这里只所以出现init进程跑失败,是因为Linux启动参数设置的文件系统和实际烧入的文件系统不匹配,所以一定要对照好两个。

posted @ 2015-11-19 14:50  木鱼长老  阅读(1555)  评论(0编辑  收藏  举报