diff options
| author | Felix Fietkau <nbd@openwrt.org> | 2010-10-20 20:47:24 -0400 |
|---|---|---|
| committer | John W. Linville <linville@tuxdriver.com> | 2010-10-25 14:45:55 -0400 |
| commit | 0299a50abb5ee8d605c93b61b70e51a717c9960b (patch) | |
| tree | f2d00c20821eaf5028b0d907d32ab52c456459e9 | |
| parent | 0845735e2d1e4c177076d4bc2d841d9f77e95131 (diff) | |
ath9k: fix handling of rate control probe frames
The ath9k aggregation code was already checking the rate control probe flag
to prevent starting an aggregate frame with a sampling rate. What was missing
was closing an aggregate before adding a probing frame to it.
Without that, rate control cannot have precise control over probing, which
delays using faster rates when the channel conditions improve.
Signed-off-by: Felix Fietkau <nbd@openwrt.org>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
| -rw-r--r-- | drivers/net/wireless/ath/ath9k/xmit.c | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/drivers/net/wireless/ath/ath9k/xmit.c b/drivers/net/wireless/ath/ath9k/xmit.c index d077186da870..089b05ed6772 100644 --- a/drivers/net/wireless/ath/ath9k/xmit.c +++ b/drivers/net/wireless/ath/ath9k/xmit.c | |||
| @@ -673,6 +673,7 @@ static enum ATH_AGGR_STATUS ath_tx_form_aggr(struct ath_softc *sc, | |||
| 673 | u16 aggr_limit = 0, al = 0, bpad = 0, | 673 | u16 aggr_limit = 0, al = 0, bpad = 0, |
| 674 | al_delta, h_baw = tid->baw_size / 2; | 674 | al_delta, h_baw = tid->baw_size / 2; |
| 675 | enum ATH_AGGR_STATUS status = ATH_AGGR_DONE; | 675 | enum ATH_AGGR_STATUS status = ATH_AGGR_DONE; |
| 676 | struct ieee80211_tx_info *tx_info; | ||
| 676 | 677 | ||
| 677 | bf_first = list_first_entry(&tid->buf_q, struct ath_buf, list); | 678 | bf_first = list_first_entry(&tid->buf_q, struct ath_buf, list); |
| 678 | 679 | ||
| @@ -699,6 +700,11 @@ static enum ATH_AGGR_STATUS ath_tx_form_aggr(struct ath_softc *sc, | |||
| 699 | break; | 700 | break; |
| 700 | } | 701 | } |
| 701 | 702 | ||
| 703 | tx_info = IEEE80211_SKB_CB(bf->bf_mpdu); | ||
| 704 | if (nframes && ((tx_info->flags & IEEE80211_TX_CTL_RATE_CTRL_PROBE) || | ||
| 705 | !(tx_info->control.rates[0].flags & IEEE80211_TX_RC_MCS))) | ||
| 706 | break; | ||
| 707 | |||
| 702 | /* do not exceed subframe limit */ | 708 | /* do not exceed subframe limit */ |
| 703 | if (nframes >= min((int)h_baw, ATH_AMPDU_SUBFRAME_DEFAULT)) { | 709 | if (nframes >= min((int)h_baw, ATH_AMPDU_SUBFRAME_DEFAULT)) { |
| 704 | status = ATH_AGGR_LIMITED; | 710 | status = ATH_AGGR_LIMITED; |
