|
@@ -285,7 +285,7 @@ static int vgif = true;
|
|
module_param(vgif, int, 0444);
|
|
module_param(vgif, int, 0444);
|
|
|
|
|
|
static void svm_set_cr0(struct kvm_vcpu *vcpu, unsigned long cr0);
|
|
static void svm_set_cr0(struct kvm_vcpu *vcpu, unsigned long cr0);
|
|
-static void svm_flush_tlb(struct kvm_vcpu *vcpu);
|
|
|
|
|
|
+static void svm_flush_tlb(struct kvm_vcpu *vcpu, bool invalidate_gpa);
|
|
static void svm_complete_interrupts(struct vcpu_svm *svm);
|
|
static void svm_complete_interrupts(struct vcpu_svm *svm);
|
|
|
|
|
|
static int nested_svm_exit_handled(struct vcpu_svm *svm);
|
|
static int nested_svm_exit_handled(struct vcpu_svm *svm);
|
|
@@ -2035,7 +2035,7 @@ static int svm_set_cr4(struct kvm_vcpu *vcpu, unsigned long cr4)
|
|
return 1;
|
|
return 1;
|
|
|
|
|
|
if (npt_enabled && ((old_cr4 ^ cr4) & X86_CR4_PGE))
|
|
if (npt_enabled && ((old_cr4 ^ cr4) & X86_CR4_PGE))
|
|
- svm_flush_tlb(vcpu);
|
|
|
|
|
|
+ svm_flush_tlb(vcpu, true);
|
|
|
|
|
|
vcpu->arch.cr4 = cr4;
|
|
vcpu->arch.cr4 = cr4;
|
|
if (!npt_enabled)
|
|
if (!npt_enabled)
|
|
@@ -2385,7 +2385,7 @@ static void nested_svm_set_tdp_cr3(struct kvm_vcpu *vcpu,
|
|
|
|
|
|
svm->vmcb->control.nested_cr3 = __sme_set(root);
|
|
svm->vmcb->control.nested_cr3 = __sme_set(root);
|
|
mark_dirty(svm->vmcb, VMCB_NPT);
|
|
mark_dirty(svm->vmcb, VMCB_NPT);
|
|
- svm_flush_tlb(vcpu);
|
|
|
|
|
|
+ svm_flush_tlb(vcpu, true);
|
|
}
|
|
}
|
|
|
|
|
|
static void nested_svm_inject_npf_exit(struct kvm_vcpu *vcpu,
|
|
static void nested_svm_inject_npf_exit(struct kvm_vcpu *vcpu,
|
|
@@ -2989,7 +2989,7 @@ static void enter_svm_guest_mode(struct vcpu_svm *svm, u64 vmcb_gpa,
|
|
svm->nested.intercept_exceptions = nested_vmcb->control.intercept_exceptions;
|
|
svm->nested.intercept_exceptions = nested_vmcb->control.intercept_exceptions;
|
|
svm->nested.intercept = nested_vmcb->control.intercept;
|
|
svm->nested.intercept = nested_vmcb->control.intercept;
|
|
|
|
|
|
- svm_flush_tlb(&svm->vcpu);
|
|
|
|
|
|
+ svm_flush_tlb(&svm->vcpu, true);
|
|
svm->vmcb->control.int_ctl = nested_vmcb->control.int_ctl | V_INTR_MASKING_MASK;
|
|
svm->vmcb->control.int_ctl = nested_vmcb->control.int_ctl | V_INTR_MASKING_MASK;
|
|
if (nested_vmcb->control.int_ctl & V_INTR_MASKING_MASK)
|
|
if (nested_vmcb->control.int_ctl & V_INTR_MASKING_MASK)
|
|
svm->vcpu.arch.hflags |= HF_VINTR_MASK;
|
|
svm->vcpu.arch.hflags |= HF_VINTR_MASK;
|
|
@@ -4785,7 +4785,7 @@ static int svm_set_tss_addr(struct kvm *kvm, unsigned int addr)
|
|
return 0;
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
|
|
-static void svm_flush_tlb(struct kvm_vcpu *vcpu)
|
|
|
|
|
|
+static void svm_flush_tlb(struct kvm_vcpu *vcpu, bool invalidate_gpa)
|
|
{
|
|
{
|
|
struct vcpu_svm *svm = to_svm(vcpu);
|
|
struct vcpu_svm *svm = to_svm(vcpu);
|
|
|
|
|
|
@@ -5076,7 +5076,7 @@ static void svm_set_cr3(struct kvm_vcpu *vcpu, unsigned long root)
|
|
|
|
|
|
svm->vmcb->save.cr3 = __sme_set(root);
|
|
svm->vmcb->save.cr3 = __sme_set(root);
|
|
mark_dirty(svm->vmcb, VMCB_CR);
|
|
mark_dirty(svm->vmcb, VMCB_CR);
|
|
- svm_flush_tlb(vcpu);
|
|
|
|
|
|
+ svm_flush_tlb(vcpu, true);
|
|
}
|
|
}
|
|
|
|
|
|
static void set_tdp_cr3(struct kvm_vcpu *vcpu, unsigned long root)
|
|
static void set_tdp_cr3(struct kvm_vcpu *vcpu, unsigned long root)
|
|
@@ -5090,7 +5090,7 @@ static void set_tdp_cr3(struct kvm_vcpu *vcpu, unsigned long root)
|
|
svm->vmcb->save.cr3 = kvm_read_cr3(vcpu);
|
|
svm->vmcb->save.cr3 = kvm_read_cr3(vcpu);
|
|
mark_dirty(svm->vmcb, VMCB_CR);
|
|
mark_dirty(svm->vmcb, VMCB_CR);
|
|
|
|
|
|
- svm_flush_tlb(vcpu);
|
|
|
|
|
|
+ svm_flush_tlb(vcpu, true);
|
|
}
|
|
}
|
|
|
|
|
|
static int is_disabled(void)
|
|
static int is_disabled(void)
|