peterdelevoryas / rpms / qemu

Forked from rpms/qemu 2 years ago
Clone

Blame 0357-ehci-Fix-interrupts-stopping-when-Interrupt-Threshol.patch

93b7e3
From 2ebb3309738501fcc9e8da807866fa4225bb5e91 Mon Sep 17 00:00:00 2001
93b7e3
From: Hans de Goede <hdegoede@redhat.com>
93b7e3
Date: Mon, 10 Sep 2012 11:44:08 +0200
93b7e3
Subject: [PATCH 357/369] ehci: Fix interrupts stopping when Interrupt
93b7e3
 Threshold Control is 8
93b7e3
93b7e3
If Interrupt Threshold Control is 8 or a multiple of 8, then
93b7e3
s->usbsts_frindex can become exactly 0x4000, at which point
93b7e3
(s->usbsts_frindex > s->frindex) will never become true, as
93b7e3
s->usbsts_frindex will not be lowered / reset in this case.
93b7e3
93b7e3
This patch fixes this.
93b7e3
93b7e3
Signed-off-by: Hans de Goede <hdegoede@redhat.com>
93b7e3
---
93b7e3
 hw/usb/hcd-ehci.c | 2 +-
93b7e3
 1 file changed, 1 insertion(+), 1 deletion(-)
93b7e3
93b7e3
diff --git a/hw/usb/hcd-ehci.c b/hw/usb/hcd-ehci.c
93b7e3
index f5ba8e1..54273d7 100644
93b7e3
--- a/hw/usb/hcd-ehci.c
93b7e3
+++ b/hw/usb/hcd-ehci.c
93b7e3
@@ -2413,7 +2413,7 @@ static void ehci_update_frindex(EHCIState *ehci, int frames)
93b7e3
         if (ehci->frindex == 0x00004000) {
93b7e3
             ehci_raise_irq(ehci, USBSTS_FLR);
93b7e3
             ehci->frindex = 0;
93b7e3
-            if (ehci->usbsts_frindex > 0x00004000) {
93b7e3
+            if (ehci->usbsts_frindex >= 0x00004000) {
93b7e3
                 ehci->usbsts_frindex -= 0x00004000;
93b7e3
             } else {
93b7e3
                 ehci->usbsts_frindex = 0;
93b7e3
-- 
93b7e3
1.7.12
93b7e3