diff options
author | Dave Chinner <dchinner@redhat.com> | 2011-04-21 05:34:28 -0400 |
---|---|---|
committer | Alex Elder <aelder@sgi.com> | 2011-05-19 13:03:48 -0400 |
commit | bf59170a66bc3eaf3ee513aa6ce9774aa2ab5188 (patch) | |
tree | aae7b19e61ea88cddf4ba5508ef971c767f15b4d /fs | |
parent | 44396476a0f24e5174768d3732f1958857c26d22 (diff) |
xfs: obey minleft values during extent allocation correctly
When allocating an extent that is long enough to consume the
remaining free space in an AG, we need to ensure that the allocation
leaves enough space in the AG for any subsequent bmap btree blocks
that are needed to track the new extent. These have to be allocated
in the same AG as we only reserve enough blocks in an allocation
transaction for modification of the freespace trees in a single AG.
xfs_alloc_fix_minleft() has been considering blocks on the AGFL as
free blocks available for extent and bmbt block allocation, which is
not correct - blocks on the AGFL are there exclusively for the use
of the free space btrees. As a result, when minleft is less than the
number of blocks on the AGFL, xfs_alloc_fix_minleft() does not trim
the given extent to leave minleft blocks available for bmbt
allocation, and hence we can fail allocation during bmbt record
insertion.
Signed-off-by: Dave Chinner <dchinner@redhat.com>
Reviewed-by: Christoph Hellwig <hch@lst.de>
Signed-off-by: Alex Elder <aelder@sgi.com>
Diffstat (limited to 'fs')
-rw-r--r-- | fs/xfs/xfs_alloc.c | 1 |
1 files changed, 0 insertions, 1 deletions
diff --git a/fs/xfs/xfs_alloc.c b/fs/xfs/xfs_alloc.c index 44a51a7b4c3a..acdced86413c 100644 --- a/fs/xfs/xfs_alloc.c +++ b/fs/xfs/xfs_alloc.c | |||
@@ -276,7 +276,6 @@ xfs_alloc_fix_minleft( | |||
276 | return 1; | 276 | return 1; |
277 | agf = XFS_BUF_TO_AGF(args->agbp); | 277 | agf = XFS_BUF_TO_AGF(args->agbp); |
278 | diff = be32_to_cpu(agf->agf_freeblks) | 278 | diff = be32_to_cpu(agf->agf_freeblks) |
279 | + be32_to_cpu(agf->agf_flcount) | ||
280 | - args->len - args->minleft; | 279 | - args->len - args->minleft; |
281 | if (diff >= 0) | 280 | if (diff >= 0) |
282 | return 1; | 281 | return 1; |