svn commit: r233988 - head/sys/dev/ath

Adrian Chadd adrian at FreeBSD.org
Sat Apr 7 05:46:01 UTC 2012


Author: adrian
Date: Sat Apr  7 05:46:00 2012
New Revision: 233988
URL: http://svn.freebsd.org/changeset/base/233988

Log:
  As I thought, this is a bad idea. When forming aggregates, the RTS/CTS
  stuff and rate control lookup is only done on the first frame.

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

Modified: head/sys/dev/ath/if_ath_tx_ht.c
==============================================================================
--- head/sys/dev/ath/if_ath_tx_ht.c	Sat Apr  7 05:43:50 2012	(r233987)
+++ head/sys/dev/ath/if_ath_tx_ht.c	Sat Apr  7 05:46:00 2012	(r233988)
@@ -741,18 +741,14 @@ ath_tx_form_aggr(struct ath_softc *sc, s
 
 		/*
 		 * If the current frame has an RTS/CTS configuration
-		 * that differs from the first frame, don't include
-		 * this in the aggregate.  It's possible that the
-		 * "right" thing to do here is enforce the aggregate
-		 * configuration.
-		 */
-		if ((bf_first->bf_state.bfs_txflags &
-		    (HAL_TXDESC_RTSENA | HAL_TXDESC_CTSENA)) !=
-		   (bf->bf_state.bfs_txflags &
-		    (HAL_TXDESC_RTSENA | HAL_TXDESC_CTSENA))) {
-			status = ATH_AGGR_NONAGGR;
-			break;
-		}
+		 * that differs from the first frame, override the
+		 * subsequent frame with this config.
+		 */
+		bf->bf_state.bfs_txflags &=
+		    (HAL_TXDESC_RTSENA | HAL_TXDESC_CTSENA);
+		bf->bf_state.bfs_txflags |=
+		    bf_first->bf_state.bfs_txflags &
+		    (HAL_TXDESC_RTSENA | HAL_TXDESC_CTSENA);
 
 		/*
 		 * TODO: If it's _before_ the BAW left edge, complain very


More information about the svn-src-all mailing list