diff options
author | Gleb Natapov <gleb@redhat.com> | 2010-07-29 08:11:52 -0400 |
---|---|---|
committer | Avi Kivity <avi@redhat.com> | 2010-10-24 04:50:27 -0400 |
commit | e85d28f8e8cef09b8e424448ccedb7244cfbf147 (patch) | |
tree | 64d4b0ee60ee1999a828db8967b806c70ad18521 | |
parent | 63540382ccb83d2857964858c1ac7eb7d37de497 (diff) |
KVM: x86 emulator: don't update vcpu state if instruction is restarted
No need to update vcpu state since instruction is in the middle of the
emulation.
Signed-off-by: Gleb Natapov <gleb@redhat.com>
Signed-off-by: Marcelo Tosatti <mtosatti@redhat.com>
-rw-r--r-- | arch/x86/kvm/x86.c | 31 |
1 files changed, 13 insertions, 18 deletions
diff --git a/arch/x86/kvm/x86.c b/arch/x86/kvm/x86.c index 33deb75f16ee..3cbe8032394a 100644 --- a/arch/x86/kvm/x86.c +++ b/arch/x86/kvm/x86.c | |||
@@ -4057,32 +4057,27 @@ restart: | |||
4057 | return handle_emulation_failure(vcpu); | 4057 | return handle_emulation_failure(vcpu); |
4058 | } | 4058 | } |
4059 | 4059 | ||
4060 | toggle_interruptibility(vcpu, vcpu->arch.emulate_ctxt.interruptibility); | 4060 | r = EMULATE_DONE; |
4061 | kvm_x86_ops->set_rflags(vcpu, vcpu->arch.emulate_ctxt.eflags); | ||
4062 | memcpy(vcpu->arch.regs, c->regs, sizeof c->regs); | ||
4063 | kvm_rip_write(vcpu, vcpu->arch.emulate_ctxt.eip); | ||
4064 | 4061 | ||
4065 | if (vcpu->arch.emulate_ctxt.exception >= 0) { | 4062 | if (vcpu->arch.emulate_ctxt.exception >= 0) |
4066 | inject_emulated_exception(vcpu); | 4063 | inject_emulated_exception(vcpu); |
4067 | return EMULATE_DONE; | 4064 | else if (vcpu->arch.pio.count) { |
4068 | } | ||
4069 | |||
4070 | if (vcpu->arch.pio.count) { | ||
4071 | if (!vcpu->arch.pio.in) | 4065 | if (!vcpu->arch.pio.in) |
4072 | vcpu->arch.pio.count = 0; | 4066 | vcpu->arch.pio.count = 0; |
4073 | return EMULATE_DO_MMIO; | 4067 | r = EMULATE_DO_MMIO; |
4074 | } | 4068 | } else if (vcpu->mmio_needed) { |
4075 | |||
4076 | if (vcpu->mmio_needed) { | ||
4077 | if (vcpu->mmio_is_write) | 4069 | if (vcpu->mmio_is_write) |
4078 | vcpu->mmio_needed = 0; | 4070 | vcpu->mmio_needed = 0; |
4079 | return EMULATE_DO_MMIO; | 4071 | r = EMULATE_DO_MMIO; |
4080 | } | 4072 | } else if (vcpu->arch.emulate_ctxt.restart) |
4081 | |||
4082 | if (vcpu->arch.emulate_ctxt.restart) | ||
4083 | goto restart; | 4073 | goto restart; |
4084 | 4074 | ||
4085 | return EMULATE_DONE; | 4075 | toggle_interruptibility(vcpu, vcpu->arch.emulate_ctxt.interruptibility); |
4076 | kvm_x86_ops->set_rflags(vcpu, vcpu->arch.emulate_ctxt.eflags); | ||
4077 | memcpy(vcpu->arch.regs, c->regs, sizeof c->regs); | ||
4078 | kvm_rip_write(vcpu, vcpu->arch.emulate_ctxt.eip); | ||
4079 | |||
4080 | return r; | ||
4086 | } | 4081 | } |
4087 | EXPORT_SYMBOL_GPL(emulate_instruction); | 4082 | EXPORT_SYMBOL_GPL(emulate_instruction); |
4088 | 4083 | ||