Source-Changes-HG archive

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

[src/trunk]: src/sys/dev/usb minor clean up, almost NFCI:



details:   https://anonhg.NetBSD.org/src/rev/9c7d80886e93
branches:  trunk
changeset: 999836:9c7d80886e93
user:      mrg <mrg%NetBSD.org@localhost>
date:      Thu Jun 20 10:46:24 2019 +0000

description:
minor clean up, almost NFCI:
- use const, __func__, more
- axen_mii_lock is a normal mutex not rwlock, and make sure it's
  properly cleaned up for failed attach
- check axen_dying in axen_miibus_statchg()
- rename axen_ax88179_eeprom() to axen_get_eaddr() and move the code
  here into the support the current method.
- adjust some comments

diffstat:

 sys/dev/usb/if_axen.c |  104 ++++++++++++++++++++++++-------------------------
 1 files changed, 50 insertions(+), 54 deletions(-)

diffs (truncated from 374 to 300 lines):

diff -r 94c746a53de9 -r 9c7d80886e93 sys/dev/usb/if_axen.c
--- a/sys/dev/usb/if_axen.c     Thu Jun 20 10:41:58 2019 +0000
+++ b/sys/dev/usb/if_axen.c     Thu Jun 20 10:46:24 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: if_axen.c,v 1.42 2019/06/18 09:34:57 mrg Exp $ */
+/*     $NetBSD: if_axen.c,v 1.43 2019/06/20 10:46:24 mrg Exp $ */
 /*     $OpenBSD: if_axen.c,v 1.3 2013/10/21 10:10:22 yuo Exp $ */
 
 /*
@@ -23,7 +23,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: if_axen.c,v 1.42 2019/06/18 09:34:57 mrg Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if_axen.c,v 1.43 2019/06/20 10:46:24 mrg Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_inet.h"
@@ -112,7 +112,7 @@
 
        struct usb_task         axen_tick_task;
 
-       krwlock_t               axen_mii_lock;
+       kmutex_t                axen_mii_lock;
 
        int                     axen_link;
 
@@ -178,14 +178,8 @@
 static int     axen_ifmedia_upd(struct ifnet *);
 static void    axen_ifmedia_sts(struct ifnet *, struct ifmediareq *);
 static void    axen_reset(struct axen_softc *);
-#if 0
-static int     axen_ax88179_eeprom(struct axen_softc *, void *);
-#endif
-
+static int     axen_get_eaddr(struct axen_softc *, void *);
 static void    axen_iff(struct axen_softc *);
-static void    axen_lock_mii(struct axen_softc *);
-static void    axen_unlock_mii(struct axen_softc *);
-
 static void    axen_ax88179_init(struct axen_softc *);
 static void    axen_setcoe(struct axen_softc *);
 
@@ -195,14 +189,14 @@
 {
 
        sc->axen_refcnt++;
-       rw_enter(&sc->axen_mii_lock, RW_WRITER);
+       mutex_enter(&sc->axen_mii_lock);
 }
 
 static void
 axen_unlock_mii(struct axen_softc *sc)
 {
 
-       rw_exit(&sc->axen_mii_lock);
+       mutex_exit(&sc->axen_mii_lock);
        if (--sc->axen_refcnt < 0)
                usb_detach_wakeupold(sc->axen_dev);
 }
@@ -213,7 +207,7 @@
        usb_device_request_t req;
        usbd_status err;
 
-       KASSERT(rw_lock_held(&sc->axen_mii_lock));
+       KASSERT(mutex_owned(&sc->axen_mii_lock));
 
        if (sc->axen_dying)
                return 0;
@@ -232,7 +226,7 @@
            cmd, val, AXEN_CMD_LEN(cmd)));
 
        if (err) {
-               DPRINTF(("axen_cmd err: cmd: %d, error: %d\n", cmd, err));
+               DPRINTF(("%s: cmd: %d, error: %d\n", __func__, cmd, err));
                return -1;
        }
 
@@ -242,7 +236,7 @@
 static int
 axen_miibus_readreg(device_t dev, int phy, int reg, uint16_t *val)
 {
-       struct axen_softc *sc = device_private(dev);
+       struct axen_softc * const sc = device_private(dev);
        usbd_status err;
        uint16_t data;
 
@@ -259,7 +253,7 @@
        axen_unlock_mii(sc);
 
        if (err) {
-               aprint_error_dev(sc->axen_dev, "read PHY failed\n");
+               aprint_error_dev(sc->axen_dev, "read PHY failed: %d\n", err);
                return err;
        }
 
@@ -277,7 +271,7 @@
 static int
 axen_miibus_writereg(device_t dev, int phy, int reg, uint16_t val)
 {
-       struct axen_softc *sc = device_private(dev);
+       struct axen_softc * const sc = device_private(dev);
        usbd_status err;
        uint16_t uval;
 
@@ -291,11 +285,12 @@
        axen_lock_mii(sc);
        err = axen_cmd(sc, AXEN_CMD_MII_WRITE_REG, reg, phy, &uval);
        axen_unlock_mii(sc);
+
        DPRINTFN(2, ("axen_miibus_writereg: phy 0x%x reg 0x%x val 0x%04hx\n",
            phy, reg, val));
 
        if (err) {
-               aprint_error_dev(sc->axen_dev, "write PHY failed\n");
+               aprint_error_dev(sc->axen_dev, "write PHY failed: %d\n", err);
                return err;
        }
 
@@ -305,12 +300,15 @@
 static void
 axen_miibus_statchg(struct ifnet *ifp)
 {
-       struct axen_softc *sc = ifp->if_softc;
+       struct axen_softc * const sc = ifp->if_softc;
        struct mii_data *mii = GET_MII(sc);
        int err;
        uint16_t val;
        uint16_t wval;
 
+       if (sc->axen_dying)
+               return;
+
        sc->axen_link = 0;
        if ((mii->mii_media_status & (IFM_ACTIVE | IFM_AVALID)) ==
            (IFM_ACTIVE | IFM_AVALID)) {
@@ -349,7 +347,7 @@
                break;
        }
 
-       DPRINTF(("axen_miibus_statchg: val=0x%x\n", val));
+       DPRINTF(("%s: val=0x%x\n", __func__, val));
        wval = htole16(val);
        axen_lock_mii(sc);
        err = axen_cmd(sc, AXEN_CMD_MAC_WRITE2, 2, AXEN_MEDIUM_STATUS, &wval);
@@ -366,7 +364,7 @@
 static int
 axen_ifmedia_upd(struct ifnet *ifp)
 {
-       struct axen_softc *sc = ifp->if_softc;
+       struct axen_softc * const sc = ifp->if_softc;
        struct mii_data *mii = GET_MII(sc);
        int rc;
 
@@ -390,7 +388,7 @@
 static void
 axen_ifmedia_sts(struct ifnet *ifp, struct ifmediareq *ifmr)
 {
-       struct axen_softc *sc = ifp->if_softc;
+       struct axen_softc * const sc = ifp->if_softc;
        struct mii_data *mii = GET_MII(sc);
 
        mii_pollstat(mii);
@@ -474,15 +472,18 @@
        DELAY(1000);
 }
 
-#if 0 /* not used */
 #define AXEN_GPIO_WRITE(x, y) do {                             \
        axen_cmd(sc, AXEN_CMD_WRITE_GPIO, 0, (x), NULL);        \
        usbd_delay_ms(sc->axen_udev, (y));                      \
 } while (/*CONSTCOND*/0)
 
 static int
