KVM: nVMX: Make an event request when pending an MTF nested VM-Exit
authorSean Christopherson <seanjc@google.com>
Wed, 21 Sep 2022 00:31:51 +0000 (00:31 +0000)
committerPaolo Bonzini <pbonzini@redhat.com>
Mon, 26 Sep 2022 16:37:18 +0000 (12:37 -0400)
Set KVM_REQ_EVENT when MTF becomes pending to ensure that KVM will run
through inject_pending_event() and thus vmx_check_nested_events() prior
to re-entering the guest.

MTF currently works by virtue of KVM's hack that calls
kvm_check_nested_events() from kvm_vcpu_running(), but that hack will
be removed in the near future.  Until that call is removed, the patch
introduces no real functional change.

Fixes: 5ef8acbdd687 ("KVM: nVMX: Emulate MTF when performing instruction emulation")
Cc: stable@vger.kernel.org
Reviewed-by: Maxim Levitsky <mlevitsk@redhat.com>
Signed-off-by: Sean Christopherson <seanjc@google.com>
Message-Id: <20220921003201.1441511-3-seanjc@google.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
arch/x86/kvm/vmx/nested.c
arch/x86/kvm/vmx/vmx.c

index 85318d803f4f4300234d249be40fa9e391ae8b4b..3a080051a4ec9ba895e89d81309cbb7b0927633e 100644 (file)
@@ -6632,6 +6632,9 @@ static int vmx_set_nested_state(struct kvm_vcpu *vcpu,
        if (ret)
                goto error_guest_mode;
 
+       if (vmx->nested.mtf_pending)
+               kvm_make_request(KVM_REQ_EVENT, vcpu);
+
        return 0;
 
 error_guest_mode:
index 94c314dc239332cf71c3096e6f0c3f2e01f8d227..9dba04b6b019aca4ec263395a85df9a9d494a033 100644 (file)
@@ -1665,10 +1665,12 @@ static void vmx_update_emulated_instruction(struct kvm_vcpu *vcpu)
            (!vcpu->arch.exception.pending ||
             vcpu->arch.exception.vector == DB_VECTOR) &&
            (!vcpu->arch.exception_vmexit.pending ||
-            vcpu->arch.exception_vmexit.vector == DB_VECTOR))
+            vcpu->arch.exception_vmexit.vector == DB_VECTOR)) {
                vmx->nested.mtf_pending = true;
-       else
+               kvm_make_request(KVM_REQ_EVENT, vcpu);
+       } else {
                vmx->nested.mtf_pending = false;
+       }
 }
 
 static int vmx_skip_emulated_instruction(struct kvm_vcpu *vcpu)