summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorEliad Peller <eliad@wizery.com>2012-06-27 13:18:22 +0200
committerJohannes Berg <johannes.berg@intel.com>2012-06-28 11:36:14 +0200
commitf823981e288f83113bf1129ff2c94e2fd74a28dd (patch)
treed441332c9230fc0276c9aeecc723e5077c9b1a15
parentmac80211: don't expose ieee80211_add_srates_ie() (diff)
downloadlinux-f823981e288f83113bf1129ff2c94e2fd74a28dd.tar.xz
linux-f823981e288f83113bf1129ff2c94e2fd74a28dd.zip
mac80211: flush queues before deauth/disassoc
On deauth/disassoc we tear down all BA sessions. These DELBA packets are sent on the appropriate TID, while deauth/disassoc is always sent on VO. This sometimes ends with the DELBA being sent after the deauth was already sent. Fix it by flushing all the pending frames before sending deauth/disassoc. Signed-off-by: Eliad Peller <eliad@wizery.com> Signed-off-by: Johannes Berg <johannes.berg@intel.com>
-rw-r--r--net/mac80211/mlme.c4
1 files changed, 4 insertions, 0 deletions
diff --git a/net/mac80211/mlme.c b/net/mac80211/mlme.c
index e11cd0e033ef..c54388b3ebff 100644
--- a/net/mac80211/mlme.c
+++ b/net/mac80211/mlme.c
@@ -1364,6 +1364,10 @@ static void ieee80211_set_disassoc(struct ieee80211_sub_if_data *sdata,
}
mutex_unlock(&local->sta_mtx);
+ /* flush out any pending frame (e.g. DELBA) before deauth/disassoc */
+ if (tx)
+ drv_flush(local, false);
+
/* deauthenticate/disassociate now */
if (tx || frame_buf)
ieee80211_send_deauth_disassoc(sdata, bssid, stype, reason,