mirror of
https://github.com/torvalds/linux.git
synced 2026-05-31 18:43:33 +02:00
btrfs: avoid recomputing used space in btrfs_try_granting_tickets()
In every iteration of the loop we call btrfs_space_info_used() which sums a bunch of fields from a space_info object. This implies doing a function call besides the sum, and we are holding the space_info's spinlock while we do this, so we want to keep the critical section as short as possible since that spinlock is used in all the code for space reservation and flushing (therefore it's heavily used). So call btrfs_try_granting_tickets() only once, before entering the loop, and then update it as we remove tickets. Reviewed-by: Johannes Thumshirn <johannes.thumshirn@wdc.com> Signed-off-by: Filipe Manana <fdmanana@suse.com> Reviewed-by: David Sterba <dsterba@suse.com> Signed-off-by: David Sterba <dsterba@suse.com>
This commit is contained in:
parent
063171a4f0
commit
60532c2136
|
|
@ -526,6 +526,7 @@ void btrfs_try_granting_tickets(struct btrfs_space_info *space_info)
|
|||
{
|
||||
struct list_head *head;
|
||||
enum btrfs_reserve_flush_enum flush = BTRFS_RESERVE_NO_FLUSH;
|
||||
u64 used = btrfs_space_info_used(space_info, true);
|
||||
|
||||
lockdep_assert_held(&space_info->lock);
|
||||
|
||||
|
|
@ -533,18 +534,20 @@ void btrfs_try_granting_tickets(struct btrfs_space_info *space_info)
|
|||
again:
|
||||
while (!list_empty(head)) {
|
||||
struct reserve_ticket *ticket;
|
||||
u64 used = btrfs_space_info_used(space_info, true);
|
||||
u64 used_after;
|
||||
|
||||
ticket = list_first_entry(head, struct reserve_ticket, list);
|
||||
used_after = used + ticket->bytes;
|
||||
|
||||
/* Check and see if our ticket can be satisfied now. */
|
||||
if ((used + ticket->bytes <= space_info->total_bytes) ||
|
||||
if (used_after <= space_info->total_bytes ||
|
||||
btrfs_can_overcommit(space_info, ticket->bytes, flush)) {
|
||||
btrfs_space_info_update_bytes_may_use(space_info, ticket->bytes);
|
||||
remove_ticket(space_info, ticket);
|
||||
ticket->bytes = 0;
|
||||
space_info->tickets_id++;
|
||||
wake_up(&ticket->wait);
|
||||
used = used_after;
|
||||
} else {
|
||||
break;
|
||||
}
|
||||
|
|
|
|||
Loading…
Reference in New Issue
Block a user