aboutsummaryrefslogtreecommitdiffstats
path: root/arch/x86/kvm/cpuid.c
diff options
context:
space:
mode:
authorPaolo Bonzini <pbonzini@redhat.com>2013-10-02 10:06:14 -0400
committerGleb Natapov <gleb@redhat.com>2013-10-03 05:29:04 -0400
commit647e23bb333ff196e7be8ae08c842d855fb850f6 (patch)
treea71cae213807d51e30ad5e942281dfdfd55db99f /arch/x86/kvm/cpuid.c
parent29242cb5c63b1f8e12e8055ba1a6c3e0004fa86d (diff)
KVM: x86: mask unsupported XSAVE entries from leaf 0Dh index 0
XSAVE entries that KVM does not support are reported by KVM_GET_SUPPORTED_CPUID for leaf 0Dh index 0 if the host supports them; they should be left out unless there is also hypervisor support for them. Sub-leafs are correctly handled in supported_xcr0_bit, fix index 0 to match. Signed-off-by: Paolo Bonzini <pbonzini@redhat.com> Signed-off-by: Gleb Natapov <gleb@redhat.com>
Diffstat (limited to 'arch/x86/kvm/cpuid.c')
-rw-r--r--arch/x86/kvm/cpuid.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/arch/x86/kvm/cpuid.c b/arch/x86/kvm/cpuid.c
index b110fe6c03d4..a03a9faf81b0 100644
--- a/arch/x86/kvm/cpuid.c
+++ b/arch/x86/kvm/cpuid.c
@@ -182,7 +182,7 @@ static bool supported_xcr0_bit(unsigned bit)
182{ 182{
183 u64 mask = ((u64)1 << bit); 183 u64 mask = ((u64)1 << bit);
184 184
185 return mask & (XSTATE_FP | XSTATE_SSE | XSTATE_YMM) & host_xcr0; 185 return mask & KVM_SUPPORTED_XCR0 & host_xcr0;
186} 186}
187 187
188#define F(x) bit(X86_FEATURE_##x) 188#define F(x) bit(X86_FEATURE_##x)
@@ -383,6 +383,8 @@ static int do_cpuid_ent(struct kvm_cpuid_entry2 *entry, u32 function,
383 case 0xd: { 383 case 0xd: {
384 int idx, i; 384 int idx, i;
385 385
386 entry->eax &= host_xcr0 & KVM_SUPPORTED_XCR0;
387 entry->edx &= (host_xcr0 & KVM_SUPPORTED_XCR0) >> 32;
386 entry->flags |= KVM_CPUID_FLAG_SIGNIFCANT_INDEX; 388 entry->flags |= KVM_CPUID_FLAG_SIGNIFCANT_INDEX;
387 for (idx = 1, i = 1; idx < 64; ++idx) { 389 for (idx = 1, i = 1; idx < 64; ++idx) {
388 if (*nent >= maxnent) 390 if (*nent >= maxnent)