aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authoryuchenlin <yuchenlin@synology.com>2019-02-21 11:08:05 +0000
committerMax Reitz <mreitz@redhat.com>2019-02-25 15:11:28 +0100
commit26c9296c31bc5d0fab24379af0a1684b099067de (patch)
tree3a2e0776369063febff896e6b35c7fcae8645ee5
parent0482098608b83b559bc1802e4c612051b51f6c4c (diff)
downloadqemu-26c9296c31bc5d0fab24379af0a1684b099067de.zip
qemu-26c9296c31bc5d0fab24379af0a1684b099067de.tar.gz
qemu-26c9296c31bc5d0fab24379af0a1684b099067de.tar.bz2
vmdk: false positive of compat6 with hwversion not set
In vmdk_co_create_opts, when it finds hw_version is undefined, it will set it to 4, which misleading the compat6 and hwversion in vmdk_co_do_create. Simply set hw_version to NULL after free, let the logic in vmdk_co_do_create to decide the value of hw_version. This bug can be reproduced by: $ qemu-img convert -O vmdk -o subformat=streamOptimized,compat6 /home/yuchenlin/syno.qcow2 /home/yuchenlin/syno.vmdk qemu-img: /home/yuchenlin/syno.vmdk: error while converting vmdk: compat6 cannot be enabled with hwversion set Signed-off-by: yuchenlin <yuchenlin@synology.com> Message-id: 20190221110805.28239-1-yuchenlin@synology.com Signed-off-by: Max Reitz <mreitz@redhat.com>
-rw-r--r--block/vmdk.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/block/vmdk.c b/block/vmdk.c
index 91345ba..f4e68aa 100644
--- a/block/vmdk.c
+++ b/block/vmdk.c
@@ -2267,7 +2267,7 @@ static int coroutine_fn vmdk_co_create_opts(const char *filename, QemuOpts *opts
compat6 = qemu_opt_get_bool_del(opts, BLOCK_OPT_COMPAT6, false);
if (strcmp(hw_version, "undefined") == 0) {
g_free(hw_version);
- hw_version = g_strdup("4");
+ hw_version = NULL;
}
fmt = qemu_opt_get_del(opts, BLOCK_OPT_SUBFMT);
zeroed_grain = qemu_opt_get_bool_del(opts, BLOCK_OPT_ZEROED_GRAIN, false);