Commit c6b22f59 authored by Paolo Bonzini's avatar Paolo Bonzini

KVM: x86: track manually whether an event has been injected

Instead of calling kvm_event_needs_reinjection, track its
future return value in a variable.  This will be useful in
the next patch.
Signed-off-by: default avatarPaolo Bonzini <pbonzini@redhat.com>
parent b6162e82
...@@ -7717,11 +7717,14 @@ static void update_cr8_intercept(struct kvm_vcpu *vcpu) ...@@ -7717,11 +7717,14 @@ static void update_cr8_intercept(struct kvm_vcpu *vcpu)
static int inject_pending_event(struct kvm_vcpu *vcpu) static int inject_pending_event(struct kvm_vcpu *vcpu)
{ {
int r; int r;
bool can_inject = true;
/* try to reinject previous events if any */ /* try to reinject previous events if any */
if (vcpu->arch.exception.injected) if (vcpu->arch.exception.injected) {
kvm_x86_ops.queue_exception(vcpu); kvm_x86_ops.queue_exception(vcpu);
can_inject = false;
}
/* /*
* Do not inject an NMI or interrupt if there is a pending * Do not inject an NMI or interrupt if there is a pending
* exception. Exceptions and interrupts are recognized at * exception. Exceptions and interrupts are recognized at
...@@ -7737,10 +7740,13 @@ static int inject_pending_event(struct kvm_vcpu *vcpu) ...@@ -7737,10 +7740,13 @@ static int inject_pending_event(struct kvm_vcpu *vcpu)
* fully complete the previous instruction. * fully complete the previous instruction.
*/ */
else if (!vcpu->arch.exception.pending) { else if (!vcpu->arch.exception.pending) {
if (vcpu->arch.nmi_injected) if (vcpu->arch.nmi_injected) {
kvm_x86_ops.set_nmi(vcpu); kvm_x86_ops.set_nmi(vcpu);
else if (vcpu->arch.interrupt.injected) can_inject = false;
} else if (vcpu->arch.interrupt.injected) {
kvm_x86_ops.set_irq(vcpu); kvm_x86_ops.set_irq(vcpu);
can_inject = false;
}
} }
WARN_ON_ONCE(vcpu->arch.exception.injected && WARN_ON_ONCE(vcpu->arch.exception.injected &&
...@@ -7790,10 +7796,11 @@ static int inject_pending_event(struct kvm_vcpu *vcpu) ...@@ -7790,10 +7796,11 @@ static int inject_pending_event(struct kvm_vcpu *vcpu)
} }
kvm_x86_ops.queue_exception(vcpu); kvm_x86_ops.queue_exception(vcpu);
can_inject = false;
} }
/* Don't consider new event if we re-injected an event */ /* Finish re-injection before considering new events */
if (kvm_event_needs_reinjection(vcpu)) if (!can_inject)
return 0; return 0;
if (vcpu->arch.smi_pending && if (vcpu->arch.smi_pending &&
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment