summaryrefslogtreecommitdiff
path: root/drivers/mcb/mcb-core.c
diff options
context:
space:
mode:
authorJohannes Berg <johannes.berg@intel.com>2017-02-27 11:38:11 +0300
committerJohannes Berg <johannes.berg@intel.com>2017-02-28 09:42:05 +0300
commit19d19e960598161be92a7e4828eb7706c6410ce6 (patch)
tree883afa1a2e507d58d32c5340b73a3fb2be40d574 /drivers/mcb/mcb-core.c
parentff4dd73dd2b4806419f8ff65cbce11d5019548d0 (diff)
downloadlinux-19d19e960598161be92a7e4828eb7706c6410ce6.tar.xz
mac80211: use driver-indicated transmitter STA only for data frames
When I originally introduced using the driver-indicated station as an optimisation to avoid the hashtable lookup/iteration, of course it wasn't intended to really functionally change anything. I neglected, however, to take into account VLAN interfaces, which have the property that management and data frames are handled differently: data frames go directly to the station and the VLAN while management frames continue to be processed over the underlying/associated AP-type interface. As a consequence, when a driver used this optimisation for management frames and the user enabled VLANs, my change broke things since any management frames, particularly disassoc/deauth, were missed by hostapd. Fix this by restoring the original code path for non-data frames, they aren't critical for performance to begin with. This fixes https://bugzilla.kernel.org/show_bug.cgi?id=194713. Big thanks goes to Jarek who bisected the issue and provided a very detailed bug report, including the crucial information that he was using VLANs in his configuration. Cc: stable@vger.kernel.org Fixes: 771e846bea9e ("mac80211: allow passing transmitter station on RX") Reported-and-tested-by: Jarek KamiƄski <jarek@freeside.be> Signed-off-by: Johannes Berg <johannes.berg@intel.com>
Diffstat (limited to 'drivers/mcb/mcb-core.c')
0 files changed, 0 insertions, 0 deletions