s3c2440-linux内核挂载启动不了yaffs2文件系统,请问怎么搞?两天快崩溃了。

时间:2022-09-19 09:06:04
##### EmbedSky BIOS for SKY2440/TQ2440 #####

Press Space key to Download Mode !

Booting Linux ...

Copy linux kernel from 0x00200000 to 0x30008000, size = 0x00200000 ... Copy Kernel to SDRAM done,NOW, Booting Linux......

Uncompressing Linux... done, booting the kernel.
Linux version 2.6.33.1 (root@lhg-desktop) (gcc version 4.4.1 (Sourcery G++ Lite 2009q3-67) ) #5 Tue Apr 6 23:27:58 CST 2010
CPU: ARM920T [41129200] revision 0 (ARMv4T), cr=c0007177
CPU: VIVT data cache, VIVT instruction cache
Machine: SMDK2440
ATAG_INITRD is deprecated; please update your bootloader.
Memory policy: ECC disabled, Data cache writeback
CPU S3C2440A (id 0x32440001)
S3C24XX Clocks, Copyright 2004 Simtec Electronics
S3C244X: core 400.000 MHz, memory 100.000 MHz, peripheral 50.000 MHz
CLOCK: Slow mode (1.500 MHz), fast, MPLL on, UPLL on
Built 1 zonelists in Zone order, mobility grouping on.  Total pages: 16256
Kernel command line: noinitrd root=/dev/mtdblock2 init=/linuxrc console=ttySAC0
PID hash table entries: 256 (order: -2, 1024 bytes)
Dentry cache hash table entries: 8192 (order: 3, 32768 bytes)
Inode-cache hash table entries: 4096 (order: 2, 16384 bytes)
Memory: 64MB = 64MB total
Memory: 60664KB available (3732K code, 311K data, 136K init, 0K highmem)
Hierarchical RCU implementation.
NR_IRQS:85
irq: clearing pending ext status 00080000
irq: clearing subpending status 00000002
Console: colour dummy device 80x30
console [ttySAC0] enabled
Calibrating delay loop... 199.47 BogoMIPS (lpj=498688)
Mount-cache hash table entries: 512
CPU: Testing write buffer coherency: ok
NET: Registered protocol family 16
S3C Power Management, Copyright 2004 Simtec Electronics
S3C2440: Initialising architecture
S3C2440: IRQ Support
S3C24XX DMA Driver, Copyright 2003-2006 Simtec Electronics
DMA channel 0 at c4808000, irq 33
DMA channel 1 at c4808040, irq 34
DMA channel 2 at c4808080, irq 35
DMA channel 3 at c48080c0, irq 36
S3C244X: Clock Support, DVS off
bio: create slab <bio-0> at 0
SCSI subsystem initialized
usbcore: registered new interface driver usbfs
usbcore: registered new interface driver hub
usbcore: registered new device driver usb
s3c-i2c s3c2440-i2c: slave address 0x10
s3c-i2c s3c2440-i2c: bus frequency set to 97 KHz
s3c-i2c s3c2440-i2c: i2c-0: S3C I2C adapter
Advanced Linux Sound Architecture Driver Version 1.0.21.
NET: Registered protocol family 2
IP route cache hash table entries: 1024 (order: 0, 4096 bytes)
TCP established hash table entries: 2048 (order: 2, 16384 bytes)
TCP bind hash table entries: 2048 (order: 1, 8192 bytes)
TCP: Hash tables configured (established 2048 bind 2048)
TCP reno registered
UDP hash table entries: 256 (order: 0, 4096 bytes)
UDP-Lite hash table entries: 256 (order: 0, 4096 bytes)
NET: Registered protocol family 1
RPC: Registered udp transport module.
RPC: Registered tcp transport module.
RPC: Registered tcp NFSv4.1 backchannel transport module.
NetWinder Floating Point Emulator V0.97 (extended precision)
JFFS2 version 2.2. (NAND) (SUMMARY)  漏 2001-2006 Red Hat, Inc.
ROMFS MTD (C) 2007 Red Hat, Inc.
yaffs Apr  6 2010 23:20:38 Installing. 
msgmni has been set to 118
io scheduler noop registered
io scheduler deadline registered
io scheduler cfq registered (default)
Console: switching to colour frame buffer device 30x40
fb0: s3c2410fb frame buffer device
lp: driver loaded but no devices found
ppdev: user-space parallel port driver
Serial: 8250/16550 driver, 4 ports, IRQ sharing enabled
s3c2440-uart.0: ttySAC0 at MMIO 0x50000000 (irq = 70) is a S3C2440
s3c2440-uart.1: ttySAC1 at MMIO 0x50004000 (irq = 73) is a S3C2440
s3c2440-uart.2: ttySAC2 at MMIO 0x50008000 (irq = 76) is a S3C2440
brd: module loaded
loop: module loaded
Uniform Multi-Platform E-IDE driver
ide-gd driver 1.18
ide-cd driver 5.00
S3C24XX NAND Driver, (c) 2004 Simtec Electronics
s3c24xx-nand s3c2440-nand: Tacls=1, 10ns Twrph0=3 30ns, Twrph1=1 10ns
s3c24xx-nand s3c2440-nand: NAND hardware ECC
NAND device: Manufacturer ID: 0xec, Chip ID: 0xda (Samsung NAND 256MiB 3,3V 8-bit)
Scanning device for bad blocks
Bad eraseblock 33 at 0x000000420000
Bad eraseblock 34 at 0x000000440000
Bad eraseblock 35 at 0x000000460000
Bad eraseblock 36 at 0x000000480000
Bad eraseblock 37 at 0x0000004a0000
Bad eraseblock 38 at 0x0000004c0000
Bad eraseblock 39 at 0x0000004e0000
Bad eraseblock 40 at 0x000000500000
Bad eraseblock 41 at 0x000000520000
Bad eraseblock 42 at 0x000000540000
Bad eraseblock 43 at 0x000000560000
Bad eraseblock 44 at 0x000000580000
Bad eraseblock 45 at 0x0000005a0000
Bad eraseblock 46 at 0x0000005c0000
Bad eraseblock 47 at 0x0000005e0000
Bad eraseblock 48 at 0x000000600000
Bad eraseblock 49 at 0x000000620000
Bad eraseblock 50 at 0x000000640000
Bad eraseblock 51 at 0x000000660000
Bad eraseblock 52 at 0x000000680000
Bad eraseblock 53 at 0x0000006a0000
Bad eraseblock 54 at 0x0000006c0000
Bad eraseblock 55 at 0x0000006e0000
Bad eraseblock 56 at 0x000000700000
Bad eraseblock 57 at 0x000000720000
Bad eraseblock 58 at 0x000000740000
Bad eraseblock 59 at 0x000000760000
Bad eraseblock 60 at 0x000000780000
Bad eraseblock 61 at 0x0000007a0000
Bad eraseblock 62 at 0x0000007c0000
Bad eraseblock 63 at 0x0000007e0000
Bad eraseblock 64 at 0x000000800000
Bad eraseblock 65 at 0x000000820000
Bad eraseblock 66 at 0x000000840000
Bad eraseblock 67 at 0x000000860000
Bad eraseblock 68 at 0x000000880000
Bad eraseblock 69 at 0x0000008a0000
Bad eraseblock 70 at 0x0000008c0000
Bad eraseblock 71 at 0x0000008e0000
Bad eraseblock 72 at 0x000000900000
Bad eraseblock 73 at 0x000000920000
Bad eraseblock 74 at 0x000000940000
Bad eraseblock 75 at 0x000000960000
Bad eraseblock 76 at 0x000000980000
Bad eraseblock 77 at 0x0000009a0000
Bad eraseblock 78 at 0x0000009c0000
Bad eraseblock 79 at 0x0000009e0000
Bad eraseblock 80 at 0x000000a00000
Bad eraseblock 81 at 0x000000a20000
Bad eraseblock 82 at 0x000000a40000
Bad eraseblock 83 at 0x000000a60000
Creating 3 MTD partitions on "NAND 256MiB 3,3V 8-bit":
0x000000000000-0x000000040000 : "LHG_Board_uboot"
0x000000200000-0x000000400000 : "LHG_Board_kernel"
0x000000400000-0x00000ff80000 : "LHG_Board_yaffs2"
dm9000 Ethernet Driver, V1.31
usbmon: debugfs is not available
ohci_hcd: USB 1.1 'Open' Host Controller (OHCI) Driver
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
hub 1-0:1.0: USB hub found
hub 1-0:1.0: 2 ports detected
usbcore: registered new interface driver libusual
usbcore: registered new interface driver usbserial
USB Serial support registered for generic
usbcore: registered new interface driver usbserial_generic
usbserial: USB Serial Driver core
USB Serial support registered for FTDI USB Serial Device
usbcore: registered new interface driver ftdi_sio
ftdi_sio: v1.5.0:USB FTDI Serial Converters Driver
USB Serial support registered for pl2303
usbcore: registered new interface driver pl2303
pl2303: Prolific PL2303 USB to serial adaptor driver
mice: PS/2 mouse device common for all mice
S3C24XX RTC, (c) 2004,2006 Simtec Electronics
S3C2410 Watchdog Timer, (c) 2004 Simtec Electronics
s3c2410-wdt s3c2410-wdt: watchdog inactive, reset disabled, irq enabled
ALSA device list:
  No soundcards found.
