Author: hselasky
Date: Wed Nov 21 22:04:40 2012
New Revision: 243380
URL: http://svnweb.freebsd.org/changeset/base/243380

Log:
  Fix uplcom clear stall logic for PL2303HX.
  
  Submitted by: Mark Johnston
  MFC after:    1 week

Modified:
  head/sys/dev/usb/serial/uplcom.c

Modified: head/sys/dev/usb/serial/uplcom.c
==============================================================================
--- head/sys/dev/usb/serial/uplcom.c    Wed Nov 21 21:03:14 2012        
(r243379)
+++ head/sys/dev/usb/serial/uplcom.c    Wed Nov 21 22:04:40 2012        
(r243380)
@@ -432,11 +432,21 @@ uplcom_attach(device_t dev)
                    usbd_errstr(error));
                goto detach;
        }
-       /* clear stall at first run */
-       mtx_lock(&sc->sc_mtx);
-       usbd_xfer_set_stall(sc->sc_xfer[UPLCOM_BULK_DT_WR]);
-       usbd_xfer_set_stall(sc->sc_xfer[UPLCOM_BULK_DT_RD]);
-       mtx_unlock(&sc->sc_mtx);
+
+       if (sc->sc_chiptype != TYPE_PL2303HX) {
+               /* HX variants seem to lock up after a clear stall request. */
+               mtx_lock(&sc->sc_mtx);
+               usbd_xfer_set_stall(sc->sc_xfer[UPLCOM_BULK_DT_WR]);
+               usbd_xfer_set_stall(sc->sc_xfer[UPLCOM_BULK_DT_RD]);
+               mtx_unlock(&sc->sc_mtx);
+       } else {
+               if (uplcom_pl2303_do(sc->sc_udev, UT_WRITE_VENDOR_DEVICE,
+                   UPLCOM_SET_REQUEST, 8, 0, 0) ||
+                   uplcom_pl2303_do(sc->sc_udev, UT_WRITE_VENDOR_DEVICE,
+                   UPLCOM_SET_REQUEST, 9, 0, 0)) {
+                       goto detach;
+               }
+       }
 
        error = ucom_attach(&sc->sc_super_ucom, &sc->sc_ucom, 1, sc,
            &uplcom_callback, &sc->sc_mtx);
@@ -555,9 +565,6 @@ uplcom_pl2303_init(struct usb_device *ud
        if (err)
                return (EIO);
        
-       if (uplcom_pl2303_do(udev, UT_WRITE_VENDOR_DEVICE, UPLCOM_SET_REQUEST, 
8, 0, 0)
-           || uplcom_pl2303_do(udev, UT_WRITE_VENDOR_DEVICE, 
UPLCOM_SET_REQUEST, 9, 0, 0))
-               return (EIO);
        return (0);
 }
 
_______________________________________________
svn-src-all@freebsd.org mailing list
http://lists.freebsd.org/mailman/listinfo/svn-src-all
To unsubscribe, send any mail to "svn-src-all-unsubscr...@freebsd.org"

Reply via email to