block: Only the main loop can change AioContexts
commit43eaaaef0e18817bf78d8f135993f8579cad2cc6
authorMax Reitz <mreitz@redhat.com>
Mon, 22 Jul 2019 13:30:54 +0000 (22 15:30 +0200)
committerMax Reitz <mreitz@redhat.com>
Mon, 22 Jul 2019 16:41:43 +0000 (22 18:41 +0200)
treed177e7167cf62b61f3aa97d6d7fb7b72225eccf6
parent65181d63817b33b10ecb1c418eb96c99e7cf8842
block: Only the main loop can change AioContexts

bdrv_set_aio_context_ignore() can only work in the main loop:
bdrv_drained_begin() only works in the main loop and the node's (old)
AioContext; and bdrv_drained_end() really only works in the main loop
and the node's (new) AioContext (contrary to its current comment, which
is just wrong).

Consequentially, bdrv_set_aio_context_ignore() must be called from the
main loop.  Luckily, assuming that we can make block graph changes only
from the main loop as well, all its callers do that already.

Note that changing a node's context in a sense is an operation that
changes the block graph, so it actually makes sense to require this
function to be called from the main loop.

Also, fix bdrv_drained_end()'s description.  You can only use it from
the main loop or the node's AioContext, and in the latter case, the
whole subtree must be in the same context.

Fixes: e037c09c78520cbdb6da7cfc6ad0256d5870b814
Signed-off-by: Max Reitz <mreitz@redhat.com>
Message-id: 20190722133054.21781-3-mreitz@redhat.com
Signed-off-by: Max Reitz <mreitz@redhat.com>
block.c
include/block/block.h