diff options
| author | Fam Zheng | 2014-09-11 07:41:22 +0200 |
|---|---|---|
| committer | Stefan Hajnoczi | 2014-09-22 12:39:13 +0200 |
| commit | 7940e5056bfdb5d2861774e294d5459952cd0aee (patch) | |
| tree | 9bc42d3d09e067306f1eeb83e48835701d7b940f /block | |
| parent | quorum: fix quorum_aio_cancel() (diff) | |
| download | qemu-7940e5056bfdb5d2861774e294d5459952cd0aee.tar.gz qemu-7940e5056bfdb5d2861774e294d5459952cd0aee.tar.xz qemu-7940e5056bfdb5d2861774e294d5459952cd0aee.zip | |
quorum: Convert quorum_aiocb_info.cancel to .cancel_async
Before, we cancel all the child requests with bdrv_aio_cancel, then free
the acb..
Now we just kick off asynchronous cancellation of child requests and
return, we know quorum_aio_cb will be called later, so in the end
quorum_aio_finalize will take care of calling the caller's cb.
Signed-off-by: Fam Zheng <famz@redhat.com>
Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com>
Diffstat (limited to 'block')
| -rw-r--r-- | block/quorum.c | 7 |
1 files changed, 2 insertions, 5 deletions
diff --git a/block/quorum.c b/block/quorum.c index 41c4249547..f343c04c53 100644 --- a/block/quorum.c +++ b/block/quorum.c @@ -139,17 +139,14 @@ static void quorum_aio_cancel(BlockDriverAIOCB *blockacb) /* cancel all callbacks */ for (i = 0; i < s->num_children; i++) { if (acb->qcrs[i].aiocb) { - bdrv_aio_cancel(acb->qcrs[i].aiocb); + bdrv_aio_cancel_async(acb->qcrs[i].aiocb); } } - - g_free(acb->qcrs); - qemu_aio_release(acb); } static AIOCBInfo quorum_aiocb_info = { .aiocb_size = sizeof(QuorumAIOCB), - .cancel = quorum_aio_cancel, + .cancel_async = quorum_aio_cancel, }; static void quorum_aio_finalize(QuorumAIOCB *acb) |
