fe8c83f34fb7e8465c9dc8d0804bb04aa58ef928
[linux-3.10.git] / net / wireless / reg.h
1 #ifndef __NET_WIRELESS_REG_H
2 #define __NET_WIRELESS_REG_H
3
4 extern const struct ieee80211_regdomain *cfg80211_regdomain;
5
6 bool is_world_regdom(const char *alpha2);
7 bool reg_is_valid_request(const char *alpha2);
8
9 void reg_device_remove(struct wiphy *wiphy);
10
11 int regulatory_init(void);
12 void regulatory_exit(void);
13
14 int set_regdom(const struct ieee80211_regdomain *rd);
15
16 /**
17  * __regulatory_hint - hint to the wireless core a regulatory domain
18  * @wiphy: if the hint comes from country information from an AP, this
19  *      is required to be set to the wiphy that received the information
20  * @alpha2: the ISO/IEC 3166 alpha2 being claimed the regulatory domain
21  *      should be in.
22  * @country_ie_checksum: checksum of processed country IE, set this to 0
23  *      if the hint did not come from a country IE
24  * @country_ie_env: the environment the IE told us we are in, %ENVIRON_*
25  *
26  * The Wireless subsystem can use this function to hint to the wireless core
27  * what it believes should be the current regulatory domain by giving it an
28  * ISO/IEC 3166 alpha2 country code it knows its regulatory domain should be
29  * in.
30  *
31  * Returns zero if all went fine, %-EALREADY if a regulatory domain had
32  * already been set or other standard error codes.
33  *
34  */
35 extern int __regulatory_hint(struct wiphy *wiphy, enum reg_set_by set_by,
36                              const char *alpha2, u32 country_ie_checksum,
37                              enum environment_cap country_ie_env);
38
39 #endif  /* __NET_WIRELESS_REG_H */