diff options
author | Martin Pieuchot <mpi@cvs.openbsd.org> | 2015-11-20 12:41:30 +0000 |
---|---|---|
committer | Martin Pieuchot <mpi@cvs.openbsd.org> | 2015-11-20 12:41:30 +0000 |
commit | 91b27ed57884836ad277500fb3eff12c35d8faf7 (patch) | |
tree | 97158f4f55ddb7c5707d01d7433a9647e5f27f29 /sys/dev/ic | |
parent | e313fe8c34e2271b9c57faee82709bbf4ee4d3ae (diff) |
Check for space on the ring before dequeuing packets.
Allows us to get rid of mq_requeue(9) and IFQ_POLL(9) because wireless
drivers use a special queue for management frames.
Tested by stsp@, ok dlg@, stsp@
Diffstat (limited to 'sys/dev/ic')
-rw-r--r-- | sys/dev/ic/rt2560.c | 22 | ||||
-rw-r--r-- | sys/dev/ic/rt2661.c | 24 |
2 files changed, 24 insertions, 22 deletions
diff --git a/sys/dev/ic/rt2560.c b/sys/dev/ic/rt2560.c index 75b69c79cb2..85e0ef34bda 100644 --- a/sys/dev/ic/rt2560.c +++ b/sys/dev/ic/rt2560.c @@ -1,4 +1,4 @@ -/* $OpenBSD: rt2560.c,v 1.75 2015/11/20 03:35:22 dlg Exp $ */ +/* $OpenBSD: rt2560.c,v 1.76 2015/11/20 12:41:29 mpi Exp $ */ /*- * Copyright (c) 2005, 2006 @@ -1928,15 +1928,16 @@ rt2560_start(struct ifnet *ifp) return; for (;;) { - m0 = mq_dequeue(&ic->ic_mgtq); - if (m0 != NULL) { + if (mq_len(&ic->ic_mgtq) > 0) { if (sc->prioq.queued >= RT2560_PRIO_RING_COUNT) { ifp->if_flags |= IFF_OACTIVE; sc->sc_flags |= RT2560_PRIO_OACTIVE; - mq_requeue(&ic->ic_mgtq, m0); break; } + m0 = mq_dequeue(&ic->ic_mgtq); + if (m0 == NULL) + continue; ni = m0->m_pkthdr.ph_cookie; #if NBPFILTER > 0 if (ic->ic_rawbpf != NULL) @@ -1946,18 +1947,19 @@ rt2560_start(struct ifnet *ifp) break; } else { - if (ic->ic_state != IEEE80211_S_RUN) - break; - m0 = ifq_deq_begin(&ifp->if_snd); - if (m0 == NULL) - break; if (sc->txq.queued >= RT2560_TX_RING_COUNT - 1) { ifq_deq_rollback(&ifp->if_snd, m0); ifp->if_flags |= IFF_OACTIVE; sc->sc_flags |= RT2560_DATA_OACTIVE; break; } - ifq_deq_commit(&ifp->if_snd, m0); + + if (ic->ic_state != IEEE80211_S_RUN) + break; + + IFQ_DEQUEUE(&ifp->if_snd, m0); + if (m0 == NULL) + break; #if NBPFILTER > 0 if (ifp->if_bpf != NULL) bpf_mtap(ifp->if_bpf, m0, BPF_DIRECTION_OUT); diff --git a/sys/dev/ic/rt2661.c b/sys/dev/ic/rt2661.c index 1fefe88c366..87deca78ac3 100644 --- a/sys/dev/ic/rt2661.c +++ b/sys/dev/ic/rt2661.c @@ -1,4 +1,4 @@ -/* $OpenBSD: rt2661.c,v 1.85 2015/11/20 03:35:22 dlg Exp $ */ +/* $OpenBSD: rt2661.c,v 1.86 2015/11/20 12:41:29 mpi Exp $ */ /*- * Copyright (c) 2006 @@ -1933,14 +1933,15 @@ rt2661_start(struct ifnet *ifp) return; for (;;) { - m0 = mq_dequeue(&ic->ic_mgtq); - if (m0 != NULL) { + if (mq_len(&ic->ic_mgtq) > 0) { if (sc->mgtq.queued >= RT2661_MGT_RING_COUNT) { ifp->if_flags |= IFF_OACTIVE; - mq_requeue(&ic->ic_mgtq, m0); break; } + m0 = mq_dequeue(&ic->ic_mgtq); + if (m0 == NULL) + continue; ni = m0->m_pkthdr.ph_cookie; #if NBPFILTER > 0 if (ic->ic_rawbpf != NULL) @@ -1950,18 +1951,17 @@ rt2661_start(struct ifnet *ifp) break; } else { - if (ic->ic_state != IEEE80211_S_RUN) - break; - m0 = ifq_deq_begin(&ifp->if_snd); - if (m0 == NULL) - break; if (sc->txq[0].queued >= RT2661_TX_RING_COUNT - 1) { - ifq_deq_rollback(&ifp->if_snd, m0); - /* there is no place left in this ring */ ifp->if_flags |= IFF_OACTIVE; break; } - ifq_deq_commit(&ifp->if_snd, m0); + + if (ic->ic_state != IEEE80211_S_RUN) + break; + + IFQ_DEQUEUE(&ifp->if_snd, m0); + if (m0 == NULL) + break; #if NBPFILTER > 0 if (ifp->if_bpf != NULL) bpf_mtap(ifp->if_bpf, m0, BPF_DIRECTION_OUT); |