]> git.proxmox.com Git - pve-qemu.git/blame - debian/patches/pve/0013-qemu-img-dd-add-l-option-for-loading-a-snapshot.patch
bump version to 8.0.2-1
[pve-qemu.git] / debian / patches / pve / 0013-qemu-img-dd-add-l-option-for-loading-a-snapshot.patch
CommitLineData
f6d40bfd
FE
1From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
2From: Fabian Ebner <f.ebner@proxmox.com>
3Date: Mon, 7 Feb 2022 14:21:01 +0100
db5d2a4b 4Subject: [PATCH] qemu-img dd: add -l option for loading a snapshot
f6d40bfd 5
db5d2a4b 6Signed-off-by: Fiona Ebner <f.ebner@proxmox.com>
2fd4ea28 7Signed-off-by: Thomas Lamprecht <t.lamprecht@proxmox.com>
f6d40bfd
FE
8---
9 docs/tools/qemu-img.rst | 6 +++---
10 qemu-img-cmds.hx | 4 ++--
11 qemu-img.c | 33 +++++++++++++++++++++++++++++++--
12 3 files changed, 36 insertions(+), 7 deletions(-)
13
14diff --git a/docs/tools/qemu-img.rst b/docs/tools/qemu-img.rst
d03e1b3c 15index 5e713e231d..9390d5e5cf 100644
f6d40bfd
FE
16--- a/docs/tools/qemu-img.rst
17+++ b/docs/tools/qemu-img.rst
18@@ -492,10 +492,10 @@ Command description:
19 it doesn't need to be specified separately in this case.
20
21
22-.. option:: dd [--image-opts] [-U] [-f FMT] [-O OUTPUT_FMT] [-n] [bs=BLOCK_SIZE] [count=BLOCKS] [skip=BLOCKS] if=INPUT of=OUTPUT
23+.. option:: dd [--image-opts] [-U] [-f FMT] [-O OUTPUT_FMT] [-n] [-l SNAPSHOT_PARAM] [bs=BLOCK_SIZE] [count=BLOCKS] [skip=BLOCKS] if=INPUT of=OUTPUT
24
25- dd copies from *INPUT* file to *OUTPUT* file converting it from
26- *FMT* format to *OUTPUT_FMT* format.
27+ dd copies from *INPUT* file or snapshot *SNAPSHOT_PARAM* to *OUTPUT* file
28+ converting it from *FMT* format to *OUTPUT_FMT* format.
29
30 The data is by default read and written using blocks of 512 bytes but can be
31 modified by specifying *BLOCK_SIZE*. If count=\ *BLOCKS* is specified
32diff --git a/qemu-img-cmds.hx b/qemu-img-cmds.hx
dc9827a6 33index b5b0bb4467..36f97e1f19 100644
f6d40bfd
FE
34--- a/qemu-img-cmds.hx
35+++ b/qemu-img-cmds.hx
36@@ -58,9 +58,9 @@ SRST
37 ERST
38
39 DEF("dd", img_dd,
40- "dd [--image-opts] [-U] [-f fmt] [-O output_fmt] [-n] [bs=block_size] [count=blocks] [skip=blocks] [osize=output_size] if=input of=output")
41+ "dd [--image-opts] [-U] [-f fmt] [-O output_fmt] [-n] [-l snapshot_param] [bs=block_size] [count=blocks] [skip=blocks] [osize=output_size] if=input of=output")
42 SRST
43-.. option:: dd [--image-opts] [-U] [-f FMT] [-O OUTPUT_FMT] [-n] [bs=BLOCK_SIZE] [count=BLOCKS] [skip=BLOCKS] [osize=OUTPUT_SIZE] if=INPUT of=OUTPUT
44+.. option:: dd [--image-opts] [-U] [-f FMT] [-O OUTPUT_FMT] [-n] [-l SNAPSHOT_PARAM] [bs=BLOCK_SIZE] [count=BLOCKS] [skip=BLOCKS] [osize=OUTPUT_SIZE] if=INPUT of=OUTPUT
45 ERST
46
47 DEF("info", img_info,
48diff --git a/qemu-img.c b/qemu-img.c
bf251437 49index 06d814e39c..e2c06c496d 100644
f6d40bfd
FE
50--- a/qemu-img.c
51+++ b/qemu-img.c
bf251437 52@@ -5002,6 +5002,7 @@ static int img_dd(int argc, char **argv)
f6d40bfd
FE
53 BlockDriver *drv = NULL, *proto_drv = NULL;
54 BlockBackend *blk1 = NULL, *blk2 = NULL;
55 QemuOpts *opts = NULL;
56+ QemuOpts *sn_opts = NULL;
57 QemuOptsList *create_opts = NULL;
58 Error *local_err = NULL;
59 bool image_opts = false;
bf251437 60@@ -5011,6 +5012,7 @@ static int img_dd(int argc, char **argv)
f6d40bfd 61 int64_t size = 0, readsize = 0;
d03e1b3c 62 int64_t out_pos, in_pos;
f6d40bfd
FE
63 bool force_share = false, skip_create = false;
64+ const char *snapshot_name = NULL;
65 struct DdInfo dd = {
66 .flags = 0,
67 .count = 0,
bf251437 68@@ -5048,7 +5050,7 @@ static int img_dd(int argc, char **argv)
f6d40bfd
FE
69 { 0, 0, 0, 0 }
70 };
71
72- while ((c = getopt_long(argc, argv, ":hf:O:Un", long_options, NULL))) {
73+ while ((c = getopt_long(argc, argv, ":hf:O:l:Un", long_options, NULL))) {
74 if (c == EOF) {
75 break;
76 }
bf251437 77@@ -5071,6 +5073,19 @@ static int img_dd(int argc, char **argv)
f6d40bfd
FE
78 case 'n':
79 skip_create = true;
80 break;
81+ case 'l':
82+ if (strstart(optarg, SNAPSHOT_OPT_BASE, NULL)) {
83+ sn_opts = qemu_opts_parse_noisily(&internal_snapshot_opts,
84+ optarg, false);
85+ if (!sn_opts) {
86+ error_report("Failed in parsing snapshot param '%s'",
87+ optarg);
88+ goto out;
89+ }
90+ } else {
91+ snapshot_name = optarg;
92+ }
93+ break;
94 case 'U':
95 force_share = true;
96 break;
bf251437 97@@ -5130,11 +5145,24 @@ static int img_dd(int argc, char **argv)
f6d40bfd
FE
98 if (dd.flags & C_IF) {
99 blk1 = img_open(image_opts, in.filename, fmt, 0, false, false,
100 force_share);
101-
102 if (!blk1) {
103 ret = -1;
104 goto out;
105 }
106+ if (sn_opts) {
107+ bdrv_snapshot_load_tmp(blk_bs(blk1),
108+ qemu_opt_get(sn_opts, SNAPSHOT_OPT_ID),
109+ qemu_opt_get(sn_opts, SNAPSHOT_OPT_NAME),
110+ &local_err);
111+ } else if (snapshot_name != NULL) {
112+ bdrv_snapshot_load_tmp_by_id_or_name(blk_bs(blk1), snapshot_name,
113+ &local_err);
114+ }
115+ if (local_err) {
116+ error_reportf_err(local_err, "Failed to load snapshot: ");
117+ ret = -1;
118+ goto out;
119+ }
120 }
121
122 if (dd.flags & C_OSIZE) {
bf251437 123@@ -5289,6 +5317,7 @@ static int img_dd(int argc, char **argv)
f6d40bfd
FE
124 out:
125 g_free(arg);
126 qemu_opts_del(opts);
127+ qemu_opts_del(sn_opts);
128 qemu_opts_free(create_opts);
129 blk_unref(blk1);
130 blk_unref(blk2);