btrfs: reset fs_root to NULL on error in open_ctree
While running my error injection script I hit a panic when we tried to clean up the fs_root when freeing the fs_root. This is because fs_info->fs_root == PTR_ERR(-EIO), which isn't great. Fix this by setting fs_info->fs_root = NULL; if we fail to read the root. CC: stable@vger.kernel.org # 4.4+ Reviewed-by: Nikolay Borisov <nborisov@suse.com> Reviewed-by: Johannes Thumshirn <johannes.thumshirn@wdc.com> Reviewed-by: Qu Wenruo <wqu@suse.com> Signed-off-by: Josef Bacik <josef@toxicpanda.com> Reviewed-by: David Sterba <dsterba@suse.com> Signed-off-by: David Sterba <dsterba@suse.com>
This commit is contained in:
parent
81f7eb00ff
commit
315bf8ef91
|
@ -3200,6 +3200,7 @@ int __cold open_ctree(struct super_block *sb,
|
||||||
if (IS_ERR(fs_info->fs_root)) {
|
if (IS_ERR(fs_info->fs_root)) {
|
||||||
err = PTR_ERR(fs_info->fs_root);
|
err = PTR_ERR(fs_info->fs_root);
|
||||||
btrfs_warn(fs_info, "failed to read fs tree: %d", err);
|
btrfs_warn(fs_info, "failed to read fs tree: %d", err);
|
||||||
|
fs_info->fs_root = NULL;
|
||||||
goto fail_qgroup;
|
goto fail_qgroup;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue