summaryrefslogtreecommitdiff
path: root/cmds-check.c
diff options
context:
space:
mode:
authorAnand Jain <anand.jain@oracle.com>2013-12-02 14:11:54 +0800
committerChris Mason <clm@fb.com>2014-01-31 08:22:10 -0800
commitb94a3003aebe235171383ced624da10b2a2fa94b (patch)
tree9490f8d52b629b29371198a3c1da2f3f8534aafb /cmds-check.c
parent4956a16711ba0029857f7d69899b778556b152d2 (diff)
btrfs-progs: fix backref after init-csum-tree
btrfsck reports backref error after running init-csum-tree btrfsck --init-csum-tree /dev/sdc btrfsck /dev/sdc :: ref mismatch on [29474816 16384] extent item 1, found 0 Backref 29474816 root 7 not referenced back 0x1101d30 Incorrect global backref count on 29474816 found 1 wanted 0 backpointer mismatch on [29474816 16384] owner ref check failed [29474816 16384] Errors found in extent allocation tree or chunk allocation :: Signed-off-by: Anand Jain <anand.jain@oracle.com> Signed-off-by: David Sterba <dsterba@suse.cz> Signed-off-by: Chris Mason <clm@fb.com>
Diffstat (limited to 'cmds-check.c')
-rw-r--r--cmds-check.c6
1 files changed, 6 insertions, 0 deletions
diff --git a/cmds-check.c b/cmds-check.c
index c15d8d03..e7d4edfc 100644
--- a/cmds-check.c
+++ b/cmds-check.c
@@ -6159,6 +6159,7 @@ int cmd_check(int argc, char **argv)
} else if (option_index == 2) {
printf("Creating a new CRC tree\n");
init_csum_tree = 1;
+ repair = 1;
ctree_flags |= OPEN_CTREE_WRITES;
} else if (option_index == 3) {
init_extent_tree = 1;
@@ -6232,6 +6233,11 @@ int cmd_check(int argc, char **argv)
ret = btrfs_commit_transaction(trans, info->csum_root);
if (ret)
exit(1);
+
+ ret = check_chunks_and_extents(root);
+ if (ret)
+ fprintf(stderr,
+ "Errors found in extent allocation tree or chunk allocation\n");
goto out;
}
ret = check_chunks_and_extents(root);