Skip site navigation (1)Skip section navigation (2)
Date:      Thu, 9 Aug 2007 00:54:58 GMT
From:      Kip Macy <kmacy@FreeBSD.org>
To:        Perforce Change Reviews <perforce@freebsd.org>
Subject:   PERFORCE change 124928 for review
Message-ID:  <200708090054.l790swYO057918@repoman.freebsd.org>

next in thread | raw e-mail | index | archive | help
http://perforce.freebsd.org/chv.cgi?CH=124928

Change 124928 by kmacy@kmacy_home:ethng on 2007/08/09 00:54:45

	get cxgb support for IFNET_MULTIQUEUE performance 
	within 10% of default case

Affected files ...

.. //depot/projects/ethng/src/sys/dev/cxgb/cxgb_adapter.h#6 edit
.. //depot/projects/ethng/src/sys/dev/cxgb/cxgb_main.c#9 edit
.. //depot/projects/ethng/src/sys/dev/cxgb/cxgb_multiq.c#4 edit
.. //depot/projects/ethng/src/sys/dev/cxgb/cxgb_sge.c#7 edit

Differences ...

==== //depot/projects/ethng/src/sys/dev/cxgb/cxgb_adapter.h#6 (text+ko) ====

@@ -51,6 +51,7 @@
 
 #include <machine/bus.h>
 #include <machine/resource.h>
+
 #include <sys/bus_dma.h>
 #include <dev/pci/pcireg.h>
 #include <dev/pci/pcivar.h>
@@ -584,5 +585,6 @@
 int cxgb_tx_common(struct ifnet *ifp, struct sge_qset  *qs, uint32_t txmax);
 struct mbuf *cxgb_dequeue_packet(struct ifnet *ifp, struct sge_txq *unused);
 void cxgb_start(struct ifnet *ifp);
+void refill_fl_service(adapter_t *adap, struct sge_fl *fl);
 
 #endif

==== //depot/projects/ethng/src/sys/dev/cxgb/cxgb_main.c#9 (text+ko) ====

@@ -1961,7 +1961,7 @@
 			break;
 		BPF_MTAP(ifp, m);
 	}
-#ifdef IFNET_MULTIQUEUE	
+#ifndef IFNET_MULTIQUEUE	
 	if (__predict_false(err)) {
 		if (err == ENOMEM) {
 			ifp->if_drv_flags |= IFF_DRV_OACTIVE;
@@ -1970,8 +1970,9 @@
 			IFQ_UNLOCK(&ifp->if_snd);
 		}
 	}
