aboutsummaryrefslogtreecommitdiffstats
path: root/fs
diff options
context:
space:
mode:
authorStefan Behrens <sbehrens@giantdisaster.de>2013-08-23 04:34:42 -0400
committerChris Mason <chris.mason@fusionio.com>2013-09-01 08:16:29 -0400
commit48475471728f060bfd2e686f592ef208d3ba8b7d (patch)
treed37a3d7661cb2c5a81e8acd2c81580a102554e68 /fs
parent9d565ba4330db102127f19d159609df5c3a375d8 (diff)
Btrfs: fix for patch "cleanup: don't check the same thing twice"
Mitch Harder noticed that the patch 3c64a1a mentioned in the subject line was causing a kernel BUG() on snapshot deletion. The patch was wrong. It did not handle cached roots correctly. The check for root_refs == 0 was removed everywhere where btrfs_read_fs_root_no_name() had been used to retrieve the root, because this check was already dealt with in btrfs_read_fs_root_no_name(). But in the case when the root was found in the cache, there was no such check. This patch adds the missing check in the case where the root is found in the cache. Reported-by: Mitch Harder <mitch.harder@sabayonlinux.org> Signed-off-by: Stefan Behrens <sbehrens@giantdisaster.de> Reviewed-by: Miao Xie <miaox@cn.fujitsu.com> Signed-off-by: Josef Bacik <jbacik@fusionio.com> Signed-off-by: Chris Mason <chris.mason@fusionio.com>
Diffstat (limited to 'fs')
-rw-r--r--fs/btrfs/disk-io.c5
1 files changed, 4 insertions, 1 deletions
diff --git a/fs/btrfs/disk-io.c b/fs/btrfs/disk-io.c
index 0f75a01f69e2..21d1d066758e 100644
--- a/fs/btrfs/disk-io.c
+++ b/fs/btrfs/disk-io.c
@@ -1584,8 +1584,11 @@ struct btrfs_root *btrfs_read_fs_root_no_name(struct btrfs_fs_info *fs_info,
1584 ERR_PTR(-ENOENT); 1584 ERR_PTR(-ENOENT);
1585again: 1585again:
1586 root = btrfs_lookup_fs_root(fs_info, location->objectid); 1586 root = btrfs_lookup_fs_root(fs_info, location->objectid);
1587 if (root) 1587 if (root) {
1588 if (btrfs_root_refs(&root->root_item) == 0)
1589 return ERR_PTR(-ENOENT);
1588 return root; 1590 return root;
1591 }
1589 1592
1590 root = btrfs_read_fs_root(fs_info->tree_root, location); 1593 root = btrfs_read_fs_root(fs_info->tree_root, location);
1591 if (IS_ERR(root)) 1594 if (IS_ERR(root))