From: Arik Nemtsov Date: Thu, 4 Dec 2014 10:22:16 +0000 (+0200) Subject: cfg80211: avoid mem leak on driver hint set X-Git-Tag: v3.16.35~3235 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=8509cd39be23744fd62b4e4e23302342736c935a;p=thirdparty%2Fkernel%2Fstable.git cfg80211: avoid mem leak on driver hint set commit 34f05f543f02350e920bddb7660ffdd4697aaf60 upstream. In the already-set and intersect case of a driver-hint, the previous wiphy regdomain was not freed before being reset with a copy of the cfg80211 regdomain. Signed-off-by: Arik Nemtsov Acked-by: Luis R. Rodriguez Signed-off-by: Johannes Berg Signed-off-by: Luis Henriques --- diff --git a/net/wireless/reg.c b/net/wireless/reg.c index 1afdf45db38f2..ff7ffeb7947ac 100644 --- a/net/wireless/reg.c +++ b/net/wireless/reg.c @@ -1720,7 +1720,7 @@ static enum reg_request_treatment reg_process_hint_driver(struct wiphy *wiphy, struct regulatory_request *driver_request) { - const struct ieee80211_regdomain *regd; + const struct ieee80211_regdomain *regd, *tmp; enum reg_request_treatment treatment; treatment = __reg_process_hint_driver(driver_request); @@ -1740,7 +1740,10 @@ reg_process_hint_driver(struct wiphy *wiphy, reg_free_request(driver_request); return REG_REQ_IGNORE; } + + tmp = get_wiphy_regdom(wiphy); rcu_assign_pointer(wiphy->regd, regd); + rcu_free_regdom(tmp); }