diff options
author | Anand Jain <anand.jain@oracle.com> | 2013-12-02 14:11:54 +0800 |
---|---|---|
committer | Chris Mason <clm@fb.com> | 2014-01-31 08:22:10 -0800 |
commit | b94a3003aebe235171383ced624da10b2a2fa94b (patch) | |
tree | 9490f8d52b629b29371198a3c1da2f3f8534aafb /cmds-check.c | |
parent | 4956a16711ba0029857f7d69899b778556b152d2 (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.c | 6 |
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); |