Commit b611fddc authored by Christoph Hellwig's avatar Christoph Hellwig Committed by Carlos Maiolino

xfs: don't ifdef around the exact minlen allocations

Exact minlen allocations only exist as an error injection tool for debug
builds.  Currently this is implemented using ifdefs, which means the code
isn't even compiled for non-XFS_DEBUG builds.  Enhance the compile test
coverage by always building the code and use the compilers' dead code
elimination to remove it from the generated binary instead.

The only downside is that the alloc_minlen_only field is unconditionally
added to struct xfs_alloc_args now, but by moving it around and packing
it tightly this doesn't actually increase the size of the structure.
Signed-off-by: default avatarChristoph Hellwig <hch@lst.de>
Reviewed-by: default avatarDarrick J. Wong <djwong@kernel.org>
Signed-off-by: default avatarCarlos Maiolino <cem@kernel.org>
parent 865469cd
...@@ -2766,7 +2766,6 @@ xfs_alloc_commit_autoreap( ...@@ -2766,7 +2766,6 @@ xfs_alloc_commit_autoreap(
xfs_defer_item_unpause(tp, aarp->dfp); xfs_defer_item_unpause(tp, aarp->dfp);
} }
#ifdef DEBUG
/* /*
* Check if an AGF has a free extent record whose length is equal to * Check if an AGF has a free extent record whose length is equal to
* args->minlen. * args->minlen.
...@@ -2806,7 +2805,6 @@ xfs_exact_minlen_extent_available( ...@@ -2806,7 +2805,6 @@ xfs_exact_minlen_extent_available(
return error; return error;
} }
#endif
/* /*
* Decide whether to use this allocation group for this allocation. * Decide whether to use this allocation group for this allocation.
...@@ -2880,15 +2878,14 @@ xfs_alloc_fix_freelist( ...@@ -2880,15 +2878,14 @@ xfs_alloc_fix_freelist(
if (!xfs_alloc_space_available(args, need, alloc_flags)) if (!xfs_alloc_space_available(args, need, alloc_flags))
goto out_agbp_relse; goto out_agbp_relse;
#ifdef DEBUG if (IS_ENABLED(CONFIG_XFS_DEBUG) && args->alloc_minlen_only) {
if (args->alloc_minlen_only) {
int stat; int stat;
error = xfs_exact_minlen_extent_available(args, agbp, &stat); error = xfs_exact_minlen_extent_available(args, agbp, &stat);
if (error || !stat) if (error || !stat)
goto out_agbp_relse; goto out_agbp_relse;
} }
#endif
/* /*
* Make the freelist shorter if it's too long. * Make the freelist shorter if it's too long.
* *
......
...@@ -53,11 +53,9 @@ typedef struct xfs_alloc_arg { ...@@ -53,11 +53,9 @@ typedef struct xfs_alloc_arg {
int datatype; /* mask defining data type treatment */ int datatype; /* mask defining data type treatment */
char wasdel; /* set if allocation was prev delayed */ char wasdel; /* set if allocation was prev delayed */
char wasfromfl; /* set if allocation is from freelist */ char wasfromfl; /* set if allocation is from freelist */
bool alloc_minlen_only; /* allocate exact minlen extent */
struct xfs_owner_info oinfo; /* owner of blocks being allocated */ struct xfs_owner_info oinfo; /* owner of blocks being allocated */
enum xfs_ag_resv_type resv; /* block reservation to use */ enum xfs_ag_resv_type resv; /* block reservation to use */
#ifdef DEBUG
bool alloc_minlen_only; /* allocate exact minlen extent */
#endif
} xfs_alloc_arg_t; } xfs_alloc_arg_t;
/* /*
......
...@@ -3477,7 +3477,6 @@ xfs_bmap_process_allocated_extent( ...@@ -3477,7 +3477,6 @@ xfs_bmap_process_allocated_extent(
xfs_bmap_alloc_account(ap); xfs_bmap_alloc_account(ap);
} }
#ifdef DEBUG
static int static int
xfs_bmap_exact_minlen_extent_alloc( xfs_bmap_exact_minlen_extent_alloc(
struct xfs_bmalloca *ap) struct xfs_bmalloca *ap)
...@@ -3539,11 +3538,6 @@ xfs_bmap_exact_minlen_extent_alloc( ...@@ -3539,11 +3538,6 @@ xfs_bmap_exact_minlen_extent_alloc(
return 0; return 0;
} }
#else
#define xfs_bmap_exact_minlen_extent_alloc(bma) (-EFSCORRUPTED)
#endif
/* /*
* If we are not low on available data blocks and we are allocating at * If we are not low on available data blocks and we are allocating at
......
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