summaryrefslogtreecommitdiffstats
path: root/scripts/qapi-gen.py
diff options
context:
space:
mode:
authorStefan Hajnoczi2018-03-07 15:42:03 +0100
committerStefan Hajnoczi2018-03-08 18:38:51 +0100
commit1010cadf62332017648abee0d7a3dc7f2eef9632 (patch)
tree8c4e09b21136d13a26c6d00c4b87d693781e993d /scripts/qapi-gen.py
parentblock: add aio_wait_bh_oneshot() (diff)
downloadqemu-1010cadf62332017648abee0d7a3dc7f2eef9632.tar.gz
qemu-1010cadf62332017648abee0d7a3dc7f2eef9632.tar.xz
qemu-1010cadf62332017648abee0d7a3dc7f2eef9632.zip
virtio-blk: fix race between .ioeventfd_stop() and vq handler
If the main loop thread invokes .ioeventfd_stop() just as the vq handler function begins in the IOThread then the handler may lose the race for the AioContext lock. By the time the vq handler is able to acquire the AioContext lock the ioeventfd has already been removed and the handler isn't supposed to run anymore! Use the new aio_wait_bh_oneshot() function to perform ioeventfd removal from within the IOThread. This way no races with the vq handler are possible. Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com> Reviewed-by: Fam Zheng <famz@redhat.com> Acked-by: Paolo Bonzini <pbonzini@redhat.com> Message-id: 20180307144205.20619-3-stefanha@redhat.com Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com>
Diffstat (limited to 'scripts/qapi-gen.py')
0 files changed, 0 insertions, 0 deletions