diff options
author | Vasanthakumar Thiagarajan <vasanth@atheros.com> | 2009-06-09 15:28:21 +0530 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2009-06-10 13:28:38 -0400 |
commit | 5eae6592e9bdc989151171828ee97e0ad9e1b1ac (patch) | |
tree | bda15e3f62747c889f35a4d648c2a714319f5ec0 /drivers/net | |
parent | 736708bd04b7a8941fddda32211982cab5d14431 (diff) | |
download | kernel_samsung_aries-5eae6592e9bdc989151171828ee97e0ad9e1b1ac.zip kernel_samsung_aries-5eae6592e9bdc989151171828ee97e0ad9e1b1ac.tar.gz kernel_samsung_aries-5eae6592e9bdc989151171828ee97e0ad9e1b1ac.tar.bz2 |
ath9k: Fix tx stuck when connected to aggr disabled HT AP
This patch along with my previous patch in mac80211 "Fix the
way ADDBA count..", fixes hang in tx when connected to an HT
AP which rejects/times out on addba req.
AGGR_ADDBA_PROGRESS should be cleared in aggr state when addba
negotiation is terminated due to either addba response is timed out
or addba is denied by the AP. With out clearing this bit,
all frames are queued onto s/w queue for getting tx'd as aggr and
will never be scheduled onto hw queue.
Signed-off-by: Vasanthakumar Thiagarajan <vasanth@atheros.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'drivers/net')
-rw-r--r-- | drivers/net/wireless/ath/ath9k/xmit.c | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/drivers/net/wireless/ath/ath9k/xmit.c b/drivers/net/wireless/ath/ath9k/xmit.c index a8def4f..b61a071 100644 --- a/drivers/net/wireless/ath/ath9k/xmit.c +++ b/drivers/net/wireless/ath/ath9k/xmit.c @@ -711,6 +711,7 @@ int ath_tx_aggr_stop(struct ath_softc *sc, struct ieee80211_sta *sta, u16 tid) return 0; if (!(txtid->state & AGGR_ADDBA_COMPLETE)) { + txtid->state &= ~AGGR_ADDBA_PROGRESS; txtid->addba_exchangeattempts = 0; return 0; } |