diff options
-rw-r--r-- | net/mac80211/mlme.c | 11 |
1 files changed, 11 insertions, 0 deletions
diff --git a/net/mac80211/mlme.c b/net/mac80211/mlme.c index 6044c6d87e4c..b756d2924690 100644 --- a/net/mac80211/mlme.c +++ b/net/mac80211/mlme.c | |||
@@ -4319,6 +4319,17 @@ void ieee80211_mgd_stop(struct ieee80211_sub_if_data *sdata) | |||
4319 | { | 4319 | { |
4320 | struct ieee80211_if_managed *ifmgd = &sdata->u.mgd; | 4320 | struct ieee80211_if_managed *ifmgd = &sdata->u.mgd; |
4321 | 4321 | ||
4322 | /* | ||
4323 | * Make sure some work items will not run after this, | ||
4324 | * they will not do anything but might not have been | ||
4325 | * cancelled when disconnecting. | ||
4326 | */ | ||
4327 | cancel_work_sync(&ifmgd->monitor_work); | ||
4328 | cancel_work_sync(&ifmgd->beacon_connection_loss_work); | ||
4329 | cancel_work_sync(&ifmgd->request_smps_work); | ||
4330 | cancel_work_sync(&ifmgd->csa_connection_drop_work); | ||
4331 | cancel_work_sync(&ifmgd->chswitch_work); | ||
4332 | |||
4322 | mutex_lock(&ifmgd->mtx); | 4333 | mutex_lock(&ifmgd->mtx); |
4323 | if (ifmgd->assoc_data) | 4334 | if (ifmgd->assoc_data) |
4324 | ieee80211_destroy_assoc_data(sdata, false); | 4335 | ieee80211_destroy_assoc_data(sdata, false); |