diff options
author | Paolo Bonzini <pbonzini@redhat.com> | 2020-07-08 13:02:50 +0200 |
---|---|---|
committer | Paolo Bonzini <pbonzini@redhat.com> | 2020-07-08 22:21:58 +0200 |
commit | 53efe527ca4a4432d17c693efde6eec56fb43ebb (patch) | |
tree | e67e0a34edefc7ff722716d5fd7dbdf616626414 /arch/x86/kvm/x86.h | |
parent | KVM: x86: Create mask for guest CR4 reserved bits in kvm_update_cpuid() (diff) | |
download | linux-53efe527ca4a4432d17c693efde6eec56fb43ebb.tar.xz linux-53efe527ca4a4432d17c693efde6eec56fb43ebb.zip |
KVM: x86: Make CR4.VMXE reserved for the guest
CR4.VMXE is reserved unless the VMX CPUID bit is set. On Intel,
it is also tested by vmx_set_cr4, but AMD relies on kvm_valid_cr4,
so fix it.
Reviewed-by: Jim Mattson <jmattson@google.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
Diffstat (limited to 'arch/x86/kvm/x86.h')
-rw-r--r-- | arch/x86/kvm/x86.h | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/arch/x86/kvm/x86.h b/arch/x86/kvm/x86.h index 15276ed224d5..10441fbb4073 100644 --- a/arch/x86/kvm/x86.h +++ b/arch/x86/kvm/x86.h @@ -391,6 +391,8 @@ bool kvm_vcpu_exit_request(struct kvm_vcpu *vcpu); __reserved_bits |= X86_CR4_LA57; \ if (!__cpu_has(__c, X86_FEATURE_UMIP)) \ __reserved_bits |= X86_CR4_UMIP; \ + if (!__cpu_has(__c, X86_FEATURE_VMX)) \ + __reserved_bits |= X86_CR4_VMXE; \ __reserved_bits; \ }) |