diff options
author | Marek Lindner <lindner_marek@yahoo.de> | 2011-12-20 10:16:52 -0500 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2011-12-21 15:06:12 -0500 |
commit | ec2b774e7c91094d8c00de579646f1162b87b01e (patch) | |
tree | 29000f5c9ee2f2d51c71c392322970ac1f9955bc /net/mac80211/sta_info.c | |
parent | eca107ff8a25e0528d6e6225ac6ce59bd498136f (diff) |
mac80211: ibss should not purge clients it is not responsible for
The IBSS merge code calls ieee80211_sta_expire() with a relatively
short expire timeout that purges other clients prematurely. The
expire function has to check that only the clients belonging to
the vif in question are purged.
Signed-off-by: Marek Lindner <lindner_marek@yahoo.de>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'net/mac80211/sta_info.c')
-rw-r--r-- | net/mac80211/sta_info.c | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/net/mac80211/sta_info.c b/net/mac80211/sta_info.c index 3d01abb2b813..f0d3b483dabd 100644 --- a/net/mac80211/sta_info.c +++ b/net/mac80211/sta_info.c | |||
@@ -946,6 +946,9 @@ void ieee80211_sta_expire(struct ieee80211_sub_if_data *sdata, | |||
946 | 946 | ||
947 | mutex_lock(&local->sta_mtx); | 947 | mutex_lock(&local->sta_mtx); |
948 | list_for_each_entry_safe(sta, tmp, &local->sta_list, list) | 948 | list_for_each_entry_safe(sta, tmp, &local->sta_list, list) |
949 | if (sdata != sta->sdata) | ||
950 | continue; | ||
951 | |||
949 | if (time_after(jiffies, sta->last_rx + exp_time)) { | 952 | if (time_after(jiffies, sta->last_rx + exp_time)) { |
950 | #ifdef CONFIG_MAC80211_IBSS_DEBUG | 953 | #ifdef CONFIG_MAC80211_IBSS_DEBUG |
951 | printk(KERN_DEBUG "%s: expiring inactive STA %pM\n", | 954 | printk(KERN_DEBUG "%s: expiring inactive STA %pM\n", |