From: "Michael Köppl" <m.koeppl@proxmox.com>
To: pve-devel@lists.proxmox.com
Subject: [PATCH container v10 05/10] allow pending mount point changes if storage is gone
Date: Wed, 1 Jul 2026 16:13:34 +0200 [thread overview]
Message-ID: <20260701141339.181276-6-m.koeppl@proxmox.com> (raw)
In-Reply-To: <20260701141339.181276-1-m.koeppl@proxmox.com>
Previously, applying a pending removal of an unused volume whose
backing storage was already removed would fail with "unable to apply
pending change unusedN", leaving a dangling reference that could never
be cleaned up.
Guard the volume deletion in vmconfig_apply_pending and
vmconfig_hotplug_pending with a check to ensure that the storage
exists. If the storage is gone, drop the entry with a warning instead of
trying to free a volume that no longer exists.
Apply the same check when a detached mount point is turned into an
'unusedN' entry, so a volume on a removed storage is not re-added as a
dangling unused entry, matching VM behavior.
Signed-off-by: Michael Köppl <m.koeppl@proxmox.com>
---
src/PVE/LXC/Config.pm | 42 +++++++++++++++++++++++++++++++++---------
1 file changed, 33 insertions(+), 9 deletions(-)
diff --git a/src/PVE/LXC/Config.pm b/src/PVE/LXC/Config.pm
index 57c93e8a..8c99c931 100644
--- a/src/PVE/LXC/Config.pm
+++ b/src/PVE/LXC/Config.pm
@@ -1678,8 +1678,14 @@ sub vmconfig_hotplug_pending {
# pass
} elsif ($opt =~ m/^unused(\d+)$/) {
my $volid = $class->parse_volume($opt, $conf->{$opt})->{volume};
- PVE::LXC::delete_mountpoint_volume($storecfg, $vmid, $volid)
- if !$class->is_volume_in_use($conf, $volid, 1, 1);
+ with_checked_volid(
+ $storecfg,
+ $volid,
+ sub {
+ PVE::LXC::delete_mountpoint_volume($storecfg, $vmid, $volid)
+ if !$class->is_volume_in_use($conf, $volid, 1, 1);
+ },
+ );
} elsif ($opt eq 'swap') {
$hotplug_memory->(undef, 0);
} elsif ($opt eq 'cpulimit') {
@@ -1780,14 +1786,26 @@ sub vmconfig_apply_pending {
if ($opt =~ m/^mp(\d+)$/) {
my $mp = $class->parse_volume($opt, $conf->{$opt});
if ($mp->{type} eq 'volume') {
- # FIXME: use $mp->{volume} for is_volume_in_use, fix conditions for check
- $class->add_unused_volume($conf, $mp->{volume})
- if !$class->is_volume_in_use($conf, $conf->{$opt}, 1, 1);
+ with_checked_volid(
+ $storecfg,
+ $mp->{volume},
+ sub {
+ # FIXME: use $mp->{volume} for is_volume_in_use, fix conditions for check
+ $class->add_unused_volume($conf, $mp->{volume})
+ if !$class->is_volume_in_use($conf, $conf->{$opt}, 1, 1);
+ },
+ );
}
} elsif ($opt =~ m/^unused(\d+)$/) {
my $volid = $class->parse_volume($opt, $conf->{$opt})->{volume};
- PVE::LXC::delete_mountpoint_volume($storecfg, $vmid, $volid)
- if !$class->is_volume_in_use($conf, $volid, 1, 1);
+ with_checked_volid(
+ $storecfg,
+ $volid,
+ sub {
+ PVE::LXC::delete_mountpoint_volume($storecfg, $vmid, $volid)
+ if !$class->is_volume_in_use($conf, $volid, 1, 1);
+ },
+ );
} elsif ($opt =~ m/^net(\d+)$/) {
if ($have_sdn) {
my $net = $class->parse_lxc_network($conf->{$opt});
@@ -1906,8 +1924,14 @@ sub apply_pending_mountpoint {
if (defined($old)) {
my $mp = $class->parse_volume($opt, $old);
if ($mp->{type} eq 'volume') {
- $class->add_unused_volume($conf, $mp->{volume})
- if !$class->is_volume_in_use($conf, $conf->{$opt}, 1, 1);
+ with_checked_volid(
+ $storecfg,
+ $mp->{volume},
+ sub {
+ $class->add_unused_volume($conf, $mp->{volume})
+ if !$class->is_volume_in_use($conf, $conf->{$opt}, 1, 1);
+ },
+ );
}
}
}
--
2.47.3
next prev parent reply other threads:[~2026-07-01 14:14 UTC|newest]
Thread overview: 12+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-07-01 14:13 [PATCH container/qemu-server v10 00/10] fix #3711 and adapt drive detach/remove behavior Michael Köppl
2026-07-01 14:13 ` [PATCH container v10 01/10] fix #3711: warn about storage errors during mountpoint delete Michael Köppl
2026-07-01 14:13 ` [PATCH container v10 02/10] destroy_lxc, delete_mp_volume: rename $volume to $volid Michael Köppl
2026-07-01 14:13 ` [PATCH container v10 03/10] config: ensure valid volid through parse_volume() Michael Köppl
2026-07-01 14:13 ` [PATCH container v10 04/10] lxc config: add helper for parsing volid and checking if storage exists Michael Köppl
2026-07-01 14:13 ` Michael Köppl [this message]
2026-07-01 14:13 ` [PATCH container v10 06/10] destroy template: add early check for linked clones of volumes Michael Köppl
2026-07-01 14:13 ` [PATCH qemu-server v10 07/10] adapt linked clone check to not die if an error occurs during check Michael Köppl
2026-07-01 14:13 ` [PATCH qemu-server v10 08/10] fix #3711: make removal of VM possible if store does not exist anymore Michael Köppl
2026-07-01 14:13 ` [PATCH qemu-server v10 09/10] destroy_vm: use log_warn for vdisk_free errors for consistency Michael Köppl
2026-07-01 14:13 ` [PATCH qemu-server v10 10/10] display warnings for storage errors or if storage no longer exists Michael Köppl
2026-07-03 12:44 ` applied: [PATCH container/qemu-server v10 00/10] fix #3711 and adapt drive detach/remove behavior 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=20260701141339.181276-6-m.koeppl@proxmox.com \
--to=m.koeppl@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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.