From: Fiona Ebner <f.ebner@proxmox.com>
To: pve-devel@lists.proxmox.com
Subject: [PATCH qemu-server v4 09/18] blockdev: switch blockdev_replace() to use QMP peer
Date: Fri, 24 Apr 2026 13:46:43 +0200 [thread overview]
Message-ID: <20260424114722.107671-10-f.ebner@proxmox.com> (raw)
In-Reply-To: <20260424114722.107671-1-f.ebner@proxmox.com>
Signed-off-by: Fiona Ebner <f.ebner@proxmox.com>
Tested-by: Lukas Sichert <l.sichert@proxmox.com>
---
src/PVE/QemuServer.pm | 2 +-
src/PVE/QemuServer/VolumeChain.pm | 32 ++++++++++++++++++-------------
2 files changed, 20 insertions(+), 14 deletions(-)
diff --git a/src/PVE/QemuServer.pm b/src/PVE/QemuServer.pm
index 7d1ec232..88a5a863 100644
--- a/src/PVE/QemuServer.pm
+++ b/src/PVE/QemuServer.pm
@@ -4440,7 +4440,7 @@ sub qemu_volume_snapshot_delete {
PVE::QemuServer::VolumeChain::blockdev_replace(
$storecfg,
- $vmid,
+ vm_qmp_peer($vmid),
$machine_version,
$attached_deviceid,
$drive,
diff --git a/src/PVE/QemuServer/VolumeChain.pm b/src/PVE/QemuServer/VolumeChain.pm
index e522e201..01c5dd9b 100644
--- a/src/PVE/QemuServer/VolumeChain.pm
+++ b/src/PVE/QemuServer/VolumeChain.pm
@@ -11,7 +11,7 @@ use PVE::Storage;
use PVE::QemuServer::Blockdev qw(generate_file_blockdev generate_format_blockdev);
use PVE::QemuServer::BlockJob;
use PVE::QemuServer::Drive;
-use PVE::QemuServer::Monitor qw(mon_cmd vm_qmp_peer);
+use PVE::QemuServer::Monitor qw(mon_cmd qmp_cmd vm_qmp_peer);
sub blockdev_external_snapshot {
my ($storecfg, $vmid, $machine_version, $deviceid, $drive, $snap, $parent_snap) = @_;
@@ -25,7 +25,14 @@ sub blockdev_external_snapshot {
#reopen current to snap
blockdev_replace(
- $storecfg, $vmid, $machine_version, $deviceid, $drive, 'current', $snap, $parent_snap,
+ $storecfg,
+ vm_qmp_peer($vmid),
+ $machine_version,
+ $deviceid,
+ $drive,
+ 'current',
+ $snap,
+ $parent_snap,
);
#be sure to add drive in write mode
@@ -88,7 +95,7 @@ my sub blockdev_relative_backing_file {
sub blockdev_replace {
my (
$storecfg,
- $vmid,
+ $qmp_peer,
$machine_version,
$deviceid,
$drive,
@@ -106,9 +113,8 @@ sub blockdev_replace {
my $src_blockdev_name;
if ($src_snap eq 'current') {
# there might be other nodes on top like zeroinit, look up the current node below throttle
- $src_blockdev_name = PVE::QemuServer::Blockdev::get_node_name_below_throttle(
- vm_qmp_peer($vmid), $deviceid, 1,
- );
+ $src_blockdev_name =
+ PVE::QemuServer::Blockdev::get_node_name_below_throttle($qmp_peer, $deviceid, 1);
} else {
$src_name_options = { 'snapshot-name' => $src_snap };
$src_blockdev_name =
@@ -141,16 +147,16 @@ sub blockdev_replace {
);
$target_fmt_blockdev->{backing} = $parent_fmt_nodename;
}
- mon_cmd($vmid, 'blockdev-add', %$target_fmt_blockdev);
+ qmp_cmd($qmp_peer, 'blockdev-add', %$target_fmt_blockdev);
#reopen the current throttlefilter nodename with the target fmt nodename
my $throttle_blockdev = PVE::QemuServer::Blockdev::generate_throttle_blockdev(
$drive, $target_fmt_blockdev->{'node-name'}, {},
);
- mon_cmd($vmid, 'blockdev-reopen', options => [$throttle_blockdev]);
+ qmp_cmd($qmp_peer, 'blockdev-reopen', options => [$throttle_blockdev]);
} else {
#intermediate snapshot
- mon_cmd($vmid, 'blockdev-add', %$target_fmt_blockdev);
+ qmp_cmd($qmp_peer, 'blockdev-add', %$target_fmt_blockdev);
#reopen the parent node with the new target fmt backing node
my $parent_file_blockdev = generate_file_blockdev(
@@ -166,14 +172,14 @@ sub blockdev_replace {
{ 'snapshot-name' => $parent_snap },
);
$parent_fmt_blockdev->{backing} = $target_fmt_blockdev->{'node-name'};
- mon_cmd($vmid, 'blockdev-reopen', options => [$parent_fmt_blockdev]);
+ qmp_cmd($qmp_peer, 'blockdev-reopen', options => [$parent_fmt_blockdev]);
my $backing_file =
blockdev_relative_backing_file($target_file_blockdev, $parent_file_blockdev);
#change backing-file in qcow2 metadatas
- mon_cmd(
- $vmid, 'change-backing-file',
+ qmp_cmd(
+ $qmp_peer, 'change-backing-file',
device => $deviceid,
'image-node-name' => $parent_fmt_blockdev->{'node-name'},
'backing-file' => $backing_file,
@@ -181,7 +187,7 @@ sub blockdev_replace {
}
# delete old file|fmt nodes
- eval { PVE::QemuServer::Blockdev::detach(vm_qmp_peer($vmid), $src_blockdev_name); };
+ eval { PVE::QemuServer::Blockdev::detach($qmp_peer, $src_blockdev_name); };
warn "detaching block node for $src_snap failed - $@" if $@;
}
--
2.47.3
next prev parent reply other threads:[~2026-04-24 11:48 UTC|newest]
Thread overview: 20+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-04-24 11:46 [PATCH-SERIES qemu-server v4 00/18] fix #7066: api: allow live snapshot (remove) of qcow2 TPM drive with snapshot-as-volume-chain Fiona Ebner
2026-04-24 11:46 ` [PATCH qemu-server v4 01/18] block job: fix variable name in documentation Fiona Ebner
2026-04-24 11:46 ` [PATCH qemu-server v4 02/18] qmp client: add default timeouts for more block commands Fiona Ebner
2026-04-24 11:46 ` [PATCH qemu-server v4 03/18] drive: introduce drive_uses_qsd_fuse() helper Fiona Ebner
2026-04-24 11:46 ` [PATCH qemu-server v4 04/18] monitor: add vm_qmp_peer() helper Fiona Ebner
2026-04-24 11:46 ` [PATCH qemu-server v4 05/18] monitor: add qsd_peer() helper Fiona Ebner
2026-04-24 11:46 ` [PATCH qemu-server v4 06/18] blockdev: rename variable in get_node_name_below_throttle() for readability Fiona Ebner
2026-04-24 11:46 ` [PATCH qemu-server v4 07/18] blockdev: switch get_node_name_below_throttle() to use QMP peer Fiona Ebner
2026-04-24 11:46 ` [PATCH qemu-server v4 08/18] blockdev: switch detach() " Fiona Ebner
2026-04-24 11:46 ` Fiona Ebner [this message]
2026-04-24 11:46 ` [PATCH qemu-server v4 10/18] blockdev: switch blockdev_external_snapshot() " Fiona Ebner
2026-04-24 11:46 ` [PATCH qemu-server v4 11/18] block job: switch qemu_handle_concluded_blockjob() " Fiona Ebner
2026-04-24 11:46 ` [PATCH qemu-server v4 12/18] block job: switch qemu_blockjobs_cancel() " Fiona Ebner
2026-04-24 11:46 ` [PATCH qemu-server v4 13/18] block job: switch qemu_drive_mirror_monitor() " Fiona Ebner
2026-04-24 11:46 ` [PATCH qemu-server v4 14/18] blockdev: switch blockdev_delete() " Fiona Ebner
2026-04-24 11:46 ` [PATCH qemu-server v4 15/18] blockdev: switch blockdev_stream() " Fiona Ebner
2026-04-24 11:46 ` [PATCH qemu-server v4 16/18] blockdev: switch blockdev_commit() " Fiona Ebner
2026-04-24 11:46 ` [PATCH qemu-server v4 17/18] snapshot: support live snapshot (remove) of qcow2 TPM drive on storage with snapshot-as-volume-chain Fiona Ebner
2026-04-24 11:46 ` [PATCH qemu-server v4 18/18] fix #7066: api: allow live snapshot (remove) of qcow2 TPM drive " Fiona Ebner
2026-04-24 12:06 ` [PATCH v4 qemu-server 19/19] monitor: rename qsd_peer() to qsd_qmp_peer() Fiona Ebner
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20260424114722.107671-10-f.ebner@proxmox.com \
--to=f.ebner@proxmox.com \
--cc=pve-devel@lists.proxmox.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox