aboutsummaryrefslogtreecommitdiffstats
path: root/include
diff options
context:
space:
mode:
authorGleb Natapov <gleb@redhat.com>2009-07-05 18:48:11 +0300
committerAvi Kivity <avi@redhat.com>2009-08-09 11:45:49 +0300
commitb4a2f5e723e4f7df46731106faf9e2405673c073 (patch)
tree98766bcb94182957b27b9bdd371c742d927da951 /include
parent53a27b39ff4d2492f84b1fdc2f0047175f0b0b93 (diff)
downloadkernel_samsung_espresso10-b4a2f5e723e4f7df46731106faf9e2405673c073.zip
kernel_samsung_espresso10-b4a2f5e723e4f7df46731106faf9e2405673c073.tar.gz
kernel_samsung_espresso10-b4a2f5e723e4f7df46731106faf9e2405673c073.tar.bz2
KVM: Avoid redelivery of edge interrupt before next edge
The check for an edge is broken in current ioapic code. ioapic->irr is cleared on each edge interrupt by ioapic_service() and this makes old_irr != ioapic->irr condition in kvm_ioapic_set_irq() to be always true. The patch fixes the code to properly recognise edge. Some HW emulation calls set_irq() without level change. If each such call is propagated to an OS it may confuse a device driver. This is the case with keyboard device emulation and Windows XP x64 installer on SMP VM. Each keystroke produce two interrupts (down/up) one interrupt is submitted to CPU0 and another to CPU1. This confuses Windows somehow and it ignores keystrokes. Signed-off-by: Gleb Natapov <gleb@redhat.com> Signed-off-by: Avi Kivity <avi@redhat.com>
Diffstat (limited to 'include')
0 files changed, 0 insertions, 0 deletions