Unbreak AMD nested virtualization.
-----BEGIN PGP SIGNATURE----- Version: GnuPG v2.0.22 (GNU/Linux) iQEcBAABAgAGBQJcHOSgAAoJEL/70l94x66DAw4H/jQjdRjT1DAf4vswXwMD6lpJ qHcSyAYL4d/PFbcovfAm2ca8F0HJylVWDeZcqQRP3zdX53diqJ4gyYMaNuuY0niX zKvzNhFw1oaZK93rwrF6BX1jl4Virw2uC4qL9bhgV/OfkmvTPvIFkP8gJGVDt9YY Kn5yhWnJOpHOCQs3GW8zOy2LWtiuCrp7epSrMGjGsWrp50ccW1tTioxYyDmBr3mF GizAIgDD2xMwIeOlj4IngQhDTahwekOA9XzhSMKjm0/GMcZ33TXPcnUdoa0Yxguj Uu3cXLfcEUfakZdefi3FB5eDB2knDe3kbmKviok2giAAY1hBvEO5b6bHrn+5W2g= =l4oP -----END PGP SIGNATURE----- Merge tag 'for-linus' of git://git.kernel.org/pub/scm/virt/kvm/kvm Pull kvm fix from Paolo Bonzini: "A simple patch for a pretty bad bug: Unbreak AMD nested virtualization." * tag 'for-linus' of git://git.kernel.org/pub/scm/virt/kvm/kvm: KVM: x86: nSVM: fix switch to guest mmu
This commit is contained in:
commit
5092adb227
@ -2937,6 +2937,8 @@ static void nested_svm_inject_npf_exit(struct kvm_vcpu *vcpu,
|
|||||||
static void nested_svm_init_mmu_context(struct kvm_vcpu *vcpu)
|
static void nested_svm_init_mmu_context(struct kvm_vcpu *vcpu)
|
||||||
{
|
{
|
||||||
WARN_ON(mmu_is_nested(vcpu));
|
WARN_ON(mmu_is_nested(vcpu));
|
||||||
|
|
||||||
|
vcpu->arch.mmu = &vcpu->arch.guest_mmu;
|
||||||
kvm_init_shadow_mmu(vcpu);
|
kvm_init_shadow_mmu(vcpu);
|
||||||
vcpu->arch.mmu->set_cr3 = nested_svm_set_tdp_cr3;
|
vcpu->arch.mmu->set_cr3 = nested_svm_set_tdp_cr3;
|
||||||
vcpu->arch.mmu->get_cr3 = nested_svm_get_tdp_cr3;
|
vcpu->arch.mmu->get_cr3 = nested_svm_get_tdp_cr3;
|
||||||
@ -2949,6 +2951,7 @@ static void nested_svm_init_mmu_context(struct kvm_vcpu *vcpu)
|
|||||||
|
|
||||||
static void nested_svm_uninit_mmu_context(struct kvm_vcpu *vcpu)
|
static void nested_svm_uninit_mmu_context(struct kvm_vcpu *vcpu)
|
||||||
{
|
{
|
||||||
|
vcpu->arch.mmu = &vcpu->arch.root_mmu;
|
||||||
vcpu->arch.walk_mmu = &vcpu->arch.root_mmu;
|
vcpu->arch.walk_mmu = &vcpu->arch.root_mmu;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3458,7 +3461,6 @@ static void enter_svm_guest_mode(struct vcpu_svm *svm, u64 vmcb_gpa,
|
|||||||
svm->vcpu.arch.hflags &= ~HF_HIF_MASK;
|
svm->vcpu.arch.hflags &= ~HF_HIF_MASK;
|
||||||
|
|
||||||
if (nested_vmcb->control.nested_ctl & SVM_NESTED_CTL_NP_ENABLE) {
|
if (nested_vmcb->control.nested_ctl & SVM_NESTED_CTL_NP_ENABLE) {
|
||||||
kvm_mmu_unload(&svm->vcpu);
|
|
||||||
svm->nested.nested_cr3 = nested_vmcb->control.nested_cr3;
|
svm->nested.nested_cr3 = nested_vmcb->control.nested_cr3;
|
||||||
nested_svm_init_mmu_context(&svm->vcpu);
|
nested_svm_init_mmu_context(&svm->vcpu);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user