Re: linux-next: JFFS2 corruption
From: Stephen Rothwell
Date: Tue Feb 26 2013 - 18:18:33 EST
Hi Mark,
On Tue, 26 Feb 2013 15:50:18 +0000 Mark Jackson <mpfj-list@xxxxxxxxxx> wrote:
>
> Just tested the current next-20130226 on a custom AM335X board, and if I mount
> our JFFS2 image as read/write, the next reboot shows the image as being corrupt.
>
> If I reprogram the jffs2 image into NAND and only mount the volume as read-only,
> no corruption occurs and the system remains intact.
>
> I have also tested:-
>
> (a) reprogram ubifs image into nand
> (b) boot the volume as read-only (corrupt -> no)
> (c) remount the volume as read/write
> (d) rebooting the volume as read-only (corrupt -> yes)
Thanks for all the testing. Sam questions as in my other email.
Al, same for you as well ...
> Below is the log showing (d) ...
>
> Regards
> Mark J.
> ---
> [ 0.000000] Booting Linux on physical CPU 0x0
> [ 0.000000] Linux version 3.8.0-next-20130226-dirty (mpfj@mpfj-nanobone) (gcc version 4.5.4 (Buildroot 2012.11) ) #12 SMP Tue Feb 26 14:04:28 GMT 2013
> [ 0.000000] CPU: ARMv7 Processor [413fc082] revision 2 (ARMv7), cr=10c53c7d
> [ 0.000000] CPU: PIPT / VIPT nonaliasing data cache, VIPT aliasing instruction cache
> [ 0.000000] Machine: Generic AM33XX (Flattened Device Tree), model: TI AM335x BeagleBone
> [ 0.000000] Memory policy: ECC disabled, Data cache writeback
> [ 0.000000] CPU: All CPU(s) started in SVC mode.
> [ 0.000000] AM335X ES1.0 (neon )
> [ 0.000000] PERCPU: Embedded 9 pages/cpu @c0e02000 s13696 r8192 d14976 u36864
> [ 0.000000] Built 1 zonelists in Zone order, mobility grouping on. Total pages: 64768
> [ 0.000000] Kernel command line: console=ttyO0,115200n8 noinitrd ip=off mem=256M rootwait=1 rootfstype=jffs2 root=/dev/mtdblock6 ro
> [ 0.000000] PID hash table entries: 1024 (order: 0, 4096 bytes)
> [ 0.000000] Dentry cache hash table entries: 32768 (order: 5, 131072 bytes)
> [ 0.000000] Inode-cache hash table entries: 16384 (order: 4, 65536 bytes)
> [ 0.000000] __ex_table already sorted, skipping sort
> [ 0.000000] Memory: 255MB = 255MB total
> [ 0.000000] Memory: 246536k/246536k available, 15608k reserved, 0K highmem
> [ 0.000000] Virtual kernel memory layout:
> [ 0.000000] vector : 0xffff0000 - 0xffff1000 ( 4 kB)
> [ 0.000000] fixmap : 0xfff00000 - 0xfffe0000 ( 896 kB)
> [ 0.000000] vmalloc : 0xd0800000 - 0xff000000 ( 744 MB)
> [ 0.000000] lowmem : 0xc0000000 - 0xd0000000 ( 256 MB)
> [ 0.000000] pkmap : 0xbfe00000 - 0xc0000000 ( 2 MB)
> [ 0.000000] modules : 0xbf000000 - 0xbfe00000 ( 14 MB)
> [ 0.000000] .text : 0xc0008000 - 0xc05cd3a0 (5909 kB)
> [ 0.000000] .init : 0xc05ce000 - 0xc061e580 ( 322 kB)
> [ 0.000000] .data : 0xc0620000 - 0xc06a6820 ( 539 kB)
> [ 0.000000] .bss : 0xc06a6820 - 0xc0bf4d6c (5434 kB)
> [ 0.000000] Hierarchical RCU implementation.
> [ 0.000000] RCU restricting CPUs from NR_CPUS=2 to nr_cpu_ids=1.
> [ 0.000000] NR_IRQS:16 nr_irqs:16 16
> [ 0.000000] IRQ: Found an INTC at 0xfa200000 (revision 5.0) with 128 interrupts
> [ 0.000000] Total of 128 interrupts on 1 active controller
> [ 0.000000] OMAP clockevent source: GPTIMER1 at 26000000 Hz
> [ 0.000000] sched_clock: 32 bits at 26MHz, resolution 38ns, wraps every 165191ms
> [ 0.000000] OMAP clocksource: GPTIMER2 at 26000000 Hz
> [ 0.000000] Console: colour dummy device 80x30
> [ 0.000000] Lock dependency validator: Copyright (c) 2006 Red Hat, Inc., Ingo Molnar
> [ 0.000000] ... MAX_LOCKDEP_SUBCLASSES: 8
> [ 0.000000] ... MAX_LOCK_DEPTH: 48
> [ 0.000000] ... MAX_LOCKDEP_KEYS: 8191
> [ 0.000000] ... CLASSHASH_SIZE: 4096
> [ 0.000000] ... MAX_LOCKDEP_ENTRIES: 16384
> [ 0.000000] ... MAX_LOCKDEP_CHAINS: 32768
> [ 0.000000] ... CHAINHASH_SIZE: 16384
> [ 0.000000] memory used by lock dependency info: 3695 kB
> [ 0.000000] per task-struct memory footprint: 1152 bytes
> [ 0.001032] Calibrating delay loop... 476.77 BogoMIPS (lpj=2383872)
> [ 0.109736] pid_max: default: 32768 minimum: 301
> [ 0.110266] Security Framework initialized
> [ 0.110426] Mount-cache hash table entries: 512
> [ 0.121717] CPU: Testing write buffer coherency: ok
> [ 0.123210] CPU0: thread -1, cpu 0, socket -1, mpidr 0
> [ 0.123295] Setting up static identity map for 0xc041e950 - 0xc041e9c0
> [ 0.126044] Brought up 1 CPUs
> [ 0.126069] SMP: Total of 1 processors activated (476.77 BogoMIPS).
> [ 0.126081] CPU: All CPU(s) started in SVC mode.
> [ 0.129080] devtmpfs: initialized
> [ 0.200411] pinctrl core: initialized pinctrl subsystem
> [ 0.206461] regulator-dummy: no parameters
> [ 0.209043] NET: Registered protocol family 16
> [ 0.209939] DMA: preallocated 256 KiB pool for atomic coherent allocations
> [ 0.233770] OMAP GPIO hardware version 0.1
> [ 0.263351] omap-gpmc 50000000.gpmc: GPMC revision 6.0
> [ 0.265960] No ATAGs?
> [ 0.265988] hw-breakpoint: debug architecture 0x4 unsupported.
> [ 0.311687] bio: create slab <bio-0> at 0
> [ 0.398050] omap-dma-engine omap-dma-engine: OMAP DMA engine driver
> [ 0.405918] usbcore: registered new interface driver usbfs
> [ 0.406470] usbcore: registered new interface driver hub
> [ 0.407327] usbcore: registered new device driver usb
> [ 0.409003] omap_i2c 44e0b000.i2c: did not get pins for i2c error: -19
> [ 0.411618] omap_i2c 44e0b000.i2c: bus 0 rev0.11 at 400 kHz
> [ 0.413344] mcp230xx: probe of 0-0020 failed with error -22
> [ 0.419117] DCDC1: at 1800 mV
> [ 0.422543] vdd_mpu: 925 <--> 1325 mV at 3300 mV
> [ 0.424721] vdd_core: 925 <--> 1150 mV at 1100 mV
> [ 0.426984] LDO1: at 1800 mV
> [ 0.429065] LDO2: at 3300 mV
> [ 0.431676] LDO3: at 3300 mV
> [ 0.433749] LDO4: at 2800 mV
> [ 0.435554] tps65217 0-0024: TPS65217 ID 0x7 version 1.1
> [ 0.446197] Switching to clocksource gp_timer
> [ 0.560007] NET: Registered protocol family 2
> [ 0.562070] TCP established hash table entries: 2048 (order: 2, 16384 bytes)
> [ 0.562292] TCP bind hash table entries: 2048 (order: 4, 73728 bytes)
> [ 0.563243] TCP: Hash tables configured (established 2048 bind 2048)
> [ 0.563476] TCP: reno registered
> [ 0.563510] UDP hash table entries: 256 (order: 2, 20480 bytes)
> [ 0.563775] UDP-Lite hash table entries: 256 (order: 2, 20480 bytes)
> [ 0.564666] NET: Registered protocol family 1
> [ 0.565819] NetWinder Floating Point Emulator V0.97 (double precision)
> [ 0.566339] CPU PMU: probing PMU on CPU 0
> [ 0.566373] hw perfevents: enabled with ARMv7 Cortex-A8 PMU driver, 5 counters available
> [ 0.710679] jffs2: version 2.2. (NAND) (SUMMARY) Â 2001-2006 Red Hat, Inc.
> [ 0.711291] msgmni has been set to 481
> [ 0.714998] io scheduler noop registered
> [ 0.715027] io scheduler deadline registered
> [ 0.715110] io scheduler cfq registered (default)
> [ 0.716538] pinctrl-single 44e10800.pinmux: 142 pins at pa f9e10800 size 568
> [ 0.721523] Serial: 8250/16550 driver, 4 ports, IRQ sharing enabled
> [ 0.728884] omap_uart 44e09000.serial: did not get pins for uart0 error: -19
> [ 0.729525] 44e09000.serial: ttyO0 at MMIO 0x44e09000 (irq = 88) is a OMAP UART0
> [ 1.319153] console [ttyO0] enabled
> [ 1.325110] omap_uart 48022000.serial: did not get pins for uart1 error: -19
> [ 1.333400] 48022000.serial: ttyO1 at MMIO 0x48022000 (irq = 89) is a OMAP UART1
> [ 1.343363] omap_uart 48024000.serial: did not get pins for uart2 error: -19
> [ 1.351285] 48024000.serial: ttyO2 at MMIO 0x48024000 (irq = 90) is a OMAP UART2
> [ 1.360714] omap_uart 481a6000.serial: did not get pins for uart3 error: -19
> [ 1.368752] 481a6000.serial: ttyO3 at MMIO 0x481a6000 (irq = 60) is a OMAP UART3
> [ 1.378159] omap_uart 481a8000.serial: did not get pins for uart4 error: -19
> [ 1.385862] 481a8000.serial: ttyO4 at MMIO 0x481a8000 (irq = 61) is a OMAP UART4
> [ 1.395315] omap_uart 481aa000.serial: did not get pins for uart5 error: -19
> [ 1.403172] 481aa000.serial: ttyO5 at MMIO 0x481aa000 (irq = 62) is a OMAP UART5
> [ 1.446256] brd: module loaded
> [ 1.471131] loop: module loaded
> [ 1.478556] mtdoops: mtd device (mtddev=name/number) must be supplied
> [ 1.487714] Generic platform RAM MTD, (c) 2004 Simtec Electronics
> [ 1.496006] enabling NAND BCH ecc with 8-bit correction
> [ 1.502018] ONFI param page 0 valid
> [ 1.505695] ONFI flash detected
> [ 1.509090] NAND device: Manufacturer ID: 0x2c, Chip ID: 0xda (Micron MT29F2G08ABAEAWP), 256MiB, page size: 2048, OOB size: 64
> [ 1.521348] 8 ofpart partitions found on MTD device omap2-nand.0
> [ 1.527717] Creating 8 MTD partitions on "omap2-nand.0":
> [ 1.533316] 0x000000000000-0x000000020000 : "spl1"
> [ 1.545257] 0x000000020000-0x000000040000 : "spl2"
> [ 1.555022] 0x000000040000-0x000000060000 : "spl3"
> [ 1.564408] 0x000000060000-0x000000080000 : "spl4"
> [ 1.573946] 0x000000080000-0x0000001e0000 : "boot"
> [ 1.584828] 0x0000001e0000-0x000000200000 : "env"
> [ 1.594707] 0x000000200000-0x000004200000 : "rootfs"
> [ 1.659562] 0x000004200000-0x000010000000 : "data"
> [ 1.839654] usbcore: registered new interface driver asix
> [ 1.845828] usbcore: registered new interface driver cdc_ether
> [ 1.852728] usbcore: registered new interface driver smsc95xx
> [ 1.859890] usbcore: registered new interface driver net1080
> [ 1.866332] usbcore: registered new interface driver cdc_subset
> [ 1.873194] usbcore: registered new interface driver zaurus
> [ 1.879727] usbcore: registered new interface driver cdc_ncm
> [ 1.888250] usbcore: registered new interface driver cdc_wdm
> [ 1.894777] usbcore: registered new interface driver usbtest
> [ 1.904123] rtc-ds1307 0-0068: rtc core: registered ds1307 as rtc0
> [ 1.910851] rtc-ds1307 0-0068: 56 bytes nvram
> [ 1.916215] i2c /dev entries driver
> [ 1.925777] omap_wdt: OMAP Watchdog Timer Rev 0x01: initial timeout 60 sec
> [ 1.934797] omap_cpufreq_init: unable to get MPU regulator
> [ 1.944756] usbcore: registered new interface driver usbhid
> [ 1.950806] usbhid: USB HID core driver
> [ 1.956489] oprofile: using arm/armv7
> [ 1.961449] TCP: cubic registered
> [ 1.964949] Initializing XFRM netlink socket
> [ 1.969694] NET: Registered protocol family 17
> [ 1.974613] NET: Registered protocol family 15
> [ 1.979855] Key type dns_resolver registered
> [ 1.984457] VFP support v0.3: implementor 41 architecture 3 part 30 variant c rev 3
> [ 1.992657] ThumbEE CPU extension supported.
> [ 2.066693] davinci_mdio 4a101000.mdio: davinci mdio revision 1.6
> [ 2.073130] davinci_mdio 4a101000.mdio: detected phy mask fffffffc
> [ 2.084362] libphy: 4a101000.mdio: probed
> [ 2.088760] davinci_mdio 4a101000.mdio: phy[0]: device 4a101000.mdio:00, driver SMSC LAN8710/LAN8720
> [ 2.098421] davinci_mdio 4a101000.mdio: phy[1]: device 4a101000.mdio:01, driver SMSC LAN8710/LAN8720
> [ 2.108516] Random MACID = fa:91:6f:36:0e:b0
> [ 2.118076] rtc-ds1307 0-0068: setting system clock to 2013-01-21 20:34:58 UTC (1358800498)
> [ 2.652964] jffs2: mtd->read(0x1fc54 bytes from 0x3a03ac) returned ECC error
> [ 2.676730] jffs2: mtd->read(0x1e260 bytes from 0x3a1da0) returned ECC error
> [ 2.684150] jffs2: Empty flash at 0x003a1d9c ends at 0x003a2000
> [ 3.161187] jffs2: notice: (1) jffs2_build_xattr_subsystem: complete building xattr subsystem, 0 of xdatum (0 unchecked, 0 orphan) and 0 of xref (0 dead, 0 orphan) found.
> [ 3.179148] VFS: Mounted root (jffs2 filesystem) readonly on device 31:6.
> [ 3.188034] devtmpfs: mounted
> [ 3.191762] Freeing init memory: 320K
> [ 3.606040]
> [ 3.607646] ======================================================
> [ 3.614138] [ INFO: possible circular locking dependency detected ]
> [ 3.620728] 3.8.0-next-20130226-dirty #12 Not tainted
> [ 3.626033] -------------------------------------------------------
> [ 3.632615] rcS/631 is trying to acquire lock:
> [ 3.637283] (&mm->mmap_sem){++++++}, at: [<c00f0af4>] might_fault+0x3c/0x90
> [ 3.644741]
> [ 3.644741] but task is already holding lock:
> [ 3.650867] (&f->sem){+.+.+.}, at: [<c01a278c>] jffs2_readdir+0x44/0x1a8
> [ 3.658040]
> [ 3.658040] which lock already depends on the new lock.
> [ 3.658040]
> [ 3.666633]
> [ 3.666633] the existing dependency chain (in reverse order) is:
> [ 3.674496]
> -> #1 (&f->sem){+.+.+.}:
> [ 3.678463] [<c0092df0>] lock_acquire+0x9c/0x104
> [ 3.683975] [<c0416c04>] mutex_lock_nested+0x3c/0x334
> [ 3.689941] [<c01a2fb4>] jffs2_readpage+0x20/0x44
> [ 3.695530] [<c00d9d38>] __do_page_cache_readahead+0x2a0/0x2cc
> [ 3.702313] [<c00da004>] ra_submit+0x28/0x30
> [ 3.707446] [<c00d179c>] filemap_fault+0x304/0x458
> [ 3.713138] [<c00f0c58>] __do_fault+0x6c/0x490
> [ 3.718454] [<c00f3c5c>] handle_pte_fault+0xb0/0x6f0
> [ 3.724316] [<c00f433c>] handle_mm_fault+0xa0/0xd4
> [ 3.729994] [<c041b30c>] do_page_fault+0x2a0/0x3d4
> [ 3.735679] [<c000845c>] do_DataAbort+0x30/0x9c
> [ 3.741085] [<c04197e4>] __dabt_svc+0x44/0x80
> [ 3.746309] [<c0222b98>] __clear_user_std+0x1c/0x64
> [ 3.752089]
> -> #0 (&mm->mmap_sem){++++++}:
> [ 3.756599] [<c00927ec>] __lock_acquire+0x1d70/0x1de0
> [ 3.762554] [<c0092df0>] lock_acquire+0x9c/0x104
> [ 3.768051] [<c00f0b18>] might_fault+0x60/0x90
> [ 3.773364] [<c011bc3c>] filldir+0x5c/0x158
> [ 3.778416] [<c01a2824>] jffs2_readdir+0xdc/0x1a8
> [ 3.784005] [<c011becc>] vfs_readdir+0x98/0xb4
> [ 3.789319] [<c011bfcc>] sys_getdents+0x74/0xd0
> [ 3.794724] [<c0013820>] ret_fast_syscall+0x0/0x3c
> [ 3.800416]
> [ 3.800416] other info that might help us debug this:
> [ 3.800416]
> [ 3.808824] Possible unsafe locking scenario:
> [ 3.808824]
> [ 3.815041] CPU0 CPU1
> [ 3.819797] ---- ----
> [ 3.824550] lock(&f->sem);
> [ 3.827587] lock(&mm->mmap_sem);
> [ 3.833815] lock(&f->sem);
> [ 3.839496] lock(&mm->mmap_sem);
> [ 3.843079]
> [ 3.843079] *** DEADLOCK ***
> [ 3.843079]
> [ 3.849302] 2 locks held by rcS/631:
> [ 3.853055] #0: (&type->i_mutex_dir_key){+.+.+.}, at: [<c011be90>] vfs_readdir+0x5c/0xb4
> [ 3.861778] #1: (&f->sem){+.+.+.}, at: [<c01a278c>] jffs2_readdir+0x44/0x1a8
> [ 3.869404]
> [ 3.869404] stack backtrace:
> [ 3.874009] [<c001b158>] (unwind_backtrace+0x0/0xf0) from [<c008f29c>] (print_circular_bug+0x1d0/0x2dc)
> [ 3.883888] [<c008f29c>] (print_circular_bug+0x1d0/0x2dc) from [<c00927ec>] (__lock_acquire+0x1d70/0x1de0)
> [ 3.894040] [<c00927ec>] (__lock_acquire+0x1d70/0x1de0) from [<c0092df0>] (lock_acquire+0x9c/0x104)
> [ 3.903553] [<c0092df0>] (lock_acquire+0x9c/0x104) from [<c00f0b18>] (might_fault+0x60/0x90)
> [ 3.912427] [<c00f0b18>] (might_fault+0x60/0x90) from [<c011bc3c>] (filldir+0x5c/0x158)
> [ 3.920844] [<c011bc3c>] (filldir+0x5c/0x158) from [<c01a2824>] (jffs2_readdir+0xdc/0x1a8)
> [ 3.929533] [<c01a2824>] (jffs2_readdir+0xdc/0x1a8) from [<c011becc>] (vfs_readdir+0x98/0xb4)
> [ 3.938500] [<c011becc>] (vfs_readdir+0x98/0xb4) from [<c011bfcc>] (sys_getdents+0x74/0xd0)
> [ 3.947285] [<c011bfcc>] (sys_getdents+0x74/0xd0) from [<c0013820>] (ret_fast_syscall+0x0/0x3c)
> Starting logging: OK
> Initializing random number generator... [ 3.997350] jffs2: mtd->read(0x778 bytes from 0x3a3888) returned ECC error
> [ 4.021216] jffs2: mtd->read(0x7bc bytes from 0x3a3844) returned ECC error
> [ 4.043965] jffs2: mtd->read(0x800 bytes from 0x3a3800) returned ECC error
> [ 4.059373] jffs2: mtd->read(0x44 bytes from 0x3a3888) returned ECC error
> [ 4.075443] jffs2: mtd->read(0x44 bytes from 0x3a3888) returned ECC error
> [ 4.083554] jffs2: mtd->read(0x200 bytes from 0x3a38cc) returned ECC error
> read-only file system detected...done
> Starting network...
> Starting dropbear sshd: mkdir: can't create directory '/etc/dropbear': Read-only file system
> generating rsa key... generating dsa key... OK
> Starting lighttpd: OK
>
> Welcome to Buildroot
> beaglebone login:
--
Cheers,
Stephen Rothwell sfr@xxxxxxxxxxxxxxxx
http://www.canb.auug.org.au/~sfr/
Attachment:
pgp00000.pgp
Description: PGP signature