btrfs: drop fs_info parameter from btrfs_run_delayed_refs

It's provided by the transaction handle.

Signed-off-by: Nikolay Borisov <nborisov@suse.com>
Signed-off-by: David Sterba <dsterba@suse.com>
This commit is contained in:
Nikolay Borisov 2018-03-15 17:27:37 +02:00 committed by David Sterba
parent 39d7d09dc2
commit c79a70b133
4 changed files with 18 additions and 20 deletions

View File

@ -2623,7 +2623,7 @@ void btrfs_dec_nocow_writers(struct btrfs_fs_info *fs_info, u64 bytenr);
void btrfs_wait_nocow_writers(struct btrfs_block_group_cache *bg); void btrfs_wait_nocow_writers(struct btrfs_block_group_cache *bg);
void btrfs_put_block_group(struct btrfs_block_group_cache *cache); void btrfs_put_block_group(struct btrfs_block_group_cache *cache);
int btrfs_run_delayed_refs(struct btrfs_trans_handle *trans, int btrfs_run_delayed_refs(struct btrfs_trans_handle *trans,
struct btrfs_fs_info *fs_info, unsigned long count); unsigned long count);
int btrfs_async_run_delayed_refs(struct btrfs_fs_info *fs_info, int btrfs_async_run_delayed_refs(struct btrfs_fs_info *fs_info,
unsigned long count, u64 transid, int wait); unsigned long count, u64 transid, int wait);
int btrfs_lookup_data_extent(struct btrfs_fs_info *fs_info, u64 start, u64 len); int btrfs_lookup_data_extent(struct btrfs_fs_info *fs_info, u64 start, u64 len);

View File

