mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-16 05:26:07 +00:00
e38f8a7a8b
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>
63 lines
2.3 KiB
C
63 lines
2.3 KiB
C
#ifndef __NET_WIRELESS_REG_H
|
|
#define __NET_WIRELESS_REG_H
|
|
|
|
extern const struct ieee80211_regdomain *cfg80211_regdomain;
|
|
|
|
bool is_world_regdom(const char *alpha2);
|
|
bool reg_is_valid_request(const char *alpha2);
|
|
|
|
int regulatory_hint_user(const char *alpha2);
|
|
|
|
void reg_device_remove(struct wiphy *wiphy);
|
|
|
|
int regulatory_init(void);
|
|
void regulatory_exit(void);
|
|
|
|
int set_regdom(const struct ieee80211_regdomain *rd);
|
|
|
|
/**
|
|
* __regulatory_hint - hint to the wireless core a regulatory domain
|
|
* @wiphy: if the hint comes from country information from an AP, this
|
|
* is required to be set to the wiphy that received the information
|
|
* @alpha2: the ISO/IEC 3166 alpha2 being claimed the regulatory domain
|
|
* should be in.
|
|
* @country_ie_checksum: checksum of processed country IE, set this to 0
|
|
* if the hint did not come from a country IE
|
|
* @country_ie_env: the environment the IE told us we are in, %ENVIRON_*
|
|
*
|
|
* The Wireless subsystem can use this function to hint to the wireless core
|
|
* what it believes should be the current regulatory domain by giving it an
|
|
* ISO/IEC 3166 alpha2 country code it knows its regulatory domain should be
|
|
* in.
|
|
*
|
|
* Returns zero if all went fine, %-EALREADY if a regulatory domain had
|
|
* already been set or other standard error codes.
|
|
*
|
|
*/
|
|
extern int __regulatory_hint(struct wiphy *wiphy, enum reg_set_by set_by,
|
|
const char *alpha2, u32 country_ie_checksum,
|
|
enum environment_cap country_ie_env);
|
|
|
|
/**
|
|
* regulatory_hint_found_beacon - hints a beacon was found on a channel
|
|
* @wiphy: the wireless device where the beacon was found on
|
|
* @beacon_chan: the channel on which the beacon was found on
|
|
* @gfp: context flags
|
|
*
|
|
* This informs the wireless core that a beacon from an AP was found on
|
|
* the channel provided. This allows the wireless core to make educated
|
|
* guesses on regulatory to help with world roaming. This is only used for
|
|
* world roaming -- when we do not know our current location. This is
|
|
* only useful on channels 12, 13 and 14 on the 2 GHz band as channels
|
|
* 1-11 are already enabled by the world regulatory domain; and on
|
|
* non-radar 5 GHz channels.
|
|
*
|
|
* Drivers do not need to call this, cfg80211 will do it for after a scan
|
|
* on a newly found BSS.
|
|
*/
|
|
int regulatory_hint_found_beacon(struct wiphy *wiphy,
|
|
struct ieee80211_channel *beacon_chan,
|
|
gfp_t gfp);
|
|
|
|
#endif /* __NET_WIRELESS_REG_H */
|