summaryrefslogtreecommitdiff
path: root/fs/xfs/xfs_mount.h
diff options
context:
space:
mode:
authorDarrick J. Wong <djwong@kernel.org>2023-08-10 07:48:07 -0700
committerDarrick J. Wong <djwong@kernel.org>2023-08-10 07:48:07 -0700
commit764018caa99f7629cefc92257a26b83289a674f3 (patch)
treee7ff249e79fc61f4e4cad115e4611cf634a9a73b /fs/xfs/xfs_mount.h
parentcf36f4f64c2d4e928b6fdfff06d8e21561e3e32f (diff)
downloadlwn-764018caa99f7629cefc92257a26b83289a674f3.tar.gz
lwn-764018caa99f7629cefc92257a26b83289a674f3.zip
xfs: improve xfarray quicksort pivot
Now that we have the means to do insertion sorts of small in-memory subsets of an xfarray, use it to improve the quicksort pivot algorithm by reading 7 records into memory and finding the median of that. This should prevent bad partitioning when a[lo] and a[hi] end up next to each other in the final sort, which can happen when sorting for cntbt repair when the free space is extremely fragmented (e.g. generic/176). This doesn't speed up the average quicksort run by much, but it will (hopefully) avoid the quadratic time collapse for which quicksort is famous. Signed-off-by: Darrick J. Wong <djwong@kernel.org> Reviewed-by: Kent Overstreet <kent.overstreet@linux.dev> Reviewed-by: Dave Chinner <dchinner@redhat.com>
Diffstat (limited to 'fs/xfs/xfs_mount.h')
0 files changed, 0 insertions, 0 deletions