TCP cubic registered
NET: Registered protocol family 17
drivers/rtc/hctosys.c: unable to open rtc device (rtc0)
end_request: I/O error, dev mtdblock2, sector 256
isofs_fill_super: bread failed, dev=mtdblock2, iso_blknum=64, block=128
yaffs: dev is 32505858 name is "mtdblock2"
yaffs: passed flags ""
yaffs: Attempting MTD mount on 31.2, "mtdblock2"
yaffs: auto selecting yaffs2
block 2 is bad
block 3 is bad
block 4 is bad
block 5 is bad
block 6 is bad
block 7 is bad
block 8 is bad
block 9 is bad
block 10 is bad
block 11 is bad
block 12 is bad
block 13 is bad
block 14 is bad
block 15 is bad
block 16 is bad
block 17 is bad
block 18 is bad
block 19 is bad
block 20 is bad
block 21 is bad
block 22 is bad
block 23 is bad
block 24 is bad
block 25 is bad
block 26 is bad
block 27 is bad
block 28 is bad
block 29 is bad
block 30 is bad
block 31 is bad
block 32 is bad
block 33 is bad
block 34 is bad
block 35 is bad
block 36 is bad
block 37 is bad
block 38 is bad
block 39 is bad
block 40 is bad
block 41 is bad
block 42 is bad
block 43 is bad
block 44 is bad
block 45 is bad
block 46 is bad
block 47 is bad
block 48 is bad
block 49 is bad
block 50 is bad
block 51 is bad
block 52 is bad
yaffs_read_super: isCheckpointed 0
VFS: Mounted root (yaffs filesystem) on device 31:2.
Freeing init memory: 136K
Warning: unable to open an initial console.
Failed to execute /linuxrc.  Attempting defaults...
Kernel panic - not syncing: No init found.  Try passing init= option to kernel.
Backtrace: 
[<c002e89c>] (dump_backtrace+0x0/0x114) from [<c02f4bdc>] (dump_stack+0x18/0x1c)
 r6:00000000 r5:00000000 r4:c03f2364
