diff options
author | Avi Kivity <avi@redhat.com> | 2012-06-12 20:22:28 +0300 |
---|---|---|
committer | Avi Kivity <avi@redhat.com> | 2012-07-09 14:19:04 +0300 |
commit | de5f70e0c65fcd0472a412a7a9690afcd3ee4526 (patch) | |
tree | 5b5bd6482e5731a5209b46820104021310efbb48 /arch/x86 | |
parent | de87dcddc70ec6a90adfcc81f0ad7d84a892ffce (diff) | |
download | linux-de5f70e0c65fcd0472a412a7a9690afcd3ee4526.tar.gz linux-de5f70e0c65fcd0472a412a7a9690afcd3ee4526.tar.bz2 linux-de5f70e0c65fcd0472a412a7a9690afcd3ee4526.zip |
KVM: VMX: Improve error reporting during invalid guest state emulation
If instruction emulation fails, report it properly to userspace.
Signed-off-by: Avi Kivity <avi@redhat.com>
Diffstat (limited to 'arch/x86')
-rw-r--r-- | arch/x86/kvm/vmx.c | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/arch/x86/kvm/vmx.c b/arch/x86/kvm/vmx.c index a62f92ab1be2..c61eb34a39e7 100644 --- a/arch/x86/kvm/vmx.c +++ b/arch/x86/kvm/vmx.c @@ -4996,8 +4996,12 @@ static int handle_invalid_guest_state(struct kvm_vcpu *vcpu) goto out; } - if (err != EMULATE_DONE) + if (err != EMULATE_DONE) { + vcpu->run->exit_reason = KVM_EXIT_INTERNAL_ERROR; + vcpu->run->internal.suberror = KVM_INTERNAL_ERROR_EMULATION; + vcpu->run->internal.ndata = 0; return 0; + } if (signal_pending(current)) goto out; |