block: add max_hw_transfer to BlockLimits
For block host devices, I/O can happen through either the kernel file
descriptor I/O system calls (preadv/pwritev, io_submit, io_uring)
or the SCSI passthrough ioctl SG_IO.
In the latter case, the size of each transfer can be limited by the
HBA, while for file descriptor I/O the kernel is able to split and
merge I/O in smaller pieces as needed. Applying the HBA limits to
file descriptor I/O results in more system calls and suboptimal
performance, so this patch splits the max_transfer limit in two:
max_transfer remains valid and is used in general, while max_hw_transfer
is limited to the maximum hardware size. max_hw_transfer can then be
included by the scsi-generic driver in the block limits page, to ensure
that the stricter hardware limit is used.
Signed-off-by:
Paolo Bonzini <pbonzini@redhat.com>
Showing
- block/block-backend.c 13 additions, 0 deletionsblock/block-backend.c
- block/file-posix.c 1 addition, 1 deletionblock/file-posix.c
- block/io.c 2 additions, 0 deletionsblock/io.c
- hw/scsi/scsi-generic.c 1 addition, 1 deletionhw/scsi/scsi-generic.c
- include/block/block_int.h 7 additions, 0 deletionsinclude/block/block_int.h
- include/sysemu/block-backend.h 1 addition, 0 deletionsinclude/sysemu/block-backend.h
Please register or sign in to comment