关于linux移植时Resetting CPU …的问题(在我的系统中可行,已

这两天移植做linux的移植,遇到的问题也很多,其中有一个问题就是移植uImage以后不断的Resetting CPU …的问题。首先,内核配置好以后,我们会先生成一个zImage的文件,但为了支持u-boot启动,我们还得制作uImage。

我的过程如下:

(1)内核配置好以后:linux-q4mf:/home/fangdong/linux #make zImage//这一步是先生成zImage文件。

(2)然后制作uImag文件:所谓制作uImage,就是在zImage前面加上一个64字节的头部

将fangdong/u-boot-1.2.0/tools下的mkimage复制到linux2.6.30.10/arch/arm/boot下然后执行:linux-q4mf:/home/fangdong/linux-2.6.30.10/arch/arm/boot # ./mkimage -A arm -Olinux-T kernel -C none -a 0x30008000 -e 0x30008000 -n linux-2.6.30.10 -d zImage uImage参数说明: -A arm ——– 架构是arm -O linux ——– 操作系统是linux -T kernel ——– 类型是kernel -C none ——– 压缩类型为无压缩 -a 30008000 —- image的载入地址(hex) -e 30008000 —- 内核的入口地址(hex)-n linux-2.6.30.10 — image的名字 -d zImage —- 无头信息的image文件名 uImage —- 加了头信息之后的image文件名

这样uImage就制作好了,然后我们通过网络下载到RAM中,进行一些设置,使之从NAND FLASH 启动。

(3)设置好ip后下载:

fangdong2410 # tftp 0x30008000 uImage

NE2000 – eeprom ESA: 08:08:08:12:34:56TFTP from server 10.103.0.154; our IP address is 10.103.0.153Filename ‘uImage’.Load address: 0x30008000Loading: ################################################################# ################################################################# ################################################################# ################################################################# ################################################################# ############################################################doneBytes transferred = 1966616 (1e0218 hex)fangdong2410 # nand erase 0x00080000 0x00200000fangdong2410 # nand write 0x30008000 0x00080000 0x1e0218fangdong2410 # setenv bootcmd nand read 0x30008000 0x00080000 0x1e0218\;bootm 0x30008000fangdong2410 #saveenv

重启,结果出现以下情况:

NAND read: device 0 offset 524288, size 2097152 …2097152 bytes read: OK## Booting image at 30008000 … Image Name: Linux-2.6.30.10 Created: 2010-04-25 9:59:17 UTC Image Type: ARM Linux Kernel Image (uncompressed) Data Size: 1966552 Bytes = 1.9 MB Load Address: 30008000 Entry Point: 30008000 Verifying Checksum … OK XIP Kernel Image … OK

Starting kernel …

data abortpc : [<30008010>] lr : [<33f94754>]sp : 33f4faa0 ip : 30008000 fp : 00000002r10: 00000000 r9 : 33e7fe2c r8 : 33f4ffdcr7 : 33f9e278 r6 : 33f9e278 r5 : 30008000 r4 : 00000000r3 : 30008000 r2 : 30000100 r1 : 000000c1 r0 : 33f4fce8Flags: nZCv IRQs off FIQs off Mode SVC_32Resetting CPU …

也就是总是重启CPU,上网一查,发现原来是制作uImage时出现的错误:

有位网友是这么说的:因为uImage是压缩的,需要解压,解压的地址是30008000,而这个地址又放了你的uImage本身,这样一解压就把自己覆盖了,于是不断的重启CPU。我想了想,在制作uImage是在zImage基础上加上6464byte的头部,因此uImage的载入地址是0x30008000,在真正的内核的入口地址应该是0x30008000+64byte。因此,内核的真正入口地址应该是0x30008040(0x40=64)所以-e的参数是0x30008040。

(4)重新制作uImage

linux-q4mf:/home/fangdong/linux-2.6.30.10/arch/arm/boot # ./mkimage -A arm -Olinux-T kernel -C none -a 0x30008000 -e 0x30008040 -n linux-2.6.30.10 -d zImage uImage(对比以前改了-e 0x30008040)

问题解决。

fangdong2410 # tftp 0x30008000 uImage

NE2000 – eeprom ESA: 08:08:08:12:34:56TFTP from server 10.103.0.154; our IP address is 10.103.0.153Filename ‘uImage’.Load address: 0x30008000Loading: ################################################################# ################################################################# ################################################################# ################################################################# ################################################################# ############################################################

doneBytes transferred = 1966616 (1e0218 hex)fangdong2410 # nand erase 0x00080000 0x00200000fangdong2410 # nand write 0x30008000 0x00080000 0x1e0218

重启

NAND read: device 0 offset 524288, size 1966616 …1966616 bytes read: OK## Booting image at 30008000 … Image Name: linux-2.6.30.10 Created: 2010-04-27 1:40:03 UTC Image Type: ARM Linux Kernel Image (uncompressed) Data Size: 1966552 Bytes = 1.9 MB Load Address: 30008000 Entry Point: 30008040 Verifying Checksum … OK XIP Kernel Image … OK

Starting kernel …

Uncompressing Linux………………………………………………………………………………………………………………. done, booting the kernel.Linux version 2.6.30.10 (root@linux-q4mf) (gcc version 3.4.4) #1 Sun Apr 25 17:59:00 CST 2010CPU: ARM920T [41129200] revision 0 (ARMv4T), cr=00007177CPU: VIVT data cache, VIVT instruction cacheMachine: SMDK2410Warning: bad configuration page, trying to continueMemory policy: ECC disabled, Data cache writebackCPU S3C2410A (id 0x32410002)S3C24XX Clocks, (c) 2004 Simtec ElectronicsS3C2410: core 202.800 MHz, memory 101.400 MHz, peripheral 50.700 MHzCLOCK: Slow mode (1.500 MHz), fast, MPLL on, UPLL onBuilt 1 zonelists in Zone order, mobility grouping off. Total pages: 4064Kernel command line: root=/dev/mtdblock2 init=/linuxrc console=ttySAC0,115200

…..

当爱丽思丢失了通往仙境的钥匙,

关于linux移植时Resetting CPU …的问题(在我的系统中可行,已

相关文章:

你感兴趣的文章:

标签云: