From 012d4869c1eb195e83f159ed7b2bced33f37f960 Mon Sep 17 00:00:00 2001 From: Stefan Hajnoczi Date: Wed, 21 Apr 2010 20:35:45 +0100 Subject: block: Free iovec arrays allocated by multiwrite_merge() A new iovec array is allocated when creating a merged write request. This patch ensures that the iovec array is deleted in addition to its qiov owner. Reported-by: Leszek Urbanski Signed-off-by: Stefan Hajnoczi Signed-off-by: Kevin Wolf (cherry picked from commit 1e1ea48d42e011b9bdd0d689d184e7cac4617b66) --- block.c | 3 +++ 1 file changed, 3 insertions(+) diff --git a/block.c b/block.c index 4f9a48b71..7326bfeee 100644 --- a/block.c +++ b/block.c @@ -1608,6 +1608,9 @@ static void multiwrite_user_cb(MultiwriteCB *mcb) for (i = 0; i < mcb->num_callbacks; i++) { mcb->callbacks[i].cb(mcb->callbacks[i].opaque, mcb->error); + if (mcb->callbacks[i].free_qiov) { + qemu_iovec_destroy(mcb->callbacks[i].free_qiov); + } qemu_free(mcb->callbacks[i].free_qiov); qemu_vfree(mcb->callbacks[i].free_buf); } -- cgit v1.2.3-65-gdbad