diff options
author | Kevin Wolf <kwolf@redhat.com> | 2018-03-23 15:57:20 +0100 |
---|---|---|
committer | Kevin Wolf <kwolf@redhat.com> | 2018-06-18 15:03:25 +0200 |
commit | dcf94a23b1add0f856db51e9ff5ba0774e096076 (patch) | |
tree | 658311bddefe5487845018e8230a03c4d5d6435b /block.c | |
parent | ebd31837618cdc7bda83090773dcdd87475d55b7 (diff) | |
download | qemu-dcf94a23b1add0f856db51e9ff5ba0774e096076.zip qemu-dcf94a23b1add0f856db51e9ff5ba0774e096076.tar.gz qemu-dcf94a23b1add0f856db51e9ff5ba0774e096076.tar.bz2 |
block: Don't poll in parent drain callbacks
bdrv_do_drained_begin() is only safe if we have a single
BDRV_POLL_WHILE() after quiescing all affected nodes. We cannot allow
that parent callbacks introduce a nested polling loop that could cause
graph changes while we're traversing the graph.
Split off bdrv_do_drained_begin_quiesce(), which only quiesces a single
node without waiting for its requests to complete. These requests will
be waited for in the BDRV_POLL_WHILE() call down the call chain.
Signed-off-by: Kevin Wolf <kwolf@redhat.com>
Diffstat (limited to 'block.c')
-rw-r--r-- | block.c | 2 |
1 files changed, 1 insertions, 1 deletions
@@ -818,7 +818,7 @@ static char *bdrv_child_get_parent_desc(BdrvChild *c) static void bdrv_child_cb_drained_begin(BdrvChild *child) { BlockDriverState *bs = child->opaque; - bdrv_drained_begin(bs); + bdrv_do_drained_begin_quiesce(bs, NULL); } static bool bdrv_child_cb_drained_poll(BdrvChild *child) |