v4: Drop patch 1. [Cornelia]
Add the last trivial patch.
v3: Rebase to master.
Squash 4 into 3. [Paolo]
Add comment and commit message. [Stefan]
Add Stefan's r-b in patch 1 and 2.
v2: Only convert virtio-{blk,scsi}. [Paolo]
The benifit of this is we don't use event_notifier_set_handler even in
non-dataplane now, which in turn makes virtio-blk and virtio-scsi follow block
layer aio context semantics. Specifically, I/O requests must come from
blk_get_aio_context(blk) events, rather than iohandler_get_aio_context(), so
that bdrv_drained_begin/end will work as expected.
Patch 4 reverts the hack (ab27c3b5e7) we added for 2.6. Lately, commit
b880481579 added another pair of bdrv_drained_begin/end so the crash cannot
happen even without ab27c3b5e7, but in order to avoid leaking requests, patch
two is still a must.
Fam Zheng (6):
virtio: Add typedef for handle_output
virtio: Introduce virtio_add_queue_aio
virtio-blk: Call virtio_add_queue_aio
virtio-scsi: Call virtio_add_queue_aio
Revert "mirror: Workaround for unexpected iohandler events during
completion"
virtio-scsi: Replace HandleOutput typedef
block/mirror.c | 9 ---------
hw/block/virtio-blk.c | 2 +-
hw/scsi/virtio-scsi.c | 14 ++++++-------
hw/virtio/virtio.c | 45 +++++++++++++++++++++++++++++++++--------
include/hw/virtio/virtio-scsi.h | 6 ++----
include/hw/virtio/virtio.h | 8 ++++++--
6 files changed, 52 insertions(+), 32 deletions(-)
--
2.7.4