mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-12 07:42:56 +00:00
qemuDomainDefPostParse: Fail if unable to fill machine type
Previously, we used virCapabilitiesDomainDataLookup() to fill machine type in post parse callback if none was provided in the domain XML. If machine type couldn't be filled in an error was reported. After 4a4132b4625 we've changed it to virQEMUCapsGetPreferredMachine() which returns NULL, but we no longer report an error and proceed with the post parse callbacks processing. This may lead to a crash because the code later on assumes def->os.machine is not NULL. Fixes: 4a4132b4625 Signed-off-by: Michal Privoznik <mprivozn@redhat.com> Reviewed-by: Pavel Mores <pmores@redhat.com>
This commit is contained in:
parent
67e19fc99a
commit
67b973b510
@ -4973,6 +4973,14 @@ qemuDomainDefPostParse(virDomainDefPtr def,
|
||||
if (!def->os.machine) {
|
||||
const char *machine = virQEMUCapsGetPreferredMachine(qemuCaps,
|
||||
def->virtType);
|
||||
if (!machine) {
|
||||
virReportError(VIR_ERR_INVALID_ARG,
|
||||
_("could not get preferred machine for %s type=%s"),
|
||||
def->emulator,
|
||||
virDomainVirtTypeToString(def->virtType));
|
||||
return -1;
|
||||
}
|
||||
|
||||
def->os.machine = g_strdup(machine);
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user