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);
|
||||
if (ret > 0)
|
||||
ret = -EIO;
|
||||
if (ret < 0)
|
||||
if (ret < 0) {
|
||||
btrfs_end_transaction(trans, root);
|
||||
goto out;
|
||||
}
|
||||
|
||||
clear_extent_bits(&info->block_group_cache, key.objectid,
|
||||
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,
|
||||
objectid, trans->transid, 0, 0,
|
||||
0, 0);
|
||||
if (IS_ERR(leaf))
|
||||
return PTR_ERR(leaf);
|
||||
if (IS_ERR(leaf)) {
|
||||
ret = PTR_ERR(leaf);
|
||||
goto fail;
|
||||
}
|
||||
|
||||
btrfs_set_header_nritems(leaf, 0);
|
||||
btrfs_set_header_level(leaf, 0);
|
||||
|
Loading…
Reference in New Issue
Block a user