mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-11 07:39:47 +00:00
b2e1b30290
This adds the new wireless regulatory infrastructure. The main motiviation behind this was to centralize regulatory code as each driver was implementing their own regulatory solution, and to replace the initial centralized code we have where: * only 3 regulatory domains are supported: US, JP and EU * regulatory domains can only be changed through module parameter * all rules were built statically in the kernel We now have support for regulatory domains for many countries and regulatory domains are now queried through a userspace agent through udev allowing distributions to update regulatory rules without updating the kernel. Each driver can regulatory_hint() a regulatory domain based on either their EEPROM mapped regulatory domain value to a respective ISO/IEC 3166-1 country code or pass an internally built regulatory domain. We also add support to let the user set the regulatory domain through userspace in case of faulty EEPROMs to further help compliance. Support for world roaming will be added soon for cards capable of this. For more information see: http://wireless.kernel.org/en/developers/Regulatory/CRDA For now we leave an option to enable the old module parameter, ieee80211_regdom, and to build the 3 old regdomains statically (US, JP and EU). This option is CONFIG_WIRELESS_OLD_REGULATORY. These old static definitions and the module parameter is being scheduled for removal for 2.6.29. Note that if you use this you won't make use of a world regulatory domain as its pointless. If you leave this option enabled and if CRDA is present and you use US or JP we will try to ask CRDA to update us a regulatory domain for us. Signed-off-by: Luis R. Rodriguez <lrodriguez@atheros.com> Signed-off-by: John W. Linville <linville@tuxdriver.com>
85 lines
2.5 KiB
C
85 lines
2.5 KiB
C
/*
|
|
* Wireless configuration interface internals.
|
|
*
|
|
* Copyright 2006, 2007 Johannes Berg <johannes@sipsolutions.net>
|
|
*/
|
|
#ifndef __NET_WIRELESS_CORE_H
|
|
#define __NET_WIRELESS_CORE_H
|
|
#include <linux/mutex.h>
|
|
#include <linux/list.h>
|
|
#include <linux/netdevice.h>
|
|
#include <net/genetlink.h>
|
|
#include <net/wireless.h>
|
|
#include <net/cfg80211.h>
|
|
|
|
struct cfg80211_registered_device {
|
|
struct cfg80211_ops *ops;
|
|
struct list_head list;
|
|
/* we hold this mutex during any call so that
|
|
* we cannot do multiple calls at once, and also
|
|
* to avoid the deregister call to proceed while
|
|
* any call is in progress */
|
|
struct mutex mtx;
|
|
|
|
/* wiphy index, internal only */
|
|
int idx;
|
|
|
|
/* associate netdev list */
|
|
struct mutex devlist_mtx;
|
|
struct list_head netdev_list;
|
|
|
|
/* must be last because of the way we do wiphy_priv(),
|
|
* and it should at least be aligned to NETDEV_ALIGN */
|
|
struct wiphy wiphy __attribute__((__aligned__(NETDEV_ALIGN)));
|
|
};
|
|
|
|
static inline
|
|
struct cfg80211_registered_device *wiphy_to_dev(struct wiphy *wiphy)
|
|
{
|
|
BUG_ON(!wiphy);
|
|
return container_of(wiphy, struct cfg80211_registered_device, wiphy);
|
|
}
|
|
|
|
extern struct mutex cfg80211_drv_mutex;
|
|
extern struct list_head cfg80211_drv_list;
|
|
|
|
/*
|
|
* This function returns a pointer to the driver
|
|
* that the genl_info item that is passed refers to.
|
|
* If successful, it returns non-NULL and also locks
|
|
* the driver's mutex!
|
|
*
|
|
* This means that you need to call cfg80211_put_dev()
|
|
* before being allowed to acquire &cfg80211_drv_mutex!
|
|
*
|
|
* This is necessary because we need to lock the global
|
|
* mutex to get an item off the list safely, and then
|
|
* we lock the drv mutex so it doesn't go away under us.
|
|
*
|
|
* We don't want to keep cfg80211_drv_mutex locked
|
|
* for all the time in order to allow requests on
|
|
* other interfaces to go through at the same time.
|
|
*
|
|
* The result of this can be a PTR_ERR and hence must
|
|
* be checked with IS_ERR() for errors.
|
|
*/
|
|
extern struct cfg80211_registered_device *
|
|
cfg80211_get_dev_from_info(struct genl_info *info);
|
|
|
|
/* identical to cfg80211_get_dev_from_info but only operate on ifindex */
|
|
extern struct cfg80211_registered_device *
|
|
cfg80211_get_dev_from_ifindex(int ifindex);
|
|
|
|
extern void cfg80211_put_dev(struct cfg80211_registered_device *drv);
|
|
|
|
/* free object */
|
|
extern void cfg80211_dev_free(struct cfg80211_registered_device *drv);
|
|
|
|
extern int cfg80211_dev_rename(struct cfg80211_registered_device *drv,
|
|
char *newname);
|
|
|
|
void ieee80211_set_bitrate_flags(struct wiphy *wiphy);
|
|
void wiphy_update_regulatory(struct wiphy *wiphy, enum reg_set_by setby);
|
|
|
|
#endif /* __NET_WIRELESS_CORE_H */
|