btrfs: btrfs_abort_transaction, drop root parameter
__btrfs_abort_transaction doesn't use its root parameter except to obtain an fs_info pointer. We can obtain that from trans->root->fs_info for now and from trans->fs_info in a later patch. Signed-off-by: Jeff Mahoney <jeffm@suse.com> Signed-off-by: David Sterba <dsterba@suse.com>
This commit is contained in:
parent
64b6358072
commit
66642832f0
|
@ -1153,14 +1153,14 @@ static noinline int __btrfs_cow_block(struct btrfs_trans_handle *trans,
|
||||||
|
|
||||||
ret = update_ref_for_cow(trans, root, buf, cow, &last_ref);
|
ret = update_ref_for_cow(trans, root, buf, cow, &last_ref);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (test_bit(BTRFS_ROOT_REF_COWS, &root->state)) {
|
if (test_bit(BTRFS_ROOT_REF_COWS, &root->state)) {
|
||||||
ret = btrfs_reloc_cow_block(trans, root, buf, cow);
|
ret = btrfs_reloc_cow_block(trans, root, buf, cow);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1198,7 +1198,7 @@ static noinline int __btrfs_cow_block(struct btrfs_trans_handle *trans,
|
||||||
if (last_ref) {
|
if (last_ref) {
|
||||||
ret = tree_mod_log_free_eb(root->fs_info, buf);
|
ret = tree_mod_log_free_eb(root->fs_info, buf);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -3255,7 +3255,7 @@ static int push_node_left(struct btrfs_trans_handle *trans,
|
||||||
ret = tree_mod_log_eb_copy(root->fs_info, dst, src, dst_nritems, 0,
|
ret = tree_mod_log_eb_copy(root->fs_info, dst, src, dst_nritems, 0,
|
||||||
push_items);
|
push_items);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
copy_extent_buffer(dst, src,
|
copy_extent_buffer(dst, src,
|
||||||
|
@ -3330,7 +3330,7 @@ static int balance_node_right(struct btrfs_trans_handle *trans,
|
||||||
ret = tree_mod_log_eb_copy(root->fs_info, dst, src, 0,
|
ret = tree_mod_log_eb_copy(root->fs_info, dst, src, 0,
|
||||||
src_nritems - push_items, push_items);
|
src_nritems - push_items, push_items);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
copy_extent_buffer(dst, src,
|
copy_extent_buffer(dst, src,
|
||||||
|
@ -3534,7 +3534,7 @@ static noinline int split_node(struct btrfs_trans_handle *trans,
|
||||||
ret = tree_mod_log_eb_copy(root->fs_info, split, c, 0,
|
ret = tree_mod_log_eb_copy(root->fs_info, split, c, 0,
|
||||||
mid, c_nritems - mid);
|
mid, c_nritems - mid);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
copy_extent_buffer(split, c,
|
copy_extent_buffer(split, c,
|
||||||
|
|
|
@ -3379,23 +3379,23 @@ const char *btrfs_decode_error(int errno);
|
||||||
|
|
||||||
__cold
|
__cold
|
||||||
void __btrfs_abort_transaction(struct btrfs_trans_handle *trans,
|
void __btrfs_abort_transaction(struct btrfs_trans_handle *trans,
|
||||||
struct btrfs_root *root, const char *function,
|
const char *function,
|
||||||
unsigned int line, int errno);
|
unsigned int line, int errno);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Call btrfs_abort_transaction as early as possible when an error condition is
|
* Call btrfs_abort_transaction as early as possible when an error condition is
|
||||||
* detected, that way the exact line number is reported.
|
* detected, that way the exact line number is reported.
|
||||||
*/
|
*/
|
||||||
#define btrfs_abort_transaction(trans, root, errno) \
|
#define btrfs_abort_transaction(trans, errno) \
|
||||||
do { \
|
do { \
|
||||||
/* Report first abort since mount */ \
|
/* Report first abort since mount */ \
|
||||||
if (!test_and_set_bit(BTRFS_FS_STATE_TRANS_ABORTED, \
|
if (!test_and_set_bit(BTRFS_FS_STATE_TRANS_ABORTED, \
|
||||||
&((root)->fs_info->fs_state))) { \
|
&((trans)->fs_info->fs_state))) { \
|
||||||
WARN(1, KERN_DEBUG \
|
WARN(1, KERN_DEBUG \
|
||||||
"BTRFS: Transaction aborted (error %d)\n", \
|
"BTRFS: Transaction aborted (error %d)\n", \
|
||||||
(errno)); \
|
(errno)); \
|
||||||
} \
|
} \
|
||||||
__btrfs_abort_transaction((trans), (root), __func__, \
|
__btrfs_abort_transaction((trans), __func__, \
|
||||||
__LINE__, (errno)); \
|
__LINE__, (errno)); \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
|
|
|
@ -1170,7 +1170,7 @@ static int __btrfs_run_delayed_items(struct btrfs_trans_handle *trans,
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_release_delayed_node(curr_node);
|
btrfs_release_delayed_node(curr_node);
|
||||||
curr_node = NULL;
|
curr_node = NULL;
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -2180,7 +2180,7 @@ static int __btrfs_inc_extent_ref(struct btrfs_trans_handle *trans,
|
||||||
path, bytenr, parent, root_objectid,
|
path, bytenr, parent, root_objectid,
|
||||||
owner, offset, refs_to_add);
|
owner, offset, refs_to_add);
|
||||||
if (ret)
|
if (ret)
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
out:
|
out:
|
||||||
btrfs_free_path(path);
|
btrfs_free_path(path);
|
||||||
return ret;
|
return ret;
|
||||||
|
@ -2971,7 +2971,7 @@ again:
|
||||||
trans->can_flush_pending_bgs = false;
|
trans->can_flush_pending_bgs = false;
|
||||||
ret = __btrfs_run_delayed_refs(trans, root, count);
|
ret = __btrfs_run_delayed_refs(trans, root, count);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3430,7 +3430,7 @@ again:
|
||||||
* transaction, this only happens in really bad situations
|
* transaction, this only happens in really bad situations
|
||||||
* anyway.
|
* anyway.
|
||||||
*/
|
*/
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out_put;
|
goto out_put;
|
||||||
}
|
}
|
||||||
WARN_ON(ret);
|
WARN_ON(ret);
|
||||||
|
@ -3670,7 +3670,7 @@ again:
|
||||||
}
|
}
|
||||||
spin_unlock(&cur_trans->dirty_bgs_lock);
|
spin_unlock(&cur_trans->dirty_bgs_lock);
|
||||||
} else if (ret) {
|
} else if (ret) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3816,7 +3816,7 @@ int btrfs_write_dirty_block_groups(struct btrfs_trans_handle *trans,
|
||||||
cache);
|
cache);
|
||||||
}
|
}
|
||||||
if (ret)
|
if (ret)
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* if its not on the io list, we need to put the block group */
|
/* if its not on the io list, we need to put the block group */
|
||||||
|
@ -6881,7 +6881,7 @@ static int __btrfs_free_extent(struct btrfs_trans_handle *trans,
|
||||||
NULL, refs_to_drop,
|
NULL, refs_to_drop,
|
||||||
is_data, &last_ref);
|
is_data, &last_ref);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, extent_root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
btrfs_release_path(path);
|
btrfs_release_path(path);
|
||||||
|
@ -6930,7 +6930,7 @@ static int __btrfs_free_extent(struct btrfs_trans_handle *trans,
|
||||||
path->nodes[0]);
|
path->nodes[0]);
|
||||||
}
|
}
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
btrfs_abort_transaction(trans, extent_root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
extent_slot = path->slots[0];
|
extent_slot = path->slots[0];
|
||||||
|
@ -6941,10 +6941,10 @@ static int __btrfs_free_extent(struct btrfs_trans_handle *trans,
|
||||||
"unable to find ref byte nr %llu parent %llu root %llu owner %llu offset %llu",
|
"unable to find ref byte nr %llu parent %llu root %llu owner %llu offset %llu",
|
||||||
bytenr, parent, root_objectid, owner_objectid,
|
bytenr, parent, root_objectid, owner_objectid,
|
||||||
owner_offset);
|
owner_offset);
|
||||||
btrfs_abort_transaction(trans, extent_root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out;
|
goto out;
|
||||||
} else {
|
} else {
|
||||||
btrfs_abort_transaction(trans, extent_root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -6956,7 +6956,7 @@ static int __btrfs_free_extent(struct btrfs_trans_handle *trans,
|
||||||
ret = convert_extent_item_v0(trans, extent_root, path,
|
ret = convert_extent_item_v0(trans, extent_root, path,
|
||||||
owner_objectid, 0);
|
owner_objectid, 0);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
btrfs_abort_transaction(trans, extent_root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -6975,7 +6975,7 @@ static int __btrfs_free_extent(struct btrfs_trans_handle *trans,
|
||||||
btrfs_print_leaf(extent_root, path->nodes[0]);
|
btrfs_print_leaf(extent_root, path->nodes[0]);
|
||||||
}
|
}
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
btrfs_abort_transaction(trans, extent_root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -7000,7 +7000,7 @@ static int __btrfs_free_extent(struct btrfs_trans_handle *trans,
|
||||||
btrfs_err(info, "trying to drop %d refs but we only have %Lu "
|
btrfs_err(info, "trying to drop %d refs but we only have %Lu "
|
||||||
"for bytenr %Lu", refs_to_drop, refs, bytenr);
|
"for bytenr %Lu", refs_to_drop, refs, bytenr);
|
||||||
ret = -EINVAL;
|
ret = -EINVAL;
|
||||||
btrfs_abort_transaction(trans, extent_root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
refs -= refs_to_drop;
|
refs -= refs_to_drop;
|
||||||
|
@ -7023,7 +7023,7 @@ static int __btrfs_free_extent(struct btrfs_trans_handle *trans,
|
||||||
iref, refs_to_drop,
|
iref, refs_to_drop,
|
||||||
is_data, &last_ref);
|
is_data, &last_ref);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, extent_root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -7046,7 +7046,7 @@ static int __btrfs_free_extent(struct btrfs_trans_handle *trans,
|
||||||
ret = btrfs_del_items(trans, extent_root, path, path->slots[0],
|
ret = btrfs_del_items(trans, extent_root, path, path->slots[0],
|
||||||
num_to_del);
|
num_to_del);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, extent_root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
btrfs_release_path(path);
|
btrfs_release_path(path);
|
||||||
|
@ -7054,7 +7054,7 @@ static int __btrfs_free_extent(struct btrfs_trans_handle *trans,
|
||||||
if (is_data) {
|
if (is_data) {
|
||||||
ret = btrfs_del_csums(trans, root, bytenr, num_bytes);
|
ret = btrfs_del_csums(trans, root, bytenr, num_bytes);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, extent_root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -7062,13 +7062,13 @@ static int __btrfs_free_extent(struct btrfs_trans_handle *trans,
|
||||||
ret = add_to_free_space_tree(trans, root->fs_info, bytenr,
|
ret = add_to_free_space_tree(trans, root->fs_info, bytenr,
|
||||||
num_bytes);
|
num_bytes);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, extent_root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = update_block_group(trans, root, bytenr, num_bytes, 0);
|
ret = update_block_group(trans, root, bytenr, num_bytes, 0);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, extent_root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -7852,8 +7852,7 @@ loop:
|
||||||
* can do more things.
|
* can do more things.
|
||||||
*/
|
*/
|
||||||
if (ret < 0 && ret != -ENOSPC)
|
if (ret < 0 && ret != -ENOSPC)
|
||||||
btrfs_abort_transaction(trans,
|
btrfs_abort_transaction(trans, ret);
|
||||||
root, ret);
|
|
||||||
else
|
else
|
||||||
ret = 0;
|
ret = 0;
|
||||||
if (!exist)
|
if (!exist)
|
||||||
|
@ -9329,7 +9328,7 @@ int btrfs_drop_snapshot(struct btrfs_root *root,
|
||||||
&root->root_key,
|
&root->root_key,
|
||||||
root_item);
|
root_item);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, tree_root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
err = ret;
|
err = ret;
|
||||||
goto out_end_trans;
|
goto out_end_trans;
|
||||||
}
|
}
|
||||||
|
@ -9356,7 +9355,7 @@ int btrfs_drop_snapshot(struct btrfs_root *root,
|
||||||
|
|
||||||
ret = btrfs_del_root(trans, tree_root, &root->root_key);
|
ret = btrfs_del_root(trans, tree_root, &root->root_key);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, tree_root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out_end_trans;
|
goto out_end_trans;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -9364,7 +9363,7 @@ int btrfs_drop_snapshot(struct btrfs_root *root,
|
||||||
ret = btrfs_find_root(tree_root, &root->root_key, path,
|
ret = btrfs_find_root(tree_root, &root->root_key, path,
|
||||||
NULL, NULL);
|
NULL, NULL);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
btrfs_abort_transaction(trans, tree_root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
err = ret;
|
err = ret;
|
||||||
goto out_end_trans;
|
goto out_end_trans;
|
||||||
} else if (ret > 0) {
|
} else if (ret > 0) {
|
||||||
|
@ -10324,11 +10323,11 @@ void btrfs_create_pending_block_groups(struct btrfs_trans_handle *trans,
|
||||||
ret = btrfs_insert_item(trans, extent_root, &key, &item,
|
ret = btrfs_insert_item(trans, extent_root, &key, &item,
|
||||||
sizeof(item));
|
sizeof(item));
|
||||||
if (ret)
|
if (ret)
|
||||||
btrfs_abort_transaction(trans, extent_root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
ret = btrfs_finish_chunk_alloc(trans, extent_root,
|
ret = btrfs_finish_chunk_alloc(trans, extent_root,
|
||||||
key.objectid, key.offset);
|
key.objectid, key.offset);
|
||||||
if (ret)
|
if (ret)
|
||||||
btrfs_abort_transaction(trans, extent_root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
add_block_group_free_space(trans, root->fs_info, block_group);
|
add_block_group_free_space(trans, root->fs_info, block_group);
|
||||||
/* already aborted the transaction if it failed. */
|
/* already aborted the transaction if it failed. */
|
||||||
next:
|
next:
|
||||||
|
|
|
@ -698,7 +698,7 @@ int btrfs_del_csums(struct btrfs_trans_handle *trans,
|
||||||
*/
|
*/
|
||||||
ret = btrfs_split_item(trans, root, path, &key, offset);
|
ret = btrfs_split_item(trans, root, path, &key, offset);
|
||||||
if (ret && ret != -EAGAIN) {
|
if (ret && ret != -EAGAIN) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -950,7 +950,7 @@ delete_extent_item:
|
||||||
ret = btrfs_del_items(trans, root, path, del_slot,
|
ret = btrfs_del_items(trans, root, path, del_slot,
|
||||||
del_nr);
|
del_nr);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -974,7 +974,7 @@ delete_extent_item:
|
||||||
path->slots[0] = del_slot;
|
path->slots[0] = del_slot;
|
||||||
ret = btrfs_del_items(trans, root, path, del_slot, del_nr);
|
ret = btrfs_del_items(trans, root, path, del_slot, del_nr);
|
||||||
if (ret)
|
if (ret)
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
}
|
}
|
||||||
|
|
||||||
leaf = path->nodes[0];
|
leaf = path->nodes[0];
|
||||||
|
@ -1190,7 +1190,7 @@ again:
|
||||||
goto again;
|
goto again;
|
||||||
}
|
}
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1278,7 +1278,7 @@ again:
|
||||||
|
|
||||||
ret = btrfs_del_items(trans, root, path, del_slot, del_nr);
|
ret = btrfs_del_items(trans, root, path, del_slot, del_nr);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -280,7 +280,7 @@ fail:
|
||||||
if (locked)
|
if (locked)
|
||||||
mutex_unlock(&trans->transaction->cache_write_mutex);
|
mutex_unlock(&trans->transaction->cache_write_mutex);
|
||||||
if (ret)
|
if (ret)
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
|
@ -305,7 +305,7 @@ int convert_free_space_to_bitmaps(struct btrfs_trans_handle *trans,
|
||||||
out:
|
out:
|
||||||
kvfree(bitmap);
|
kvfree(bitmap);
|
||||||
if (ret)
|
if (ret)
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -454,7 +454,7 @@ int convert_free_space_to_extents(struct btrfs_trans_handle *trans,
|
||||||
out:
|
out:
|
||||||
kvfree(bitmap);
|
kvfree(bitmap);
|
||||||
if (ret)
|
if (ret)
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -851,7 +851,7 @@ int remove_from_free_space_tree(struct btrfs_trans_handle *trans,
|
||||||
out:
|
out:
|
||||||
btrfs_free_path(path);
|
btrfs_free_path(path);
|
||||||
if (ret)
|
if (ret)
|
||||||
btrfs_abort_transaction(trans, fs_info->free_space_root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1047,7 +1047,7 @@ int add_to_free_space_tree(struct btrfs_trans_handle *trans,
|
||||||
out:
|
out:
|
||||||
btrfs_free_path(path);
|
btrfs_free_path(path);
|
||||||
if (ret)
|
if (ret)
|
||||||
btrfs_abort_transaction(trans, fs_info->free_space_root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1193,7 +1193,7 @@ int btrfs_create_free_space_tree(struct btrfs_fs_info *fs_info)
|
||||||
|
|
||||||
abort:
|
abort:
|
||||||
fs_info->creating_free_space_tree = 0;
|
fs_info->creating_free_space_tree = 0;
|
||||||
btrfs_abort_transaction(trans, tree_root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
btrfs_end_transaction(trans, tree_root);
|
btrfs_end_transaction(trans, tree_root);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
@ -1280,7 +1280,7 @@ int btrfs_clear_free_space_tree(struct btrfs_fs_info *fs_info)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
abort:
|
abort:
|
||||||
btrfs_abort_transaction(trans, tree_root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
btrfs_end_transaction(trans, tree_root);
|
btrfs_end_transaction(trans, tree_root);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
@ -1333,7 +1333,7 @@ out:
|
||||||
btrfs_free_path(path);
|
btrfs_free_path(path);
|
||||||
mutex_unlock(&block_group->free_space_lock);
|
mutex_unlock(&block_group->free_space_lock);
|
||||||
if (ret)
|
if (ret)
|
||||||
btrfs_abort_transaction(trans, fs_info->free_space_root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1410,7 +1410,7 @@ int remove_block_group_free_space(struct btrfs_trans_handle *trans,
|
||||||
out:
|
out:
|
||||||
btrfs_free_path(path);
|
btrfs_free_path(path);
|
||||||
if (ret)
|
if (ret)
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -458,7 +458,7 @@ again:
|
||||||
BTRFS_I(inode)->generation = 0;
|
BTRFS_I(inode)->generation = 0;
|
||||||
ret = btrfs_update_inode(trans, root, inode);
|
ret = btrfs_update_inode(trans, root, inode);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out_put;
|
goto out_put;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -466,7 +466,7 @@ again:
|
||||||
ret = btrfs_truncate_free_space_cache(root, trans, NULL, inode);
|
ret = btrfs_truncate_free_space_cache(root, trans, NULL, inode);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
if (ret != -ENOSPC)
|
if (ret != -ENOSPC)
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out_put;
|
goto out_put;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -296,7 +296,7 @@ static noinline int cow_file_range_inline(struct btrfs_root *root,
|
||||||
start, aligned_end, NULL,
|
start, aligned_end, NULL,
|
||||||
1, 1, extent_item_size, &extent_inserted);
|
1, 1, extent_item_size, &extent_inserted);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -307,7 +307,7 @@ static noinline int cow_file_range_inline(struct btrfs_root *root,
|
||||||
inline_len, compressed_size,
|
inline_len, compressed_size,
|
||||||
compress_type, compressed_pages);
|
compress_type, compressed_pages);
|
||||||
if (ret && ret != -ENOSPC) {
|
if (ret && ret != -ENOSPC) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out;
|
goto out;
|
||||||
} else if (ret == -ENOSPC) {
|
} else if (ret == -ENOSPC) {
|
||||||
ret = 1;
|
ret = 1;
|
||||||
|
@ -2603,7 +2603,7 @@ again:
|
||||||
ret = btrfs_insert_empty_item(trans, root, path, &key,
|
ret = btrfs_insert_empty_item(trans, root, path, &key,
|
||||||
sizeof(*extent));
|
sizeof(*extent));
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out_free_path;
|
goto out_free_path;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2630,7 +2630,7 @@ again:
|
||||||
backref->root_id, backref->inum,
|
backref->root_id, backref->inum,
|
||||||
new->file_pos); /* start - extent_offset */
|
new->file_pos); /* start - extent_offset */
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out_free_path;
|
goto out_free_path;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2899,7 +2899,7 @@ static int btrfs_finish_ordered_io(struct btrfs_ordered_extent *ordered_extent)
|
||||||
trans->block_rsv = &root->fs_info->delalloc_block_rsv;
|
trans->block_rsv = &root->fs_info->delalloc_block_rsv;
|
||||||
ret = btrfs_update_inode_fallback(trans, root, inode);
|
ret = btrfs_update_inode_fallback(trans, root, inode);
|
||||||
if (ret) /* -ENOMEM or corruption */
|
if (ret) /* -ENOMEM or corruption */
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2959,7 +2959,7 @@ static int btrfs_finish_ordered_io(struct btrfs_ordered_extent *ordered_extent)
|
||||||
ordered_extent->file_offset, ordered_extent->len,
|
ordered_extent->file_offset, ordered_extent->len,
|
||||||
trans->transid);
|
trans->transid);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out_unlock;
|
goto out_unlock;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2969,7 +2969,7 @@ static int btrfs_finish_ordered_io(struct btrfs_ordered_extent *ordered_extent)
|
||||||
btrfs_ordered_update_i_size(inode, 0, ordered_extent);
|
btrfs_ordered_update_i_size(inode, 0, ordered_extent);
|
||||||
ret = btrfs_update_inode_fallback(trans, root, inode);
|
ret = btrfs_update_inode_fallback(trans, root, inode);
|
||||||
if (ret) { /* -ENOMEM or corruption */
|
if (ret) { /* -ENOMEM or corruption */
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out_unlock;
|
goto out_unlock;
|
||||||
}
|
}
|
||||||
ret = 0;
|
ret = 0;
|
||||||
|
@ -3213,7 +3213,7 @@ void btrfs_orphan_commit_root(struct btrfs_trans_handle *trans,
|
||||||
ret = btrfs_del_orphan_item(trans, root->fs_info->tree_root,
|
ret = btrfs_del_orphan_item(trans, root->fs_info->tree_root,
|
||||||
root->root_key.objectid);
|
root->root_key.objectid);
|
||||||
if (ret)
|
if (ret)
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
else
|
else
|
||||||
clear_bit(BTRFS_ROOT_ORPHAN_ITEM_INSERTED,
|
clear_bit(BTRFS_ROOT_ORPHAN_ITEM_INSERTED,
|
||||||
&root->state);
|
&root->state);
|
||||||
|
@ -3304,7 +3304,7 @@ int btrfs_orphan_add(struct btrfs_trans_handle *trans, struct inode *inode)
|
||||||
if (ret != -EEXIST) {
|
if (ret != -EEXIST) {
|
||||||
clear_bit(BTRFS_INODE_HAS_ORPHAN_ITEM,
|
clear_bit(BTRFS_INODE_HAS_ORPHAN_ITEM,
|
||||||
&BTRFS_I(inode)->runtime_flags);
|
&BTRFS_I(inode)->runtime_flags);
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -3316,7 +3316,7 @@ int btrfs_orphan_add(struct btrfs_trans_handle *trans, struct inode *inode)
|
||||||
ret = btrfs_insert_orphan_item(trans, root->fs_info->tree_root,
|
ret = btrfs_insert_orphan_item(trans, root->fs_info->tree_root,
|
||||||
root->root_key.objectid);
|
root->root_key.objectid);
|
||||||
if (ret && ret != -EEXIST) {
|
if (ret && ret != -EEXIST) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -4015,20 +4015,20 @@ static int __btrfs_unlink_inode(struct btrfs_trans_handle *trans,
|
||||||
btrfs_info(root->fs_info,
|
btrfs_info(root->fs_info,
|
||||||
"failed to delete reference to %.*s, inode %llu parent %llu",
|
"failed to delete reference to %.*s, inode %llu parent %llu",
|
||||||
name_len, name, ino, dir_ino);
|
name_len, name, ino, dir_ino);
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto err;
|
goto err;
|
||||||
}
|
}
|
||||||
skip_backref:
|
skip_backref:
|
||||||
ret = btrfs_delete_delayed_dir_index(trans, root, dir, index);
|
ret = btrfs_delete_delayed_dir_index(trans, root, dir, index);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto err;
|
goto err;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = btrfs_del_inode_ref_in_log(trans, root, name, name_len,
|
ret = btrfs_del_inode_ref_in_log(trans, root, name, name_len,
|
||||||
inode, dir_ino);
|
inode, dir_ino);
|
||||||
if (ret != 0 && ret != -ENOENT) {
|
if (ret != 0 && ret != -ENOENT) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto err;
|
goto err;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -4037,7 +4037,7 @@ skip_backref:
|
||||||
if (ret == -ENOENT)
|
if (ret == -ENOENT)
|
||||||
ret = 0;
|
ret = 0;
|
||||||
else if (ret)
|
else if (ret)
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
err:
|
err:
|
||||||
btrfs_free_path(path);
|
btrfs_free_path(path);
|
||||||
if (ret)
|
if (ret)
|
||||||
|
@ -4151,7 +4151,7 @@ int btrfs_unlink_subvol(struct btrfs_trans_handle *trans,
|
||||||
WARN_ON(key.type != BTRFS_ROOT_ITEM_KEY || key.objectid != objectid);
|
WARN_ON(key.type != BTRFS_ROOT_ITEM_KEY || key.objectid != objectid);
|
||||||
ret = btrfs_delete_one_dir_name(trans, root, path, di);
|
ret = btrfs_delete_one_dir_name(trans, root, path, di);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
btrfs_release_path(path);
|
btrfs_release_path(path);
|
||||||
|
@ -4161,7 +4161,7 @@ int btrfs_unlink_subvol(struct btrfs_trans_handle *trans,
|
||||||
dir_ino, &index, name, name_len);
|
dir_ino, &index, name, name_len);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
if (ret != -ENOENT) {
|
if (ret != -ENOENT) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
di = btrfs_search_dir_index_item(root, path, dir_ino,
|
di = btrfs_search_dir_index_item(root, path, dir_ino,
|
||||||
|
@ -4171,7 +4171,7 @@ int btrfs_unlink_subvol(struct btrfs_trans_handle *trans,
|
||||||
ret = -ENOENT;
|
ret = -ENOENT;
|
||||||
else
|
else
|
||||||
ret = PTR_ERR(di);
|
ret = PTR_ERR(di);
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -4184,7 +4184,7 @@ int btrfs_unlink_subvol(struct btrfs_trans_handle *trans,
|
||||||
|
|
||||||
ret = btrfs_delete_delayed_dir_index(trans, root, dir, index);
|
ret = btrfs_delete_delayed_dir_index(trans, root, dir, index);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -4193,7 +4193,7 @@ int btrfs_unlink_subvol(struct btrfs_trans_handle *trans,
|
||||||
dir->i_mtime = dir->i_ctime = current_fs_time(dir->i_sb);
|
dir->i_mtime = dir->i_ctime = current_fs_time(dir->i_sb);
|
||||||
ret = btrfs_update_inode_fallback(trans, root, dir);
|
ret = btrfs_update_inode_fallback(trans, root, dir);
|
||||||
if (ret)
|
if (ret)
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
out:
|
out:
|
||||||
btrfs_free_path(path);
|
btrfs_free_path(path);
|
||||||
return ret;
|
return ret;
|
||||||
|
@ -4514,7 +4514,6 @@ search_again:
|
||||||
pending_del_nr);
|
pending_del_nr);
|
||||||
if (err) {
|
if (err) {
|
||||||
btrfs_abort_transaction(trans,
|
btrfs_abort_transaction(trans,
|
||||||
root,
|
|
||||||
err);
|
err);
|
||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
@ -4526,8 +4525,7 @@ search_again:
|
||||||
item_end,
|
item_end,
|
||||||
new_size);
|
new_size);
|
||||||
if (err) {
|
if (err) {
|
||||||
btrfs_abort_transaction(trans,
|
btrfs_abort_transaction(trans, err);
|
||||||
root, err);
|
|
||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
} else if (test_bit(BTRFS_ROOT_REF_COWS,
|
} else if (test_bit(BTRFS_ROOT_REF_COWS,
|
||||||
|
@ -4591,8 +4589,7 @@ delete:
|
||||||
pending_del_slot,
|
pending_del_slot,
|
||||||
pending_del_nr);
|
pending_del_nr);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans,
|
btrfs_abort_transaction(trans, ret);
|
||||||
root, ret);
|
|
||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
pending_del_nr = 0;
|
pending_del_nr = 0;
|
||||||
|
@ -4625,7 +4622,7 @@ out:
|
||||||
ret = btrfs_del_items(trans, root, path, pending_del_slot,
|
ret = btrfs_del_items(trans, root, path, pending_del_slot,
|
||||||
pending_del_nr);
|
pending_del_nr);
|
||||||
if (ret)
|
if (ret)
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
}
|
}
|
||||||
error:
|
error:
|
||||||
if (root->root_key.objectid != BTRFS_TREE_LOG_OBJECTID)
|
if (root->root_key.objectid != BTRFS_TREE_LOG_OBJECTID)
|
||||||
|
@ -4794,7 +4791,7 @@ static int maybe_insert_hole(struct btrfs_root *root, struct inode *inode,
|
||||||
|
|
||||||
ret = btrfs_drop_extents(trans, root, inode, offset, offset + len, 1);
|
ret = btrfs_drop_extents(trans, root, inode, offset, offset + len, 1);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
btrfs_end_transaction(trans, root);
|
btrfs_end_transaction(trans, root);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
@ -4802,7 +4799,7 @@ static int maybe_insert_hole(struct btrfs_root *root, struct inode *inode,
|
||||||
ret = btrfs_insert_file_extent(trans, root, btrfs_ino(inode), offset,
|
ret = btrfs_insert_file_extent(trans, root, btrfs_ino(inode), offset,
|
||||||
0, 0, len, 0, len, 0, 0, 0);
|
0, 0, len, 0, len, 0, 0, 0);
|
||||||
if (ret)
|
if (ret)
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
else
|
else
|
||||||
btrfs_update_inode(trans, root, inode);
|
btrfs_update_inode(trans, root, inode);
|
||||||
btrfs_end_transaction(trans, root);
|
btrfs_end_transaction(trans, root);
|
||||||
|
@ -5029,7 +5026,7 @@ static int btrfs_setsize(struct inode *inode, struct iattr *attr)
|
||||||
i_size_write(inode, BTRFS_I(inode)->disk_i_size);
|
i_size_write(inode, BTRFS_I(inode)->disk_i_size);
|
||||||
err = btrfs_orphan_del(trans, inode);
|
err = btrfs_orphan_del(trans, inode);
|
||||||
if (err)
|
if (err)
|
||||||
btrfs_abort_transaction(trans, root, err);
|
btrfs_abort_transaction(trans, err);
|
||||||
btrfs_end_transaction(trans, root);
|
btrfs_end_transaction(trans, root);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -6335,7 +6332,7 @@ int btrfs_add_link(struct btrfs_trans_handle *trans,
|
||||||
if (ret == -EEXIST || ret == -EOVERFLOW)
|
if (ret == -EEXIST || ret == -EOVERFLOW)
|
||||||
goto fail_dir_item;
|
goto fail_dir_item;
|
||||||
else if (ret) {
|
else if (ret) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -6346,7 +6343,7 @@ int btrfs_add_link(struct btrfs_trans_handle *trans,
|
||||||
current_fs_time(parent_inode->i_sb);
|
current_fs_time(parent_inode->i_sb);
|
||||||
ret = btrfs_update_inode(trans, root, parent_inode);
|
ret = btrfs_update_inode(trans, root, parent_inode);
|
||||||
if (ret)
|
if (ret)
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
fail_dir_item:
|
fail_dir_item:
|
||||||
|
@ -9568,7 +9565,7 @@ static int btrfs_rename_exchange(struct inode *old_dir,
|
||||||
ret = btrfs_update_inode(trans, root, old_inode);
|
ret = btrfs_update_inode(trans, root, old_inode);
|
||||||
}
|
}
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out_fail;
|
goto out_fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -9588,7 +9585,7 @@ static int btrfs_rename_exchange(struct inode *old_dir,
|
||||||
ret = btrfs_update_inode(trans, dest, new_inode);
|
ret = btrfs_update_inode(trans, dest, new_inode);
|
||||||
}
|
}
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out_fail;
|
goto out_fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -9596,7 +9593,7 @@ static int btrfs_rename_exchange(struct inode *old_dir,
|
||||||
new_dentry->d_name.name,
|
new_dentry->d_name.name,
|
||||||
new_dentry->d_name.len, 0, old_idx);
|
new_dentry->d_name.len, 0, old_idx);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out_fail;
|
goto out_fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -9604,7 +9601,7 @@ static int btrfs_rename_exchange(struct inode *old_dir,
|
||||||
old_dentry->d_name.name,
|
old_dentry->d_name.name,
|
||||||
old_dentry->d_name.len, 0, new_idx);
|
old_dentry->d_name.len, 0, new_idx);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out_fail;
|
goto out_fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -9843,7 +9840,7 @@ static int btrfs_rename(struct inode *old_dir, struct dentry *old_dentry,
|
||||||
ret = btrfs_update_inode(trans, root, old_inode);
|
ret = btrfs_update_inode(trans, root, old_inode);
|
||||||
}
|
}
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out_fail;
|
goto out_fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -9867,7 +9864,7 @@ static int btrfs_rename(struct inode *old_dir, struct dentry *old_dentry,
|
||||||
if (!ret && new_inode->i_nlink == 0)
|
if (!ret && new_inode->i_nlink == 0)
|
||||||
ret = btrfs_orphan_add(trans, d_inode(new_dentry));
|
ret = btrfs_orphan_add(trans, d_inode(new_dentry));
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out_fail;
|
goto out_fail;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -9876,7 +9873,7 @@ static int btrfs_rename(struct inode *old_dir, struct dentry *old_dentry,
|
||||||
new_dentry->d_name.name,
|
new_dentry->d_name.name,
|
||||||
new_dentry->d_name.len, 0, index);
|
new_dentry->d_name.len, 0, index);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out_fail;
|
goto out_fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -9896,7 +9893,7 @@ static int btrfs_rename(struct inode *old_dir, struct dentry *old_dentry,
|
||||||
old_dentry);
|
old_dentry);
|
||||||
|
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out_fail;
|
goto out_fail;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -10322,7 +10319,7 @@ static int __btrfs_prealloc_file_range(struct inode *inode, int mode,
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_free_reserved_extent(root, ins.objectid,
|
btrfs_free_reserved_extent(root, ins.objectid,
|
||||||
ins.offset, 0);
|
ins.offset, 0);
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
if (own_trans)
|
if (own_trans)
|
||||||
btrfs_end_transaction(trans, root);
|
btrfs_end_transaction(trans, root);
|
||||||
break;
|
break;
|
||||||
|
@ -10382,7 +10379,7 @@ next:
|
||||||
ret = btrfs_update_inode(trans, root, inode);
|
ret = btrfs_update_inode(trans, root, inode);
|
||||||
|
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
if (own_trans)
|
if (own_trans)
|
||||||
btrfs_end_transaction(trans, root);
|
btrfs_end_transaction(trans, root);
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -561,7 +561,7 @@ static noinline int create_subvol(struct inode *dir,
|
||||||
new_root = btrfs_read_fs_root_no_name(root->fs_info, &key);
|
new_root = btrfs_read_fs_root_no_name(root->fs_info, &key);
|
||||||
if (IS_ERR(new_root)) {
|
if (IS_ERR(new_root)) {
|
||||||
ret = PTR_ERR(new_root);
|
ret = PTR_ERR(new_root);
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -570,7 +570,7 @@ static noinline int create_subvol(struct inode *dir,
|
||||||
ret = btrfs_create_subvol_root(trans, new_root, root, new_dirid);
|
ret = btrfs_create_subvol_root(trans, new_root, root, new_dirid);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
/* We potentially lose an unused inode item here */
|
/* We potentially lose an unused inode item here */
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -583,7 +583,7 @@ static noinline int create_subvol(struct inode *dir,
|
||||||
*/
|
*/
|
||||||
ret = btrfs_set_inode_index(dir, &index);
|
ret = btrfs_set_inode_index(dir, &index);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -591,7 +591,7 @@ static noinline int create_subvol(struct inode *dir,
|
||||||
name, namelen, dir, &key,
|
name, namelen, dir, &key,
|
||||||
BTRFS_FT_DIR, index);
|
BTRFS_FT_DIR, index);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -608,7 +608,7 @@ static noinline int create_subvol(struct inode *dir,
|
||||||
root_item->uuid, BTRFS_UUID_KEY_SUBVOL,
|
root_item->uuid, BTRFS_UUID_KEY_SUBVOL,
|
||||||
objectid);
|
objectid);
|
||||||
if (ret)
|
if (ret)
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
|
|
||||||
fail:
|
fail:
|
||||||
kfree(root_item);
|
kfree(root_item);
|
||||||
|
@ -2488,7 +2488,7 @@ static noinline int btrfs_ioctl_snap_destroy(struct file *file,
|
||||||
dentry->d_name.len);
|
dentry->d_name.len);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
err = ret;
|
err = ret;
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out_end_trans;
|
goto out_end_trans;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2504,7 +2504,7 @@ static noinline int btrfs_ioctl_snap_destroy(struct file *file,
|
||||||
root->fs_info->tree_root,
|
root->fs_info->tree_root,
|
||||||
dest->root_key.objectid);
|
dest->root_key.objectid);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
err = ret;
|
err = ret;
|
||||||
goto out_end_trans;
|
goto out_end_trans;
|
||||||
}
|
}
|
||||||
|
@ -2514,7 +2514,7 @@ static noinline int btrfs_ioctl_snap_destroy(struct file *file,
|
||||||
dest->root_item.uuid, BTRFS_UUID_KEY_SUBVOL,
|
dest->root_item.uuid, BTRFS_UUID_KEY_SUBVOL,
|
||||||
dest->root_key.objectid);
|
dest->root_key.objectid);
|
||||||
if (ret && ret != -ENOENT) {
|
if (ret && ret != -ENOENT) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
err = ret;
|
err = ret;
|
||||||
goto out_end_trans;
|
goto out_end_trans;
|
||||||
}
|
}
|
||||||
|
@ -2524,7 +2524,7 @@ static noinline int btrfs_ioctl_snap_destroy(struct file *file,
|
||||||
BTRFS_UUID_KEY_RECEIVED_SUBVOL,
|
BTRFS_UUID_KEY_RECEIVED_SUBVOL,
|
||||||
dest->root_key.objectid);
|
dest->root_key.objectid);
|
||||||
if (ret && ret != -ENOENT) {
|
if (ret && ret != -ENOENT) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
err = ret;
|
err = ret;
|
||||||
goto out_end_trans;
|
goto out_end_trans;
|
||||||
}
|
}
|
||||||
|
@ -3291,7 +3291,7 @@ static int clone_finish_inode_update(struct btrfs_trans_handle *trans,
|
||||||
|
|
||||||
ret = btrfs_update_inode(trans, root, inode);
|
ret = btrfs_update_inode(trans, root, inode);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
btrfs_end_transaction(trans, root);
|
btrfs_end_transaction(trans, root);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
@ -3693,7 +3693,7 @@ process_slot:
|
||||||
if (ret) {
|
if (ret) {
|
||||||
if (ret != -EOPNOTSUPP)
|
if (ret != -EOPNOTSUPP)
|
||||||
btrfs_abort_transaction(trans,
|
btrfs_abort_transaction(trans,
|
||||||
root, ret);
|
ret);
|
||||||
btrfs_end_transaction(trans, root);
|
btrfs_end_transaction(trans, root);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
@ -3701,8 +3701,7 @@ process_slot:
|
||||||
ret = btrfs_insert_empty_item(trans, root, path,
|
ret = btrfs_insert_empty_item(trans, root, path,
|
||||||
&new_key, size);
|
&new_key, size);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, root,
|
btrfs_abort_transaction(trans, ret);
|
||||||
ret);
|
|
||||||
btrfs_end_transaction(trans, root);
|
btrfs_end_transaction(trans, root);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
@ -3734,7 +3733,6 @@ process_slot:
|
||||||
new_key.offset - datao);
|
new_key.offset - datao);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans,
|
btrfs_abort_transaction(trans,
|
||||||
root,
|
|
||||||
ret);
|
ret);
|
||||||
btrfs_end_transaction(trans,
|
btrfs_end_transaction(trans,
|
||||||
root);
|
root);
|
||||||
|
@ -3771,7 +3769,6 @@ process_slot:
|
||||||
if (ret) {
|
if (ret) {
|
||||||
if (ret != -EOPNOTSUPP)
|
if (ret != -EOPNOTSUPP)
|
||||||
btrfs_abort_transaction(trans,
|
btrfs_abort_transaction(trans,
|
||||||
root,
|
|
||||||
ret);
|
ret);
|
||||||
btrfs_end_transaction(trans, root);
|
btrfs_end_transaction(trans, root);
|
||||||
goto out;
|
goto out;
|
||||||
|
@ -3827,7 +3824,7 @@ process_slot:
|
||||||
last_dest_end, destoff + len, 1);
|
last_dest_end, destoff + len, 1);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
if (ret != -EOPNOTSUPP)
|
if (ret != -EOPNOTSUPP)
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
btrfs_end_transaction(trans, root);
|
btrfs_end_transaction(trans, root);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
@ -5163,13 +5160,13 @@ static long _btrfs_ioctl_set_received_subvol(struct file *file,
|
||||||
BTRFS_UUID_KEY_RECEIVED_SUBVOL,
|
BTRFS_UUID_KEY_RECEIVED_SUBVOL,
|
||||||
root->root_key.objectid);
|
root->root_key.objectid);
|
||||||
if (ret < 0 && ret != -EEXIST) {
|
if (ret < 0 && ret != -EEXIST) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
ret = btrfs_commit_transaction(trans, root);
|
ret = btrfs_commit_transaction(trans, root);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1723,7 +1723,7 @@ int replace_file_extents(struct btrfs_trans_handle *trans,
|
||||||
btrfs_header_owner(leaf),
|
btrfs_header_owner(leaf),
|
||||||
key.objectid, key.offset);
|
key.objectid, key.offset);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1731,7 +1731,7 @@ int replace_file_extents(struct btrfs_trans_handle *trans,
|
||||||
parent, btrfs_header_owner(leaf),
|
parent, btrfs_header_owner(leaf),
|
||||||
key.objectid, key.offset);
|
key.objectid, key.offset);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -150,7 +150,7 @@ int btrfs_update_root(struct btrfs_trans_handle *trans, struct btrfs_root
|
||||||
|
|
||||||
ret = btrfs_search_slot(trans, root, key, path, 0, 1);
|
ret = btrfs_search_slot(trans, root, key, path, 0, 1);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -176,20 +176,20 @@ int btrfs_update_root(struct btrfs_trans_handle *trans, struct btrfs_root
|
||||||
ret = btrfs_search_slot(trans, root, key, path,
|
ret = btrfs_search_slot(trans, root, key, path,
|
||||||
-1, 1);
|
-1, 1);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = btrfs_del_item(trans, root, path);
|
ret = btrfs_del_item(trans, root, path);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
btrfs_release_path(path);
|
btrfs_release_path(path);
|
||||||
ret = btrfs_insert_empty_item(trans, root, path,
|
ret = btrfs_insert_empty_item(trans, root, path,
|
||||||
key, sizeof(*item));
|
key, sizeof(*item));
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
l = path->nodes[0];
|
l = path->nodes[0];
|
||||||
|
@ -448,7 +448,7 @@ again:
|
||||||
ret = btrfs_insert_empty_item(trans, tree_root, path, &key,
|
ret = btrfs_insert_empty_item(trans, tree_root, path, &key,
|
||||||
sizeof(*ref) + name_len);
|
sizeof(*ref) + name_len);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, tree_root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
btrfs_free_path(path);
|
btrfs_free_path(path);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
|
@ -251,9 +251,11 @@ void btrfs_printk(const struct btrfs_fs_info *fs_info, const char *fmt, ...)
|
||||||
*/
|
*/
|
||||||
__cold
|
__cold
|
||||||
void __btrfs_abort_transaction(struct btrfs_trans_handle *trans,
|
void __btrfs_abort_transaction(struct btrfs_trans_handle *trans,
|
||||||
struct btrfs_root *root, const char *function,
|
const char *function,
|
||||||
unsigned int line, int errno)
|
unsigned int line, int errno)
|
||||||
{
|
{
|
||||||
|
struct btrfs_fs_info *fs_info = trans->fs_info;
|
||||||
|
|
||||||
trans->aborted = errno;
|
trans->aborted = errno;
|
||||||
/* Nothing used. The other threads that have joined this
|
/* Nothing used. The other threads that have joined this
|
||||||
* transaction may be able to continue. */
|
* transaction may be able to continue. */
|
||||||
|
@ -261,16 +263,16 @@ void __btrfs_abort_transaction(struct btrfs_trans_handle *trans,
|
||||||
const char *errstr;
|
const char *errstr;
|
||||||
|
|
||||||
errstr = btrfs_decode_error(errno);
|
errstr = btrfs_decode_error(errno);
|
||||||
btrfs_warn(root->fs_info,
|
btrfs_warn(fs_info,
|
||||||
"%s:%d: Aborting unused transaction(%s).",
|
"%s:%d: Aborting unused transaction(%s).",
|
||||||
function, line, errstr);
|
function, line, errstr);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
ACCESS_ONCE(trans->transaction->aborted) = errno;
|
ACCESS_ONCE(trans->transaction->aborted) = errno;
|
||||||
/* Wake up anybody who may be waiting on this transaction */
|
/* Wake up anybody who may be waiting on this transaction */
|
||||||
wake_up(&root->fs_info->transaction_wait);
|
wake_up(&fs_info->transaction_wait);
|
||||||
wake_up(&root->fs_info->transaction_blocked_wait);
|
wake_up(&fs_info->transaction_blocked_wait);
|
||||||
__btrfs_handle_fs_error(root->fs_info, function, line, errno, NULL);
|
__btrfs_handle_fs_error(fs_info, function, line, errno, NULL);
|
||||||
}
|
}
|
||||||
/*
|
/*
|
||||||
* __btrfs_panic decodes unexpected, fatal errors from the caller,
|
* __btrfs_panic decodes unexpected, fatal errors from the caller,
|
||||||
|
|
|
@ -1492,7 +1492,7 @@ static noinline int create_pending_snapshot(struct btrfs_trans_handle *trans,
|
||||||
goto dir_item_existed;
|
goto dir_item_existed;
|
||||||
} else if (IS_ERR(dir_item)) {
|
} else if (IS_ERR(dir_item)) {
|
||||||
ret = PTR_ERR(dir_item);
|
ret = PTR_ERR(dir_item);
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
btrfs_release_path(path);
|
btrfs_release_path(path);
|
||||||
|
@ -1505,7 +1505,7 @@ static noinline int create_pending_snapshot(struct btrfs_trans_handle *trans,
|
||||||
*/
|
*/
|
||||||
ret = btrfs_run_delayed_items(trans, root);
|
ret = btrfs_run_delayed_items(trans, root);
|
||||||
if (ret) { /* Transaction aborted */
|
if (ret) { /* Transaction aborted */
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1544,7 +1544,7 @@ static noinline int create_pending_snapshot(struct btrfs_trans_handle *trans,
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_tree_unlock(old);
|
btrfs_tree_unlock(old);
|
||||||
free_extent_buffer(old);
|
free_extent_buffer(old);
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1555,7 +1555,7 @@ static noinline int create_pending_snapshot(struct btrfs_trans_handle *trans,
|
||||||
btrfs_tree_unlock(old);
|
btrfs_tree_unlock(old);
|
||||||
free_extent_buffer(old);
|
free_extent_buffer(old);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
/* see comments in should_cow_block() */
|
/* see comments in should_cow_block() */
|
||||||
|
@ -1569,7 +1569,7 @@ static noinline int create_pending_snapshot(struct btrfs_trans_handle *trans,
|
||||||
btrfs_tree_unlock(tmp);
|
btrfs_tree_unlock(tmp);
|
||||||
free_extent_buffer(tmp);
|
free_extent_buffer(tmp);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1581,7 +1581,7 @@ static noinline int create_pending_snapshot(struct btrfs_trans_handle *trans,
|
||||||
btrfs_ino(parent_inode), index,
|
btrfs_ino(parent_inode), index,
|
||||||
dentry->d_name.name, dentry->d_name.len);
|
dentry->d_name.name, dentry->d_name.len);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1589,19 +1589,19 @@ static noinline int create_pending_snapshot(struct btrfs_trans_handle *trans,
|
||||||
pending->snap = btrfs_read_fs_root_no_name(root->fs_info, &key);
|
pending->snap = btrfs_read_fs_root_no_name(root->fs_info, &key);
|
||||||
if (IS_ERR(pending->snap)) {
|
if (IS_ERR(pending->snap)) {
|
||||||
ret = PTR_ERR(pending->snap);
|
ret = PTR_ERR(pending->snap);
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = btrfs_reloc_post_snapshot(trans, pending);
|
ret = btrfs_reloc_post_snapshot(trans, pending);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = btrfs_run_delayed_refs(trans, root, (unsigned long)-1);
|
ret = btrfs_run_delayed_refs(trans, root, (unsigned long)-1);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1623,7 +1623,7 @@ static noinline int create_pending_snapshot(struct btrfs_trans_handle *trans,
|
||||||
/* We have check then name at the beginning, so it is impossible. */
|
/* We have check then name at the beginning, so it is impossible. */
|
||||||
BUG_ON(ret == -EEXIST || ret == -EOVERFLOW);
|
BUG_ON(ret == -EEXIST || ret == -EOVERFLOW);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1633,13 +1633,13 @@ static noinline int create_pending_snapshot(struct btrfs_trans_handle *trans,
|
||||||
current_fs_time(parent_inode->i_sb);
|
current_fs_time(parent_inode->i_sb);
|
||||||
ret = btrfs_update_inode_fallback(trans, parent_root, parent_inode);
|
ret = btrfs_update_inode_fallback(trans, parent_root, parent_inode);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
ret = btrfs_uuid_tree_add(trans, fs_info->uuid_root, new_uuid.b,
|
ret = btrfs_uuid_tree_add(trans, fs_info->uuid_root, new_uuid.b,
|
||||||
BTRFS_UUID_KEY_SUBVOL, objectid);
|
BTRFS_UUID_KEY_SUBVOL, objectid);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
if (!btrfs_is_empty_uuid(new_root_item->received_uuid)) {
|
if (!btrfs_is_empty_uuid(new_root_item->received_uuid)) {
|
||||||
|
@ -1648,14 +1648,14 @@ static noinline int create_pending_snapshot(struct btrfs_trans_handle *trans,
|
||||||
BTRFS_UUID_KEY_RECEIVED_SUBVOL,
|
BTRFS_UUID_KEY_RECEIVED_SUBVOL,
|
||||||
objectid);
|
objectid);
|
||||||
if (ret && ret != -EEXIST) {
|
if (ret && ret != -EEXIST) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = btrfs_run_delayed_refs(trans, root, (unsigned long)-1);
|
ret = btrfs_run_delayed_refs(trans, root, (unsigned long)-1);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1851,7 +1851,7 @@ static void cleanup_transaction(struct btrfs_trans_handle *trans,
|
||||||
|
|
||||||
WARN_ON(trans->use_count > 1);
|
WARN_ON(trans->use_count > 1);
|
||||||
|
|
||||||
btrfs_abort_transaction(trans, root, err);
|
btrfs_abort_transaction(trans, err);
|
||||||
|
|
||||||
spin_lock(&root->fs_info->trans_lock);
|
spin_lock(&root->fs_info->trans_lock);
|
||||||
|
|
||||||
|
|
|
@ -2788,7 +2788,7 @@ int btrfs_sync_log(struct btrfs_trans_handle *trans,
|
||||||
ret = btrfs_write_marked_extents(log, &log->dirty_log_pages, mark);
|
ret = btrfs_write_marked_extents(log, &log->dirty_log_pages, mark);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
blk_finish_plug(&plug);
|
blk_finish_plug(&plug);
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
btrfs_free_logged_extents(log, log_transid);
|
btrfs_free_logged_extents(log, log_transid);
|
||||||
btrfs_set_log_full_commit(root->fs_info, trans);
|
btrfs_set_log_full_commit(root->fs_info, trans);
|
||||||
mutex_unlock(&root->log_mutex);
|
mutex_unlock(&root->log_mutex);
|
||||||
|
@ -2838,7 +2838,7 @@ int btrfs_sync_log(struct btrfs_trans_handle *trans,
|
||||||
btrfs_set_log_full_commit(root->fs_info, trans);
|
btrfs_set_log_full_commit(root->fs_info, trans);
|
||||||
|
|
||||||
if (ret != -ENOSPC) {
|
if (ret != -ENOSPC) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
mutex_unlock(&log_root_tree->log_mutex);
|
mutex_unlock(&log_root_tree->log_mutex);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
@ -2898,7 +2898,7 @@ int btrfs_sync_log(struct btrfs_trans_handle *trans,
|
||||||
blk_finish_plug(&plug);
|
blk_finish_plug(&plug);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_set_log_full_commit(root->fs_info, trans);
|
btrfs_set_log_full_commit(root->fs_info, trans);
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
btrfs_free_logged_extents(log, log_transid);
|
btrfs_free_logged_extents(log, log_transid);
|
||||||
mutex_unlock(&log_root_tree->log_mutex);
|
mutex_unlock(&log_root_tree->log_mutex);
|
||||||
goto out_wake_log_root;
|
goto out_wake_log_root;
|
||||||
|
@ -2934,7 +2934,7 @@ int btrfs_sync_log(struct btrfs_trans_handle *trans,
|
||||||
ret = write_ctree_super(trans, root->fs_info->tree_root, 1);
|
ret = write_ctree_super(trans, root->fs_info->tree_root, 1);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_set_log_full_commit(root->fs_info, trans);
|
btrfs_set_log_full_commit(root->fs_info, trans);
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out_wake_log_root;
|
goto out_wake_log_root;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2991,7 +2991,7 @@ static void free_log_tree(struct btrfs_trans_handle *trans,
|
||||||
ret = walk_log_tree(trans, log, &wc);
|
ret = walk_log_tree(trans, log, &wc);
|
||||||
/* I don't think this can happen but just in case */
|
/* I don't think this can happen but just in case */
|
||||||
if (ret)
|
if (ret)
|
||||||
btrfs_abort_transaction(trans, log, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
|
|
||||||
while (1) {
|
while (1) {
|
||||||
ret = find_first_extent_bit(&log->dirty_log_pages,
|
ret = find_first_extent_bit(&log->dirty_log_pages,
|
||||||
|
@ -3160,7 +3160,7 @@ out_unlock:
|
||||||
btrfs_set_log_full_commit(root->fs_info, trans);
|
btrfs_set_log_full_commit(root->fs_info, trans);
|
||||||
ret = 0;
|
ret = 0;
|
||||||
} else if (ret < 0)
|
} else if (ret < 0)
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
|
|
||||||
btrfs_end_log_trans(root);
|
btrfs_end_log_trans(root);
|
||||||
|
|
||||||
|
@ -3193,7 +3193,7 @@ int btrfs_del_inode_ref_in_log(struct btrfs_trans_handle *trans,
|
||||||
btrfs_set_log_full_commit(root->fs_info, trans);
|
btrfs_set_log_full_commit(root->fs_info, trans);
|
||||||
ret = 0;
|
ret = 0;
|
||||||
} else if (ret < 0 && ret != -ENOENT)
|
} else if (ret < 0 && ret != -ENOENT)
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
btrfs_end_log_trans(root);
|
btrfs_end_log_trans(root);
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
|
|
|
@ -2438,14 +2438,14 @@ int btrfs_init_new_device(struct btrfs_root *root, char *device_path)
|
||||||
ret = init_first_rw_device(trans, root, device);
|
ret = init_first_rw_device(trans, root, device);
|
||||||
unlock_chunks(root);
|
unlock_chunks(root);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto error_trans;
|
goto error_trans;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = btrfs_add_device(trans, root, device);
|
ret = btrfs_add_device(trans, root, device);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto error_trans;
|
goto error_trans;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2454,7 +2454,7 @@ int btrfs_init_new_device(struct btrfs_root *root, char *device_path)
|
||||||
|
|
||||||
ret = btrfs_finish_sprout(trans, root);
|
ret = btrfs_finish_sprout(trans, root);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto error_trans;
|
goto error_trans;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2840,7 +2840,7 @@ int btrfs_remove_chunk(struct btrfs_trans_handle *trans,
|
||||||
&dev_extent_len);
|
&dev_extent_len);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
mutex_unlock(&fs_devices->device_list_mutex);
|
mutex_unlock(&fs_devices->device_list_mutex);
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2859,7 +2859,7 @@ int btrfs_remove_chunk(struct btrfs_trans_handle *trans,
|
||||||
ret = btrfs_update_device(trans, map->stripes[i].dev);
|
ret = btrfs_update_device(trans, map->stripes[i].dev);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
mutex_unlock(&fs_devices->device_list_mutex);
|
mutex_unlock(&fs_devices->device_list_mutex);
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2868,7 +2868,7 @@ int btrfs_remove_chunk(struct btrfs_trans_handle *trans,
|
||||||
|
|
||||||
ret = btrfs_free_chunk(trans, root, chunk_objectid, chunk_offset);
|
ret = btrfs_free_chunk(trans, root, chunk_objectid, chunk_offset);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2877,14 +2877,14 @@ int btrfs_remove_chunk(struct btrfs_trans_handle *trans,
|
||||||
if (map->type & BTRFS_BLOCK_GROUP_SYSTEM) {
|
if (map->type & BTRFS_BLOCK_GROUP_SYSTEM) {
|
||||||
ret = btrfs_del_sys_chunk(root, chunk_objectid, chunk_offset);
|
ret = btrfs_del_sys_chunk(root, chunk_objectid, chunk_offset);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = btrfs_remove_block_group(trans, extent_root, chunk_offset, em);
|
ret = btrfs_remove_block_group(trans, extent_root, chunk_offset, em);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
btrfs_abort_transaction(trans, extent_root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -4299,7 +4299,7 @@ int btrfs_create_uuid_tree(struct btrfs_fs_info *fs_info)
|
||||||
BTRFS_UUID_TREE_OBJECTID);
|
BTRFS_UUID_TREE_OBJECTID);
|
||||||
if (IS_ERR(uuid_root)) {
|
if (IS_ERR(uuid_root)) {
|
||||||
ret = PTR_ERR(uuid_root);
|
ret = PTR_ERR(uuid_root);
|
||||||
btrfs_abort_transaction(trans, tree_root, ret);
|
btrfs_abort_transaction(trans, ret);
|
||||||
btrfs_end_transaction(trans, tree_root);
|
btrfs_end_transaction(trans, tree_root);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue