mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-25 10:03:49 +03:00
Add invariant TSC cpu flag
Add suport for invariant TSC flag (CPUID 0x80000007, bit 8 of EDX). If this flag is enabled, the TSC ticks at a constant rate across all ACPI P-, C- and T-states. This can be enabled by adding: <feature name='invtsc'/> to the <cpu> element. Migration and saving the domain does not work with this flag. QEMU support: http://git.qemu.org/?p=qemu.git;a=commitdiff;h=303752a The feature name "invtsc" differs from the name "" used by the linux kernel: https://git.kernel.org/cgit/linux/kernel/git/torvalds/linux.git/tree/arch/x86/kernel/cpu/powerflags.c?id=30321c7b#n18
This commit is contained in:
parent
72f919f558
commit
fba6bc47cb
@ -327,6 +327,11 @@
|
|||||||
<cpuid function='0x00000007' ebx='0x00100000'/>
|
<cpuid function='0x00000007' ebx='0x00100000'/>
|
||||||
</feature>
|
</feature>
|
||||||
|
|
||||||
|
<!-- Advanced Power Management edx features -->
|
||||||
|
<feature name='invtsc'>
|
||||||
|
<cpuid function='0x80000007' edx='0x00000100'/>
|
||||||
|
</feature>
|
||||||
|
|
||||||
<!-- models -->
|
<!-- models -->
|
||||||
<model name='486'>
|
<model name='486'>
|
||||||
<feature name='fpu'/>
|
<feature name='fpu'/>
|
||||||
|
@ -1513,6 +1513,21 @@ qemuMigrationIsAllowed(virQEMUDriverPtr driver, virDomainObjPtr vm,
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
for (i = 0; i < def->cpu->nfeatures; i++) {
|
||||||
|
virCPUFeatureDefPtr feature = &def->cpu->features[i];
|
||||||
|
|
||||||
|
if (feature->policy != VIR_CPU_FEATURE_REQUIRE)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
/* QEMU blocks migration and save with invariant TSC enabled */
|
||||||
|
if (STREQ(feature->name, "invtsc")) {
|
||||||
|
virReportError(VIR_ERR_OPERATION_INVALID,
|
||||||
|
_("domain has CPU feature: %s"),
|
||||||
|
feature->name);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3612,6 +3612,7 @@ qemuProcessVerifyGuestCPU(virQEMUDriverPtr driver, virDomainObjPtr vm)
|
|||||||
qemuDomainObjPrivatePtr priv = vm->privateData;
|
qemuDomainObjPrivatePtr priv = vm->privateData;
|
||||||
int rc;
|
int rc;
|
||||||
bool ret = false;
|
bool ret = false;
|
||||||
|
size_t i;
|
||||||
|
|
||||||
switch (arch) {
|
switch (arch) {
|
||||||
case VIR_ARCH_I686:
|
case VIR_ARCH_I686:
|
||||||
@ -3634,6 +3635,20 @@ qemuProcessVerifyGuestCPU(virQEMUDriverPtr driver, virDomainObjPtr vm)
|
|||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
for (i = 0; i < def->cpu->nfeatures; i++) {
|
||||||
|
virCPUFeatureDefPtr feature = &def->cpu->features[i];
|
||||||
|
|
||||||
|
if (feature->policy != VIR_CPU_FEATURE_REQUIRE)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
if (STREQ(feature->name, "invtsc") &&
|
||||||
|
!cpuHasFeature(guestcpu, feature->name)) {
|
||||||
|
virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
|
||||||
|
_("host doesn't support invariant TSC"));
|
||||||
|
goto cleanup;
|
||||||
|
}
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
|
Loading…
x
Reference in New Issue
Block a user