Commit e3e469f8 authored by Josef Bacik's avatar Josef Bacik Committed by Chris Mason

Btrfs: fix free space leak

In my batch delete/update/insert patch I introduced a free space leak.  The
extent that we do the original search on in free_extents is never pinned, so we
always update the block saying that it has free space, but the free space never
actually gets added to the free space tree, since op->del will always be 0 and
it's never actually added to the pinned extents tree.

This patch fixes this problem by making sure we call pin_down_bytes on the
pending extent op and set op->del to the return value of pin_down_bytes so
update_block_group is called with the right value.  This seems to fix the case
where we were getting ENOSPC when there was plenty of space available.
Signed-off-by: default avatarJosef Bacik <jbacik@redhat.com>
parent 7cbd8a83
...@@ -999,6 +999,14 @@ static int noinline free_extents(struct btrfs_trans_handle *trans, ...@@ -999,6 +999,14 @@ static int noinline free_extents(struct btrfs_trans_handle *trans,
path->slots[0] = extent_slot; path->slots[0] = extent_slot;
bytes_freed = op->num_bytes; bytes_freed = op->num_bytes;
mutex_lock(&info->pinned_mutex);
ret = pin_down_bytes(trans, extent_root, op->bytenr,
op->num_bytes, op->level >=
BTRFS_FIRST_FREE_OBJECTID);
mutex_unlock(&info->pinned_mutex);
BUG_ON(ret < 0);
op->del = ret;
/* /*
* we need to see if we can delete multiple things at once, so * we need to see if we can delete multiple things at once, so
* start looping through the list of extents we are wanting to * start looping through the list of extents we are wanting to
......
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