@ -2992,7 +2992,7 @@ static void delayed_ref_async_start(struct btrfs_work *work)
if (trans->transid > async->transid) if (trans->transid > async->transid)
goto end; goto end;
ret = btrfs_run_delayed_refs(trans, fs_info, async->count); ret = btrfs_run_delayed_refs(trans, async->count);
if (ret) if (ret)
async->error = ret; async->error = ret;
end: end:
@ -3051,8 +3051,9 @@ int btrfs_async_run_delayed_refs(struct btrfs_fs_info *fs_info,
* Returns <0 on error and aborts the transaction * Returns <0 on error and aborts the transaction
*/ */
int btrfs_run_delayed_refs(struct btrfs_trans_handle *trans, int btrfs_run_delayed_refs(struct btrfs_trans_handle *trans,
struct btrfs_fs_info *fs_info, unsigned long count) unsigned long count)
{ {
struct btrfs_fs_info *fs_info = trans->fs_info;
struct rb_node *node; struct rb_node *node;
struct btrfs_delayed_ref_root *delayed_refs; struct btrfs_delayed_ref_root *delayed_refs;
struct btrfs_delayed_ref_head *head; struct btrfs_delayed_ref_head *head;
@ -3799,7 +3800,7 @@ again:
* go through delayed refs for all the stuff we've just kicked off * go through delayed refs for all the stuff we've just kicked off
* and then loop back (just once) * and then loop back (just once)
*/ */
ret = btrfs_run_delayed_refs(trans, fs_info, 0); ret = btrfs_run_delayed_refs(trans, 0);
if (!ret && loops == 0) { if (!ret && loops == 0) {
loops++; loops++;
spin_lock(&cur_trans->dirty_bgs_lock); spin_lock(&cur_trans->dirty_bgs_lock);
@ -3881,7 +3882,7 @@ int btrfs_write_dirty_block_groups(struct btrfs_trans_handle *trans,
cache_save_setup(cache, trans, path); cache_save_setup(cache, trans, path);
if (!ret) if (!ret)
ret = btrfs_run_delayed_refs(trans, fs_info, ret = btrfs_run_delayed_refs(trans,
(unsigned long) -1); (unsigned long) -1);
if (!ret && cache->disk_cache_state == BTRFS_DC_SETUP) { if (!ret && cache->disk_cache_state == BTRFS_DC_SETUP) {

View File

@ -4730,7 +4730,6 @@ delete:
if (updates) { if (updates) {
trans->delayed_ref_updates = 0; trans->delayed_ref_updates = 0;
ret = btrfs_run_delayed_refs(trans, ret = btrfs_run_delayed_refs(trans,
fs_info,
updates * 2); updates * 2);
if (ret && !err) if (ret && !err)
err = ret; err = ret;
@ -4770,8 +4769,7 @@ error:
unsigned long updates = trans->delayed_ref_updates; unsigned long updates = trans->delayed_ref_updates;
if (updates) { if (updates) {
trans->delayed_ref_updates = 0; trans->delayed_ref_updates = 0;
ret = btrfs_run_delayed_refs(trans, fs_info, ret = btrfs_run_delayed_refs(trans, updates * 2);
updates * 2);
if (ret && !err) if (ret && !err)
err = ret; err = ret;
} }

View File

@ -781,7 +781,6 @@ static int should_end_transaction(struct btrfs_trans_handle *trans)
int btrfs_should_end_transaction(struct btrfs_trans_handle *trans) int btrfs_should_end_transaction(struct btrfs_trans_handle *trans)
{ {
struct btrfs_transaction *cur_trans = trans->transaction; struct btrfs_transaction *cur_trans = trans->transaction;
struct btrfs_fs_info *fs_info = trans->fs_info;
int updates; int updates;
int err; int err;
@ -793,7 +792,7 @@ int btrfs_should_end_transaction(struct btrfs_trans_handle *trans)
updates = trans->delayed_ref_updates; updates = trans->delayed_ref_updates;
trans->delayed_ref_updates = 0; trans->delayed_ref_updates = 0;
if (updates) { if (updates) {
err = btrfs_run_delayed_refs(trans, fs_info, updates * 2); err = btrfs_run_delayed_refs(trans, updates * 2);
if (err) /* Error code will also eval true */ if (err) /* Error code will also eval true */
return err; return err;
} }
@ -1161,7 +1160,7 @@ static noinline int commit_cowonly_roots(struct btrfs_trans_handle *trans)
if (ret) if (ret)
return ret; return ret;
ret = btrfs_run_delayed_refs(trans, fs_info, (unsigned long)-1); ret = btrfs_run_delayed_refs(trans, (unsigned long)-1);
if (ret) if (ret)
return ret; return ret;
@ -1180,7 +1179,7 @@ static noinline int commit_cowonly_roots(struct btrfs_trans_handle *trans)
return ret; return ret;
/* run_qgroups might have added some more refs */ /* run_qgroups might have added some more refs */
ret = btrfs_run_delayed_refs(trans, fs_info, (unsigned long)-1); ret = btrfs_run_delayed_refs(trans, (unsigned long)-1);
if (ret) if (ret)
return ret; return ret;
again: again:
@ -1197,7 +1196,7 @@ again:
ret = update_cowonly_root(trans, root); ret = update_cowonly_root(trans, root);
if (ret) if (ret)
return ret; return ret;
ret = btrfs_run_delayed_refs(trans, fs_info, (unsigned long)-1); ret = btrfs_run_delayed_refs(trans, (unsigned long)-1);
if (ret) if (ret)
return ret; return ret;
} }
@ -1206,7 +1205,7 @@ again:
ret = btrfs_write_dirty_block_groups(trans, fs_info); ret = btrfs_write_dirty_block_groups(trans, fs_info);
if (ret) if (ret)
return ret; return ret;
ret = btrfs_run_delayed_refs(trans, fs_info, (unsigned long)-1); ret = btrfs_run_delayed_refs(trans, (unsigned long)-1);
if (ret) if (ret)
return ret; return ret;
} }
@ -1617,7 +1616,7 @@ static noinline int create_pending_snapshot(struct btrfs_trans_handle *trans,
goto fail; goto fail;
} }
ret = btrfs_run_delayed_refs(trans, fs_info, (unsigned long)-1); ret = btrfs_run_delayed_refs(trans, (unsigned long)-1);
if (ret) { if (ret) {
btrfs_abort_transaction(trans, ret); btrfs_abort_transaction(trans, ret);
goto fail; goto fail;
@ -1671,7 +1670,7 @@ static noinline int create_pending_snapshot(struct btrfs_trans_handle *trans,
} }
} }
ret = btrfs_run_delayed_refs(trans, fs_info, (unsigned long)-1); ret = btrfs_run_delayed_refs(trans, (unsigned long)-1);
if (ret) { if (ret) {
btrfs_abort_transaction(trans, ret); btrfs_abort_transaction(trans, ret);
goto fail; goto fail;
@ -1954,7 +1953,7 @@ int btrfs_commit_transaction(struct btrfs_trans_handle *trans)
/* make a pass through all the delayed refs we have so far /* make a pass through all the delayed refs we have so far
* any runnings procs may add more while we are here * any runnings procs may add more while we are here
*/ */
ret = btrfs_run_delayed_refs(trans, fs_info, 0); ret = btrfs_run_delayed_refs(trans, 0);
if (ret) { if (ret) {
btrfs_end_transaction(trans); btrfs_end_transaction(trans);
return ret; return ret;
@ -1975,7 +1974,7 @@ int btrfs_commit_transaction(struct btrfs_trans_handle *trans)
if (!list_empty(&trans->new_bgs)) if (!list_empty(&trans->new_bgs))
btrfs_create_pending_block_groups(trans); btrfs_create_pending_block_groups(trans);
ret = btrfs_run_delayed_refs(trans, fs_info, 0); ret = btrfs_run_delayed_refs(trans, 0);
if (ret) { if (ret) {
btrfs_end_transaction(trans); btrfs_end_transaction(trans);
return ret; return ret;
@ -2124,7 +2123,7 @@ int btrfs_commit_transaction(struct btrfs_trans_handle *trans)
goto scrub_continue; goto scrub_continue;
} }
ret = btrfs_run_delayed_refs(trans, fs_info, (unsigned long)-1); ret = btrfs_run_delayed_refs(trans, (unsigned long)-1);
if (ret) { if (ret) {
mutex_unlock(&fs_info->reloc_mutex); mutex_unlock(&fs_info->reloc_mutex);
goto scrub_continue; goto scrub_continue;
@ -2175,7 +2174,7 @@ int btrfs_commit_transaction(struct btrfs_trans_handle *trans)
* commit_fs_roots() can call btrfs_save_ino_cache(), which generates * commit_fs_roots() can call btrfs_save_ino_cache(), which generates
* new delayed refs. Must handle them or qgroup can be wrong. * new delayed refs. Must handle them or qgroup can be wrong.
*/ */
ret = btrfs_run_delayed_refs(trans, fs_info, (unsigned long)-1); ret = btrfs_run_delayed_refs(trans, (unsigned long)-1);
if (ret) { if (ret) {
mutex_unlock(&fs_info->tree_log_mutex); mutex_unlock(&fs_info->tree_log_mutex);
mutex_unlock(&fs_info->reloc_mutex); mutex_unlock(&fs_info->reloc_mutex);