instead of using the mdev uuid. The nvidia driver does not actually care that it's the same as the mdev, and in qemu the uuid parameter overwrites the smbios1 uuid internally, so we should have been reusing that in the first place.
Signed-off-by: Dominik Csapak <d.csa...@proxmox.com> --- when i was writing the uuid appending in the first place, i was sure that the nvidia driver needed the mdev uuid, but i was wrong also i wrongly assumed the '-uuid' parameter does not do anything to the guest, but it overwrites the smbios uuid. seems i misread the qemu source code then.. (the man/help pages are not very helpful in that regard) PVE/QemuServer.pm | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/PVE/QemuServer.pm b/PVE/QemuServer.pm index 096e7f0d..b5836f7a 100644 --- a/PVE/QemuServer.pm +++ b/PVE/QemuServer.pm @@ -5851,9 +5851,14 @@ sub vm_start_nolock { for my $dev ($d->{pciid}->@*) { my $info = PVE::QemuServer::PCI::prepare_pci_device($vmid, $dev->{id}, $id, $d->{mdev}); - # nvidia grid needs the uuid of the mdev as qemu parameter + # nvidia grid needs the qemu parameter '-uuid' set + # use smbios uuid or mdev uuid as fallback for that if ($d->{mdev} && !defined($uuid) && $info->{vendor} eq '10de') { - $uuid = PVE::QemuServer::PCI::generate_mdev_uuid($vmid, $id); + if (defined($conf->{smbios1})) { + my $smbios_conf = parse_smbios1($conf->{smbios1}); + $uuid = $smbios_conf->{uuid} if defined($smbios_conf->{uuid}); + } + $uuid = PVE::QemuServer::PCI::generate_mdev_uuid($vmid, $id) if !defined($uuid); } } } -- 2.30.2 _______________________________________________ pve-devel mailing list pve-devel@lists.proxmox.com https://lists.proxmox.com/cgi-bin/mailman/listinfo/pve-devel