summaryrefslogtreecommitdiff
path: root/block/stream.c
diff options
context:
space:
mode:
authorAlberto Garcia <berto@igalia.com>2016-03-21 15:47:25 +0200
committerJeff Cody <jcody@redhat.com>2016-03-28 13:56:44 -0400
commit6578629e08db7081e1890ba019170d452e09430b (patch)
tree15834138f165fe2af76c83d8392753a79533dc62 /block/stream.c
parentb68a80139e37e806f004237e55311ebc42151434 (diff)
downloadqemu-6578629e08db7081e1890ba019170d452e09430b.tar.gz
block: never cancel a streaming job without running stream_complete()
We need to call stream_complete() in order to do all the necessary clean-ups, even if there's an early failure. At the moment it's only useful to make sure that s->backing_file_str is not leaked, but it will become more important if we introduce support for streaming to any intermediate node. Signed-off-by: Alberto Garcia <berto@igalia.com> Reviewed-by: Max Reitz <mreitz@redhat.com> Reviewed-by: Fam Zheng <famz@redhat.com> Reviewed-by: Stefan Hajnoczi <stefanha@redhat.com> Message-id: 2abedf2debc65c250560237f31a8e6756883c8fc.1458566441.git.berto@igalia.com Signed-off-by: Jeff Cody <jcody@redhat.com>
Diffstat (limited to 'block/stream.c')
-rw-r--r--block/stream.c11
1 files changed, 6 insertions, 5 deletions
diff --git a/block/stream.c b/block/stream.c
index cafaa07a01..eea3938626 100644
--- a/block/stream.c
+++ b/block/stream.c
@@ -89,21 +89,21 @@ static void coroutine_fn stream_run(void *opaque)
StreamCompleteData *data;
BlockDriverState *bs = s->common.bs;
BlockDriverState *base = s->base;
- int64_t sector_num, end;
+ int64_t sector_num = 0;
+ int64_t end = -1;
int error = 0;
int ret = 0;
int n = 0;
void *buf;
if (!bs->backing) {
- block_job_completed(&s->common, 0);
- return;
+ goto out;
}
s->common.len = bdrv_getlength(bs);
if (s->common.len < 0) {
- block_job_completed(&s->common, s->common.len);
- return;
+ ret = s->common.len;
+ goto out;
}
end = s->common.len >> BDRV_SECTOR_BITS;
@@ -190,6 +190,7 @@ wait:
qemu_vfree(buf);
+out:
/* Modify backing chain and close BDSes in main loop */
data = g_malloc(sizeof(*data));
data->ret = ret;