|
@@ -762,11 +762,27 @@ void ieee80211_process_addba_resp(struct ieee80211_local *local,
|
|
|
goto out;
|
|
|
}
|
|
|
|
|
|
- del_timer(&tid_tx->addba_resp_timer);
|
|
|
+ del_timer_sync(&tid_tx->addba_resp_timer);
|
|
|
|
|
|
#ifdef CONFIG_MAC80211_HT_DEBUG
|
|
|
printk(KERN_DEBUG "switched off addBA timer for tid %d\n", tid);
|
|
|
#endif
|
|
|
+
|
|
|
+ /*
|
|
|
+ * addba_resp_timer may have fired before we got here, and
|
|
|
+ * caused WANT_STOP to be set. If the stop then was already
|
|
|
+ * processed further, STOPPING might be set.
|
|
|
+ */
|
|
|
+ if (test_bit(HT_AGG_STATE_WANT_STOP, &tid_tx->state) ||
|
|
|
+ test_bit(HT_AGG_STATE_STOPPING, &tid_tx->state)) {
|
|
|
+#ifdef CONFIG_MAC80211_HT_DEBUG
|
|
|
+ printk(KERN_DEBUG
|
|
|
+ "got addBA resp for tid %d but we already gave up\n",
|
|
|
+ tid);
|
|
|
+#endif
|
|
|
+ goto out;
|
|
|
+ }
|
|
|
+
|
|
|
/*
|
|
|
* IEEE 802.11-2007 7.3.1.14:
|
|
|
* In an ADDBA Response frame, when the Status Code field
|