KVM: nSVM: only copy L1 non-VMLOAD/VMSAVE data in svm_set_nested_state()
authorPaolo Bonzini <pbonzini@redhat.com>
Tue, 17 Nov 2020 07:51:35 +0000 (02:51 -0500)
committerPaolo Bonzini <pbonzini@redhat.com>
Mon, 15 Mar 2021 08:42:34 +0000 (04:42 -0400)
The VMLOAD/VMSAVE data is not taken from userspace, since it will
not be restored on VMEXIT (it will be copied from VMCB02 to VMCB01).
For clarity, replace the wholesale copy of the VMCB save area
with a copy of that state only.

Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
arch/x86/kvm/svm/nested.c

index e6254bddc621eaf7a016a42136fdc9a02cae9cfb..56e6198d8f33dcb526c87c25ecac5a6e6d2f6e2b 100644 (file)
@@ -717,7 +717,7 @@ int nested_svm_vmexit(struct vcpu_svm *svm)
        /*
         * Restore processor state that had been saved in vmcb01
         */
-       kvm_set_rflags(&svm->vcpu, svm->vmcb->save.rflags | X86_EFLAGS_FIXED);
+       kvm_set_rflags(&svm->vcpu, svm->vmcb->save.rflags);
        svm_set_efer(&svm->vcpu, svm->vmcb->save.efer);
        svm_set_cr0(&svm->vcpu, svm->vmcb->save.cr0 | X86_CR0_PE);
        svm_set_cr4(&svm->vcpu, svm->vmcb->save.cr4);
@@ -1252,7 +1252,23 @@ static int svm_set_nested_state(struct kvm_vcpu *vcpu,
        svm->nested.vmcb12_gpa = kvm_state->hdr.svm.vmcb_pa;
        if (svm->current_vmcb == &svm->vmcb01)
                svm->nested.vmcb02.ptr->save = svm->vmcb01.ptr->save;
-       svm->vmcb01.ptr->save = *save;
+
+       svm->vmcb01.ptr->save.es = save->es;
+       svm->vmcb01.ptr->save.cs = save->cs;
+       svm->vmcb01.ptr->save.ss = save->ss;
+       svm->vmcb01.ptr->save.ds = save->ds;
+       svm->vmcb01.ptr->save.gdtr = save->gdtr;
+       svm->vmcb01.ptr->save.idtr = save->idtr;
+       svm->vmcb01.ptr->save.rflags = save->rflags | X86_EFLAGS_FIXED;
+       svm->vmcb01.ptr->save.efer = save->efer;
+       svm->vmcb01.ptr->save.cr0 = save->cr0;
+       svm->vmcb01.ptr->save.cr3 = save->cr3;
+       svm->vmcb01.ptr->save.cr4 = save->cr4;
+       svm->vmcb01.ptr->save.rax = save->rax;
+       svm->vmcb01.ptr->save.rsp = save->rsp;
+       svm->vmcb01.ptr->save.rip = save->rip;
+       svm->vmcb01.ptr->save.cpl = 0;
+
        nested_load_control_from_vmcb12(svm, ctl);
 
        svm_switch_vmcb(svm, &svm->nested.vmcb02);