aboutsummaryrefslogtreecommitdiffstats
path: root/net/mac80211
diff options
context:
space:
mode:
authorEmmanuel Grumbach <emmanuel.grumbach@intel.com>2015-01-22 16:30:19 -0500
committerJohannes Berg <johannes.berg@intel.com>2015-01-23 04:54:21 -0500
commit14f2ae83d07a0a0d499d4760dd4a1bffd310b6ae (patch)
treebc12644be9bc7c8959464353f2fb63e5ce1aa930 /net/mac80211
parent9c74893441d3cf4b258a82b19cbf6bfd2ed6e549 (diff)
mac80211: synchronize_net() before flushing the queues
When mac80211 disconnects, it drops all the packets on the queues. This happens after the net stack has been notified that we have no link anymore (netif_carrier_off). netif_carrier_off ensures that no new packets are sent to xmit() callback, but we might have older packets in the middle of the Tx path. These packets will land in the driver's queues after the latter have been flushed. Synchronize_net() between netif_carrier_off and drv_flush() will fix this. Note that we can't call synchronize_net inside ieee80211_flush_queues since there are flows that call ieee80211_flush_queues and don't need synchronize_net() which is an expensive operation. Signed-off-by: Emmanuel Grumbach <emmanuel.grumbach@intel.com> [reword comment to be more accurate] Signed-off-by: Johannes Berg <johannes.berg@intel.com>
Diffstat (limited to 'net/mac80211')
-rw-r--r--net/mac80211/mlme.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/net/mac80211/mlme.c b/net/mac80211/mlme.c
index 1875181ebd94..5cce6055f3ae 100644
--- a/net/mac80211/mlme.c
+++ b/net/mac80211/mlme.c
@@ -2011,6 +2011,9 @@ static void ieee80211_set_disassoc(struct ieee80211_sub_if_data *sdata,
2011 /* disable per-vif ps */ 2011 /* disable per-vif ps */
2012 ieee80211_recalc_ps_vif(sdata); 2012 ieee80211_recalc_ps_vif(sdata);
2013 2013
2014 /* make sure ongoing transmission finishes */
2015 synchronize_net();
2016
2014 /* 2017 /*
2015 * drop any frame before deauth/disassoc, this can be data or 2018 * drop any frame before deauth/disassoc, this can be data or
2016 * management frame. Since we are disconnecting, we should not 2019 * management frame. Since we are disconnecting, we should not