svn commit: r238316 - head/sys/dev/ath
Adrian Chadd
adrian at FreeBSD.org
Tue Jul 10 00:02:19 UTC 2012
Author: adrian
Date: Tue Jul 10 00:02:19 2012
New Revision: 238316
URL: http://svn.freebsd.org/changeset/base/238316
Log:
Convert sc_rxpending to a per-EDMA queue, and use that for the legacy code.
Prepare ath_rx_pkt() to handle multiple RX queues, and default the legacy
RX queue to use the HP queue.
Modified:
head/sys/dev/ath/if_ath_rx.c
head/sys/dev/ath/if_ath_rx.h
head/sys/dev/ath/if_athvar.h
Modified: head/sys/dev/ath/if_ath_rx.c
==============================================================================
--- head/sys/dev/ath/if_ath_rx.c Tue Jul 10 00:01:00 2012 (r238315)
+++ head/sys/dev/ath/if_ath_rx.c Tue Jul 10 00:02:19 2012 (r238316)
@@ -463,9 +463,9 @@ ath_handle_micerror(struct ieee80211com
}
}
-static int
+int
ath_rx_pkt(struct ath_softc *sc, struct ath_rx_status *rs, HAL_STATUS status,
- uint64_t tsf, int nf, struct ath_buf *bf)
+ uint64_t tsf, int nf, HAL_RX_QUEUE qtype, struct ath_buf *bf)
{
struct ath_hal *ah = sc->sc_ah;
struct mbuf *m = bf->bf_m;
@@ -475,6 +475,7 @@ ath_rx_pkt(struct ath_softc *sc, struct
struct ieee80211com *ic = ifp->if_l2com;
struct ieee80211_node *ni;
int is_good = 0;
+ struct ath_rx_edma *re = &sc->sc_rxedma[qtype];
/*
* Calculate the correct 64 bit TSF given
@@ -559,9 +560,9 @@ rx_error:
/*
* Cleanup any pending partial frame.
*/
- if (sc->sc_rxpending != NULL) {
- m_freem(sc->sc_rxpending);
- sc->sc_rxpending = NULL;
+ if (re->m_rxpending != NULL) {
+ m_freem(re->m_rxpending);
+ re->m_rxpending = NULL;
}
/*
* When a tap is present pass error frames
@@ -608,25 +609,25 @@ rx_accept:
* it for the next completed descriptor, it
* will be used to construct a jumbogram.
*/
- if (sc->sc_rxpending != NULL) {
+ if (re->m_rxpending != NULL) {
/* NB: max frame size is currently 2 clusters */
sc->sc_stats.ast_rx_toobig++;
- m_freem(sc->sc_rxpending);
+ m_freem(re->m_rxpending);
}
m->m_pkthdr.rcvif = ifp;
m->m_pkthdr.len = len;
- sc->sc_rxpending = m;
+ re->m_rxpending = m;
goto rx_next;
- } else if (sc->sc_rxpending != NULL) {
+ } else if (re->m_rxpending != NULL) {
/*
* This is the second part of a jumbogram,
* chain it to the first mbuf, adjust the
* frame length, and clear the rxpending state.
*/
- sc->sc_rxpending->m_next = m;
- sc->sc_rxpending->m_pkthdr.len += len;
- m = sc->sc_rxpending;
- sc->sc_rxpending = NULL;
+ re->m_rxpending->m_next = m;
+ re->m_rxpending->m_pkthdr.len += len;
+ m = re->m_rxpending;
+ re->m_rxpending = NULL;
} else {
/*
* Normal single-descriptor receive; setup
@@ -883,7 +884,7 @@ ath_rx_proc(struct ath_softc *sc, int re
/*
* Process a single frame.
*/
- if (ath_rx_pkt(sc, rs, status, tsf, nf, bf))
+ if (ath_rx_pkt(sc, rs, status, tsf, nf, HAL_RX_QUEUE_HP, bf))
ngood++;
rx_proc_next:
TAILQ_INSERT_TAIL(&sc->sc_rxbuf, bf, bf_list);
@@ -1016,9 +1017,16 @@ ath_legacy_stoprecv(struct ath_softc *sc
}
}
#endif
- if (sc->sc_rxpending != NULL) {
- m_freem(sc->sc_rxpending);
- sc->sc_rxpending = NULL;
+ /*
+ * Free both high/low RX pending, just in case.
+ */
+ if (sc->sc_rxedma[HAL_RX_QUEUE_LP].m_rxpending != NULL) {
+ m_freem(sc->sc_rxedma[HAL_RX_QUEUE_LP].m_rxpending);
+ sc->sc_rxedma[HAL_RX_QUEUE_LP].m_rxpending = NULL;
+ }
+ if (sc->sc_rxedma[HAL_RX_QUEUE_HP].m_rxpending != NULL) {
+ m_freem(sc->sc_rxedma[HAL_RX_QUEUE_HP].m_rxpending);
+ sc->sc_rxedma[HAL_RX_QUEUE_HP].m_rxpending = NULL;
}
sc->sc_rxlink = NULL; /* just in case */
#undef PA2DESC
@@ -1034,7 +1042,8 @@ ath_legacy_startrecv(struct ath_softc *s
struct ath_buf *bf;
sc->sc_rxlink = NULL;
- sc->sc_rxpending = NULL;
+ sc->sc_rxedma[HAL_RX_QUEUE_LP].m_rxpending = NULL;
+ sc->sc_rxedma[HAL_RX_QUEUE_HP].m_rxpending = NULL;
TAILQ_FOREACH(bf, &sc->sc_rxbuf, bf_list) {
int error = ath_rxbuf_init(sc, bf);
if (error != 0) {
Modified: head/sys/dev/ath/if_ath_rx.h
==============================================================================
--- head/sys/dev/ath/if_ath_rx.h Tue Jul 10 00:01:00 2012 (r238315)
+++ head/sys/dev/ath/if_ath_rx.h Tue Jul 10 00:02:19 2012 (r238316)
@@ -56,6 +56,10 @@ extern void ath_stoprecv(struct ath_soft
extern int ath_startrecv(struct ath_softc *sc);
#endif
+extern int ath_rx_pkt(struct ath_softc *sc, struct ath_rx_status *rs,
+ HAL_STATUS status, uint64_t tsf, int nf, HAL_RX_QUEUE qtype,
+ struct ath_buf *bf);
+
extern void ath_recv_setup_legacy(struct ath_softc *sc);
#endif
Modified: head/sys/dev/ath/if_athvar.h
==============================================================================
--- head/sys/dev/ath/if_athvar.h Tue Jul 10 00:01:00 2012 (r238315)
+++ head/sys/dev/ath/if_athvar.h Tue Jul 10 00:02:19 2012 (r238316)
@@ -531,7 +531,6 @@ struct ath_softc {
struct ath_descdma sc_rxdma; /* RX descriptors */
ath_bufhead sc_rxbuf; /* receive buffer */
- struct mbuf *sc_rxpending; /* pending receive data */
u_int32_t *sc_rxlink; /* link ptr in last RX desc */
struct task sc_rxtask; /* rx int processing */
u_int8_t sc_defant; /* current default antenna */
More information about the svn-src-head
mailing list