Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/dev/pci iwi_start(): Replace "IFQ_DEQUEUE() -> IF_PREPEN...
details:   https://anonhg.NetBSD.org/src/rev/df0ab0cd3327
branches:  trunk
changeset: 369597:df0ab0cd3327
user:      thorpej <thorpej%NetBSD.org@localhost>
date:      Mon Aug 22 18:09:04 2022 +0000
description:
iwi_start(): Replace "IFQ_DEQUEUE() -> IF_PREPEND() on failure" with
"IFQ_POLL() -> IFQ_DEQUEUE() on success (or fatal error)".
diffstat:
 sys/dev/pci/if_iwi.c |  12 ++++++------
 1 files changed, 6 insertions(+), 6 deletions(-)
diffs (57 lines):
diff -r cc8d3cea6dae -r df0ab0cd3327 sys/dev/pci/if_iwi.c
--- a/sys/dev/pci/if_iwi.c      Mon Aug 22 18:08:05 2022 +0000
+++ b/sys/dev/pci/if_iwi.c      Mon Aug 22 18:09:04 2022 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: if_iwi.c,v 1.119 2022/08/22 17:07:40 thorpej Exp $  */
+/*     $NetBSD: if_iwi.c,v 1.120 2022/08/22 18:09:04 thorpej Exp $  */
 /*     $OpenBSD: if_iwi.c,v 1.111 2010/11/15 19:11:57 damien Exp $     */
 
 /*-
@@ -19,7 +19,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: if_iwi.c,v 1.119 2022/08/22 17:07:40 thorpej Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if_iwi.c,v 1.120 2022/08/22 18:09:04 thorpej Exp $");
 
 /*-
  * Intel(R) PRO/Wireless 2200BG/2225BG/2915ABG driver
@@ -1781,7 +1781,7 @@
                return;
 
        for (;;) {
-               IFQ_DEQUEUE(&ifp->if_snd, m0);
+               IFQ_POLL(&ifp->if_snd, m0);
                if (m0 == NULL)
                        break;
 
@@ -1790,6 +1790,7 @@
                eh = mtod(m0, struct ether_header *);
                ni = ieee80211_find_txnode(ic, eh->ether_dhost);
                if (ni == NULL) {
+                       IFQ_DEQUEUE(&ifp->if_snd, m0);
                        m_freem(m0);
                        if_statinc(ifp, if_oerrors);
                        continue;
@@ -1797,6 +1798,7 @@
 
                /* classify mbuf so we can find which tx ring to use */
                if (ieee80211_classify(ic, m0, ni) != 0) {
+                       IFQ_DEQUEUE(&ifp->if_snd, m0);
                        m_freem(m0);
                        ieee80211_free_node(ni);
                        if_statinc(ifp, if_oerrors);
@@ -1809,12 +1811,10 @@
 
                if (sc->txq[ac].queued > sc->txq[ac].count - 8) {
                        /* there is no place left in this ring */
-                       IFQ_LOCK(&ifp->if_snd);
-                       IF_PREPEND(&ifp->if_snd, m0);
-                       IFQ_UNLOCK(&ifp->if_snd);
                        ifp->if_flags |= IFF_OACTIVE;
                        break;
                }
+               IFQ_DEQUEUE(&ifp->if_snd, m0);
 
                bpf_mtap(ifp, m0, BPF_D_OUT);
 
Home |
Main Index |
Thread Index |
Old Index