1
0
mirror of https://git.FreeBSD.org/src.git synced 2025-01-01 12:19:28 +00:00

Mostly revert previous commit(s). After doing a bunch of local testing,

it turns out that it negatively affects performance.  I'm stil investigating
exactly why deferring the IO causes such negative TCP performance but
doesn't affect UDP preformance.

Leave the ath_tx_kick() change in there however; it's going to be useful
to have that there for if_transmit() work.

PR:		kern/168649
This commit is contained in:
Adrian Chadd 2012-06-05 06:03:55 +00:00
parent 36eeafa0e5
commit 9f95609828
Notes: svn2git 2020-12-20 02:59:44 +00:00
svn path=/head/; revision=236599
3 changed files with 1 additions and 18 deletions

View File

@ -142,7 +142,6 @@ static void ath_vap_delete(struct ieee80211vap *);
static void ath_init(void *); static void ath_init(void *);
static void ath_stop_locked(struct ifnet *); static void ath_stop_locked(struct ifnet *);
static void ath_stop(struct ifnet *); static void ath_stop(struct ifnet *);
static void ath_tx_tasklet(void *arg, int npending);
static int ath_reset_vap(struct ieee80211vap *, u_long); static int ath_reset_vap(struct ieee80211vap *, u_long);
static int ath_media_change(struct ifnet *); static int ath_media_change(struct ifnet *);
static void ath_watchdog(void *); static void ath_watchdog(void *);
@ -374,7 +373,6 @@ ath_attach(u_int16_t devid, struct ath_softc *sc)
"%s taskq", ifp->if_xname); "%s taskq", ifp->if_xname);
TASK_INIT(&sc->sc_rxtask, 0, ath_rx_tasklet, sc); TASK_INIT(&sc->sc_rxtask, 0, ath_rx_tasklet, sc);
TASK_INIT(&sc->sc_txstarttask, 0, ath_tx_tasklet, sc);
TASK_INIT(&sc->sc_bmisstask, 0, ath_bmiss_proc, sc); TASK_INIT(&sc->sc_bmisstask, 0, ath_bmiss_proc, sc);
TASK_INIT(&sc->sc_bstucktask,0, ath_bstuck_proc, sc); TASK_INIT(&sc->sc_bstucktask,0, ath_bstuck_proc, sc);
TASK_INIT(&sc->sc_resettask,0, ath_reset_proc, sc); TASK_INIT(&sc->sc_resettask,0, ath_reset_proc, sc);
@ -2327,15 +2325,6 @@ void
ath_start(struct ifnet *ifp) ath_start(struct ifnet *ifp)
{ {
struct ath_softc *sc = ifp->if_softc; struct ath_softc *sc = ifp->if_softc;
taskqueue_enqueue(sc->sc_tq, &sc->sc_txstarttask);
}
static void
ath_tx_tasklet(void *arg, int npending)
{
struct ath_softc *sc = (struct ath_softc *) arg;
struct ifnet *ifp = sc->sc_ifp;
struct ieee80211_node *ni; struct ieee80211_node *ni;
struct ath_buf *bf; struct ath_buf *bf;
struct mbuf *m, *next; struct mbuf *m, *next;

View File

@ -88,12 +88,7 @@ static inline void
ath_tx_kick(struct ath_softc *sc) ath_tx_kick(struct ath_softc *sc)
{ {
/* ath_start(sc->sc_ifp);
* Use a taskqueue to schedule a TX completion task,
* even if we're in taskqueue context. That way this can
* be called from any context.
*/
taskqueue_enqueue(sc->sc_tq, &sc->sc_txstarttask);
} }
#endif #endif

View File

@ -476,7 +476,6 @@ struct ath_softc {
struct mbuf *sc_rxpending; /* pending receive data */ struct mbuf *sc_rxpending; /* pending receive data */
u_int32_t *sc_rxlink; /* link ptr in last RX desc */ u_int32_t *sc_rxlink; /* link ptr in last RX desc */
struct task sc_rxtask; /* rx int processing */ struct task sc_rxtask; /* rx int processing */
struct task sc_txstarttask; /* ath_start() processing */
u_int8_t sc_defant; /* current default antenna */ u_int8_t sc_defant; /* current default antenna */
u_int8_t sc_rxotherant; /* rx's on non-default antenna*/ u_int8_t sc_rxotherant; /* rx's on non-default antenna*/
u_int64_t sc_lastrx; /* tsf at last rx'd frame */ u_int64_t sc_lastrx; /* tsf at last rx'd frame */