diff options
author | Michal Kazior <michal.kazior@tieto.com> | 2014-01-29 01:56:18 -0500 |
---|---|---|
committer | Johannes Berg <johannes.berg@intel.com> | 2014-02-04 15:58:09 -0500 |
commit | 97518af1260553d2cad71b37a76b597360519e8a (patch) | |
tree | 659dff2c80ead09ddb4c72a7bc67906d0a0e9a61 /net/mac80211/cfg.c | |
parent | faf046e7231bf008715bbffe5cca2ed3aa31be1b (diff) |
mac80211: fix possible memory leak on AP CSA failure
If CSA for AP interface failed and the interface
was not stopped afterwards another CSA request
would leak sdata->u.ap.next_beacon.
Signed-off-by: Michal Kazior <michal.kazior@tieto.com>
Reviewed-by: Luciano Coelho <luciano.coelho@intel.com>
Signed-off-by: Johannes Berg <johannes.berg@intel.com>
Diffstat (limited to 'net/mac80211/cfg.c')
-rw-r--r-- | net/mac80211/cfg.c | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/net/mac80211/cfg.c b/net/mac80211/cfg.c index f215ad48985a..b98dc8ce8e25 100644 --- a/net/mac80211/cfg.c +++ b/net/mac80211/cfg.c | |||
@@ -3018,11 +3018,12 @@ static void ieee80211_csa_finalize(struct ieee80211_sub_if_data *sdata) | |||
3018 | switch (sdata->vif.type) { | 3018 | switch (sdata->vif.type) { |
3019 | case NL80211_IFTYPE_AP: | 3019 | case NL80211_IFTYPE_AP: |
3020 | err = ieee80211_assign_beacon(sdata, sdata->u.ap.next_beacon); | 3020 | err = ieee80211_assign_beacon(sdata, sdata->u.ap.next_beacon); |
3021 | kfree(sdata->u.ap.next_beacon); | ||
3022 | sdata->u.ap.next_beacon = NULL; | ||
3023 | |||
3021 | if (err < 0) | 3024 | if (err < 0) |
3022 | return; | 3025 | return; |
3023 | changed |= err; | 3026 | changed |= err; |
3024 | kfree(sdata->u.ap.next_beacon); | ||
3025 | sdata->u.ap.next_beacon = NULL; | ||
3026 | break; | 3027 | break; |
3027 | case NL80211_IFTYPE_ADHOC: | 3028 | case NL80211_IFTYPE_ADHOC: |
3028 | err = ieee80211_ibss_finish_csa(sdata); | 3029 | err = ieee80211_ibss_finish_csa(sdata); |