btrfs: run delayed iputs when flushing delalloc
authorJosef Bacik <josef@toxicpanda.com>
Wed, 21 Aug 2024 19:53:18 +0000 (15:53 -0400)
committerDavid Sterba <dsterba@suse.com>
Sun, 25 Aug 2024 17:15:34 +0000 (19:15 +0200)
commit2d3447261031503b181dacc549fe65ffe2d93d65
treef5c76e6bdb4ee2fe2450880a892efd979791d5fb
parent534f7eff9239c1b0af852fc33f5af2b62c00eddf
btrfs: run delayed iputs when flushing delalloc

We have transient failures with btrfs/301, specifically in the part
where we do

  for i in $(seq 0 10); do
  write 50m to file
  rm -f file
  done

Sometimes this will result in a transient quota error, and it's because
sometimes we start writeback on the file which results in a delayed
iput, and thus the rm doesn't actually clean the file up.  When we're
flushing the quota space we need to run the delayed iputs to make sure
all the unlinks that we think have completed have actually completed.
This removes the small window where we could fail to find enough space
in our quota.

CC: stable@vger.kernel.org # 5.15+
Reviewed-by: Qu Wenruo <wqu@suse.com>
Signed-off-by: Josef Bacik <josef@toxicpanda.com>
Signed-off-by: David Sterba <dsterba@suse.com>
fs/btrfs/qgroup.c