diff options
author | Kevin Wolf <kwolf@redhat.com> | 2017-12-06 17:05:44 +0100 |
---|---|---|
committer | Kevin Wolf <kwolf@redhat.com> | 2017-12-22 15:05:32 +0100 |
commit | b0165585900f050f403cecba9d89adeccf35dd6c (patch) | |
tree | 82a19acb79e687005a43bdaed32f8c34fdcde05f /include/block/block.h | |
parent | 0152bf400fe3ca7facb382683bfcccda70ebf51a (diff) | |
download | qemu-b0165585900f050f403cecba9d89adeccf35dd6c.zip qemu-b0165585900f050f403cecba9d89adeccf35dd6c.tar.gz qemu-b0165585900f050f403cecba9d89adeccf35dd6c.tar.bz2 |
block: Add bdrv_subtree_drained_begin/end()
bdrv_drained_begin() waits for the completion of requests in the whole
subtree, but it only actually keeps its immediate bs parameter quiesced
until bdrv_drained_end().
Add a version that keeps the whole subtree drained. As of this commit,
graph changes cannot be allowed during a subtree drained section, but
this will be fixed soon.
Signed-off-by: Kevin Wolf <kwolf@redhat.com>
Diffstat (limited to 'include/block/block.h')
-rw-r--r-- | include/block/block.h | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/include/block/block.h b/include/block/block.h index 60c5d11..de9c5a2 100644 --- a/include/block/block.h +++ b/include/block/block.h @@ -608,12 +608,25 @@ void bdrv_parent_drained_end(BlockDriverState *bs, BdrvChild *ignore); void bdrv_drained_begin(BlockDriverState *bs); /** + * Like bdrv_drained_begin, but recursively begins a quiesced section for + * exclusive access to all child nodes as well. + * + * Graph changes are not allowed during a subtree drain section. + */ +void bdrv_subtree_drained_begin(BlockDriverState *bs); + +/** * bdrv_drained_end: * * End a quiescent section started by bdrv_drained_begin(). */ void bdrv_drained_end(BlockDriverState *bs); +/** + * End a quiescent section started by bdrv_subtree_drained_begin(). + */ +void bdrv_subtree_drained_end(BlockDriverState *bs); + void bdrv_add_child(BlockDriverState *parent, BlockDriverState *child, Error **errp); void bdrv_del_child(BlockDriverState *parent, BdrvChild *child, Error **errp); |