[<c02f4bc4>] (dump_stack+0x0/0x1c) from [<c02f4c2c>] (panic+0x4c/0x128)
[<c02f4be0>] (panic+0x0/0x128) from [<c002a5e8>] (init_post+0xd4/0xfc)
 r3:00000000 r2:00000003 r1:00000080 r0:c0372e13
[<c002a514>] (init_post+0x0/0xfc) from [<c000862c>] (kernel_init+0xe4/0x114)
 r4:c03f1a40
[<c0008548>] (kernel_init+0x0/0x114) from [<c004c764>] (do_exit+0x0/0x5b8)
 r4:00000000

15 个解决方案

#1


root=/dev/mtdblock2 这上面文件系统有问题。

#2


我也出现过这个问题,一直没解决。。帮LZ顶一下。。

#3


使用cramfs分区,手工烧一些内容,再用你的bootloader相同的内容,再逐个对比一下每个page。

出现这种情况应当是你的烧写过程有问题。

#4


我也在2.6.18上的 128MB nand flash上搞yaffs2 文件系统。你才研究了两天,慢慢来吧。

#5


可能是坏块,格掉吧。文件image不要直接去烧了,挂上后拷贝!

#6


关掉ECC看看---------------NAND hardware ECC

#7


Warning: unable to open an initial console.
Failed to execute /linuxrc. Attempting defaults...

确认过你的rootfs可以正常启动吗?可以先通过nfs方式挂载文件系统?

#8


哥们 你这个是烧写的yaffs文件系统与你的nand的结构不匹配的缘故
要相应修改mkyaffs2image.c的内容 或者是kernel中的oob区规则
就是说要与kernel中的oob相匹配才可以
我前不久做过  也被这个问题卡了一段时间
http://topic.csdn.net/u/20100225/09/dd14d827-e92a-46ed-b4ad-c5a9f4b90a65.html