-axen_ax88179_eeprom(struct axen_softc *sc, void *addr)
+axen_get_eaddr(struct axen_softc *sc, void *addr)
 {
+#if 1
+       return axen_cmd(sc, AXEN_CMD_MAC_READ_ETHER, 6, AXEN_CMD_MAC_NODE_ID,
+           addr);
+#else
        int i, retry;
        uint8_t eeprom[20];
        uint16_t csum;
@@ -528,8 +529,8 @@
 
        memcpy(addr, eeprom, ETHER_ADDR_LEN);
        return 0;
+#endif
 }
-#endif
 
 static void
 axen_ax88179_init(struct axen_softc *sc)
@@ -738,7 +739,7 @@
 static void
 axen_attach(device_t parent, device_t self, void *aux)
 {
-       struct axen_softc *sc = device_private(self);
+       struct axen_softc * const sc = device_private(self);
        struct usb_attach_arg *uaa = aux;
        struct usbd_device *dev = uaa->uaa_device;
        usbd_status err;
@@ -770,7 +771,6 @@
 
        sc->axen_flags = axen_lookup(uaa->uaa_vendor, uaa->uaa_product)->axen_flags;
 
-       rw_init(&sc->axen_mii_lock);
        usb_init_task(&sc->axen_tick_task, axen_tick_task, sc, 0);
 
        err = usbd_device2interface_handle(dev, AXEN_IFACE_IDX,&sc->axen_iface);
@@ -820,24 +820,24 @@
                }
        }
 
