2ba5aa
From 1824bb0b44b47af95f50afd626776acfba91174d Mon Sep 17 00:00:00 2001
2ba5aa
Message-Id: <1824bb0b44b47af95f50afd626776acfba91174d@dist-git>
2ba5aa
From: Michal Privoznik <mprivozn@redhat.com>
2ba5aa
Date: Wed, 7 Oct 2020 13:20:04 +0200
2ba5aa
Subject: [PATCH] qemuFirmwareFillDomain: Fill NVRAM template on migration too
2ba5aa
2ba5aa
In 8e1804f9f66 I've tried to fix the following use case: domain
2ba5aa
is started with path to UEFI only and relies on libvirt to figure
2ba5aa
out corresponding NVRAM template to create a per-domain copy
2ba5aa
from. The fix consisted of having a check tailored exactly for
2ba5aa
this use case and if it's hit then using FW autoselection to
2ba5aa
figure it out. Unfortunately, the NVRAM template is not saved in
2ba5aa
the inactive XML (well, the domain might be transient anyway).
2ba5aa
Then, as a part of that check we see whether the per-domain copy
2ba5aa
doesn't exist already and if it does then no template is looked
2ba5aa
up hence no template will appear in the live XML.
2ba5aa
2ba5aa
This works, until the domain is migrated. At the destination, the
2ba5aa
per-domain copy will not exist so we need to know the template to
2ba5aa
create the per-domain copy from. But we don't even get to the
2ba5aa
check because we are not starting a fresh new domain and thus the
2ba5aa
qemuFirmwareFillDomain() function quits early.
2ba5aa
2ba5aa
The solution is to switch order of these two checks. That is
2ba5aa
evaluate the check for the old style before checking flags.
2ba5aa
2ba5aa
Resolves: https://bugzilla.redhat.com/show_bug.cgi?id=1852910
2ba5aa
Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
2ba5aa
Reviewed-by: Andrea Bolognani <abologna@redhat.com>
2ba5aa
(cherry picked from commit c43622f06e295edcb9cedf33583f0bd18fb04b10)
2ba5aa
2ba5aa
Resolves: https://bugzilla.redhat.com/show_bug.cgi?id=1880418
2ba5aa
2ba5aa
Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
2ba5aa
Message-Id: <9b91110a238eba22f4b876e7b15a25d5113ee91e.1602069592.git.mprivozn@redhat.com>
2ba5aa
Reviewed-by: Andrea Bolognani <abologna@redhat.com>
2ba5aa
---
2ba5aa
 src/qemu/qemu_firmware.c | 8 +++++---
2ba5aa
 1 file changed, 5 insertions(+), 3 deletions(-)
2ba5aa
2ba5aa
diff --git a/src/qemu/qemu_firmware.c b/src/qemu/qemu_firmware.c
2ba5aa
index 68e2c6b40f..c84d03f0a8 100644
2ba5aa
--- a/src/qemu/qemu_firmware.c
2ba5aa
+++ b/src/qemu/qemu_firmware.c
2ba5aa
@@ -1241,9 +1241,6 @@ qemuFirmwareFillDomain(virQEMUDriverPtr driver,
2ba5aa
     size_t i;
2ba5aa
     int ret = -1;
2ba5aa
 
2ba5aa
-    if (!(flags & VIR_QEMU_PROCESS_START_NEW))
2ba5aa
-        return 0;
2ba5aa
-
2ba5aa
     /* Fill in FW paths if either os.firmware is enabled, or
2ba5aa
      * loader path was provided with no nvram varstore. */
2ba5aa
     if (def->os.firmware == VIR_DOMAIN_OS_DEF_FIRMWARE_NONE) {
2ba5aa
@@ -1259,6 +1256,11 @@ qemuFirmwareFillDomain(virQEMUDriverPtr driver,
2ba5aa
         /* ... then we want to consult JSON FW descriptors first,
2ba5aa
          * but we don't want to fail if we haven't found a match. */
2ba5aa
         needResult = false;
2ba5aa
+    } else {
2ba5aa
+        /* Domain has FW autoselection enabled => do nothing if
2ba5aa
+         * we are not starting it from scratch. */
2ba5aa
+        if (!(flags & VIR_QEMU_PROCESS_START_NEW))
2ba5aa
+            return 0;
2ba5aa
     }
2ba5aa
 
2ba5aa
     if ((nfirmwares = qemuFirmwareFetchParsedConfigs(driver->privileged,
2ba5aa
-- 
2ba5aa
2.28.0
2ba5aa