提交 a7c8b30e 编写于 作者: J Jiri Denemark 提交者: Cole Robinson

qemu: Give hint about -noTSX CPU model

Because of the microcode update to Haswell/Broadwell CPUs, existing
domains using these CPUs may fail to start even though they used to run
just fine. To help users solve this issue we try to suggest switching to
-noTSX variant of the CPU model:

    virsh # start cd
    error: Failed to start domain cd
    error: unsupported configuration: guest and host CPU are not
    compatible: Host CPU does not provide required features: rtm, hle;
    try using 'Haswell-noTSX' CPU model
Signed-off-by: NJiri Denemark <jdenemar@redhat.com>
(cherry picked from commit 53c8062f)
上级 f046531e
...@@ -6612,6 +6612,7 @@ qemuBuildCpuModelArgStr(virQEMUDriverPtr driver, ...@@ -6612,6 +6612,7 @@ qemuBuildCpuModelArgStr(virQEMUDriverPtr driver,
size_t ncpus = 0; size_t ncpus = 0;
char **cpus = NULL; char **cpus = NULL;
virCPUDataPtr data = NULL; virCPUDataPtr data = NULL;
virCPUDataPtr hostData = NULL;
char *compare_msg = NULL; char *compare_msg = NULL;
virCPUCompareResult cmp; virCPUCompareResult cmp;
const char *preferred; const char *preferred;
...@@ -6643,16 +6644,42 @@ qemuBuildCpuModelArgStr(virQEMUDriverPtr driver, ...@@ -6643,16 +6644,42 @@ qemuBuildCpuModelArgStr(virQEMUDriverPtr driver,
/* For non-KVM, CPU features are emulated, so host compat doesn't matter */ /* For non-KVM, CPU features are emulated, so host compat doesn't matter */
if (compareAgainstHost) { if (compareAgainstHost) {
bool noTSX = false;
cmp = cpuGuestData(host, cpu, &data, &compare_msg); cmp = cpuGuestData(host, cpu, &data, &compare_msg);
switch (cmp) { switch (cmp) {
case VIR_CPU_COMPARE_INCOMPATIBLE: case VIR_CPU_COMPARE_INCOMPATIBLE:
if (cpuEncode(host->arch, host, NULL, &hostData,
NULL, NULL, NULL, NULL) == 0 &&
(!cpuHasFeature(hostData, "hle") ||
!cpuHasFeature(hostData, "rtm")) &&
(STREQ_NULLABLE(cpu->model, "Haswell") ||
STREQ_NULLABLE(cpu->model, "Broadwell")))
noTSX = true;
if (compare_msg) { if (compare_msg) {
virReportError(VIR_ERR_CONFIG_UNSUPPORTED, if (noTSX) {
_("guest and host CPU are not compatible: %s"), virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
compare_msg); _("guest and host CPU are not compatible: "
"%s; try using '%s-noTSX' CPU model"),
compare_msg, cpu->model);
} else {
virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
_("guest and host CPU are not compatible: "
"%s"),
compare_msg);
}
} else { } else {
virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s", if (noTSX) {
_("guest CPU is not compatible with host CPU")); virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
_("guest CPU is not compatible with host "
"CPU; try using '%s-noTSX' CPU model"),
cpu->model);
} else {
virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
_("guest CPU is not compatible with host "
"CPU"));
}
} }
/* fall through */ /* fall through */
case VIR_CPU_COMPARE_ERROR: case VIR_CPU_COMPARE_ERROR:
...@@ -6746,6 +6773,7 @@ qemuBuildCpuModelArgStr(virQEMUDriverPtr driver, ...@@ -6746,6 +6773,7 @@ qemuBuildCpuModelArgStr(virQEMUDriverPtr driver,
virObjectUnref(caps); virObjectUnref(caps);
VIR_FREE(compare_msg); VIR_FREE(compare_msg);
cpuDataFree(data); cpuDataFree(data);
cpuDataFree(hostData);
virCPUDefFree(guest); virCPUDefFree(guest);
virCPUDefFree(cpu); virCPUDefFree(cpu);
return ret; return ret;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册