Commit a992f642 authored by Marcelo Tosatti's avatar Marcelo Tosatti Committed by Jiri Slaby

KVM: x86: expose invariant tsc cpuid bit (v2)

commit e4c9a5a1 upstream.

Invariant TSC is a property of TSC, no additional
support code necessary.
Signed-off-by: default avatarMarcelo Tosatti <mtosatti@redhat.com>
Signed-off-by: default avatarPaolo Bonzini <pbonzini@redhat.com>
Signed-off-by: default avatarJiri Slaby <jslaby@suse.cz>
parent 8617fe9e
...@@ -437,6 +437,13 @@ static int do_cpuid_ent(struct kvm_cpuid_entry2 *entry, u32 function, ...@@ -437,6 +437,13 @@ static int do_cpuid_ent(struct kvm_cpuid_entry2 *entry, u32 function,
entry->ecx &= kvm_supported_word6_x86_features; entry->ecx &= kvm_supported_word6_x86_features;
cpuid_mask(&entry->ecx, 6); cpuid_mask(&entry->ecx, 6);
break; break;
case 0x80000007: /* Advanced power management */
/* invariant TSC is CPUID.80000007H:EDX[8] */
entry->edx &= (1 << 8);
/* mask against host */
entry->edx &= boot_cpu_data.x86_power;
entry->eax = entry->ebx = entry->ecx = 0;
break;
case 0x80000008: { case 0x80000008: {
unsigned g_phys_as = (entry->eax >> 16) & 0xff; unsigned g_phys_as = (entry->eax >> 16) & 0xff;
unsigned virt_as = max((entry->eax >> 8) & 0xff, 48U); unsigned virt_as = max((entry->eax >> 8) & 0xff, 48U);
...@@ -467,7 +474,6 @@ static int do_cpuid_ent(struct kvm_cpuid_entry2 *entry, u32 function, ...@@ -467,7 +474,6 @@ static int do_cpuid_ent(struct kvm_cpuid_entry2 *entry, u32 function,
case 3: /* Processor serial number */ case 3: /* Processor serial number */
case 5: /* MONITOR/MWAIT */ case 5: /* MONITOR/MWAIT */
case 6: /* Thermal management */ case 6: /* Thermal management */
case 0x80000007: /* Advanced power management */
case 0xC0000002: case 0xC0000002:
case 0xC0000003: case 0xC0000003:
case 0xC0000004: case 0xC0000004:
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment