reg.h 1.4 KB

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