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:
Jeff Mahoney 2016-06-10 18:19:25 -04:00 committed by David Sterba
parent 64b6358072
commit 66642832f0
17 changed files with 147 additions and 152 deletions

View File

@ -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,

View File

@ -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)

View File

@ -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;
} }

View File

@ -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:

View File

@ -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;
} }

View File

@ -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;
} }
} }

View File

@ -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;
} }

View File

@ -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;
} }

View File

@ -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;
} }
} }

View File

@ -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;

View File

@ -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;
} }

View File

@ -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;
} }
} }

View File

@ -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;
} }

View File

@ -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,

View File

@ -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);

View File

@ -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;

View File

@ -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;
} }