aboutsummaryrefslogtreecommitdiffstats
path: root/net/mac80211/key.c
diff options
context:
space:
mode:
authorJohannes Berg <johannes.berg@intel.com>2011-05-12 08:31:49 -0400
committerJohn W. Linville <linville@tuxdriver.com>2011-05-12 14:10:53 -0400
commit5c0c36412b2dc6b1e243c7e9115306fe286583b7 (patch)
treea189957b3a8e939d19da304541ba087f1264085a /net/mac80211/key.c
parentdea4096bc41a9642039840ced91e585d04883a16 (diff)
mac80211: make key locking clearer
The code in ieee80211_del_key() doesn't acquire the key_mtx properly when it dereferences the keys. It turns out that isn't actually necessary since the key_mtx itself seems to be redundant since all key manipulations are done under the RTNL, but as long as we have the key_mtx we should use it the right way too. Signed-off-by: Johannes Berg <johannes.berg@intel.com> Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'net/mac80211/key.c')
-rw-r--r--net/mac80211/key.c8
1 files changed, 4 insertions, 4 deletions
diff --git a/net/mac80211/key.c b/net/mac80211/key.c
index b510721e3b3d..958832dd4f0a 100644
--- a/net/mac80211/key.c
+++ b/net/mac80211/key.c
@@ -471,8 +471,11 @@ int ieee80211_key_link(struct ieee80211_key *key,
471 return ret; 471 return ret;
472} 472}
473 473
474static void __ieee80211_key_free(struct ieee80211_key *key) 474void __ieee80211_key_free(struct ieee80211_key *key)
475{ 475{
476 if (!key)
477 return;
478
476 /* 479 /*
477 * Replace key with nothingness if it was ever used. 480 * Replace key with nothingness if it was ever used.
478 */ 481 */
@@ -486,9 +489,6 @@ static void __ieee80211_key_free(struct ieee80211_key *key)
486void ieee80211_key_free(struct ieee80211_local *local, 489void ieee80211_key_free(struct ieee80211_local *local,
487 struct ieee80211_key *key) 490 struct ieee80211_key *key)
488{ 491{
489 if (!key)
490 return;
491
492 mutex_lock(&local->key_mtx); 492 mutex_lock(&local->key_mtx);
493 __ieee80211_key_free(key); 493 __ieee80211_key_free(key);
494 mutex_unlock(&local->key_mtx); 494 mutex_unlock(&local->key_mtx);