Btrfs: Fix a few functions that exit without stopping their transaction
Signed-off-by: Chris Mason <chris.mason@oracle.com>
This commit is contained in:
parent
7b12876623
commit
8e8a1e31f2
@ -3275,8 +3275,10 @@ next:
|
|||||||
ret = btrfs_search_slot(trans, root, &key, path, -1, 1);
|
ret = btrfs_search_slot(trans, root, &key, path, -1, 1);
|
||||||
if (ret > 0)
|
if (ret > 0)
|
||||||
ret = -EIO;
|
ret = -EIO;
|
||||||
if (ret < 0)
|
if (ret < 0) {
|
||||||
|
btrfs_end_transaction(trans, root);
|
||||||
goto out;
|
goto out;
|
||||||
|
}
|
||||||
|
|
||||||
clear_extent_bits(&info->block_group_cache, key.objectid,
|
clear_extent_bits(&info->block_group_cache, key.objectid,
|
||||||
key.objectid + key.offset - 1,
|
key.objectid + key.offset - 1,
|
||||||
|
@ -78,8 +78,10 @@ static noinline int create_subvol(struct btrfs_root *root, char *name,
|
|||||||
leaf = btrfs_alloc_free_block(trans, root, root->leafsize,
|
leaf = btrfs_alloc_free_block(trans, root, root->leafsize,
|
||||||
objectid, trans->transid, 0, 0,
|
objectid, trans->transid, 0, 0,
|
||||||
0, 0);
|
0, 0);
|
||||||
if (IS_ERR(leaf))
|
if (IS_ERR(leaf)) {
|
||||||
return PTR_ERR(leaf);
|
ret = PTR_ERR(leaf);
|
||||||
|
goto fail;
|
||||||
|
}
|
||||||
|
|
||||||
btrfs_set_header_nritems(leaf, 0);
|
btrfs_set_header_nritems(leaf, 0);
|
||||||
btrfs_set_header_level(leaf, 0);
|
btrfs_set_header_level(leaf, 0);
|
||||||
|
Loading…
Reference in New Issue
Block a user