Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/nick-nhusb]: src/sys/dev/usb Simplify treatment of WRC condition and add...



details:   https://anonhg.NetBSD.org/src/rev/f16cd6006df9
branches:  nick-nhusb
changeset: 804360:f16cd6006df9
user:      skrll <skrll%NetBSD.org@localhost>
date:      Sat Jun 06 15:24:18 2015 +0000

description:
Simplify treatment of WRC condition and add comments.

>From t-hash.

diffstat:

 sys/dev/usb/uhub.c |  20 ++++++++++++--------
 1 files changed, 12 insertions(+), 8 deletions(-)

diffs (50 lines):

diff -r 2b3c5ac0f993 -r f16cd6006df9 sys/dev/usb/uhub.c
--- a/sys/dev/usb/uhub.c        Sat Jun 06 15:21:57 2015 +0000
+++ b/sys/dev/usb/uhub.c        Sat Jun 06 15:24:18 2015 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: uhub.c,v 1.126.2.12 2015/05/28 06:15:47 skrll Exp $    */
+/*     $NetBSD: uhub.c,v 1.126.2.13 2015/06/06 15:24:18 skrll Exp $    */
 /*     $FreeBSD: src/sys/dev/usb/uhub.c,v 1.18 1999/11/17 22:33:43 n_hibma Exp $       */
 
 /*
@@ -36,7 +36,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: uhub.c,v 1.126.2.12 2015/05/28 06:15:47 skrll Exp $");
+__KERNEL_RCSID(0, "$NetBSD: uhub.c,v 1.126.2.13 2015/06/06 15:24:18 skrll Exp $");
 
 #include <sys/param.h>
 
@@ -586,11 +586,17 @@
                                            port);
                        }
                }
-               int is_wrc = 0;
-               if (change & UPS_C_PORT_RESET)
+               if (change & UPS_C_PORT_RESET) {
                        usbd_clear_port_feature(dev, port, UHF_C_PORT_RESET);
+               }
                if (change & UPS_C_BH_PORT_RESET) {
-                       is_wrc = 1;
+                       /*
+                        * some xHCs set WarmResetChange instead of CSC
+                        * when port is reset.
+                        */
+                       if ((status & UPS_CURRENT_CONNECT_STATUS) != 0) {
+                               change |= UPS_C_CONNECT_STATUS;
+                       }
                        usbd_clear_port_feature(dev, port,
                            UHF_C_BH_PORT_RESET);
                }
@@ -603,9 +609,7 @@
 
                /* XXX handle overcurrent and resume events! */
 
-               /* xHCI sets WRC instead of CSC when port is reset */
-               if (!reconnect && !(change & UPS_C_CONNECT_STATUS) &&
-                   !(is_wrc && (status & UPS_CURRENT_CONNECT_STATUS))) {
+               if (!reconnect && !(change & UPS_C_CONNECT_STATUS)) {
                        /* No status change, just do recursive explore. */
                        if (up->up_dev != NULL && up->up_dev->ud_hub != NULL)
                                up->up_dev->ud_hub->uh_explore(up->up_dev);



Home | Main Index | Thread Index | Old Index