#9


把yaffs2烧到nand后  可以通过 nand dump     nand read等命令进行检查 看写进的内容是否与kernel要求的匹配

#10


Bad eraseblock 82 at 0x000000a40000
Bad eraseblock 83 at 0x000000a60000
每块128K。


http://topic.csdn.net/u/20100225/09/dd14d827-e92a-46ed-b4ad-c5a9f4b90a65.html  :

1 Page = (2K + 64)Bytes

1 Block = (2K + 64)B x 64 Pages

= (128K + 4K) Bytes

多出来4K了呢?

是不是zmlovelx所说的:yaffs文件系统与你的nand的结构不匹配?
楼主问题解决了,还望看到正确答案。

#11


成功挂上文件系统了。

感谢zmlovelx !
就像zmlovelx说得那样:
mkyaffs2imag.c  
修改write_chunk
mkyaffs2imag.c 把xxpackTag2结构存储时后移2byte 因kernel oob 最低两byte不使用,oobfree从低3byte开始共占38byte 从39开始为eccspace
http://topic.csdn.net/u/20100225/09/dd14d827-e92a-46ed-b4ad-c5a9f4b90a65.html

#12


现在又出现新的问题,在终端输入指令回显错误,常没有回显。

#13


有以提示信息,提示后还是可以进入系统。

[@(none)/]#-/bin/sh: can't access tty; job control turned off

Processing /etc/profile... Done

[@(none)/]#

#14


我已搞定在linux里烧写 yaffs2 image和mount问题:http://blog.csdn.net/wenxy1/archive/2010/04/13/5481616.aspx

#15


哎,,看看

#1


root=/dev/mtdblock2 这上面文件系统有问题。

#2


我也出现过这个问题,一直没解决。。帮LZ顶一下。。

#3


使用cramfs分区,手工烧一些内容,再用你的bootloader相同的内容,再逐个对比一下每个page。

出现这种情况应当是你的烧写过程有问题。

#4


我也在2.6.18上的 128MB nand flash上搞yaffs2 文件系统。你才研究了两天,慢慢来吧。

#5


可能是坏块,格掉吧。文件image不要直接去烧了,挂上后拷贝!

#6


关掉ECC看看---------------NAND hardware ECC

#7


Warning: unable to open an initial console.
Failed to execute /linuxrc. Attempting defaults...

确认过你的rootfs可以正常启动吗?可以先通过nfs方式挂载文件系统?

#8


哥们 你这个是烧写的yaffs文件系统与你的nand的结构不匹配的缘故
要相应修改mkyaffs2image.c的内容 或者是kernel中的oob区规则
就是说要与kernel中的oob相匹配才可以
我前不久做过  也被这个问题卡了一段时间
http://topic.csdn.net/u/20100225/09/dd14d827-e92a-46ed-b4ad-c5a9f4b90a65.html

#9


把yaffs2烧到nand后  可以通过 nand dump     nand read等命令进行检查 看写进的内容是否与kernel要求的匹配

#10


Bad eraseblock 82 at 0x000000a40000
Bad eraseblock 83 at 0x000000a60000
每块128K。


http://topic.csdn.net/u/20100225/09/dd14d827-e92a-46ed-b4ad-c5a9f4b90a65.html  :

1 Page = (2K + 64)Bytes

1 Block = (2K + 64)B x 64 Pages

= (128K + 4K) Bytes

多出来4K了呢?

是不是zmlovelx所说的:yaffs文件系统与你的nand的结构不匹配?
楼主问题解决了,还望看到正确答案。

#11


成功挂上文件系统了。

感谢zmlovelx !
就像zmlovelx说得那样:
mkyaffs2imag.c  
修改write_chunk
mkyaffs2imag.c 把xxpackTag2结构存储时后移2byte 因kernel oob 最低两byte不使用,oobfree从低3byte开始共占38byte 从39开始为eccspace
http://topic.csdn.net/u/20100225/09/dd14d827-e92a-46ed-b4ad-c5a9f4b90a65.html

#12


现在又出现新的问题,在终端输入指令回显错误,常没有回显。

#13


有以提示信息,提示后还是可以进入系统。

[@(none)/]#-/bin/sh: can't access tty; job control turned off

Processing /etc/profile... Done

[@(none)/]#

#14


我已搞定在linux里烧写 yaffs2 image和mount问题:http://blog.csdn.net/wenxy1/archive/2010/04/13/5481616.aspx

#15


哎,,看看