diff options
author | Paolo Bonzini <pbonzini@redhat.com> | 2020-04-07 10:07:45 -0400 |
---|---|---|
committer | Stefan Hajnoczi <stefanha@redhat.com> | 2020-04-09 16:16:28 +0100 |
commit | 3c18a92dc4b55ca8cc37a755ed119f11c0f34099 (patch) | |
tree | 1153ea1812c170bcc50e72820bae2d585827c0a0 /util/aio-win32.c | |
parent | 636b836d5f4e36ceebb788e2e0d4724f7f9406e1 (diff) |
aio-wait: delegate polling of main AioContext if BQL not held
Any thread that is not a iothread returns NULL for qemu_get_current_aio_context().
As a result, it would also return true for
in_aio_context_home_thread(qemu_get_aio_context()), causing
AIO_WAIT_WHILE to invoke aio_poll() directly. This is incorrect
if the BQL is not held, because aio_poll() does not expect to
run concurrently from multiple threads, and it can actually
happen when savevm writes to the vmstate file from the
migration thread.
Therefore, restrict in_aio_context_home_thread to return true
for the main AioContext only if the BQL is held.
The function is moved to aio-wait.h because it is mostly used
there and to avoid a circular reference between main-loop.h
and block/aio.h.
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
Message-Id: <20200407140746.8041-5-pbonzini@redhat.com>
Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com>
Diffstat (limited to 'util/aio-win32.c')
0 files changed, 0 insertions, 0 deletions