|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
From 3b92e958482155404cfd134a9608041eed69622a Mon Sep 17 00:00:00 2001
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
From: Avi Kivity <avi@redhat.com>
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
Date: Fri, 20 Mar 2009 18:26:12 +0000
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
Subject: [STABLE][PATCH 1/4] Use vectored aiocb storage to store vector translation state
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
Now that we have a dedicated acb pool for vector translation acbs, we can
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
store the vector translation state in the acbs instead of in an external
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
structure.
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
Signed-off-by: Avi Kivity <avi@redhat.com>
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
---
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
block.c | 29 ++++++++++++++---------------
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
1 files changed, 14 insertions(+), 15 deletions(-)
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
diff --git a/block.c b/block.c
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
index b12318f..689ea37 100644
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
--- a/block.c
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
+++ b/block.c
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
@@ -1332,31 +1332,32 @@ char *bdrv_snapshot_dump(char *buf, int buf_size, QEMUSnapshotInfo *sn)
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
/**************************************************************/
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
/* async I/Os */
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
-typedef struct VectorTranslationState {
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
+typedef struct VectorTranslationAIOCB {
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
+ BlockDriverAIOCB common;
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
QEMUIOVector *iov;
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
uint8_t *bounce;
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
int is_write;
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
BlockDriverAIOCB *aiocb;
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
- BlockDriverAIOCB *this_aiocb;
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
-} VectorTranslationState;
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
+} VectorTranslationAIOCB;
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
-static void bdrv_aio_cancel_vector(BlockDriverAIOCB *acb)
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
+static void bdrv_aio_cancel_vector(BlockDriverAIOCB *_acb)
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
{
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
- VectorTranslationState *s = acb->opaque;
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
+ VectorTranslationAIOCB *acb
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
+ = container_of(_acb, VectorTranslationAIOCB, common);
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
- bdrv_aio_cancel(s->aiocb);
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
+ bdrv_aio_cancel(acb->aiocb);
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
}
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
static void bdrv_aio_rw_vector_cb(void *opaque, int ret)
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
{
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
- VectorTranslationState *s = opaque;
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
+ VectorTranslationAIOCB *s = (VectorTranslationAIOCB *)opaque;
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
if (!s->is_write) {
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
qemu_iovec_from_buffer(s->iov, s->bounce, s->iov->size);
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
}
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
qemu_vfree(s->bounce);
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
- s->this_aiocb->cb(s->this_aiocb->opaque, ret);
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
- qemu_aio_release(s->this_aiocb);
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
+ s->common.cb(s->common.opaque, ret);
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
+ qemu_aio_release(s);
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
}
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
static BlockDriverAIOCB *bdrv_aio_rw_vector(BlockDriverState *bs,
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
@@ -1368,11 +1369,9 @@ static BlockDriverAIOCB *bdrv_aio_rw_vector(BlockDriverState *bs,
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
int is_write)
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
{
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
- VectorTranslationState *s = qemu_mallocz(sizeof(*s));
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
- BlockDriverAIOCB *aiocb = qemu_aio_get_pool(&vectored_aio_pool, bs,
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
- cb, opaque);
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
+ VectorTranslationAIOCB *s = qemu_aio_get_pool(&vectored_aio_pool, bs,
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
+ cb, opaque);
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
- s->this_aiocb = aiocb;
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
s->iov = iov;
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
s->bounce = qemu_memalign(512, nb_sectors * 512);
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
s->is_write = is_write;
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
@@ -1384,7 +1383,7 @@ static BlockDriverAIOCB *bdrv_aio_rw_vector(BlockDriverState *bs,
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
s->aiocb = bdrv_aio_read(bs, sector_num, s->bounce, nb_sectors,
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
bdrv_aio_rw_vector_cb, s);
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
}
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
- return aiocb;
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
+ return &s->common;
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
}
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
BlockDriverAIOCB *bdrv_aio_readv(BlockDriverState *bs, int64_t sector_num,
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
@@ -1560,7 +1559,7 @@ static int bdrv_write_em(BlockDriverState *bs, int64_t sector_num,
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
void bdrv_init(void)
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
{
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
- aio_pool_init(&vectored_aio_pool, sizeof(BlockDriverAIOCB),
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
+ aio_pool_init(&vectored_aio_pool, sizeof(VectorTranslationAIOCB),
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
bdrv_aio_cancel_vector);
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
bdrv_register(&bdrv_raw);
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
--
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
1.6.0.6
|
|
![](https://seccdn.libravatar.org/avatar/5673696e23c4c06a926777747d428f5b1042e37be4f7f123f1be96b9f2ec047c?s=16&d=retro) |
5517497 |
|