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: Paolo Bonzini <pbonzini@redhat.com>
This commit is contained in:
@@ -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)
|
|||||||
* 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)
|
|||||||
}
|
}
|
||||||
|
|
||||||
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 &&
|
||||||
|
|||||||
Reference in New Issue
Block a user