aboutsummaryrefslogtreecommitdiffstats
path: root/net/mac80211/ieee80211_i.h
diff options
context:
space:
mode:
authorJohannes Berg <johannes@sipsolutions.net>2007-09-26 09:19:47 -0400
committerDavid S. Miller <davem@sunset.davemloft.net>2007-10-10 19:53:16 -0400
commit53918994b7c8c3bf0af5f641e1f299856799d883 (patch)
tree63338872613d3c08473acfb46c8a57490f85350b /net/mac80211/ieee80211_i.h
parent50741ae05a4742cae99361f57d84b5f8d33822a4 (diff)
[PATCH] mac80211: fix iff_promiscs, iff_allmultis race
When we update the counters iff_promiscs and iff_allmultis in struct ieee80211_local we have no common lock held to protect them. The problem is that the update to each counter may not be atomic, so we could end up with iff_promiscs == -1 in unfortunate conditions. To fix it, use atomic_t values. It doesn't matter whether the two counters are updated together atomically or not, if there are two invocations of set_multicast_list we will end up with multiple configure_filter() invocations of which the latter will always be correct. Signed-off-by: Johannes Berg <johannes@sipsolutions.net> Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'net/mac80211/ieee80211_i.h')
-rw-r--r--net/mac80211/ieee80211_i.h5
1 files changed, 2 insertions, 3 deletions
diff --git a/net/mac80211/ieee80211_i.h b/net/mac80211/ieee80211_i.h
index 32d19bbf522c..38e0a467fa8e 100644
--- a/net/mac80211/ieee80211_i.h
+++ b/net/mac80211/ieee80211_i.h
@@ -444,9 +444,8 @@ struct ieee80211_local {
444 struct ieee80211_tx_stored_packet pending_packet[NUM_TX_DATA_QUEUES]; 444 struct ieee80211_tx_stored_packet pending_packet[NUM_TX_DATA_QUEUES];
445 struct tasklet_struct tx_pending_tasklet; 445 struct tasklet_struct tx_pending_tasklet;
446 446
447 int mc_count; /* total count of multicast entries in all interfaces */ 447 /* number of interfaces with corresponding IFF_ flags */
448 int iff_allmultis, iff_promiscs; 448 atomic_t iff_allmultis, iff_promiscs;
449 /* number of interfaces with corresponding IFF_ flags */
450 449
451 struct rate_control_ref *rate_ctrl; 450 struct rate_control_ref *rate_ctrl;
452 451