Commit eb81b682 authored by Filipe Manana's avatar Filipe Manana Committed by David Sterba

btrfs: fix inode reserve space leak due to nowait buffered write

During a nowait buffered write, if we fail to balance dirty pages we exit
btrfs_buffered_write() without releasing the delalloc space reserved for
an extent, resulting in leaking space from the inode's block reserve.

So fix that by releasing the delalloc space for the extent when balancing
dirty pages fails.
Reported-by: default avatarkernel test robot <yujie.liu@intel.com>
Link: https://lore.kernel.org/all/202210111304.d369bc32-yujie.liu@intel.com
Fixes: 965f47ae ("btrfs: make btrfs_buffered_write nowait compatible")
Reviewed-by: default avatarJosef Bacik <josef@toxicpanda.com>
Signed-off-by: default avatarFilipe Manana <fdmanana@suse.com>
Signed-off-by: default avatarDavid Sterba <dsterba@suse.com>
parent a348c8d4
...@@ -1607,8 +1607,10 @@ static noinline ssize_t btrfs_buffered_write(struct kiocb *iocb, ...@@ -1607,8 +1607,10 @@ static noinline ssize_t btrfs_buffered_write(struct kiocb *iocb,
release_bytes = reserve_bytes; release_bytes = reserve_bytes;
again: again:
ret = balance_dirty_pages_ratelimited_flags(inode->i_mapping, bdp_flags); ret = balance_dirty_pages_ratelimited_flags(inode->i_mapping, bdp_flags);
if (ret) if (ret) {
btrfs_delalloc_release_extents(BTRFS_I(inode), reserve_bytes);
break; break;
}
/* /*
* This is going to setup the pages array with the number of * This is going to setup the pages array with the number of
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment