KVM: SVM: Reset MMU on nested_svm_vmrun for NPT too
Without resetting the MMU the gva_to_pga function will not work reliably when the vcpu is running in nested context. Signed-off-by: Joerg Roedel <joerg.roedel@amd.com> Signed-off-by: Avi Kivity <avi@redhat.com>
This commit is contained in:
@@ -1877,10 +1877,12 @@ static bool nested_svm_vmrun(struct vcpu_svm *svm)
|
|||||||
if (npt_enabled) {
|
if (npt_enabled) {
|
||||||
svm->vmcb->save.cr3 = nested_vmcb->save.cr3;
|
svm->vmcb->save.cr3 = nested_vmcb->save.cr3;
|
||||||
svm->vcpu.arch.cr3 = nested_vmcb->save.cr3;
|
svm->vcpu.arch.cr3 = nested_vmcb->save.cr3;
|
||||||
} else {
|
} else
|
||||||
kvm_set_cr3(&svm->vcpu, nested_vmcb->save.cr3);
|
kvm_set_cr3(&svm->vcpu, nested_vmcb->save.cr3);
|
||||||
|
|
||||||
|
/* Guest paging mode is active - reset mmu */
|
||||||
kvm_mmu_reset_context(&svm->vcpu);
|
kvm_mmu_reset_context(&svm->vcpu);
|
||||||
}
|
|
||||||
svm->vmcb->save.cr2 = svm->vcpu.arch.cr2 = nested_vmcb->save.cr2;
|
svm->vmcb->save.cr2 = svm->vcpu.arch.cr2 = nested_vmcb->save.cr2;
|
||||||
kvm_register_write(&svm->vcpu, VCPU_REGS_RAX, nested_vmcb->save.rax);
|
kvm_register_write(&svm->vcpu, VCPU_REGS_RAX, nested_vmcb->save.rax);
|
||||||
kvm_register_write(&svm->vcpu, VCPU_REGS_RSP, nested_vmcb->save.rsp);
|
kvm_register_write(&svm->vcpu, VCPU_REGS_RSP, nested_vmcb->save.rsp);
|
||||||
|
Reference in New Issue
Block a user