KVM: x86: Exit to user-mode on #UD intercept when emulator requires
authorLiran Alon <liran.alon@oracle.com>
Sun, 5 Nov 2017 14:56:32 +0000 (16:56 +0200)
committerPaolo Bonzini <pbonzini@redhat.com>
Fri, 17 Nov 2017 12:20:10 +0000 (13:20 +0100)
Instruction emulation after trapping a #UD exception can result in an
MMIO access, for example when emulating a MOVBE on a processor that
doesn't support the instruction.  In this case, the #UD vmexit handler
must exit to user mode, but there wasn't any code to do so.  Add it for
both VMX and SVM.

Signed-off-by: Liran Alon <liran.alon@oracle.com>
Reviewed-by: Nikita Leshenko <nikita.leshchenko@oracle.com>
Reviewed-by: Konrad Rzeszutek Wilk <konrad.wilk@oracle.com>
Signed-off-by: Konrad Rzeszutek Wilk <konrad.wilk@oracle.com>
Reviewed-by: Wanpeng Li <wanpeng.li@hotmail.com>
Reviewed-by: Paolo Bonzini <pbonzini@redhat.com>
Cc: stable@vger.kernel.org
Signed-off-by: Radim Krčmář <rkrcmar@redhat.com>
arch/x86/kvm/svm.c
arch/x86/kvm/vmx.c

index 1bf7c09d97e61099f1e1be735db1ecee3acb6647..eb714f1cdf7eee4ca9036005c3ab72ef9228ae9b 100644 (file)
@@ -2204,6 +2204,8 @@ static int ud_interception(struct vcpu_svm *svm)
 
        WARN_ON_ONCE(is_guest_mode(&svm->vcpu));
        er = emulate_instruction(&svm->vcpu, EMULTYPE_TRAP_UD);
+       if (er == EMULATE_USER_EXIT)
+               return 0;
        if (er != EMULATE_DONE)
                kvm_queue_exception(&svm->vcpu, UD_VECTOR);
        return 1;
index d319e2666ad586252511e3329e6fcd4be703f9db..65f1f06f6aaa7f621377941ac6545473cae9723d 100644 (file)
@@ -5919,6 +5919,8 @@ static int handle_exception(struct kvm_vcpu *vcpu)
        if (is_invalid_opcode(intr_info)) {
                WARN_ON_ONCE(is_guest_mode(vcpu));
                er = emulate_instruction(vcpu, EMULTYPE_TRAP_UD);
+               if (er == EMULATE_USER_EXIT)
+                       return 0;
                if (er != EMULATE_DONE)
                        kvm_queue_exception(vcpu, UD_VECTOR);
                return 1;