mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-12 13:17:58 +03:00
qemu: Match NVRAM template extension for new domains
Keep things consistent by using the same file extension for the generated NVRAM path as the NVRAM template. Signed-off-by: Andrea Bolognani <abologna@redhat.com> Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
This commit is contained in:
parent
e96e322725
commit
b845e376a4
@ -4505,7 +4505,7 @@ qemuDomainDefBootPostParse(virDomainDef *def,
|
|||||||
* to start the domain, qemuFirmwareFillDomain() will be run
|
* to start the domain, qemuFirmwareFillDomain() will be run
|
||||||
* again, fail in the same way, and at that point we'll have a
|
* again, fail in the same way, and at that point we'll have a
|
||||||
* chance to inform the user of any issues */
|
* chance to inform the user of any issues */
|
||||||
if (qemuFirmwareFillDomain(driver, def) < 0) {
|
if (qemuFirmwareFillDomain(driver, def, abiUpdate) < 0) {
|
||||||
if (abiUpdate) {
|
if (abiUpdate) {
|
||||||
return -1;
|
return -1;
|
||||||
} else {
|
} else {
|
||||||
|
@ -32,6 +32,7 @@
|
|||||||
#include "virlog.h"
|
#include "virlog.h"
|
||||||
#include "viralloc.h"
|
#include "viralloc.h"
|
||||||
#include "virenum.h"
|
#include "virenum.h"
|
||||||
|
#include "virstring.h"
|
||||||
|
|
||||||
#define VIR_FROM_THIS VIR_FROM_QEMU
|
#define VIR_FROM_THIS VIR_FROM_QEMU
|
||||||
|
|
||||||
@ -1054,6 +1055,7 @@ qemuFirmwareOSInterfaceTypeFromOsDefLoaderType(virDomainLoader type)
|
|||||||
* qemuFirmwareEnsureNVRAM:
|
* qemuFirmwareEnsureNVRAM:
|
||||||
* @def: domain definition
|
* @def: domain definition
|
||||||
* @driver: QEMU driver
|
* @driver: QEMU driver
|
||||||
|
* @abiUpdate: whether a new domain is being defined
|
||||||
*
|
*
|
||||||
* Make sure that a source for the NVRAM file exists, possibly by
|
* Make sure that a source for the NVRAM file exists, possibly by
|
||||||
* creating it. This might involve automatically generating the
|
* creating it. This might involve automatically generating the
|
||||||
@ -1061,7 +1063,8 @@ qemuFirmwareOSInterfaceTypeFromOsDefLoaderType(virDomainLoader type)
|
|||||||
*/
|
*/
|
||||||
static void
|
static void
|
||||||
qemuFirmwareEnsureNVRAM(virDomainDef *def,
|
qemuFirmwareEnsureNVRAM(virDomainDef *def,
|
||||||
virQEMUDriver *driver)
|
virQEMUDriver *driver,
|
||||||
|
bool abiUpdate)
|
||||||
{
|
{
|
||||||
g_autoptr(virQEMUDriverConfig) cfg = virQEMUDriverGetConfig(driver);
|
g_autoptr(virQEMUDriverConfig) cfg = virQEMUDriverGetConfig(driver);
|
||||||
virDomainLoaderDef *loader = def->os.loader;
|
virDomainLoaderDef *loader = def->os.loader;
|
||||||
@ -1091,8 +1094,25 @@ qemuFirmwareEnsureNVRAM(virDomainDef *def,
|
|||||||
loader->nvram->type = VIR_STORAGE_TYPE_FILE;
|
loader->nvram->type = VIR_STORAGE_TYPE_FILE;
|
||||||
loader->nvram->format = loader->format;
|
loader->nvram->format = loader->format;
|
||||||
|
|
||||||
if (loader->nvram->format == VIR_STORAGE_FILE_RAW)
|
if (loader->nvram->format == VIR_STORAGE_FILE_RAW) {
|
||||||
|
/* The extension used by raw edk2 builds has historically
|
||||||
|
* been .fd, but more recent aarch64 builds have started
|
||||||
|
* using the .raw extension instead.
|
||||||
|
*
|
||||||
|
* If we're defining a new domain, we should try to match the
|
||||||
|
* extension for the file backing its NVRAM store with the
|
||||||
|
* one used by the template to keep things nice and
|
||||||
|
* consistent.
|
||||||
|
*
|
||||||
|
* If we're loading an existing domain, however, we need to
|
||||||
|
* stick with the .fd extension to ensure compatibility */
|
||||||
|
if (abiUpdate &&
|
||||||
|
loader->nvramTemplate &&
|
||||||
|
virStringHasSuffix(loader->nvramTemplate, ".raw"))
|
||||||
|
ext = ".raw";
|
||||||
|
else
|
||||||
ext = ".fd";
|
ext = ".fd";
|
||||||
|
}
|
||||||
if (loader->nvram->format == VIR_STORAGE_FILE_QCOW2)
|
if (loader->nvram->format == VIR_STORAGE_FILE_QCOW2)
|
||||||
ext = ".qcow2";
|
ext = ".qcow2";
|
||||||
|
|
||||||
@ -1729,6 +1749,7 @@ qemuFirmwareFillDomainModern(virQEMUDriver *driver,
|
|||||||
* qemuFirmwareFillDomain:
|
* qemuFirmwareFillDomain:
|
||||||
* @driver: QEMU driver
|
* @driver: QEMU driver
|
||||||
* @def: domain definition
|
* @def: domain definition
|
||||||
|
* @abiUpdate: whether a new domain is being defined
|
||||||
*
|
*
|
||||||
* Perform firmware selection.
|
* Perform firmware selection.
|
||||||
*
|
*
|
||||||
@ -1752,7 +1773,8 @@ qemuFirmwareFillDomainModern(virQEMUDriver *driver,
|
|||||||
*/
|
*/
|
||||||
int
|
int
|
||||||
qemuFirmwareFillDomain(virQEMUDriver *driver,
|
qemuFirmwareFillDomain(virQEMUDriver *driver,
|
||||||
virDomainDef *def)
|
virDomainDef *def,
|
||||||
|
bool abiUpdate)
|
||||||
{
|
{
|
||||||
virDomainLoaderDef *loader = def->os.loader;
|
virDomainLoaderDef *loader = def->os.loader;
|
||||||
virStorageSource *nvram = loader ? loader->nvram : NULL;
|
virStorageSource *nvram = loader ? loader->nvram : NULL;
|
||||||
@ -1822,7 +1844,7 @@ qemuFirmwareFillDomain(virQEMUDriver *driver,
|
|||||||
/* Always ensure that the NVRAM path is present, even if we
|
/* Always ensure that the NVRAM path is present, even if we
|
||||||
* haven't found a match: the configuration might simply be
|
* haven't found a match: the configuration might simply be
|
||||||
* referring to a custom firmware build */
|
* referring to a custom firmware build */
|
||||||
qemuFirmwareEnsureNVRAM(def, driver);
|
qemuFirmwareEnsureNVRAM(def, driver, abiUpdate);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -44,7 +44,8 @@ qemuFirmwareFetchConfigs(char ***firmwares,
|
|||||||
|
|
||||||
int
|
int
|
||||||
qemuFirmwareFillDomain(virQEMUDriver *driver,
|
qemuFirmwareFillDomain(virQEMUDriver *driver,
|
||||||
virDomainDef *def);
|
virDomainDef *def,
|
||||||
|
bool abiUpdate);
|
||||||
|
|
||||||
int
|
int
|
||||||
qemuFirmwareGetSupported(const char *machine,
|
qemuFirmwareGetSupported(const char *machine,
|
||||||
|
@ -6705,7 +6705,7 @@ qemuProcessPrepareDomain(virQEMUDriver *driver,
|
|||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
VIR_DEBUG("Prepare bios/uefi paths");
|
VIR_DEBUG("Prepare bios/uefi paths");
|
||||||
if (qemuFirmwareFillDomain(driver, vm->def) < 0)
|
if (qemuFirmwareFillDomain(driver, vm->def, false) < 0)
|
||||||
return -1;
|
return -1;
|
||||||
if (qemuDomainInitializePflashStorageSource(vm, cfg) < 0)
|
if (qemuDomainInitializePflashStorageSource(vm, cfg) < 0)
|
||||||
return -1;
|
return -1;
|
||||||
|
@ -12,7 +12,7 @@ XDG_CONFIG_HOME=/var/lib/libvirt/qemu/domain--1-guest/.config \
|
|||||||
-object '{"qom-type":"secret","id":"masterKey0","format":"raw","file":"/var/lib/libvirt/qemu/domain--1-guest/master-key.aes"}' \
|
-object '{"qom-type":"secret","id":"masterKey0","format":"raw","file":"/var/lib/libvirt/qemu/domain--1-guest/master-key.aes"}' \
|
||||||
-blockdev '{"driver":"file","filename":"/usr/share/edk2/aarch64/QEMU_EFI-silent-pflash.raw","node-name":"libvirt-pflash0-storage","auto-read-only":true,"discard":"unmap"}' \
|
-blockdev '{"driver":"file","filename":"/usr/share/edk2/aarch64/QEMU_EFI-silent-pflash.raw","node-name":"libvirt-pflash0-storage","auto-read-only":true,"discard":"unmap"}' \
|
||||||
-blockdev '{"node-name":"libvirt-pflash0-format","read-only":true,"driver":"raw","file":"libvirt-pflash0-storage"}' \
|
-blockdev '{"node-name":"libvirt-pflash0-format","read-only":true,"driver":"raw","file":"libvirt-pflash0-storage"}' \
|
||||||
-blockdev '{"driver":"file","filename":"/var/lib/libvirt/qemu/nvram/guest_VARS.fd","node-name":"libvirt-pflash1-storage","auto-read-only":true,"discard":"unmap"}' \
|
-blockdev '{"driver":"file","filename":"/var/lib/libvirt/qemu/nvram/guest_VARS.raw","node-name":"libvirt-pflash1-storage","auto-read-only":true,"discard":"unmap"}' \
|
||||||
-blockdev '{"node-name":"libvirt-pflash1-format","read-only":false,"driver":"raw","file":"libvirt-pflash1-storage"}' \
|
-blockdev '{"node-name":"libvirt-pflash1-format","read-only":false,"driver":"raw","file":"libvirt-pflash1-storage"}' \
|
||||||
-machine virt-4.0,usb=off,gic-version=2,dump-guest-core=off,memory-backend=mach-virt.ram,pflash0=libvirt-pflash0-format,pflash1=libvirt-pflash1-format \
|
-machine virt-4.0,usb=off,gic-version=2,dump-guest-core=off,memory-backend=mach-virt.ram,pflash0=libvirt-pflash0-format,pflash1=libvirt-pflash1-format \
|
||||||
-accel tcg \
|
-accel tcg \
|
||||||
|
@ -11,7 +11,7 @@
|
|||||||
<feature enabled='no' name='secure-boot'/>
|
<feature enabled='no' name='secure-boot'/>
|
||||||
</firmware>
|
</firmware>
|
||||||
<loader readonly='yes' type='pflash'>/usr/share/edk2/aarch64/QEMU_EFI-silent-pflash.raw</loader>
|
<loader readonly='yes' type='pflash'>/usr/share/edk2/aarch64/QEMU_EFI-silent-pflash.raw</loader>
|
||||||
<nvram template='/usr/share/edk2/aarch64/vars-template-pflash.raw'>/var/lib/libvirt/qemu/nvram/guest_VARS.fd</nvram>
|
<nvram template='/usr/share/edk2/aarch64/vars-template-pflash.raw'>/var/lib/libvirt/qemu/nvram/guest_VARS.raw</nvram>
|
||||||
<boot dev='hd'/>
|
<boot dev='hd'/>
|
||||||
</os>
|
</os>
|
||||||
<features>
|
<features>
|
||||||
|
Loading…
Reference in New Issue
Block a user