提交 768ecdcd 编写于 作者: J Jiri Denemark

qemu: Do not set default CPU for archs without CPU driver

Whenever there is a guest CPU configured in domain XML, we will call
some CPU driver APIs to validate the CPU definition and check its
compatibility with the hypervisor. Thus domains with guest CPU
specification can only be started if the guest architecture is supported
by the CPU driver. But we would add a default CPU to any domain as long
as QEMU reports it causing failures to start any domain on affected
architectures.

https://bugzilla.redhat.com/show_bug.cgi?id=1805755Signed-off-by: NJiri Denemark <jdenemar@redhat.com>
Reviewed-by: NDaniel P. Berrangé <berrange@redhat.com>
上级 d552b934
...@@ -1096,3 +1096,27 @@ virCPUDataAddFeature(virCPUDataPtr cpuData, ...@@ -1096,3 +1096,27 @@ virCPUDataAddFeature(virCPUDataPtr cpuData,
return driver->dataAddFeature(cpuData, name); return driver->dataAddFeature(cpuData, name);
} }
/**
* virCPUArchIsSupported:
*
* @arch: CPU architecture
*
* Returns true if the architecture is supported by any CPU driver.
*/
bool
virCPUArchIsSupported(virArch arch)
{
size_t i;
size_t j;
for (i = 0; i < G_N_ELEMENTS(drivers); i++) {
for (j = 0; j < drivers[i]->narch; j++) {
if (arch == drivers[i]->arch[j])
return true;
}
}
return false;
}
...@@ -265,6 +265,9 @@ int ...@@ -265,6 +265,9 @@ int
virCPUDataAddFeature(virCPUDataPtr cpuData, virCPUDataAddFeature(virCPUDataPtr cpuData,
const char *name); const char *name);
bool
virCPUArchIsSupported(virArch arch);
/* virCPUDataFormat and virCPUDataParse are implemented for unit tests only and /* virCPUDataFormat and virCPUDataParse are implemented for unit tests only and
* have no real-life usage * have no real-life usage
*/ */
......
...@@ -1310,6 +1310,7 @@ virStoragePoolObjVolumeListExport; ...@@ -1310,6 +1310,7 @@ virStoragePoolObjVolumeListExport;
# cpu/cpu.h # cpu/cpu.h
cpuDecode; cpuDecode;
cpuEncode; cpuEncode;
virCPUArchIsSupported;
virCPUBaseline; virCPUBaseline;
virCPUCheckFeature; virCPUCheckFeature;
virCPUCompare; virCPUCompare;
......
...@@ -4576,6 +4576,9 @@ qemuDomainDefSetDefaultCPU(virDomainDefPtr def, ...@@ -4576,6 +4576,9 @@ qemuDomainDefSetDefaultCPU(virDomainDefPtr def,
def->cpu->model)) def->cpu->model))
return 0; return 0;
if (!virCPUArchIsSupported(def->os.arch))
return 0;
/* Default CPU model info from QEMU is usable for TCG only except for /* Default CPU model info from QEMU is usable for TCG only except for
* x86, s390, and ppc64. */ * x86, s390, and ppc64. */
if (!ARCH_IS_X86(def->os.arch) && if (!ARCH_IS_X86(def->os.arch) &&
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册