aboutsummaryrefslogtreecommitdiffstats
path: root/arch/x86/kvm/vmx.c
diff options
context:
space:
mode:
Diffstat (limited to 'arch/x86/kvm/vmx.c')
-rw-r--r--arch/x86/kvm/vmx.c33
1 files changed, 14 insertions, 19 deletions
diff --git a/arch/x86/kvm/vmx.c b/arch/x86/kvm/vmx.c
index 2f65120cf283..da6461d5dc84 100644
--- a/arch/x86/kvm/vmx.c
+++ b/arch/x86/kvm/vmx.c
@@ -263,11 +263,6 @@ static inline int cpu_has_vmx_ept(void)
263 SECONDARY_EXEC_ENABLE_EPT); 263 SECONDARY_EXEC_ENABLE_EPT);
264} 264}
265 265
266static inline int vm_need_ept(void)
267{
268 return enable_ept;
269}
270
271static inline int vm_need_virtualize_apic_accesses(struct kvm *kvm) 266static inline int vm_need_virtualize_apic_accesses(struct kvm *kvm)
272{ 267{
273 return ((cpu_has_vmx_virtualize_apic_accesses()) && 268 return ((cpu_has_vmx_virtualize_apic_accesses()) &&
@@ -382,7 +377,7 @@ static inline void ept_sync_global(void)
382 377
383static inline void ept_sync_context(u64 eptp) 378static inline void ept_sync_context(u64 eptp)
384{ 379{
385 if (vm_need_ept()) { 380 if (enable_ept) {
386 if (cpu_has_vmx_invept_context()) 381 if (cpu_has_vmx_invept_context())
387 __invept(VMX_EPT_EXTENT_CONTEXT, eptp, 0); 382 __invept(VMX_EPT_EXTENT_CONTEXT, eptp, 0);
388 else 383 else
@@ -392,7 +387,7 @@ static inline void ept_sync_context(u64 eptp)
392 387
393static inline void ept_sync_individual_addr(u64 eptp, gpa_t gpa) 388static inline void ept_sync_individual_addr(u64 eptp, gpa_t gpa)
394{ 389{
395 if (vm_need_ept()) { 390 if (enable_ept) {
396 if (cpu_has_vmx_invept_individual_addr()) 391 if (cpu_has_vmx_invept_individual_addr())
397 __invept(VMX_EPT_EXTENT_INDIVIDUAL_ADDR, 392 __invept(VMX_EPT_EXTENT_INDIVIDUAL_ADDR,
398 eptp, gpa); 393 eptp, gpa);
@@ -491,7 +486,7 @@ static void update_exception_bitmap(struct kvm_vcpu *vcpu)
491 } 486 }
492 if (vcpu->arch.rmode.active) 487 if (vcpu->arch.rmode.active)
493 eb = ~0; 488 eb = ~0;
494 if (vm_need_ept()) 489 if (enable_ept)
495 eb &= ~(1u << PF_VECTOR); /* bypass_guest_pf = 0 */ 490 eb &= ~(1u << PF_VECTOR); /* bypass_guest_pf = 0 */
496 vmcs_write32(EXCEPTION_BITMAP, eb); 491 vmcs_write32(EXCEPTION_BITMAP, eb);
497} 492}
@@ -1502,7 +1497,7 @@ static void exit_lmode(struct kvm_vcpu *vcpu)
1502static void vmx_flush_tlb(struct kvm_vcpu *vcpu) 1497static void vmx_flush_tlb(struct kvm_vcpu *vcpu)
1503{ 1498{
1504 vpid_sync_vcpu_all(to_vmx(vcpu)); 1499 vpid_sync_vcpu_all(to_vmx(vcpu));
1505 if (vm_need_ept()) 1500 if (enable_ept)
1506 ept_sync_context(construct_eptp(vcpu->arch.mmu.root_hpa)); 1501 ept_sync_context(construct_eptp(vcpu->arch.mmu.root_hpa));
1507} 1502}
1508 1503
@@ -1587,7 +1582,7 @@ static void vmx_set_cr0(struct kvm_vcpu *vcpu, unsigned long cr0)
1587 } 1582 }
1588#endif 1583#endif
1589 1584
1590 if (vm_need_ept()) 1585 if (enable_ept)
1591 ept_update_paging_mode_cr0(&hw_cr0, cr0, vcpu); 1586 ept_update_paging_mode_cr0(&hw_cr0, cr0, vcpu);
1592 1587
1593 vmcs_writel(CR0_READ_SHADOW, cr0); 1588 vmcs_writel(CR0_READ_SHADOW, cr0);
@@ -1616,7 +1611,7 @@ static void vmx_set_cr3(struct kvm_vcpu *vcpu, unsigned long cr3)
1616 u64 eptp; 1611 u64 eptp;
1617 1612
1618 guest_cr3 = cr3; 1613 guest_cr3 = cr3;
1619 if (vm_need_ept()) { 1614 if (enable_ept) {
1620 eptp = construct_eptp(cr3); 1615 eptp = construct_eptp(cr3);
1621 vmcs_write64(EPT_POINTER, eptp); 1616 vmcs_write64(EPT_POINTER, eptp);
1622 ept_sync_context(eptp); 1617 ept_sync_context(eptp);
@@ -1637,7 +1632,7 @@ static void vmx_set_cr4(struct kvm_vcpu *vcpu, unsigned long cr4)
1637 KVM_RMODE_VM_CR4_ALWAYS_ON : KVM_PMODE_VM_CR4_ALWAYS_ON); 1632 KVM_RMODE_VM_CR4_ALWAYS_ON : KVM_PMODE_VM_CR4_ALWAYS_ON);
1638 1633
1639 vcpu->arch.cr4 = cr4; 1634 vcpu->arch.cr4 = cr4;
1640 if (vm_need_ept()) 1635 if (enable_ept)
1641 ept_update_paging_mode_cr4(&hw_cr4, vcpu); 1636 ept_update_paging_mode_cr4(&hw_cr4, vcpu);
1642 1637
1643 vmcs_writel(CR4_READ_SHADOW, cr4); 1638 vmcs_writel(CR4_READ_SHADOW, cr4);
@@ -1999,7 +1994,7 @@ static int init_rmode_identity_map(struct kvm *kvm)
1999 pfn_t identity_map_pfn; 1994 pfn_t identity_map_pfn;
2000 u32 tmp; 1995 u32 tmp;
2001 1996
2002 if (!vm_need_ept()) 1997 if (!enable_ept)
2003 return 1; 1998 return 1;
2004 if (unlikely(!kvm->arch.ept_identity_pagetable)) { 1999 if (unlikely(!kvm->arch.ept_identity_pagetable)) {
2005 printk(KERN_ERR "EPT: identity-mapping pagetable " 2000 printk(KERN_ERR "EPT: identity-mapping pagetable "
@@ -2163,7 +2158,7 @@ static int vmx_vcpu_setup(struct vcpu_vmx *vmx)
2163 CPU_BASED_CR8_LOAD_EXITING; 2158 CPU_BASED_CR8_LOAD_EXITING;
2164#endif 2159#endif
2165 } 2160 }
2166 if (!vm_need_ept()) 2161 if (!enable_ept)
2167 exec_control |= CPU_BASED_CR3_STORE_EXITING | 2162 exec_control |= CPU_BASED_CR3_STORE_EXITING |
2168 CPU_BASED_CR3_LOAD_EXITING | 2163 CPU_BASED_CR3_LOAD_EXITING |
2169 CPU_BASED_INVLPG_EXITING; 2164 CPU_BASED_INVLPG_EXITING;
@@ -2176,7 +2171,7 @@ static int vmx_vcpu_setup(struct vcpu_vmx *vmx)
2176 ~SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES; 2171 ~SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES;
2177 if (vmx->vpid == 0) 2172 if (vmx->vpid == 0)
2178 exec_control &= ~SECONDARY_EXEC_ENABLE_VPID; 2173 exec_control &= ~SECONDARY_EXEC_ENABLE_VPID;
2179 if (!vm_need_ept()) 2174 if (!enable_ept)
2180 exec_control &= ~SECONDARY_EXEC_ENABLE_EPT; 2175 exec_control &= ~SECONDARY_EXEC_ENABLE_EPT;
2181 vmcs_write32(SECONDARY_VM_EXEC_CONTROL, exec_control); 2176 vmcs_write32(SECONDARY_VM_EXEC_CONTROL, exec_control);
2182 } 2177 }
@@ -2637,7 +2632,7 @@ static int handle_exception(struct kvm_vcpu *vcpu, struct kvm_run *kvm_run)
2637 error_code = vmcs_read32(VM_EXIT_INTR_ERROR_CODE); 2632 error_code = vmcs_read32(VM_EXIT_INTR_ERROR_CODE);
2638 if (is_page_fault(intr_info)) { 2633 if (is_page_fault(intr_info)) {
2639 /* EPT won't cause page fault directly */ 2634 /* EPT won't cause page fault directly */
2640 if (vm_need_ept()) 2635 if (enable_ept)
2641 BUG(); 2636 BUG();
2642 cr2 = vmcs_readl(EXIT_QUALIFICATION); 2637 cr2 = vmcs_readl(EXIT_QUALIFICATION);
2643 KVMTRACE_3D(PAGE_FAULT, vcpu, error_code, (u32)cr2, 2638 KVMTRACE_3D(PAGE_FAULT, vcpu, error_code, (u32)cr2,
@@ -3187,7 +3182,7 @@ static int vmx_handle_exit(struct kvm_run *kvm_run, struct kvm_vcpu *vcpu)
3187 3182
3188 /* Access CR3 don't cause VMExit in paging mode, so we need 3183 /* Access CR3 don't cause VMExit in paging mode, so we need
3189 * to sync with guest real CR3. */ 3184 * to sync with guest real CR3. */
3190 if (vm_need_ept() && is_paging(vcpu)) { 3185 if (enable_ept && is_paging(vcpu)) {
3191 vcpu->arch.cr3 = vmcs_readl(GUEST_CR3); 3186 vcpu->arch.cr3 = vmcs_readl(GUEST_CR3);
3192 ept_load_pdptrs(vcpu); 3187 ept_load_pdptrs(vcpu);
3193 } 3188 }
@@ -3602,7 +3597,7 @@ static struct kvm_vcpu *vmx_create_vcpu(struct kvm *kvm, unsigned int id)
3602 if (alloc_apic_access_page(kvm) != 0) 3597 if (alloc_apic_access_page(kvm) != 0)
3603 goto free_vmcs; 3598 goto free_vmcs;
3604 3599
3605 if (vm_need_ept()) 3600 if (enable_ept)
3606 if (alloc_identity_pagetable(kvm) != 0) 3601 if (alloc_identity_pagetable(kvm) != 0)
3607 goto free_vmcs; 3602 goto free_vmcs;
3608 3603
@@ -3753,7 +3748,7 @@ static int __init vmx_init(void)
3753 vmx_disable_intercept_for_msr(MSR_IA32_SYSENTER_ESP, false); 3748 vmx_disable_intercept_for_msr(MSR_IA32_SYSENTER_ESP, false);
3754 vmx_disable_intercept_for_msr(MSR_IA32_SYSENTER_EIP, false); 3749 vmx_disable_intercept_for_msr(MSR_IA32_SYSENTER_EIP, false);
3755 3750
3756 if (vm_need_ept()) { 3751 if (enable_ept) {
3757 bypass_guest_pf = 0; 3752 bypass_guest_pf = 0;
3758 kvm_mmu_set_base_ptes(VMX_EPT_READABLE_MASK | 3753 kvm_mmu_set_base_ptes(VMX_EPT_READABLE_MASK |
3759 VMX_EPT_WRITABLE_MASK); 3754 VMX_EPT_WRITABLE_MASK);