The patch allows to check state of the software Tx queues in run time.
The information contained in this message is confidential and is intended for 
the addressee(s) only. If you have received this message in error, please 
notify the sender immediately and delete the message. Unless you are an 
addressee (or authorized to receive for an addressee), you may not use, copy or 
disclose to anyone this message or any information contained in this message. 
The unauthorized use, disclosure, copying or alteration of this message is 
strictly prohibited.
Add sysctl to get Tx queue deferred packet get-list counter

Submitted by:   Andrew Rybchenko <arybchenko at solarflare.com>
Sponsored by:   Solarflare Communications, Inc.

diff -r 099f556d39e0 sys/dev/sfxge/sfxge.h
--- a/sys/dev/sfxge/sfxge.h     Thu Sep 25 16:24:14 2014 +0400
+++ b/sys/dev/sfxge/sfxge.h     Thu Sep 25 16:30:30 2014 +0400
@@ -202,6 +202,7 @@
        struct ifnet                    *ifnet;
        unsigned int                    if_flags;
        struct sysctl_oid               *stats_node;
+       struct sysctl_oid               *txqs_node;
 
        struct task                     task_reset;
 
diff -r 099f556d39e0 sys/dev/sfxge/sfxge_tx.c
--- a/sys/dev/sfxge/sfxge_tx.c  Thu Sep 25 16:24:14 2014 +0400
+++ b/sys/dev/sfxge/sfxge_tx.c  Thu Sep 25 16:30:30 2014 +0400
@@ -176,7 +176,7 @@
        KASSERT(*get_tailp == NULL, ("*get_tailp != NULL"));
        *stdp->std_getp = get_next;
        stdp->std_getp = get_tailp;
-       stdp->std_count += count;
+       stdp->std_get_count += count;
 }
 
 #endif /* SFXGE_HAVE_MQ */
@@ -380,7 +380,7 @@
        prefetch_read_many(txq->common);
 
        mbuf = stdp->std_get;
-       count = stdp->std_count;
+       count = stdp->std_get_count;
 
        while (count != 0) {
                KASSERT(mbuf != NULL, ("mbuf == NULL"));
@@ -412,17 +412,17 @@
        if (count == 0) {
                KASSERT(mbuf == NULL, ("mbuf != NULL"));
                stdp->std_get = NULL;
-               stdp->std_count = 0;
+               stdp->std_get_count = 0;
                stdp->std_getp = &stdp->std_get;
        } else {
                stdp->std_get = mbuf;
-               stdp->std_count = count;
+               stdp->std_get_count = count;
        }
 
        if (txq->added != pushed)
                efx_tx_qpush(txq->common, txq->added);
 
-       KASSERT(txq->blocked || stdp->std_count == 0,
+       KASSERT(txq->blocked || stdp->std_get_count == 0,
                ("queue unblocked but count is non-zero"));
 }
 
@@ -476,12 +476,12 @@
 
                sfxge_tx_qdpl_swizzle(txq);
 
-               if (stdp->std_count >= SFXGE_TX_DPL_GET_PKT_LIMIT_DEFAULT)
+               if (stdp->std_get_count >= SFXGE_TX_DPL_GET_PKT_LIMIT_DEFAULT)
                        return (ENOBUFS);
 
                *(stdp->std_getp) = mbuf;
                stdp->std_getp = &mbuf->m_nextpkt;
-               stdp->std_count++;
+               stdp->std_get_count++;
        } else {
                volatile uintptr_t *putp;
                uintptr_t old;
@@ -575,7 +575,7 @@
                m_freem(mbuf);
        }
        stdp->std_get = NULL;
-       stdp->std_count = 0;
+       stdp->std_get_count = 0;
        stdp->std_getp = &stdp->std_get;
 
        mtx_unlock(&txq->lock);
