KVM: nVMX: Disable unrestricted mode if ept=0
If L0 has disabled EPT, don't advertise unrestricted
mode at all since it depends on EPT to run real mode code.
Fixes: 92fbc7b195
Cc: stable@vger.kernel.org
Reviewed-by: Jan Kiszka <jan.kiszka@siemens.com>
Signed-off-by: Bandan Das <bsd@redhat.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
This commit is contained in:
parent
64a38292ed
commit
78051e3b7e
|
@ -2399,13 +2399,13 @@ static __init void nested_vmx_setup_ctls_msrs(void)
|
||||||
nested_vmx_secondary_ctls_low = 0;
|
nested_vmx_secondary_ctls_low = 0;
|
||||||
nested_vmx_secondary_ctls_high &=
|
nested_vmx_secondary_ctls_high &=
|
||||||
SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
|
SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
|
||||||
SECONDARY_EXEC_UNRESTRICTED_GUEST |
|
|
||||||
SECONDARY_EXEC_WBINVD_EXITING |
|
SECONDARY_EXEC_WBINVD_EXITING |
|
||||||
SECONDARY_EXEC_XSAVES;
|
SECONDARY_EXEC_XSAVES;
|
||||||
|
|
||||||
if (enable_ept) {
|
if (enable_ept) {
|
||||||
/* nested EPT: emulate EPT also to L1 */
|
/* nested EPT: emulate EPT also to L1 */
|
||||||
nested_vmx_secondary_ctls_high |= SECONDARY_EXEC_ENABLE_EPT;
|
nested_vmx_secondary_ctls_high |= SECONDARY_EXEC_ENABLE_EPT |
|
||||||
|
SECONDARY_EXEC_UNRESTRICTED_GUEST;
|
||||||
nested_vmx_ept_caps = VMX_EPT_PAGE_WALK_4_BIT |
|
nested_vmx_ept_caps = VMX_EPT_PAGE_WALK_4_BIT |
|
||||||
VMX_EPTP_WB_BIT | VMX_EPT_2MB_PAGE_BIT |
|
VMX_EPTP_WB_BIT | VMX_EPT_2MB_PAGE_BIT |
|
||||||
VMX_EPT_INVEPT_BIT;
|
VMX_EPT_INVEPT_BIT;
|
||||||
|
|
Loading…
Reference in New Issue