Sebastian
2013-Jun-22 03:15 UTC
[Bug] btrfs-image from power failure, Transaction aborted (error -22), btrfsck fails
hi, i''m using Btrfs as a root partition. an hour ago i had a power failure and the root btrfs would only mount ro. find below links to the relevant btrfs-image, dmesg and kernel config. used kernel when power failed: 3.9.0-1-desktop (from openSuse) however following output from kernel: 3.10-rc4 (vanilla from kernel.org, config see below) btrfs mkfs was: mkfs.brtfs -d raid1 -m raid1 /dev/sda7 /dev/sdb1 mounting with recovery didn''t help. btrfsck failed, too (standard from opensuse and dangerdonteveruse). it outputted (forgot to write down the numbers, sorry): > warning, start mismatch %uul %uul > Aborted. i had a quick look into the source code (branch dangerdonteveruse) and found the Abort came from: > static int add_data_backref > (...) > if (rec->start != bytenr) > abort(); since my backup was just 3h old, for the heck of it i also tried btrfs-zero-log and btrfs-select-super without success. both even reported "failed to open_ctree" links (config, btrfs-image, dmesg) http://www.ifyouwantblood.de/temp/btrfs-2013-06-22-config http://www.ifyouwantblood.de/temp/btrfs-2013-06-22-sdb1 http://www.ifyouwantblood.de/temp/btrfs-2013-06-22-dmesg 3.9.0-1-desktop http://kernel.opensuse.org/cgit/kernel-source/commit/?id=97c14baeec524b749710c3a0dd18f9223ea55933 the relevant messages, i believe, are: ------------------------------------------------------------- BTRFS error (device sda7): unable to find ref byte nr 2249924608 parent 0 root 261 owner 13065 offset 5525504 BTRFS error (device sda7): trying to drop 3 refs but we only have 1 for bytenr 2249924608 BTRFS error (device sda7) in __btrfs_free_extent:5566: errno=-22 unknown BTRFS info (device sda7): forced readonly BTRFS debug (device sda7): run_one_delayed_ref returned -22 BTRFS error (device sda7) in btrfs_run_delayed_refs:2630: errno=-22 unknown BTRFS error (device sda7): Error removing orphan entry, stopping orphan cleanup BTRFS critical (device sda7): could not do orphan cleanup -22 ------------[ cut here ]------------ ------------------------------------------------------------- (see links above for full dmesg) -- MFG Sebastian -- To unsubscribe from this list: send the line "unsubscribe linux-btrfs" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html