summaryrefslogtreecommitdiffstats
path: root/fs/btrfs/disk-io.c
diff options
context:
space:
mode:
authorJosef Bacik <jbacik@redhat.com>2008-12-02 06:36:10 -0500
committerChris Mason <chris.mason@oracle.com>2008-12-02 06:36:10 -0500
commitc6e2bac1a52ffc36dd10769b594dfa3994e95f77 (patch)
treea48c535515c0d9311fa770afd0696644489cf074 /fs/btrfs/disk-io.c
parentf2b636e80d8206dd4012de6e973c2367259a7d22 (diff)
downloadlinux-c6e2bac1a52ffc36dd10769b594dfa3994e95f77.tar.gz
linux-c6e2bac1a52ffc36dd10769b594dfa3994e95f77.tar.bz2
linux-c6e2bac1a52ffc36dd10769b594dfa3994e95f77.zip
Btrfs: fix panic on error during mount
This needs to be applied on top of my previous patches, but is needed for more than just my new stuff. We're going to the wrong label when we have an error, we try to stop the workers, but they are started below all of this code. This fixes it so we go to the right error label and not panic when we fail one of these cases. Signed-off-by: Josef Bacik <jbacik@redhat.com>
Diffstat (limited to 'fs/btrfs/disk-io.c')
-rw-r--r--fs/btrfs/disk-io.c8
1 files changed, 4 insertions, 4 deletions
diff --git a/fs/btrfs/disk-io.c b/fs/btrfs/disk-io.c
index 6ae9bdf98b68..dfd5ba05ce45 100644
--- a/fs/btrfs/disk-io.c
+++ b/fs/btrfs/disk-io.c
@@ -1579,12 +1579,12 @@ struct btrfs_root *open_ctree(struct super_block *sb,
disk_super = &fs_info->super_copy;
if (!btrfs_super_root(disk_super))
- goto fail_sb_buffer;
+ goto fail_iput;
ret = btrfs_parse_options(tree_root, options);
if (ret) {
err = ret;
- goto fail_sb_buffer;
+ goto fail_iput;
}
features = btrfs_super_incompat_flags(disk_super) &
@@ -1594,7 +1594,7 @@ struct btrfs_root *open_ctree(struct super_block *sb,
"unsupported optional features (%Lx).\n",
features);
err = -EINVAL;
- goto fail_sb_buffer;
+ goto fail_iput;
}
features = btrfs_super_compat_ro_flags(disk_super) &
@@ -1604,7 +1604,7 @@ struct btrfs_root *open_ctree(struct super_block *sb,
"unsupported option features (%Lx).\n",
features);
err = -EINVAL;
- goto fail_sb_buffer;
+ goto fail_iput;
}
/*