mirror of
https://git.proxmox.com/git/qemu-server
synced 2025-05-03 01:29:13 +00:00
fix clone_disk failing for nonexistent cloudinit disk
After migration or a rollback the cloudinit disk might not be allocated, so volume_size_info() fails. As we override the value anyway for cloudinit and efi disks simply move the volume_size_info() call into the 'else' branch. Signed-off-by: Mira Limbeck <m.limbeck@proxmox.com>
This commit is contained in:
parent
f8c4b2c5ba
commit
d0abc7746a
@ -6948,10 +6948,10 @@ sub clone_disk {
|
||||
$storeid = $storage if $storage;
|
||||
|
||||
my $dst_format = resolve_dst_disk_format($storecfg, $storeid, $volname, $format);
|
||||
my ($size) = PVE::Storage::volume_size_info($storecfg, $drive->{file}, 3);
|
||||
|
||||
print "create full clone of drive $drivename ($drive->{file})\n";
|
||||
my $name = undef;
|
||||
my $size = undef;
|
||||
if (drive_is_cloudinit($drive)) {
|
||||
$name = "vm-$newvmid-cloudinit";
|
||||
$name .= ".$dst_format" if $dst_format ne 'raw';
|
||||
@ -6959,6 +6959,8 @@ sub clone_disk {
|
||||
$size = PVE::QemuServer::Cloudinit::CLOUDINIT_DISK_SIZE;
|
||||
} elsif ($drivename eq 'efidisk0') {
|
||||
$size = get_efivars_size($conf);
|
||||
} else {
|
||||
($size) = PVE::Storage::volume_size_info($storecfg, $drive->{file}, 3);
|
||||
}
|
||||
$size /= 1024;
|
||||
$newvolid = PVE::Storage::vdisk_alloc($storecfg, $storeid, $newvmid, $dst_format, $name, $size);
|
||||
|
Loading…
Reference in New Issue
Block a user