hw/dma: Let dma_buf_read() / dma_buf_write() propagate MemTxResult
commitf02b664aad8f1aaafbcdf45285f6fcab0a4bd5d0
authorPhilippe Mathieu-Daudé <philmd@redhat.com>
Thu, 16 Dec 2021 08:36:38 +0000 (16 09:36 +0100)
committerPhilippe Mathieu-Daudé <f4bug@amsat.org>
Tue, 18 Jan 2022 11:56:29 +0000 (18 12:56 +0100)
tree74a5d84b75aaaf285161545e6188ef5327d144f4
parentbfa30f3903e0542611196b21f5832a4be5775a21
hw/dma: Let dma_buf_read() / dma_buf_write() propagate MemTxResult

Since commit 292e13142d2, dma_buf_rw() returns a MemTxResult type.
Do not discard it, return it to the caller. Pass the previously
returned value (the QEMUSGList residual size, which was rarely used)
as an optional argument.

With this new API, SCSIRequest::residual might now be accessed via
a pointer. Since the size_t type does not have the same size on
32 and 64-bit host architectures, convert it to a uint64_t, which
is big enough to hold the residual size, and the type is constant
on both 32/64-bit hosts.

Update the few dma_buf_read() / dma_buf_write() callers to the new
API.

Reviewed-by: Klaus Jensen <k.jensen@samsung.com>
Signed-off-by: Philippe Mathieu-Daudé <philmd@redhat.com>
Signed-off-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
Acked-by: Peter Xu <peterx@redhat.com>
Message-Id: <20220117125130.131828-1-f4bug@amsat.org>
hw/ide/ahci.c
hw/nvme/ctrl.c
hw/scsi/megasas.c
hw/scsi/scsi-bus.c
include/hw/scsi/scsi.h
include/sysemu/dma.h
softmmu/dma-helpers.c