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 |
|