diff options
| -rw-r--r-- | net/mac80211/sta_info.c | 12 |
1 files changed, 10 insertions, 2 deletions
diff --git a/net/mac80211/sta_info.c b/net/mac80211/sta_info.c index a79ce820cb50..238a0cca320e 100644 --- a/net/mac80211/sta_info.c +++ b/net/mac80211/sta_info.c | |||
| @@ -766,6 +766,7 @@ int __must_check __sta_info_destroy(struct sta_info *sta) | |||
| 766 | struct ieee80211_local *local; | 766 | struct ieee80211_local *local; |
| 767 | struct ieee80211_sub_if_data *sdata; | 767 | struct ieee80211_sub_if_data *sdata; |
| 768 | int ret, i; | 768 | int ret, i; |
| 769 | bool have_key = false; | ||
| 769 | 770 | ||
| 770 | might_sleep(); | 771 | might_sleep(); |
| 771 | 772 | ||
| @@ -793,12 +794,19 @@ int __must_check __sta_info_destroy(struct sta_info *sta) | |||
| 793 | list_del_rcu(&sta->list); | 794 | list_del_rcu(&sta->list); |
| 794 | 795 | ||
| 795 | mutex_lock(&local->key_mtx); | 796 | mutex_lock(&local->key_mtx); |
| 796 | for (i = 0; i < NUM_DEFAULT_KEYS; i++) | 797 | for (i = 0; i < NUM_DEFAULT_KEYS; i++) { |
| 797 | __ieee80211_key_free(key_mtx_dereference(local, sta->gtk[i])); | 798 | __ieee80211_key_free(key_mtx_dereference(local, sta->gtk[i])); |
| 798 | if (sta->ptk) | 799 | have_key = true; |
| 800 | } | ||
| 801 | if (sta->ptk) { | ||
| 799 | __ieee80211_key_free(key_mtx_dereference(local, sta->ptk)); | 802 | __ieee80211_key_free(key_mtx_dereference(local, sta->ptk)); |
| 803 | have_key = true; | ||
| 804 | } | ||
| 800 | mutex_unlock(&local->key_mtx); | 805 | mutex_unlock(&local->key_mtx); |
| 801 | 806 | ||
| 807 | if (!have_key) | ||
| 808 | synchronize_net(); | ||
| 809 | |||
| 802 | sta->dead = true; | 810 | sta->dead = true; |
| 803 | 811 | ||
| 804 | local->num_sta--; | 812 | local->num_sta--; |
