]> git.proxmox.com Git - mirror_qemu.git/commit - job.c
block: Use a single global AioWait
authorKevin Wolf <kwolf@redhat.com>
Tue, 18 Sep 2018 15:09:16 +0000 (17:09 +0200)
committerKevin Wolf <kwolf@redhat.com>
Tue, 25 Sep 2018 13:50:15 +0000 (15:50 +0200)
commitcfe29d8294e06420e15d4938421ae006c8ac49e7
tree98c0ebb7866f1c3066de2ddfe1a01c8f04375bbf
parent5599c162c3bec2bc8f0123e4d5802a70d9984b3b
block: Use a single global AioWait

When draining a block node, we recurse to its parent and for subtree
drains also to its children. A single AIO_WAIT_WHILE() is then used to
wait for bdrv_drain_poll() to become true, which depends on all of the
nodes we recursed to. However, if the respective child or parent becomes
quiescent and calls bdrv_wakeup(), only the AioWait of the child/parent
is checked, while AIO_WAIT_WHILE() depends on the AioWait of the
original node.

Fix this by using a single AioWait for all callers of AIO_WAIT_WHILE().

This may mean that the draining thread gets a few more unnecessary
wakeups because an unrelated operation got completed, but we already
wake it up when something _could_ have changed rather than only if it
has certainly changed.

Apart from that, drain is a slow path anyway. In theory it would be
possible to use wakeups more selectively and still correctly, but the
gains are likely not worth the additional complexity. In fact, this
patch is a nice simplification for some places in the code.

Signed-off-by: Kevin Wolf <kwolf@redhat.com>
Reviewed-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Max Reitz <mreitz@redhat.com>
block.c
block/block-backend.c
block/io.c
blockjob.c
include/block/aio-wait.h
include/block/block.h
include/block/block_int.h
include/block/blockjob.h
job.c
util/aio-wait.c