Blame 0136-usb-ehci-Remove-dead-isoch_pause-code.patch

1b1995
From 0e6cd6e6da3d0648204526e8ebd79047f48d009a Mon Sep 17 00:00:00 2001
1b1995
From: Hans de Goede <hdegoede@redhat.com>
1b1995
Date: Fri, 2 Mar 2012 00:36:50 +0100
1b1995
Subject: [PATCH 136/140] usb-ehci: Remove dead isoch_pause code
1b1995
1b1995
I see no value in keeping this around, so lets delete it.
1b1995
1b1995
Signed-off-by: Hans de Goede <hdegoede@redhat.com>
1b1995
---
1b1995
 hw/usb-ehci.c |   60 +++++++++++++++------------------------------------------
1b1995
 1 file changed, 15 insertions(+), 45 deletions(-)
1b1995
1b1995
diff --git a/hw/usb-ehci.c b/hw/usb-ehci.c
1b1995
index aa6fae5..72c3f2a 100644
1b1995
--- a/hw/usb-ehci.c
1b1995
+++ b/hw/usb-ehci.c
1b1995
@@ -419,7 +419,6 @@ struct EHCIState {
1b1995
 
1b1995
     USBPacket ipacket;
1b1995
     QEMUSGList isgl;
1b1995
-    int isoch_pause;
1b1995
 
1b1995
     uint64_t last_run_ns;
1b1995
 };
1b1995
@@ -886,7 +885,6 @@ static void ehci_reset(void *opaque)
1b1995
 
1b1995
     s->astate = EST_INACTIVE;
1b1995
     s->pstate = EST_INACTIVE;
1b1995
-    s->isoch_pause = -1;
1b1995
     s->attach_poll_counter = 0;
1b1995
 
1b1995
     for(i = 0; i < NB_PORTS; i++) {
1b1995
@@ -1468,46 +1466,7 @@ static int ehci_process_itd(EHCIState *ehci,
1b1995
             usb_packet_unmap(&ehci->ipacket);
1b1995
             qemu_sglist_destroy(&ehci->isgl);
1b1995
 
1b1995
-#if 0
1b1995
-            /*  In isoch, there is no facility to indicate a NAK so let's
1b1995
-             *  instead just complete a zero-byte transaction.  Setting
1b1995
-             *  DBERR seems too draconian.
1b1995
-             */
1b1995
-
1b1995
-            if (ret == USB_RET_NAK) {
1b1995
-                if (ehci->isoch_pause > 0) {
1b1995
-                    DPRINTF("ISOCH: received a NAK but paused so returning\n");
1b1995
-                    ehci->isoch_pause--;
1b1995
-                    return 0;
1b1995
-                } else if (ehci->isoch_pause == -1) {
1b1995
-                    DPRINTF("ISOCH: recv NAK & isoch pause inactive, setting\n");
1b1995
-                    // Pause frindex for up to 50 msec waiting for data from
1b1995
-                    // remote
1b1995
-                    ehci->isoch_pause = 50;
1b1995
-                    return 0;
1b1995
-                } else {
1b1995
-                    DPRINTF("ISOCH: isoch pause timeout! return 0\n");
1b1995
-                    ret = 0;
1b1995
-                }
1b1995
-            } else {
1b1995
-                DPRINTF("ISOCH: received ACK, clearing pause\n");
1b1995
-                ehci->isoch_pause = -1;
1b1995
-            }
1b1995
-#else
1b1995
-            if (ret == USB_RET_NAK) {
1b1995
-                ret = 0;
1b1995
-            }
1b1995
-#endif
1b1995
-
1b1995
-            if (ret >= 0) {
1b1995
-                if (!dir) {
1b1995
-                    /* OUT */
1b1995
-                    set_field(&itd->transact[i], len - ret, ITD_XACT_LENGTH);
1b1995
-                } else {
1b1995
-                    /* IN */
1b1995
-                    set_field(&itd->transact[i], ret, ITD_XACT_LENGTH);
1b1995
-                }
1b1995
-            } else {
1b1995
+            if (ret < 0) {
1b1995
                 switch (ret) {
1b1995
                 default:
1b1995
                     fprintf(stderr, "Unexpected iso usb result: %d\n", ret);
1b1995
@@ -1523,6 +1482,19 @@ static int ehci_process_itd(EHCIState *ehci,
1b1995
                     itd->transact[i] |= ITD_XACT_BABBLE;
1b1995
                     ehci_record_interrupt(ehci, USBSTS_ERRINT);
1b1995
                     break;
1b1995
+                case USB_RET_NAK:
1b1995
+                    /* no data for us, so do a zero-length transfer */
1b1995
+                    ret = 0;
1b1995
+                    break;
1b1995
+                }
1b1995
+            }
1b1995
+            if (ret >= 0) {
1b1995
+                if (!dir) {
1b1995
+                    /* OUT */
1b1995
+                    set_field(&itd->transact[i], len - ret, ITD_XACT_LENGTH);
1b1995
+                } else {
1b1995
+                    /* IN */
1b1995
+                    set_field(&itd->transact[i], ret, ITD_XACT_LENGTH);
1b1995
                 }
1b1995
             }
1b1995
             if (itd->transact[i] & ITD_XACT_IOC) {
1b1995
@@ -2176,9 +2148,7 @@ static void ehci_frame_timer(void *opaque)
1b1995
 
1b1995
     for (i = 0; i < frames; i++) {
1b1995
         if ( !(ehci->usbsts & USBSTS_HALT)) {
1b1995
-            if (ehci->isoch_pause <= 0) {
1b1995
-                ehci->frindex += 8;
1b1995
-            }
1b1995
+            ehci->frindex += 8;
1b1995
 
1b1995
             if (ehci->frindex > 0x00001fff) {
1b1995
                 ehci->frindex = 0;
1b1995
-- 
1b1995
1.7.9.3
1b1995