xfs: speed up rmap lookups by using non-overlapped lookups when possible
authorDarrick J. Wong <djwong@kernel.org>
Tue, 26 Apr 2022 01:37:06 +0000 (18:37 -0700)
committerDarrick J. Wong <djwong@kernel.org>
Wed, 27 Apr 2022 17:47:19 +0000 (10:47 -0700)
commit75d893d19c8e1b4bf4a9acd613fe5e7a80b58974
tree38de9024465fc6915315fbf152273bc4fef69392
parent5b7ca8b313621907d80460bfcc1fa876d2a38488
xfs: speed up rmap lookups by using non-overlapped lookups when possible

Reverse mapping on a reflink-capable filesystem has some pretty high
overhead when performing file operations.  This is because the rmap
records for logically and physically adjacent extents might not be
adjacent in the rmap index due to data block sharing.  As a result, we
use expensive overlapped-interval btree search, which walks every record
that overlaps with the supplied key in the hopes of finding the record.

However, profiling data shows that when the index contains a record that
is an exact match for a query key, the non-overlapped btree search
function can find the record much faster than the overlapped version.
Try the non-overlapped lookup first, which will make scrub run much
faster.

Signed-off-by: Darrick J. Wong <djwong@kernel.org>
Reviewed-by: Dave Chinner <dchinner@redhat.com>
Reviewed-by: Christoph Hellwig <hch@lst.de>
fs/xfs/libxfs/xfs_rmap.c