block: Use blk_co_flush() for all BB level flushes
All read/write functions already have a single coroutine-based function on the BlockBackend level through which all requests go (no matter what API style the external caller used) and which passes the requests down to the block node level. This patch extends this mode of operation to flushes. Signed-off-by: Kevin Wolf <kwolf@redhat.com> Reviewed-by: Eric Blake <eblake@redhat.com>
This commit is contained in:
parent
5929d7e8a0
commit
be07a88981
@ -1099,14 +1099,19 @@ BlockAIOCB *blk_aio_pwritev(BlockBackend *blk, int64_t offset,
|
|||||||
blk_aio_write_entry, flags, cb, opaque);
|
blk_aio_write_entry, flags, cb, opaque);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void blk_aio_flush_entry(void *opaque)
|
||||||
|
{
|
||||||
|
BlkAioEmAIOCB *acb = opaque;
|
||||||
|
BlkRwCo *rwco = &acb->rwco;
|
||||||
|
|
||||||
|
rwco->ret = blk_co_flush(rwco->blk);
|
||||||
|
blk_aio_complete(acb);
|
||||||
|
}
|
||||||
|
|
||||||
BlockAIOCB *blk_aio_flush(BlockBackend *blk,
|
BlockAIOCB *blk_aio_flush(BlockBackend *blk,
|
||||||
BlockCompletionFunc *cb, void *opaque)
|
BlockCompletionFunc *cb, void *opaque)
|
||||||
{
|
{
|
||||||
if (!blk_is_available(blk)) {
|
return blk_aio_prwv(blk, 0, 0, NULL, blk_aio_flush_entry, 0, cb, opaque);
|
||||||
return blk_abort_aio_request(blk, cb, opaque, -ENOMEDIUM);
|
|
||||||
}
|
|
||||||
|
|
||||||
return bdrv_aio_flush(blk_bs(blk), cb, opaque);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
BlockAIOCB *blk_aio_pdiscard(BlockBackend *blk,
|
BlockAIOCB *blk_aio_pdiscard(BlockBackend *blk,
|
||||||
@ -1169,13 +1174,15 @@ int blk_co_flush(BlockBackend *blk)
|
|||||||
return bdrv_co_flush(blk_bs(blk));
|
return bdrv_co_flush(blk_bs(blk));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void blk_flush_entry(void *opaque)
|
||||||
|
{
|
||||||
|
BlkRwCo *rwco = opaque;
|
||||||
|
rwco->ret = blk_co_flush(rwco->blk);
|
||||||
|
}
|
||||||
|
|
||||||
int blk_flush(BlockBackend *blk)
|
int blk_flush(BlockBackend *blk)
|
||||||
{
|
{
|
||||||
if (!blk_is_available(blk)) {
|
return blk_prw(blk, 0, NULL, 0, blk_flush_entry, 0);
|
||||||
return -ENOMEDIUM;
|
|
||||||
}
|
|
||||||
|
|
||||||
return bdrv_flush(blk_bs(blk));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void blk_drain(BlockBackend *blk)
|
void blk_drain(BlockBackend *blk)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user