On Mon, 2009-03-16 at 10:57 +0200, Jouni Malinen wrote: > On Sun, Mar 15, 2009 at 10:07:39PM +0200, Kalle Valo wrote: > > ieee80211_tx_h_check_assoc() was dropping everything else than probe > > requests during software scan. So the null frame with the power save > > bit was dropped and AP never received it. This meant that AP never > > buffered any frames for the station during software scan. > > > > Fix this by allowing to transmit both probe request and null frames > > during software scan. Tested with stlc45xx. > > I would assume the nullfunc frames are sent only just before the scan > and just after the scan, not really "during" the scan. Or am I missing > something here? Correct, but if we wanted to do this properly we'd have to iterate the list twice and generally make the scan start code quite a bit more complex. I don't think it's worth it, since we _should_ control quite tightly what we're sending during scan. > > if (unlikely(tx->local->sw_scanning) && > > - !ieee80211_is_probe_req(hdr->frame_control)) > > + !ieee80211_is_probe_req(hdr->frame_control) && > > + !ieee80211_is_nullfunc(hdr->frame_control)) > > + /* > > + * When software scanning only null frames (to notify the > > + * sleep state to the AP) and probe requests (for the > > + * active scan) are allowed, everything else should be > > + * dropped. > > + */ > > return TX_DROP; > > While this is probably the easiest way of fixing the issue you are > seeing, the more correct operation would be to allow nullfunc frames > only at the beginning and end of the scan operation, not during it, > i.e., there is no point allowing those frames to go out when we are not > on our operational channel. I would hope we do not currently send those > frames at such time, so this should not matter much, but the comment > could be made more clear about the different needs for nullfunc frames > (please also s/null frames/nullfunc frames/) and probe request frames. > The former are sent only on the operational channel in the beginning and > end of scan while the latter are sent on the channels to be scanned > during an active scan. The other thing is -- we shouldn't ever actually run into this code dropping frames at all. Or rather, we should find a way to avoid it. You have to realise that when the quoted piece of code executes for frames other than nullfunc/preq frames, all is lost already! That means we've had so many frames on the queues that we have frames stuck on the software queues, and we'll start sending them while on the wrong channel... The proper way to fix this involves stopping the software queues, flushing the the driver/hardware queues, and only _then_ leaving the operational channel. Broadcom firmware will reject off-channel transmissions (if set up correctly), but even that is not really desirable here because it means we lose the packets too. Once scanning starts, we have to start the voice queue again, of course, and because it might contain frames still we should change the code above to queue up the frames internally instead of simply dropping them. If anyone wants to do anything about it, I would ask to wait for my pending frames rework though, since that will make the last part simpler and would most likely clash with any work done here. Drivers implementing hw_scan are not affected, of course, if they do things correctly. Which is probably only iwlwifi with its firmware assisted scanning. johannes
Attachment:
signature.asc
Description: This is a digitally signed message part