b43: Fix locking FIXME in beacon update top half
authorMichael Büsch <m@bues.ch>
Mon, 26 Jan 2015 17:26:17 +0000 (18:26 +0100)
committerKalle Valo <kvalo@codeaurora.org>
Thu, 29 Jan 2015 08:28:05 +0000 (10:28 +0200)
commita75d46a4f405eb19ff780410b968c8092af3fb1d
tree0d8bbcae8f9d324ce1aa365a0a1333c9bb906142
parentcf075eac9ca94ec54b5ae0c0ec798839f962be55
b43: Fix locking FIXME in beacon update top half

b43 has a FIXME about locking in the mac80211 set-beacon-int callback for a long time.
As it turns out there actually is a tiny race window that could result in
a use-after-free bug of the 'current_beacon' memory.
Nobody ever reported this, so it probably never happened.

Fix this by adding a spin lock that protects the current_beacon access.
We must not be in atomic context while accessing hardware (due to SDIO),
so the beacon update bottom half has to clone the skb and release the lock
before writing it to hardware.

Let's all hope that this stops the troll who is trying to submit incorrect
fixes for this issue repeatedly.
And let's hope that I'm not a troll, too, who just hides even more evil code
in an even more complex attempt to fix the issue.

Signed-off-by: Michael Buesch <m@bues.ch>
Tested-by: Larry Finger <Larry.Finger@lwfinger.net>
Signed-off-by: Kalle Valo <kvalo@codeaurora.org>
drivers/net/wireless/b43/b43.h
drivers/net/wireless/b43/main.c