adrian ab03e99258 Refactor and split out the net80211 software scan engine from the rest
of the scan API.

The eventual aim is to have 'ieee80211_scan.c' have the net80211 and
driver facing scan API to start, finish and continue doing scanning
while 'ieee80211_swscan.c' implements the software scanner that
runs the scan task, handles probe request/reply bits, configures
the VAP off-channel, changes channel and does the scanning bits.

For NICs that do no scanning at all, the existing code is needed.
ath(4) and most of the other NICs (dumb USB ones in particular)
do little to no scan offload - it's all done in software.

Some NICs may do single channel at a time scanning; I haven't really
checked them out in detail.

iwn(4), the upcoming 7260 driver stuff, the new Qualcomm Atheros
11ac chipsets and the Atheros mobile/USB full-offload chips all
have complete scan engines in firmware.  We don't have to drive
any of it at all - the firmware just needs to be told what to scan,
when to scan, how long to scan.  It'll take care of going off
channel, pausing TX/RX appropriately, sending sleep notification
to the AP, sending probe requests and handling probe responses.
It'll do passive/active scan itself.  It's almost completely
transparent to the network stack - all we see are scan notifications
when it finishes scanning each channel and beacons/probe responses
when it does its thing.  Once it's done we get a final notification
that the scan is complete, with some scan results in the message.
The iwn(4) NICs handle doing active scanning too as an option
and will handle waiting appropriately on 5GHz passive channels
before active scanning.

There's some more refactoring, tidying up and lock assertions to
sprinkle around to tidy this whole thing up before I turn swscan.c
into another set of ic methods to override by the driver or
alternate scan module.  So in theory this is all one big no-op
commit.  In theory.

Tested:

* iwn(4) 5200, STA mode
* ath(4) 6205, STA mode
* ath(4) - various NICs, AP mode
2015-01-06 02:08:45 +00:00
..
2011-01-06 21:04:00 +00:00
2011-01-06 21:04:00 +00:00
2014-09-17 22:26:01 +00:00
2014-09-17 22:24:51 +00:00
2011-12-30 21:22:10 +00:00
2012-08-15 06:31:32 +00:00
2014-12-19 06:51:01 +00:00
2014-12-31 23:19:16 +00:00
2013-06-04 06:38:01 +00:00
2014-07-07 00:27:09 +00:00
2014-11-07 19:13:19 +00:00
2014-10-20 14:42:42 +00:00
2014-10-09 19:32:35 +00:00
2013-08-03 08:21:35 +00:00
2014-08-28 00:05:02 +00:00
2012-03-30 23:05:48 +00:00
2012-08-15 04:03:55 +00:00
2012-04-21 01:51:16 +00:00
2013-03-03 16:17:09 +00:00
2012-05-01 07:38:40 +00:00
MFC
2013-02-21 21:59:35 +00:00
2014-09-25 14:25:38 +00:00
2012-02-11 08:34:33 +00:00
2014-07-07 00:27:09 +00:00
2014-11-07 20:23:43 +00:00
2014-09-19 10:32:20 +00:00
2012-06-25 09:46:06 +00:00
2014-07-26 17:59:25 +00:00
2014-10-23 04:47:32 +00:00
2012-06-03 12:19:16 +00:00
2012-01-17 18:20:34 +00:00