From: Johannes Berg <johannes@sipsolutions.net>
To: "Luis R. Rodriguez" <lrodriguez@atheros.com>
Cc: linux-wireless@vger.kernel.org
Subject: Re: [PATCH v2 3/3] cfg80211: enable country IE support to all cfg80211 drivers
Date: Thu, 30 Jul 2009 19:28:25 +0200 [thread overview]
Message-ID: <1248974905.23496.2.camel@johannes.local> (raw)
In-Reply-To: <1248974386-8168-4-git-send-email-lrodriguez@atheros.com>
[-- Attachment #1: Type: text/plain, Size: 5192 bytes --]
On Thu, 2009-07-30 at 10:19 -0700, Luis R. Rodriguez wrote:
> Since the bss is always set now once we are connected, if the
> bss has its own information element we refer to it and pass that
> instead of relying on mac80211's parsing.
>
> Now all cfg80211 drivers get country IE support, automatically.
Cool, thanks.
Acked-by: Johannes Berg <johannes@sipsolutions.net>
>
> Signed-off-by: Luis R. Rodriguez <lrodriguez@atheros.com>
> ---
> include/net/cfg80211.h | 14 --------------
> net/mac80211/mlme.c | 6 +-----
> net/wireless/reg.c | 1 -
> net/wireless/reg.h | 15 +++++++++++++++
> net/wireless/sme.c | 16 ++++++++++++++++
> 5 files changed, 32 insertions(+), 20 deletions(-)
>
> diff --git a/include/net/cfg80211.h b/include/net/cfg80211.h
> index e1b9235..fa72997 100644
> --- a/include/net/cfg80211.h
> +++ b/include/net/cfg80211.h
> @@ -1514,20 +1514,6 @@ unsigned int cfg80211_classify8021d(struct sk_buff *skb);
> extern int regulatory_hint(struct wiphy *wiphy, const char *alpha2);
>
> /**
> - * regulatory_hint_11d - hints a country IE as a regulatory domain
> - * @wiphy: the wireless device giving the hint (used only for reporting
> - * conflicts)
> - * @country_ie: pointer to the country IE
> - * @country_ie_len: length of the country IE
> - *
> - * We will intersect the rd with the what CRDA tells us should apply
> - * for the alpha2 this country IE belongs to, this prevents APs from
> - * sending us incorrect or outdated information against a country.
> - */
> -extern void regulatory_hint_11d(struct wiphy *wiphy,
> - u8 *country_ie,
> - u8 country_ie_len);
> -/**
> * wiphy_apply_custom_regulatory - apply a custom driver regulatory domain
> * @wiphy: the wireless device we want to process the regulatory domain on
> * @regd: the custom regulatory domain to use for this wiphy
> diff --git a/net/mac80211/mlme.c b/net/mac80211/mlme.c
> index 0779ba1..5ff1496 100644
> --- a/net/mac80211/mlme.c
> +++ b/net/mac80211/mlme.c
> @@ -1846,12 +1846,8 @@ static void ieee80211_rx_mgmt_beacon(struct ieee80211_sub_if_data *sdata,
> bssid, ap_ht_cap_flags);
> }
>
> + /* Note: country IE parsing is done for us by cfg80211 */
> if (elems.country_elem) {
> - /* Note we are only reviewing this on beacons
> - * for the BSSID we are associated to */
> - regulatory_hint_11d(local->hw.wiphy,
> - elems.country_elem, elems.country_elem_len);
> -
> /* TODO: IBSS also needs this */
> if (elems.pwr_constr_elem)
> ieee80211_handle_pwr_constr(sdata,
> diff --git a/net/wireless/reg.c b/net/wireless/reg.c
> index 14e0c87..06abd7a 100644
> --- a/net/wireless/reg.c
> +++ b/net/wireless/reg.c
> @@ -1911,7 +1911,6 @@ free_rd_out:
> out:
> mutex_unlock(®_mutex);
> }
> -EXPORT_SYMBOL(regulatory_hint_11d);
>
> static bool freq_is_chan_12_13_14(u16 freq)
> {
> diff --git a/net/wireless/reg.h b/net/wireless/reg.h
> index e37829a..662a9da 100644
> --- a/net/wireless/reg.h
> +++ b/net/wireless/reg.h
> @@ -36,4 +36,19 @@ int regulatory_hint_found_beacon(struct wiphy *wiphy,
> struct ieee80211_channel *beacon_chan,
> gfp_t gfp);
>
> +/**
> + * regulatory_hint_11d - hints a country IE as a regulatory domain
> + * @wiphy: the wireless device giving the hint (used only for reporting
> + * conflicts)
> + * @country_ie: pointer to the country IE
> + * @country_ie_len: length of the country IE
> + *
> + * We will intersect the rd with the what CRDA tells us should apply
> + * for the alpha2 this country IE belongs to, this prevents APs from
> + * sending us incorrect or outdated information against a country.
> + */
> +void regulatory_hint_11d(struct wiphy *wiphy,
> + u8 *country_ie,
> + u8 country_ie_len);
> +
> #endif /* __NET_WIRELESS_REG_H */
> diff --git a/net/wireless/sme.c b/net/wireless/sme.c
> index 3728d2b..bc0fb7d 100644
> --- a/net/wireless/sme.c
> +++ b/net/wireless/sme.c
> @@ -13,6 +13,7 @@
> #include <net/cfg80211.h>
> #include <net/rtnetlink.h>
> #include "nl80211.h"
> +#include "reg.h"
>
> struct cfg80211_conn {
> struct cfg80211_connect_params params;
> @@ -320,6 +321,7 @@ void __cfg80211_connect_result(struct net_device *dev, const u8 *bssid,
> struct cfg80211_bss *bss)
> {
> struct wireless_dev *wdev = dev->ieee80211_ptr;
> + u8 *country_ie;
> #ifdef CONFIG_WIRELESS_EXT
> union iwreq_data wrqu;
> #endif
> @@ -401,6 +403,20 @@ void __cfg80211_connect_result(struct net_device *dev, const u8 *bssid,
>
> wdev->sme_state = CFG80211_SME_CONNECTED;
> cfg80211_upload_connect_keys(wdev);
> +
> + country_ie = (u8 *) ieee80211_bss_get_ie(bss, WLAN_EID_COUNTRY);
> +
> + if (!country_ie)
> + return;
> +
> + /*
> + * ieee80211_bss_get()_ie ensures we can access:
> + * - country_ie + 2, the start of the country ie data, and
> + * - and country_ie[1] which is the IE length
> + */
> + regulatory_hint_11d(wdev->wiphy,
> + country_ie + 2,
> + country_ie[1]);
> }
>
> void cfg80211_connect_result(struct net_device *dev, const u8 *bssid,
[-- Attachment #2: This is a digitally signed message part --]
[-- Type: application/pgp-signature, Size: 801 bytes --]
next prev parent reply other threads:[~2009-07-30 17:29 UTC|newest]
Thread overview: 9+ messages / expand[flat|nested] mbox.gz Atom feed top
2009-07-30 17:19 [PATCH v2 0/3] wireless: fix 11d lockdep and move 11d hint to cfg80211 Luis R. Rodriguez
2009-07-30 17:19 ` [PATCH v2 1/3] cfg80211: use goto out on 11d reg hint failure Luis R. Rodriguez
2009-07-30 17:27 ` Johannes Berg
2009-07-30 17:19 ` [PATCH v2 2/3] cfg80211: decouple regulatory variables from cfg80211_mutex Luis R. Rodriguez
2009-07-30 17:28 ` Johannes Berg
2009-07-30 17:19 ` [PATCH v2 3/3] cfg80211: enable country IE support to all cfg80211 drivers Luis R. Rodriguez
2009-07-30 17:28 ` Johannes Berg [this message]
2009-07-30 20:59 ` [PATCH v2 0/3] wireless: fix 11d lockdep and move 11d hint to cfg80211 Luis R. Rodriguez
-- strict thread matches above, loose matches on Subject: below --
2009-07-30 17:22 Luis R. Rodriguez
2009-07-30 17:22 ` [PATCH v2 3/3] cfg80211: enable country IE support to all cfg80211 drivers Luis R. Rodriguez
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1248974905.23496.2.camel@johannes.local \
--to=johannes@sipsolutions.net \
--cc=linux-wireless@vger.kernel.org \
--cc=lrodriguez@atheros.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox