diff options
author | Fam Zheng <famz@redhat.com> | 2014-09-11 13:41:08 +0800 |
---|---|---|
committer | Stefan Hajnoczi <stefanha@redhat.com> | 2014-09-22 11:38:57 +0100 |
commit | f197fe2b2c77259b6570620f288d905bfa38e2da (patch) | |
tree | e9dcfaa75bbd9bc93ae309bbd2129207dc1e36b6 | |
parent | 0d910cfeaf2076b116b4517166d5deb0fea76394 (diff) | |
download | qemu-f197fe2b2c77259b6570620f288d905bfa38e2da.zip qemu-f197fe2b2c77259b6570620f288d905bfa38e2da.tar.gz qemu-f197fe2b2c77259b6570620f288d905bfa38e2da.tar.bz2 |
block: Add refcnt in BlockDriverAIOCB
This will be useful in synchronous cancel emulation with
bdrv_aio_cancel_async.
Signed-off-by: Fam Zheng <famz@redhat.com>
Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com>
-rw-r--r-- | block.c | 12 | ||||
-rw-r--r-- | include/block/aio.h | 2 |
2 files changed, 13 insertions, 1 deletions
@@ -4891,13 +4891,23 @@ void *qemu_aio_get(const AIOCBInfo *aiocb_info, BlockDriverState *bs, acb->bs = bs; acb->cb = cb; acb->opaque = opaque; + acb->refcnt = 1; return acb; } +void qemu_aio_ref(void *p) +{ + BlockDriverAIOCB *acb = p; + acb->refcnt++; +} + void qemu_aio_release(void *p) { BlockDriverAIOCB *acb = p; - g_slice_free1(acb->aiocb_info->aiocb_size, acb); + assert(acb->refcnt > 0); + if (--acb->refcnt == 0) { + g_slice_free1(acb->aiocb_info->aiocb_size, acb); + } } /**************************************************************/ diff --git a/include/block/aio.h b/include/block/aio.h index 4603c0f..2626fc7 100644 --- a/include/block/aio.h +++ b/include/block/aio.h @@ -35,11 +35,13 @@ struct BlockDriverAIOCB { BlockDriverState *bs; BlockDriverCompletionFunc *cb; void *opaque; + int refcnt; }; void *qemu_aio_get(const AIOCBInfo *aiocb_info, BlockDriverState *bs, BlockDriverCompletionFunc *cb, void *opaque); void qemu_aio_release(void *p); +void qemu_aio_ref(void *p); typedef struct AioHandler AioHandler; typedef void QEMUBHFunc(void *opaque); |