@@ -1315,6 +1315,8 @@
 sfxge_tx_qinit(struct sfxge_softc *sc, unsigned int txq_index,
     enum sfxge_txq_type type, unsigned int evq_index)
 {
+       char name[16];
+       struct sysctl_oid *txq_node;
        struct sfxge_txq *txq;
        struct sfxge_evq *evq;
 #ifdef SFXGE_HAVE_MQ
@@ -1367,6 +1369,16 @@
                        goto fail2;
        }
 
+       snprintf(name, sizeof(name), "%u", txq_index);
+       txq_node = SYSCTL_ADD_NODE(
+               device_get_sysctl_ctx(sc->dev),
+               SYSCTL_CHILDREN(sc->txqs_node),
+               OID_AUTO, name, CTLFLAG_RD, NULL, "");
+       if (txq_node == NULL) {
+               rc = ENOMEM;
+               goto fail_txq_node;
+       }
+
        if (type == SFXGE_TXQ_IP_TCP_UDP_CKSUM &&
            (rc = tso_init(txq)) != 0)
                goto fail3;
@@ -1377,6 +1389,11 @@
        stdp->std_getp = &stdp->std_get;
 
        mtx_init(&txq->lock, "txq", NULL, MTX_DEF);
+
+       SYSCTL_ADD_UINT(device_get_sysctl_ctx(sc->dev),
+                       SYSCTL_CHILDREN(txq_node), OID_AUTO,
+                       "dpl_get_count", CTLFLAG_RD | CTLFLAG_STATS,
+                       &stdp->std_get_count, 0, "");
 #endif
 
        txq->type = type;
@@ -1387,6 +1404,7 @@
        return (0);
 
 fail3:
+fail_txq_node:
        free(txq->pend_desc, M_SFXGE);
 fail2:
        while (nmaps-- != 0)
@@ -1480,6 +1498,15 @@
        KASSERT(intr->state == SFXGE_INTR_INITIALIZED,
            ("intr->state != SFXGE_INTR_INITIALIZED"));
 
+       sc->txqs_node = SYSCTL_ADD_NODE(
+               device_get_sysctl_ctx(sc->dev),
+               SYSCTL_CHILDREN(device_get_sysctl_tree(sc->dev)),
+               OID_AUTO, "txq", CTLFLAG_RD, NULL, "Tx queues");
+       if (sc->txqs_node == NULL) {
+               rc = ENOMEM;
+               goto fail_txq_node;
+       }
+
        /* Initialize the transmit queues */
        if ((rc = sfxge_tx_qinit(sc, SFXGE_TXQ_NON_CKSUM,
            SFXGE_TXQ_NON_CKSUM, 0)) != 0)
@@ -1509,5 +1536,6 @@
        sfxge_tx_qfini(sc, SFXGE_TXQ_NON_CKSUM);
 
 fail:
+fail_txq_node:
        return (rc);
 }
diff -r 099f556d39e0 sys/dev/sfxge/sfxge_tx.h
--- a/sys/dev/sfxge/sfxge_tx.h  Thu Sep 25 16:24:14 2014 +0400
+++ b/sys/dev/sfxge/sfxge_tx.h  Thu Sep 25 16:30:30 2014 +0400
@@ -82,10 +82,10 @@
  * Deferred packet list.
  */
 struct sfxge_tx_dpl {
-       uintptr_t               std_put;    /* Head of put list. */
-       struct mbuf             *std_get;   /* Head of get list. */
-       struct mbuf             **std_getp; /* Tail of get list. */
-       unsigned int            std_count;  /* Count of packets. */
+       uintptr_t               std_put;        /* Head of put list. */
+       struct mbuf             *std_get;       /* Head of get list. */
+       struct mbuf             **std_getp;     /* Tail of get list. */
+       unsigned int            std_get_count;  /* Packets in get list. */
 };
 
 
_______________________________________________
freebsd-net@freebsd.org mailing list
http://lists.freebsd.org/mailman/listinfo/freebsd-net
To unsubscribe, send any mail to "freebsd-net-unsubscr...@freebsd.org"

Reply via email to