Source-Changes-HG archive

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

[src/trunk]: src/sys/dev/usb Reset the hardware like other drivers do for bet...



details:   https://anonhg.NetBSD.org/src/rev/865de8242b8a
branches:  trunk
changeset: 838806:865de8242b8a
user:      jakllsch <jakllsch%NetBSD.org@localhost>
date:      Thu Jan 31 18:21:21 2019 +0000

description:
Reset the hardware like other drivers do for better compatibility with
more chip firmware versions.

>From (and should fix) PR kern/53913.

diffstat:

 sys/dev/usb/uchcom.c |  29 +++++++----------------------
 1 files changed, 7 insertions(+), 22 deletions(-)

diffs (58 lines):

diff -r 7843e4b535a0 -r 865de8242b8a sys/dev/usb/uchcom.c
--- a/sys/dev/usb/uchcom.c      Thu Jan 31 16:03:50 2019 +0000
+++ b/sys/dev/usb/uchcom.c      Thu Jan 31 18:21:21 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: uchcom.c,v 1.27 2018/12/13 01:40:02 jakllsch Exp $     */
+/*     $NetBSD: uchcom.c,v 1.28 2019/01/31 18:21:21 jakllsch Exp $     */
 
 /*
  * Copyright (c) 2007 The NetBSD Foundation, Inc.
@@ -30,7 +30,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: uchcom.c,v 1.27 2018/12/13 01:40:02 jakllsch Exp $");
+__KERNEL_RCSID(0, "$NetBSD: uchcom.c,v 1.28 2019/01/31 18:21:21 jakllsch Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_usb.h"
@@ -118,6 +118,9 @@
 #define UCHCOMIBUFSIZE 256
 #define UCHCOMOBUFSIZE 256
 
+#define UCHCOM_RESET_VALUE     0x501F
+#define UCHCOM_RESET_INDEX     0xD90A
+
 struct uchcom_softc
 {
        device_t                sc_dev;
@@ -763,27 +766,9 @@
 reset_chip(struct uchcom_softc *sc)
 {
        usbd_status err;
-       uint8_t lcr, lcr2, pre, div;
-       uint16_t val=0, idx=0;
 
-       err = read_reg(sc, UCHCOM_REG_LCR, &lcr, UCHCOM_REG_LCR2, &lcr2);
-       if (err)
-               goto failed;
-
-       err = read_reg(sc, UCHCOM_REG_BPS_PRE, &pre, UCHCOM_REG_BPS_DIV, &div);
-       if (err)
-               goto failed;
-
-       val |= (uint16_t)lcr << 8;
-       val |= 0x9c;    /* magic from vendor Linux and Android drivers */
-       idx |= pre & 0x07;
-       idx |= (uint16_t)div << 8;
-       idx |= UCHCOM_BPS_PRE_IMM;
-
-       DPRINTF(("%s: reset v=0x%04X, i=0x%04X\n",
-                device_xname(sc->sc_dev), val, idx));
-
-       err = generic_control_out(sc, UCHCOM_REQ_RESET, val, idx);
+       err = generic_control_out(sc, UCHCOM_REQ_RESET,
+           UCHCOM_RESET_VALUE, UCHCOM_RESET_INDEX);
        if (err)
                goto failed;
 



Home | Main Index | Thread Index | Old Index