mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-11-24 04:20:53 +07:00
btrfs: merge critical sections of discard lock in workfn
[ Upstream commit 8fc058597a283e9a37720abb0e8d68e342b9387d ] btrfs_discard_workfn() drops discard_ctl->lock just to take it again in a moment in btrfs_discard_schedule_work(). Avoid that and also reuse ktime. Reviewed-by: Josef Bacik <josef@toxicpanda.com> Signed-off-by: Pavel Begunkov <asml.silence@gmail.com> Reviewed-by: David Sterba <dsterba@suse.com> Signed-off-by: David Sterba <dsterba@suse.com> Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
parent
33061bd104
commit
f89d84b35a
@ -328,28 +328,15 @@ void btrfs_discard_queue_work(struct btrfs_discard_ctl *discard_ctl,
|
|||||||
btrfs_discard_schedule_work(discard_ctl, false);
|
btrfs_discard_schedule_work(discard_ctl, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
static void __btrfs_discard_schedule_work(struct btrfs_discard_ctl *discard_ctl,
|
||||||
* btrfs_discard_schedule_work - responsible for scheduling the discard work
|
u64 now, bool override)
|
||||||
* @discard_ctl: discard control
|
|
||||||
* @override: override the current timer
|
|
||||||
*
|
|
||||||
* Discards are issued by a delayed workqueue item. @override is used to
|
|
||||||
* update the current delay as the baseline delay interval is reevaluated on
|
|
||||||
* transaction commit. This is also maxed with any other rate limit.
|
|
||||||
*/
|
|
||||||
void btrfs_discard_schedule_work(struct btrfs_discard_ctl *discard_ctl,
|
|
||||||
bool override)
|
|
||||||
{
|
{
|
||||||
struct btrfs_block_group *block_group;
|
struct btrfs_block_group *block_group;
|
||||||
const u64 now = ktime_get_ns();
|
|
||||||
|
|
||||||
spin_lock(&discard_ctl->lock);
|
|
||||||
|
|
||||||
if (!btrfs_run_discard_work(discard_ctl))
|
if (!btrfs_run_discard_work(discard_ctl))
|
||||||
goto out;
|
return;
|
||||||
|
|
||||||
if (!override && delayed_work_pending(&discard_ctl->work))
|
if (!override && delayed_work_pending(&discard_ctl->work))
|
||||||
goto out;
|
return;
|
||||||
|
|
||||||
block_group = find_next_block_group(discard_ctl, now);
|
block_group = find_next_block_group(discard_ctl, now);
|
||||||
if (block_group) {
|
if (block_group) {
|
||||||
@ -382,7 +369,24 @@ void btrfs_discard_schedule_work(struct btrfs_discard_ctl *discard_ctl,
|
|||||||
mod_delayed_work(discard_ctl->discard_workers,
|
mod_delayed_work(discard_ctl->discard_workers,
|
||||||
&discard_ctl->work, delay);
|
&discard_ctl->work, delay);
|
||||||
}
|
}
|
||||||
out:
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* btrfs_discard_schedule_work - responsible for scheduling the discard work
|
||||||
|
* @discard_ctl: discard control
|
||||||
|
* @override: override the current timer
|
||||||
|
*
|
||||||
|
* Discards are issued by a delayed workqueue item. @override is used to
|
||||||
|
* update the current delay as the baseline delay interval is reevaluated on
|
||||||
|
* transaction commit. This is also maxed with any other rate limit.
|
||||||
|
*/
|
||||||
|
void btrfs_discard_schedule_work(struct btrfs_discard_ctl *discard_ctl,
|
||||||
|
bool override)
|
||||||
|
{
|
||||||
|
const u64 now = ktime_get_ns();
|
||||||
|
|
||||||
|
spin_lock(&discard_ctl->lock);
|
||||||
|
__btrfs_discard_schedule_work(discard_ctl, now, override);
|
||||||
spin_unlock(&discard_ctl->lock);
|
spin_unlock(&discard_ctl->lock);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -487,9 +491,8 @@ static void btrfs_discard_workfn(struct work_struct *work)
|
|||||||
|
|
||||||
spin_lock(&discard_ctl->lock);
|
spin_lock(&discard_ctl->lock);
|
||||||
discard_ctl->block_group = NULL;
|
discard_ctl->block_group = NULL;
|
||||||
|
__btrfs_discard_schedule_work(discard_ctl, now, false);
|
||||||
spin_unlock(&discard_ctl->lock);
|
spin_unlock(&discard_ctl->lock);
|
||||||
|
|
||||||
btrfs_discard_schedule_work(discard_ctl, false);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
Loading…
Reference in New Issue
Block a user