+       /* Set these up now for axen_cmd().  */
+       mutex_init(&sc->axen_mii_lock, MUTEX_DEFAULT, IPL_NONE);
+
        s = splnet();
 
        sc->axen_phyno = AXEN_PHY_ID;
        DPRINTF(("%s: phyno %d\n", device_xname(self), sc->axen_phyno));
 
-       /*
-        * Get station address.
-        */
-#if 0 /* read from eeprom */
-       if (axen_ax88179_eeprom(sc, &eaddr)) {
+       /* Get station address.  */
+       axen_lock_mii(sc);
+       if (axen_get_eaddr(sc, &eaddr)) {
+               axen_unlock_mii(sc);
                printf("EEPROM checksum error\n");
+               mutex_destroy(&sc->axen_mii_lock);
                return;
        }
-#else /* use MAC command */
-       axen_lock_mii(sc);
-       axen_cmd(sc, AXEN_CMD_MAC_READ_ETHER, 6, AXEN_CMD_MAC_NODE_ID, &eaddr);
        axen_unlock_mii(sc);
-#endif
+
        axen_ax88179_init(sc);
 
        /*
@@ -912,7 +912,7 @@
 static int
 axen_detach(device_t self, int flags)
 {
-       struct axen_softc *sc = device_private(self);
+       struct axen_softc * const sc = device_private(self);
        struct ifnet *ifp = GET_IFP(sc);
        int s;
 
@@ -959,7 +959,7 @@
 
        usbd_add_drv_event(USB_EVENT_DRIVER_DETACH, sc->axen_udev,sc->axen_dev);
 
-       rw_destroy(&sc->axen_mii_lock);
+       mutex_destroy(&sc->axen_mii_lock);
 
        return 0;
 }
@@ -967,7 +967,7 @@
 static int
 axen_activate(device_t self, devact_t act)
 {
-       struct axen_softc *sc = device_private(self);
+       struct axen_softc * const sc = device_private(self);
        struct ifnet *ifp = GET_IFP(sc);
 
        DPRINTFN(2,("%s: %s: enter\n", device_xname(sc->axen_dev), __func__));
@@ -1064,7 +1064,7 @@
 axen_rxeof(struct usbd_xfer *xfer, void * priv, usbd_status status)
 {
        struct axen_chain *c = (struct axen_chain *)priv;
-       struct axen_softc *sc = c->axen_sc;
+       struct axen_softc * const sc = c->axen_sc;
        struct ifnet *ifp = GET_IFP(sc);
        uint8_t *buf = c->axen_buf;
        struct mbuf *m;
@@ -1263,7 +1263,7 @@
 axen_txeof(struct usbd_xfer *xfer, void * priv, usbd_status status)
 {
        struct axen_chain *c = (struct axen_chain *)priv;
-       struct axen_softc *sc = c->axen_sc;
+       struct axen_softc * const sc = c->axen_sc;
        struct axen_cdata *cd = &sc->axen_cdata;
        struct ifnet *ifp = GET_IFP(sc);
        int s;
@@ -1302,7 +1302,7 @@
 static void
 axen_tick(void *xsc)
 {
-       struct axen_softc *sc = xsc;
+       struct axen_softc * const sc = xsc;
 
        if (sc == NULL)
                return;
@@ -1319,12 +1319,10 @@



Home | Main Index | Thread Index | Old Index