aboutsummaryrefslogtreecommitdiff
path: root/block.c
diff options
context:
space:
mode:
authorKevin Wolf <kwolf@redhat.com>2010-04-06 18:24:07 +0200
committerAurelien Jarno <aurelien@aurel32.net>2010-04-10 00:39:35 +0200
commit7eb58a6c556c3880e6712cbf6d24d681261c5095 (patch)
tree5637f04646ae1ba43672ac6c16cf50a853f17b29 /block.c
parent0f0b604b00851f2c7160b4195136c1fd27418088 (diff)
downloadqemu-7eb58a6c556c3880e6712cbf6d24d681261c5095.zip
qemu-7eb58a6c556c3880e6712cbf6d24d681261c5095.tar.gz
qemu-7eb58a6c556c3880e6712cbf6d24d681261c5095.tar.bz2
block: Fix multiwrite memory leak in error case
Previously multiwrite_user_cb was never called if a request in the multiwrite batch failed right away because it did set mcb->error immediately. Make it look more like a normal callback to fix this. Reported-by: Juan Quintela <quintela@redhat.com> Signed-off-by: Kevin Wolf <kwolf@redhat.com> Signed-off-by: Aurelien Jarno <aurelien@aurel32.net>
Diffstat (limited to 'block.c')
-rw-r--r--block.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/block.c b/block.c
index 1027ff7..0881c93 100644
--- a/block.c
+++ b/block.c
@@ -1884,7 +1884,8 @@ int bdrv_aio_multiwrite(BlockDriverState *bs, BlockRequest *reqs, int num_reqs)
reqs[i].error = -EIO;
goto fail;
} else {
- mcb->error = -EIO;
+ mcb->num_requests++;
+ multiwrite_cb(mcb, -EIO);
break;
}
} else {