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相关的选项和参数:linux

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启动参数设置的文件系统和实际烧入的文件系统不匹配,因此必定要对照好两个。shell

相关文章
相关标签/搜索