mac80211: fix a race condition during key deletion
SVN-Revision: 24895
This commit is contained in:
parent
4a177f01a2
commit
8c7ea4384c
1 changed files with 32 additions and 0 deletions
32
package/mac80211/patches/320-mac80211_fix_key_del_race.patch
Normal file
32
package/mac80211/patches/320-mac80211_fix_key_del_race.patch
Normal file
|
@ -0,0 +1,32 @@
|
||||||
|
From: Johannes Berg <johannes.berg@intel.com>
|
||||||
|
|
||||||
|
commit ad0e2b5a00dbec303e4682b403bb6703d11dcdb2
|
||||||
|
Author: Johannes Berg <johannes.berg@intel.com>
|
||||||
|
Date: Tue Jun 1 10:19:19 2010 +0200
|
||||||
|
|
||||||
|
mac80211: simplify key locking
|
||||||
|
|
||||||
|
removed the synchronization against RCU and thus
|
||||||
|
opened a race window where we can use a key for
|
||||||
|
TX while it is already freed. Put a synchronisation
|
||||||
|
into the right place to close that window.
|
||||||
|
|
||||||
|
Reported-by: Jussi Kivilinna <jussi.kivilinna@mbnet.fi>
|
||||||
|
Cc: stable@kernel.org [2.6.36+]
|
||||||
|
Signed-off-by: Johannes Berg <johannes.berg@intel.com>
|
||||||
|
|
||||||
|
--- a/net/mac80211/key.c
|
||||||
|
+++ b/net/mac80211/key.c
|
||||||
|
@@ -382,6 +382,12 @@ static void __ieee80211_key_destroy(stru
|
||||||
|
if (!key)
|
||||||
|
return;
|
||||||
|
|
||||||
|
+ /*
|
||||||
|
+ * Synchronize so the TX path can no longer be using
|
||||||
|
+ * this key before we free/remove it.
|
||||||
|
+ */
|
||||||
|
+ synchronize_rcu();
|
||||||
|
+
|
||||||
|
if (key->local)
|
||||||
|
ieee80211_key_disable_hw_accel(key);
|
||||||
|
|
Loading…
Reference in a new issue