]> git.proxmox.com Git - pve-qemu.git/blame - debian/patches/pve/0012-PVE-Up-qemu-img-dd-add-n-skip_create.patch
update submodule and patches to 6.2.0
[pve-qemu.git] / debian / patches / pve / 0012-PVE-Up-qemu-img-dd-add-n-skip_create.patch
CommitLineData
46598e97
AD
1From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
2From: Alexandre Derumier <aderumier@odiso.com>
83faa3fe 3Date: Mon, 6 Apr 2020 12:16:42 +0200
d7f4e01a 4Subject: [PATCH] PVE: [Up] qemu-img dd: add -n skip_create
46598e97 5
b855dce7 6Signed-off-by: Thomas Lamprecht <t.lamprecht@proxmox.com>
46598e97
AD
7---
8 qemu-img.c | 23 ++++++++++++++---------
9 1 file changed, 14 insertions(+), 9 deletions(-)
10
11diff --git a/qemu-img.c b/qemu-img.c
4567474e 12index d9e8a8c4d4..6e1fbd5820 100644
46598e97
AD
13--- a/qemu-img.c
14+++ b/qemu-img.c
4567474e 15@@ -4930,7 +4930,7 @@ static int img_dd(int argc, char **argv)
46598e97
AD
16 const char *fmt = NULL;
17 int64_t size = 0, readsize = 0;
18 int64_t block_count = 0, out_pos, in_pos;
19- bool force_share = false;
20+ bool force_share = false, skip_create = false;
21 struct DdInfo dd = {
22 .flags = 0,
23 .count = 0,
4567474e 24@@ -4968,7 +4968,7 @@ static int img_dd(int argc, char **argv)
46598e97
AD
25 { 0, 0, 0, 0 }
26 };
27
28- while ((c = getopt_long(argc, argv, ":hf:O:U", long_options, NULL))) {
29+ while ((c = getopt_long(argc, argv, ":hf:O:U:n", long_options, NULL))) {
30 if (c == EOF) {
31 break;
32 }
4567474e 33@@ -4988,6 +4988,9 @@ static int img_dd(int argc, char **argv)
46598e97
AD
34 case 'h':
35 help();
36 break;
37+ case 'n':
38+ skip_create = true;
39+ break;
40 case 'U':
41 force_share = true;
42 break;
4567474e 43@@ -5118,13 +5121,15 @@ static int img_dd(int argc, char **argv)
46598e97
AD
44 size - in.bsz * in.offset, &error_abort);
45 }
46
47- ret = bdrv_create(drv, out.filename, opts, &local_err);
48- if (ret < 0) {
49- error_reportf_err(local_err,
50- "%s: error while creating output image: ",
51- out.filename);
52- ret = -1;
53- goto out;
54+ if (!skip_create) {
55+ ret = bdrv_create(drv, out.filename, opts, &local_err);
56+ if (ret < 0) {
57+ error_reportf_err(local_err,
58+ "%s: error while creating output image: ",
59+ out.filename);
60+ ret = -1;
61+ goto out;
62+ }
63 }
64
65 /* TODO, we can't honour --image-opts for the target,