summaryrefslogtreecommitdiffstats
path: root/kernel/sched_fair.c
diff options
context:
space:
mode:
authorJohannes Berg <johannes@sipsolutions.net>2007-09-26 15:19:47 +0200
committerDavid S. Miller <davem@sunset.davemloft.net>2007-10-11 01:53:16 +0200
commit53918994b7c8c3bf0af5f641e1f299856799d883 (patch)
tree63338872613d3c08473acfb46c8a57490f85350b /kernel/sched_fair.c
parent[PATCH] mac80211: fix TKIP IV update (diff)
downloadlinux-53918994b7c8c3bf0af5f641e1f299856799d883.tar.xz
linux-53918994b7c8c3bf0af5f641e1f299856799d883.zip
[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 'kernel/sched_fair.c')
0 files changed, 0 insertions, 0 deletions