summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMatt Gingell <gingell@google.com>2015-11-16 23:26:05 (GMT)
committerPaolo Bonzini <pbonzini@redhat.com>2015-11-18 11:25:38 (GMT)
commit934bf65354227981df15bbc755d33f4ba3443ff2 (patch)
treeae73e5f9d4375d2a3c3cc3e64b2642ead3afeca9
parent782d422bcaee4680c640fbc8ce8c45524fd11790 (diff)
downloadlinux-934bf65354227981df15bbc755d33f4ba3443ff2.tar.xz
KVM: x86: set KVM_REQ_EVENT on local interrupt request from user space
Set KVM_REQ_EVENT when a PIC in user space injects a local interrupt. Currently a request is only made when neither the PIC nor the APIC is in the kernel, which is not sufficient in the split IRQ chip case. This addresses a problem in QEMU where interrupts are delayed until another path invokes the event loop. Reviewed-by: Steve Rutherford <srutherford@google.com> Signed-off-by: Matt Gingell <gingell@google.com> Fixes: 1c1a9ce973a7863dd46767226bce2a5f12d48bc6 Cc: stable@vger.kernel.org Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
-rw-r--r--arch/x86/kvm/x86.c1
1 files changed, 1 insertions, 0 deletions
diff --git a/arch/x86/kvm/x86.c b/arch/x86/kvm/x86.c
index 32f6b76..f254e29 100644
--- a/arch/x86/kvm/x86.c
+++ b/arch/x86/kvm/x86.c
@@ -2806,6 +2806,7 @@ static int kvm_vcpu_ioctl_interrupt(struct kvm_vcpu *vcpu,
return -EEXIST;
vcpu->arch.pending_external_vector = irq->irq;
+ kvm_make_request(KVM_REQ_EVENT, vcpu);
return 0;
}