各位好,我是立宇泰2410的开发板,移植了2.6.22.6的linux内核,并将nand flash分为3个区,分别为kernel(2M),jffs2(8M),yaffs(剩余空间)。
今天按照版主的书构造了一个根文件系统,将其制作为yaffs映象文件,通过tftp下载然后烧写至nand flash的第三分区,但是始终出现kernel panic错误,和我没有移植根文件系统时的错误信息一样。
下面是我的操作,希望大家能给点提示,可能是什么问题?我看论坛里也有一些人遇到这个问题。
网上说:
1.nand flash 分区不对 (但是我看我的内核启动信息里三个分区好像都识别出来了,见绿色字体)
2.文件系统映象制作有问题
3.nand flash的第三分区有坏块
不知道怎么去看,我个人觉得是启动信息里:
VFS: Cannot open root device "hda1" or unknown-block(2,0)这一原因~~
U-Boot 1.1.6 (Jan 30 2010 - 20:46:35)
DRAM: 64 MB
Flash: 1 MB
NAND: 64 MiB
In: serial
Out: serial
Err: serial
SMDK2410 #
printenvbootdelay=3
baudrate=115200
netmask=255.255.255.0
ipaddr=10.13.11.84
ethaddr=08:00:3e:26:0a:5b
serverip=10.13.11.79
bootargs=noinitrd console=ttySAC0 root=/dev/mtdblock2 rootfstype=yaffs
stdin=serial
stdout=serial
stderr=serial
Environment size: 228/65532 bytes
SMDK2410 #
tftp 0x30000000 fs_mini.yaffsTFTP from server 10.13.11.79; our IP address is 10.13.11.84
Filename 'fs_mini.yaffs'.
Load address: 0x30000000
Loading: #################################################################
#################################################################
#################################################################
###########
done
Bytes transferred = 1051776 (100c80 hex)
SMDK2410 #
nand erase 0xA00000 0x3600000 //擦写nand flash的第三个分区NAND erase: device 0 offset 0xa00000, size 0x3600000
Erasing at 0x3ffc000 -- 100% complete.
OK
SMDK2410 #
nand write.yaffs 0x30000000 0xA00000 0x100E00 //将文件系统映象烧写至nand flashNAND write: device 0 offset 0xa00000, size 0x100e00
1052160 bytes written: OK
SMDK2410 #
nand read.jffs2 0x32000000 0 0x180000 //将内核加载至内存NAND read: device 0 offset 0x0, size 0x180000
Bad block at 0x24000 in erase block from 0x24000 will be skipped
Reading data from 0x183e00 -- 100% complete.
1572864 bytes read: OK
SMDK2410 #
bootm 0x32000000 //启动内核## Booting image at 32000000 ...
Image Name: Linux-2.6.22.6
Created: 2010-02-06 13:05:23 UTC
Image Type: ARM Linux Kernel Image (uncompressed)
Data Size: 1549224 Bytes = 1.5 MB
Load Address: 30008000
Entry Point: 30008000
Verifying Checksum ... OK
OK
Starting kernel ...
UncompressingLinux.....................................................................................................done, booting the kernel.
Linux version 2.6.22.6 (root@mac-desktop) (gcc version 3.4.5) #2 Sat Feb 6 21:05:12 CST 2010
CPU: ARM920T [41129200] revision 0 (ARMv4T), cr=c0007177
Machine: SMDK2410
Warning: bad configuration page, trying to continue
Memory policy: ECC disabled, Data cache writeback
CPU S3C2410A (id 0x32410002)
S3C2410: core 200.000 MHz, memory 100.000 MHz, peripheral 50.000 MHz
S3C24XX Clocks, (c) 2004 Simtec Electronics
CLOCK: Slow mode (1.500 MHz), fast, MPLL on, UPLL on
CPU0: D VIVT write-back cache
CPU0: I cache: 16384 bytes, associativity 64, 32 byte lines, 8 sets
CPU0: D cache: 16384 bytes, associativity 64, 32 byte lines, 8 sets
Built 1 zonelists. Total pages: 4064
Kernel command line: root=/dev/hda1 ro init=/bin/bash console=ttySAC0
irq: clearing subpending status 00000002
PID hash table entries: 64 (order: 6, 256 bytes)
timer tcon=00500000, tcnt a2c1, tcfg 00000200,00000000, usec 00001eb8
Console: colour dummy device 80x30
Dentry cache hash table entries: 2048 (order: 1, 8192 bytes)
Inode-cache hash table entries: 1024 (order: 0, 4096 bytes)
Memory: 16MB = 16MB total
Memory: 12888KB available (2864K code, 314K data, 132K init)
Mount-cache hash table entries: 512
CPU: Testing write buffer coherency: ok
NET: Registered protocol family 16
S3C2410 Power Management, (c) 2004 Simtec Electronics
S3C2410: Initialising architecture
S3C24XX DMA Driver, (c) 2003-2004,2006 Simtec Electronics
DMA channel 0 at c1800000, irq 33
DMA channel 1 at c1800040, irq 34
DMA channel 2 at c1800080, irq 35
DMA channel 3 at c18000c0, irq 36
usbcore: registered new interface driver usbfs
usbcore: registered new interface driver hub
usbcore: registered new device driver usb
NET: Registered protocol family 2
IP route cache hash table entries: 1024 (order: 0, 4096 bytes)
TCP established hash table entries: 512 (order: 0, 4096 bytes)
TCP bind hash table entries: 512 (order: -1, 2048 bytes)
TCP: Hash tables configured (established 512 bind 512)
TCP reno registered
NetWinder Floating Point Emulator V0.97 (double precision)
JFFS2 version 2.2. (NAND) B) 2001-2006 Red Hat, Inc.
yaffs Feb 6 2010 21:03:27 Installing.
io scheduler noop registered
io scheduler anticipatory registered (default)
io scheduler deadline registered
io scheduler cfq registered
s3c2410-lcd s3c2410-lcd: no platform data for lcd, cannot attach
s3c2410-lcd: probe of s3c2410-lcd failed with error -22
lp: driver loaded but no devices found
ppdev: user-space parallel port driver
S3C2410 Watchdog Timer, (c) 2004 Simtec Electronics
Serial: 8250/16550 driver $Revision: 1.90 $ 4 ports, IRQ sharing enabled
s3c2410-uart.0: s3c2410_serial0 at MMIO 0x50000000 (irq = 70) is a S3C2410
s3c2410-uart.1: s3c2410_serial1 at MMIO 0x50004000 (irq = 73) is a S3C2410
s3c2410-uart.2: s3c2410_serial2 at MMIO 0x50008000 (irq = 76) is a S3C2410
RAMDISK driver initialized: 16 RAM disks of 4096K size 1024 blocksize
loop: module loaded
dm9000 Ethernet Driver
Uniform Multi-Platform E-IDE driver Revision: 7.00alpha2
ide: Assuming 50MHz system bus speed for PIO modes; override with idebus=xx
BAST NOR-Flash Driver, (c) 2004 Simtec Electronics
S3C24XX NAND Driver, (c) 2004 Simtec Electronics
s3c2410-nand s3c2410-nand: Tacls=3, 30ns Twrph0=7 70ns, Twrph1=3 30ns
NAND device: Manufacturer ID: 0xec, Chip ID: 0x76 (Samsung NAND 64MiB 3,3V 8-bit)
Scanning device for bad blocks
Bad eraseblock 9 at 0x00024000
Creating 3 MTD partitions on "NAND 64MiB 3,3V 8-bit":0x00000000-0x00200000 : "kernel v2.6.22.6"0x00200000-0x00a00000 : "jffs2 file system"0x00a00000-0x04000000 : "yaffs file system"usbmon: debugfs is not available
s3c2410-ohci s3c2410-ohci: S3C24XX OHCI
s3c2410-ohci s3c2410-ohci: new USB bus registered, assigned bus number 1
s3c2410-ohci s3c2410-ohci: irq 42, io mem 0x49000000
usb usb1: configuration #1 chosen from 1 choice
hub 1-0:1.0: USB hub found
hub 1-0:1.0: 2 ports detected
mice: PS/2 mouse device common for all mice
S3C24XX RTC, (c) 2004,2006 Simtec Electronics
s3c2410-i2c s3c2410-i2c: slave address 0x10
s3c2410-i2c s3c2410-i2c: bus frequency set to 390 KHz
s3c2410-i2c s3c2410-i2c: i2c-0: S3C I2C adapter
TCP cubic registered
NET: Registered protocol family 1
drivers/rtc/hctosys.c: unable to open rtc device (rtc0)
Root-NFS: No NFS server available, giving up.
VFS: Unable to mount root fs via NFS, trying floppy.
VFS: Cannot open root device "hda1" or unknown-block(2,0)Please append a correct "root=" boot option; here are the available partitions:
1f00 2048 mtdblock0 (driver?)
1f01 8192 mtdblock1 (driver?)
1f02 55296 mtdblock2 (driver?)
Kernel panic - not syncing: VFS: Unable to mount root fs on unknown-block(2,0)
另:我的光盘里怎么没有yaffs_util_mkyaffsimage.patch这个补丁,论坛哪里可以下到吗?谢谢