-	if (err == 0 && m == NULL) 
+	if (err == 0 && m == NULL) {
 		err = ENOBUFS;
+	}
 	else if ((err == 0) &&  (txq->size <= txq->in_use + TX_MAX_DESC) &&
 	    (ifp->if_drv_flags & IFF_DRV_OACTIVE) == 0) {
 		ifp->if_drv_flags |= IFF_DRV_OACTIVE;
@@ -1992,9 +1993,9 @@
 	if (!p->link_config.link_ok)
 		return (ENXIO);
 
-	if (IFQ_DRV_IS_EMPTY(&ifp->if_snd))
+	if (IFQ_DRV_IS_EMPTY(&ifp->if_snd)) {
 		return (ENOBUFS);
-
+	}
 	qs = &p->adapter->sge.qs[p->first_qset];
 	txq = &qs->txq[TXQ_ETH];
 	err = 0;

==== //depot/projects/ethng/src/sys/dev/cxgb/cxgb_multiq.c#4 (text+ko) ====

@@ -1,5 +1,3 @@
-
-
 /**************************************************************************
 
 Copyright (c) 2007, Chelsio Inc.
@@ -149,6 +147,9 @@
 		}
 		mtx_unlock(&txq->lock);
 
+		if ((qs->txq[TXQ_ETH].flags & TXQ_TRANSMITTING) == 0)
+			wakeup(qs);
+
 		if (dropped) 
 			m_freem(m);
 	}
@@ -566,8 +567,6 @@
 	sched_unpin();
 }
 
-void refill_fl_service(adapter_t *adap, struct sge_fl *fl);
-
 static void
 cxgb_pcpu_start_proc(void *arg)
 {
@@ -589,7 +588,7 @@
 		
 		refill_fl_service(qs->port->adapter, &qs->fl[0]);
 		refill_fl_service(qs->port->adapter, &qs->fl[1]);
-		tsleep(qs, 0, "cxgbidle", sleep_ticks);
+		tsleep(qs, 1, "cxgbidle", sleep_ticks);
 	}
 	thread_lock(td);
 	sched_unbind(td);

==== //depot/projects/ethng/src/sys/dev/cxgb/cxgb_sge.c#7 (text+ko) ====

@@ -188,7 +188,6 @@
 static void sge_timer_cb(void *arg);
 static void sge_timer_reclaim(void *arg, int ncount);
 static void sge_txq_reclaim_handler(void *arg, int ncount);
-static int free_tx_desc(struct sge_txq *q, int n, struct mbuf **m_vec);
 
 /**
  *	reclaim_completed_tx - reclaims completed Tx descriptors
@@ -207,7 +206,7 @@
 
 	mtx_assert(&q->lock, MA_OWNED);
 	if (reclaim > 0) {
-		n = free_tx_desc(q, min(reclaim, nbufs), mvec);
+		n = t3_free_tx_desc(q, min(reclaim, nbufs), mvec);
 		reclaimed = min(reclaim, nbufs);
 		q->cleaned += reclaimed;
 		q->in_use -= reclaimed;
@@ -580,6 +579,13 @@
 	refill_fl(adap, fl, min(16U, fl->size - fl->credits));
 }
 
+void
+refill_fl_service(adapter_t *adap, struct sge_fl *fl)
+{
+	return; /* XXX no-op for now */
+	__refill_fl(adap, fl);
+}
+
 /**
  *	recycle_rx_buf - recycle a receive buffer
  *	@adapter: the adapter
@@ -1654,7 +1660,7 @@
 
 
 /**
- *	free_tx_desc - reclaims Tx descriptors and their buffers
+ *	t3_free_tx_desc - reclaims Tx descriptors and their buffers
  *	@adapter: the adapter
  *	@q: the Tx queue to reclaim descriptors from
  *	@n: the number of descriptors to reclaim
@@ -1663,7 +1669,7 @@
  *	Tx buffers.  Called with the Tx queue lock held.
  */
 int
-free_tx_desc(struct sge_txq *q, int n, struct mbuf **m_vec)
+t3_free_tx_desc(struct sge_txq *q, int n, struct mbuf **m_vec)
 {
 	struct tx_sw_desc *d;
 	unsigned int cidx = q->cidx;
@@ -2226,9 +2232,12 @@
 	struct ifnet *ifp = pi->ifp;
 	
 	DPRINTF("rx_eth m=%p m->m_data=%p p->iff=%d\n", m, mtod(m, uint8_t *), cpl->iff);
-	if (&pi->adapter->port[cpl->iff] != pi)
-		panic("bad port index %d m->m_data=%p\n", cpl->iff, mtod(m, uint8_t *));
-
+	if (&pi->adapter->port[cpl->iff] != pi) {
+		struct sge_qset *qs = rspq_to_qset(rq);
+		
+		panic("bad port index %d m->m_data=%p cidx=%d pidx=%d\n", cpl->iff, mtod(m, uint8_t *),
+		    qs->fl[0].cidx, qs->fl[0].pidx);
+	}
 	if ((ifp->if_capenable & IFCAP_RXCSUM) && !cpl->fragment &&
 	    cpl->csum_valid && cpl->csum == 0xffff) {
 		m->m_pkthdr.csum_flags = (CSUM_IP_CHECKED|CSUM_IP_VALID);



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200708090054.l790swYO057918>