From: Johannes Berg Date: Wed, 17 Dec 2014 12:55:49 +0000 (+0100) Subject: mac80211: free management frame keys when removing station X-Git-Url: https://git.stricted.de/?a=commitdiff_plain;h=7c96d282b323a43747c05a4aef52b68267d01cf1;p=GitHub%2FLineageOS%2Fandroid_kernel_samsung_universal7580.git mac80211: free management frame keys when removing station commit 28a9bc68124c319b2b3dc861e80828a8865fd1ba upstream. When writing the code to allow per-station GTKs, I neglected to take into account the management frame keys (index 4 and 5) when freeing the station and only added code to free the first four data frame keys. Fix this by iterating the array of keys over the right length. Fixes: e31b82136d1a ("cfg80211/mac80211: allow per-station GTKs") Signed-off-by: Johannes Berg Signed-off-by: Greg Kroah-Hartman --- diff --git a/net/mac80211/key.c b/net/mac80211/key.c index 67059b88fea..635d0972b68 100644 --- a/net/mac80211/key.c +++ b/net/mac80211/key.c @@ -607,7 +607,7 @@ void ieee80211_free_sta_keys(struct ieee80211_local *local, int i; mutex_lock(&local->key_mtx); - for (i = 0; i < NUM_DEFAULT_KEYS; i++) { + for (i = 0; i < ARRAY_SIZE(sta->gtk); i++) { key = key_mtx_dereference(local, sta->gtk[i]); if (!key) continue;