diff options
author | Luis R. Rodriguez <lrodriguez@atheros.com> | 2009-02-21 00:20:39 -0500 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2009-02-27 14:52:59 -0500 |
commit | e38f8a7a8bebbab9d97f204e2cf05ef58b048a1d (patch) | |
tree | 6b0e9f6ce18eb6e2e6d1b29db3538399d0735b70 /net/wireless/reg.h | |
parent | 3fc71f775af677f640f0f0780b16f1b0958f6d9d (diff) |
cfg80211: Add AP beacon regulatory hints
When devices are world roaming they cannot beacon or do active scan
on 5 GHz or on channels 12, 13 and 14 on the 2 GHz band. Although
we have a good regulatory API some cards may _always_ world roam, this
is also true when a system does not have CRDA present. Devices doing world
roaming can still passive scan, if they find a beacon from an AP on
one of the world roaming frequencies we make the assumption we can do
the same and we also remove the passive scan requirement.
This adds support for providing beacon regulatory hints based on scans.
This works for devices that do either hardware or software scanning.
If a channel has not yet been marked as having had a beacon present
on it we queue the beacon hint processing into the workqueue.
All wireless devices will benefit from beacon regulatory hints from
any wireless device on a system including new devices connected to
the system at a later time.
Signed-off-by: Luis R. Rodriguez <lrodriguez@atheros.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'net/wireless/reg.h')
-rw-r--r-- | net/wireless/reg.h | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/net/wireless/reg.h b/net/wireless/reg.h index 4730def5a69d..65bfd0558ce1 100644 --- a/net/wireless/reg.h +++ b/net/wireless/reg.h | |||
@@ -38,4 +38,25 @@ extern int __regulatory_hint(struct wiphy *wiphy, enum reg_set_by set_by, | |||
38 | const char *alpha2, u32 country_ie_checksum, | 38 | const char *alpha2, u32 country_ie_checksum, |
39 | enum environment_cap country_ie_env); | 39 | enum environment_cap country_ie_env); |
40 | 40 | ||
41 | /** | ||
42 | * regulatory_hint_found_beacon - hints a beacon was found on a channel | ||
43 | * @wiphy: the wireless device where the beacon was found on | ||
44 | * @beacon_chan: the channel on which the beacon was found on | ||
45 | * @gfp: context flags | ||
46 | * | ||
47 | * This informs the wireless core that a beacon from an AP was found on | ||
48 | * the channel provided. This allows the wireless core to make educated | ||
49 | * guesses on regulatory to help with world roaming. This is only used for | ||
50 | * world roaming -- when we do not know our current location. This is | ||
51 | * only useful on channels 12, 13 and 14 on the 2 GHz band as channels | ||
52 | * 1-11 are already enabled by the world regulatory domain; and on | ||
53 | * non-radar 5 GHz channels. | ||
54 | * | ||
55 | * Drivers do not need to call this, cfg80211 will do it for after a scan | ||
56 | * on a newly found BSS. | ||
57 | */ | ||
58 | int regulatory_hint_found_beacon(struct wiphy *wiphy, | ||
59 | struct ieee80211_channel *beacon_chan, | ||
60 | gfp_t gfp); | ||
61 | |||
41 | #endif /* __NET_WIRELESS_REG_H */ | 62 | #endif /* __NET_WIRELESS_REG_H */ |