]> err.no Git - linux-2.6/commitdiff
mac80211: always insert key into list
authorJohannes Berg <johannes@sipsolutions.net>
Sat, 1 Mar 2008 18:32:18 +0000 (19:32 +0100)
committerJohn W. Linville <linville@tuxdriver.com>
Thu, 6 Mar 2008 20:30:47 +0000 (15:30 -0500)
Today I hit one of my new WARN_ONs in the mac80211 code because
a key wasn't being freed correctly. After wondering for a while
I finally tracked it to the fact that STA keys aren't added to
the per-sdata key list correctly, they are supposed to always be
on that list, not just for default keys. This patch fixes that.

Signed-off-by: Johannes Berg <johannes@sipsolutions.net>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
net/mac80211/key.c

index 166d0f00d135ea02d8d7c21e33728d26055d665a..f91fb4092652765aa2660695fe99081b85addbab 100644 (file)
@@ -174,6 +174,9 @@ static void __ieee80211_key_replace(struct ieee80211_sub_if_data *sdata,
 {
        int idx, defkey;
 
 {
        int idx, defkey;
 
+       if (new)
+               list_add(&new->list, &sdata->key_list);
+
        if (sta) {
                rcu_assign_pointer(sta->key, new);
        } else {
        if (sta) {
                rcu_assign_pointer(sta->key, new);
        } else {
@@ -190,9 +193,6 @@ static void __ieee80211_key_replace(struct ieee80211_sub_if_data *sdata,
                        ieee80211_set_default_key(sdata, -1);
 
                rcu_assign_pointer(sdata->keys[idx], new);
                        ieee80211_set_default_key(sdata, -1);
 
                rcu_assign_pointer(sdata->keys[idx], new);
-               if (new)
-                       list_add(&new->list, &sdata->key_list);
-
                if (defkey && new)
                        ieee80211_set_default_key(sdata, new->conf.keyidx);
        }
                if (defkey && new)
                        ieee80211_set_default_key(sdata, new->conf.keyidx);
        }