cfg80211: fix memory leak of new_ie

new_ie is used as a temporary storage for the generation of
the new elements. However, after copying from it the memory
wasn't freed and leaked. Free it.

Signed-off-by: Sara Sharon <sara.sharon@intel.com>
Signed-off-by: Johannes Berg <johannes.berg@intel.com>
This commit is contained in:
Sara Sharon 2019-01-30 08:48:21 +02:00 committed by Johannes Berg
parent c17fe043a3
commit bede8d2996

View File

@ -1576,10 +1576,8 @@ cfg80211_update_notlisted_nontrans(struct wiphy *wiphy,
if (!new_ie) if (!new_ie)
return; return;
new_ies = kzalloc(sizeof(*new_ies) + new_ie_len, gfp); new_ies = kzalloc(sizeof(*new_ies) + new_ie_len, gfp);
if (!new_ies) { if (!new_ies)
kfree(new_ie); goto out_free;
return;
}
pos = new_ie; pos = new_ie;
@ -1613,6 +1611,9 @@ cfg80211_update_notlisted_nontrans(struct wiphy *wiphy,
if (old) if (old)
kfree_rcu((struct cfg80211_bss_ies *)old, rcu_head); kfree_rcu((struct cfg80211_bss_ies *)old, rcu_head);
} }
out_free:
kfree(new_ie);
} }
/* cfg80211_inform_bss_width_frame helper */ /* cfg80211_inform_bss_width_frame helper */