btrfs: reduce critical section at btrfs_wait_ordered_roots()
authorFilipe Manana <fdmanana@suse.com>
Mon, 3 Jun 2024 12:25:00 +0000 (13:25 +0100)
committerDavid Sterba <dsterba@suse.com>
Thu, 11 Jul 2024 13:33:22 +0000 (15:33 +0200)
At btrfs_wait_ordered_roots(), there's no point in decrementing the
counter after locking fs_info->ordered_root_lock as the counter is local.
So change this to decrement the counter before taking the lock.

Reviewed-by: Josef Bacik <josef@toxicpanda.com>
Reviewed-by: Qu Wenruo <wqu@suse.com>
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>
fs/btrfs/ordered-data.c

index 65d0464..15428a8 100644 (file)
@@ -829,10 +829,10 @@ void btrfs_wait_ordered_roots(struct btrfs_fs_info *fs_info, u64 nr,
                done = btrfs_wait_ordered_extents(root, nr, bg);
                btrfs_put_root(root);
 
-               spin_lock(&fs_info->ordered_root_lock);
-               if (nr != U64_MAX) {
+               if (nr != U64_MAX)
                        nr -= done;
-               }
+
+               spin_lock(&fs_info->ordered_root_lock);
        }
        list_splice_tail(&splice, &fs_info->ordered_roots);
        spin_unlock(&fs_info->ordered_root_lock);