@@ -1079,7 +1079,12 @@ static int ieee80211_stop_ap(struct wiphy *wiphy, struct net_device *dev)
old_probe_resp = sdata_dereference(sdata->u.ap.probe_resp, sdata);
/* abort any running channel switch */
+ if (sdata->vif.csa_active) {
+ kfree(sdata->u.ap.next_beacon);
+ sdata->u.ap.next_beacon = NULL;
+ }
sdata->vif.csa_active = false;
+
cancel_work_sync(&sdata->u.ap.request_smps_work);
/* turn off carrier for this interface and dependent VLANs */
@@ -820,8 +820,13 @@ static void ieee80211_do_stop(struct ieee80211_sub_if_data *sdata,
cancel_work_sync(&local->dynamic_ps_enable_work);
cancel_work_sync(&sdata->recalc_smps);
- sdata->vif.csa_active = false;
cancel_work_sync(&sdata->csa_finalize_work);
+ /* free left-over next beacon if a CSA was aborted */
+ if (sdata->vif.csa_active && sdata->vif.type == NL80211_IFTYPE_AP) {
+ kfree(sdata->u.ap.next_beacon);
+ sdata->u.ap.next_beacon = NULL;
+ }
+ sdata->vif.csa_active = false;
cancel_delayed_work_sync(&sdata->dfs_cac_timer_work);
Signed-off-by: Simon Wunderlich <sw@simonwunderlich.de> --- net/mac80211/cfg.c | 5 +++++ net/mac80211/iface.c | 7 ++++++- 2 files changed, 11 insertions(+), 1 deletion(-)