aboutsummaryrefslogtreecommitdiffstats
path: root/net
diff options
context:
space:
mode:
authorJohannes Berg <johannes.berg@intel.com>2011-05-12 09:07:15 -0400
committerJohn W. Linville <linville@tuxdriver.com>2011-05-12 14:10:54 -0400
commit8cb231530f03961b55aa4e84e6ead5590bcde04d (patch)
tree62e94c7423bbb073640fe4fe8454ba5135b0ebc8 /net
parent5c0c36412b2dc6b1e243c7e9115306fe286583b7 (diff)
mac80211: fix another key non-race
The code here is only not racy because all the places that assign the pointers it uses are holding the sta_mtx as well as the key_mtx and so can't race against this because this code holds the sta_mtx. But that's not intuitive, so fix it to hold the key_mtx. Signed-off-by: Johannes Berg <johannes.berg@intel.com> Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'net')
-rw-r--r--net/mac80211/sta_info.c6
1 files changed, 4 insertions, 2 deletions
diff --git a/net/mac80211/sta_info.c b/net/mac80211/sta_info.c
index f05244dc773e..cba8309e9ace 100644
--- a/net/mac80211/sta_info.c
+++ b/net/mac80211/sta_info.c
@@ -652,10 +652,12 @@ static int __must_check __sta_info_destroy(struct sta_info *sta)
652 if (ret) 652 if (ret)
653 return ret; 653 return ret;
654 654
655 mutex_lock(&local->key_mtx);
655 for (i = 0; i < NUM_DEFAULT_KEYS; i++) 656 for (i = 0; i < NUM_DEFAULT_KEYS; i++)
656 ieee80211_key_free(local, sta->gtk[i]); 657 __ieee80211_key_free(sta->gtk[i]);
657 if (sta->ptk) 658 if (sta->ptk)
658 ieee80211_key_free(local, sta->ptk); 659 __ieee80211_key_free(sta->ptk);
660 mutex_unlock(&local->key_mtx);
659 661
660 sta->dead = true; 662 sta->dead = true;
661 663