diff options
author | Max Reitz <mreitz@redhat.com> | 2013-09-25 16:37:20 +0200 |
---|---|---|
committer | Kevin Wolf <kwolf@redhat.com> | 2013-09-27 17:22:43 +0200 |
commit | be0b742ee320d1139d57062fa18490e7aa485f2a (patch) | |
tree | 10f9e2198f289445546553a20f1c4f2f63fd6861 | |
parent | 8585afd8133eed037dde9c14106e7eb8d7c46968 (diff) | |
download | qemu-be0b742ee320d1139d57062fa18490e7aa485f2a.zip qemu-be0b742ee320d1139d57062fa18490e7aa485f2a.tar.gz qemu-be0b742ee320d1139d57062fa18490e7aa485f2a.tar.bz2 |
qcow2: Always use error path in l2_allocate
Just returning -errno in some cases prevents
trace_qcow2_l2_allocate_done from being executed (and, in one case, also
the unused allocated L2 table from being freed). Always going down the
error path fixes this.
Signed-off-by: Max Reitz <mreitz@redhat.com>
Signed-off-by: Kevin Wolf <kwolf@redhat.com>
-rw-r--r-- | block/qcow2-cluster.c | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/block/qcow2-cluster.c b/block/qcow2-cluster.c index 153ea50..c743db1 100644 --- a/block/qcow2-cluster.c +++ b/block/qcow2-cluster.c @@ -200,7 +200,8 @@ static int l2_allocate(BlockDriverState *bs, int l1_index, uint64_t **table) l2_offset = qcow2_alloc_clusters(bs, s->l2_size * sizeof(uint64_t)); if (l2_offset < 0) { - return l2_offset; + ret = l2_offset; + goto fail; } ret = qcow2_cache_flush(bs, s->refcount_block_cache); @@ -213,7 +214,7 @@ static int l2_allocate(BlockDriverState *bs, int l1_index, uint64_t **table) trace_qcow2_l2_allocate_get_empty(bs, l1_index); ret = qcow2_cache_get_empty(bs, s->l2_table_cache, l2_offset, (void**) table); if (ret < 0) { - return ret; + goto fail; } l2_table = *table; |