diff options
author | Alexander Motin <[email protected]> | 2021-07-07 19:39:00 -0400 |
---|---|---|
committer | Tony Hutter <[email protected]> | 2021-09-14 12:37:02 -0700 |
commit | c84670950ad8c0c5bc1e65d81b3727bfa791d8f9 (patch) | |
tree | 6c3b6ba3f85e5dcfecaa549ac525ee45c08fef5d /include | |
parent | 49bb454120d994ba87d171689f017a7b48f706e3 (diff) |
FreeBSD: Use unmapped I/O for scattered/gang ABD buffers
Many FreeBSD disk drivers support "unmapped" I/O mode, when data
buffer represented not with a virtually contiguous KVA-mapped address
range, but with a list of physical memory pages. Originally it was
designed to do I/O from buffers without KVA mapping (unmapped). But
moving virtual addresses out of equation allows us to operate even
non-contiguous data buffers with one condition: all buffer discon-
tinuities must be aligned to memory page borders.
Doing I/O to capable GEOM device this patch traverses through non-
linear ABD buffers, validating the chunks borders. If the condition
is met, it supplies GEOM with the list of original physical memory
pages instead of copying the data into temporary contiguous buffer.
On capable hardware on pools with ashift=12 and default ABD chunk of
4KB it should handle all the I/O without additional memory copying.
Reviewed-by: Brian Atkinson <[email protected]>
Reviewed-by: Ryan Moeller <[email protected]>
Signed-off-by: Alexander Motin <[email protected]>
Closes #12320
Diffstat (limited to 'include')
0 files changed, 0 insertions, 0 deletions