cfg80211: Fix memory leak
When a driver requests a specific regulatory domain after cfg80211 already has one, a struct ieee80211_regdomain is leaked. Reported-by: Larry Finger <Larry.Finger@lwfinger.net> Tested-by: Larry Finger <Larry.Finger@lwfinger.net> Signed-off-by: Larry Finger <Larry.Finger@lwfinger.net> Signed-off-by: Johannes Berg <johannes.berg@intel.com>
This commit is contained in:
parent
78f42aee88
commit
b7566fc363
1 changed files with 7 additions and 2 deletions
|
@ -2189,10 +2189,15 @@ static int __set_regdom(const struct ieee80211_regdomain *rd)
|
|||
* However if a driver requested this specific regulatory
|
||||
* domain we keep it for its private use
|
||||
*/
|
||||
if (lr->initiator == NL80211_REGDOM_SET_BY_DRIVER)
|
||||
if (lr->initiator == NL80211_REGDOM_SET_BY_DRIVER) {
|
||||
const struct ieee80211_regdomain *tmp;
|
||||
|
||||
tmp = get_wiphy_regdom(request_wiphy);
|
||||
rcu_assign_pointer(request_wiphy->regd, rd);
|
||||
else
|
||||
rcu_free_regdom(tmp);
|
||||
} else {
|
||||
kfree(rd);
|
||||
}
|
||||
|
||||
rd = NULL;
|
||||
|
||||
|
|
Loading…
Reference in a new issue