Source-Changes-HG archive

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

[src/trunk]: src/sys/dev/usb Enable multiple outstanding transfers.



details:   https://anonhg.NetBSD.org/src/rev/da58ab8bd19b
branches:  trunk
changeset: 996672:da58ab8bd19b
user:      rin <rin%NetBSD.org@localhost>
date:      Wed Feb 06 08:06:59 2019 +0000

description:
Enable multiple outstanding transfers.
XXX Linux driver uses much larger numbers of transfers.

diffstat:

 sys/dev/usb/if_axen.c    |  57 ++++++++++++++++++++++++++++-------------------
 sys/dev/usb/if_axenreg.h |  10 +++++--
 2 files changed, 41 insertions(+), 26 deletions(-)

diffs (140 lines):

diff -r f47769a66cd4 -r da58ab8bd19b sys/dev/usb/if_axen.c
--- a/sys/dev/usb/if_axen.c     Wed Feb 06 08:04:08 2019 +0000
+++ b/sys/dev/usb/if_axen.c     Wed Feb 06 08:06:59 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: if_axen.c,v 1.32 2019/02/06 08:04:08 rin Exp $ */
+/*     $NetBSD: if_axen.c,v 1.33 2019/02/06 08:06:59 rin 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.32 2019/02/06 08:04:08 rin Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if_axen.c,v 1.33 2019/02/06 08:06:59 rin Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_inet.h"
@@ -987,6 +987,8 @@
                }
        }
 
+       cd->axen_tx_prod = cd->axen_tx_cnt = 0;
+
        return 0;
 }
 
@@ -1197,6 +1199,7 @@
 {
        struct axen_chain *c = (struct axen_chain *)priv;
        struct axen_softc *sc = c->axen_sc;
+       struct axen_cdata *cd = &sc->axen_cdata;
        struct ifnet *ifp = GET_IFP(sc);
        int s;
 
@@ -1204,7 +1207,8 @@
                return;
 
        s = splnet();
-
+       KASSERT(cd->axen_tx_cnt > 0);
+       cd->axen_tx_cnt--;
        if (status != USBD_NORMAL_COMPLETION) {
                if (status == USBD_NOT_STARTED || status == USBD_CANCELLED) {
                        splx(s);
@@ -1328,18 +1332,16 @@
                return EIO;
        }
 
-       sc->axen_cdata.axen_tx_cnt++;
-
        return 0;
 }
 
 static void
 axen_start(struct ifnet *ifp)
 {
-       struct axen_softc *sc;
+       struct axen_softc *sc = ifp->if_softc;
        struct mbuf *m;
-
-       sc = ifp->if_softc;
+       struct axen_cdata *cd = &sc->axen_cdata;
+       int idx;
 
        if (sc->axen_link == 0)
                return;
@@ -1347,24 +1349,33 @@
        if ((ifp->if_flags & (IFF_OACTIVE|IFF_RUNNING)) != IFF_RUNNING)
                return;
 
-       IFQ_POLL(&ifp->if_snd, m);
-       if (m == NULL)
-               return;
+       idx = cd->axen_tx_prod;
+       while (cd->axen_tx_cnt < AXEN_TX_LIST_CNT) {
+               IFQ_POLL(&ifp->if_snd, m);
+               if (m == NULL)
+                       break;
 
-       if (axen_encap(sc, m, 0)) {
-               ifp->if_flags |= IFF_OACTIVE;
-               return;
+               if (axen_encap(sc, m, idx)) {
+                       ifp->if_flags |= IFF_OACTIVE; /* XXX */
+                       ifp->if_oerrors++;
+                       break;
+               }
+               IFQ_DEQUEUE(&ifp->if_snd, m);
+
+               /*
+                * If there's a BPF listener, bounce a copy of this frame
+                * to him.
+                */
+               bpf_mtap(ifp, m, BPF_D_OUT);
+               m_freem(m);
+
+               idx = (idx + 1) % AXEN_TX_LIST_CNT;
+               cd->axen_tx_cnt++;
        }
-       IFQ_DEQUEUE(&ifp->if_snd, m);
+       cd->axen_tx_prod = idx;
 
-       /*
-        * If there's a BPF listener, bounce a copy of this frame
-        * to him.
-        */
-       bpf_mtap(ifp, m, BPF_D_OUT);
-       m_freem(m);
-
-       ifp->if_flags |= IFF_OACTIVE;
+       if (cd->axen_tx_cnt >= AXEN_TX_LIST_CNT)
+               ifp->if_flags |= IFF_OACTIVE;
 
        /*
         * Set a timeout in case the chip goes out to lunch.
diff -r f47769a66cd4 -r da58ab8bd19b sys/dev/usb/if_axenreg.h
--- a/sys/dev/usb/if_axenreg.h  Wed Feb 06 08:04:08 2019 +0000
+++ b/sys/dev/usb/if_axenreg.h  Wed Feb 06 08:06:59 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: if_axenreg.h,v 1.8 2019/02/06 07:56:14 rin Exp $       */
+/*     $NetBSD: if_axenreg.h,v 1.9 2019/02/06 08:06:59 rin Exp $       */
 /*     $OpenBSD: if_axenreg.h,v 1.1 2013/10/07 05:37:41 yuo Exp $      */
 
 /*
@@ -210,8 +210,12 @@
 
 #define AXEN_TIMEOUT           1000
 
-#define AXEN_RX_LIST_CNT       1
-#define AXEN_TX_LIST_CNT       1
+#ifndef AXEN_RX_LIST_CNT
+#define AXEN_RX_LIST_CNT       4       /* 22 for SS mode in Linux driver */
+#endif
+#ifndef AXEN_TX_LIST_CNT
+#define AXEN_TX_LIST_CNT       4       /* 60 */
+#endif
 
 
 #define AXEN_CONFIG_NO         1



Home | Main Index | Thread Index | Old Index