Skip site navigation (1)Skip section navigation (2)
Date:      Thu, 20 Sep 2012 03:03:01 +0000 (UTC)
From:      Adrian Chadd <adrian@FreeBSD.org>
To:        src-committers@freebsd.org, svn-src-all@freebsd.org, svn-src-head@freebsd.org
Subject:   svn commit: r240721 - head/sys/dev/ath
Message-ID:  <201209200303.q8K331KZ027290@svn.freebsd.org>

next in thread | raw e-mail | index | archive | help
Author: adrian
Date: Thu Sep 20 03:03:01 2012
New Revision: 240721
URL: http://svn.freebsd.org/changeset/base/240721

Log:
  Add a work-around for some strange net80211 BAR races in the wireless
  stack.
  
  There are unfortunately quite a few odd cases in BAR TX and BAR TX
  retransmission that I haven't yet fully diagnosed.  So for now, add
  this work-around so the resume() function isn't called too often,
  decrementing pause to -1 (and causing things to stay paused.)

Modified:
  head/sys/dev/ath/if_ath_tx.c

Modified: head/sys/dev/ath/if_ath_tx.c
==============================================================================
--- head/sys/dev/ath/if_ath_tx.c	Thu Sep 20 02:49:25 2012	(r240720)
+++ head/sys/dev/ath/if_ath_tx.c	Thu Sep 20 03:03:01 2012	(r240721)
@@ -5043,10 +5043,19 @@ ath_bar_response(struct ieee80211_node *
 	 * XXX if this is attempt=50, the TID will be downgraded
 	 * XXX to a non-aggregate session. So we must unpause the
 	 * XXX TID here or it'll never be done.
+	 *
+	 * Also, don't call it if bar_tx/bar_wait are 0; something
+	 * has beaten us to the punch? (XXX figure out what?)
 	 */
 	if (status == 0 || attempts == 50) {
 		ATH_TXQ_LOCK(sc->sc_ac2q[atid->ac]);
-		ath_tx_tid_bar_unsuspend(sc, atid);
+		if (atid->bar_tx == 0 || atid->bar_wait == 0)
+			device_printf(sc->sc_dev,
+			    "%s: huh? bar_tx=%d, bar_wait=%d\n",
+			    __func__,
+			    atid->bar_tx, atid->bar_wait);
+		else
+			ath_tx_tid_bar_unsuspend(sc, atid);
 		ATH_TXQ_UNLOCK(sc->sc_ac2q[atid->ac]);
 	}
 }



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