From: Ben Greear <greearb@xxxxxxxxxxxxxxx> This allows a user to configure a wifi station interface to disable 802.11n, even if the AP and NIC supports it. The additional netlink bits is to allow this patch to work on 3.0 and should not be included in the final patch. Signed-off-by: Ben Greear <greearb@xxxxxxxxxxxxxxx> --- :100644 100644 8049bf7... d9c2cdb... M include/linux/nl80211.h :100644 100644 92cf1c2... 1331a5b... M include/net/cfg80211.h :100644 100644 e253afa... 8221a3a... M net/mac80211/cfg.c :100644 100644 4c3d1f5... 72c6726... M net/mac80211/ieee80211_i.h :100644 100644 0e5d8da... 393b480... M net/mac80211/mlme.c :100644 100644 48260c2... cb2eb67... M net/wireless/nl80211.c include/linux/nl80211.h | 4 ++++ include/net/cfg80211.h | 4 +++- net/mac80211/cfg.c | 3 +++ net/mac80211/ieee80211_i.h | 2 ++ net/mac80211/mlme.c | 3 +++ net/wireless/nl80211.c | 7 +++++++ 6 files changed, 22 insertions(+), 1 deletions(-) diff --git a/include/linux/nl80211.h b/include/linux/nl80211.h index 8049bf7..d9c2cdb 100644 --- a/include/linux/nl80211.h +++ b/include/linux/nl80211.h @@ -1109,6 +1109,9 @@ enum nl80211_commands { * %NL80211_CMD_TDLS_MGMT. Otherwise %NL80211_CMD_TDLS_OPER should be * used for asking the driver to perform a TDLS operation. * + * @NL80211_ATTR_DISABLE_80211N: Force /n capable stations to instead + * function as /a/b/g stations. + * * @NL80211_ATTR_MAX: highest attribute number currently defined * @__NL80211_ATTR_AFTER_LAST: internal use */ @@ -1337,6 +1340,7 @@ enum nl80211_attrs { NL80211_ATTR_TDLS_SUPPORT, NL80211_ATTR_TDLS_EXTERNAL_SETUP, + NL80211_ATTR_DISABLE_11N, /* add attributes here, update the policy in nl80211.c */ __NL80211_ATTR_AFTER_LAST, diff --git a/include/net/cfg80211.h b/include/net/cfg80211.h index 92cf1c2..1331a5b 100644 --- a/include/net/cfg80211.h +++ b/include/net/cfg80211.h @@ -254,9 +254,11 @@ struct ieee80211_supported_band { /** * struct vif_params - describes virtual interface parameters * @use_4addr: use 4-address frames + * @disable_11n: Don't use 11n features (HT, etc) */ struct vif_params { - int use_4addr; + int use_4addr; + int disable_11n; }; /** diff --git a/net/mac80211/cfg.c b/net/mac80211/cfg.c index e253afa..8221a3a 100644 --- a/net/mac80211/cfg.c +++ b/net/mac80211/cfg.c @@ -57,6 +57,9 @@ static int ieee80211_change_iface(struct wiphy *wiphy, struct ieee80211_sub_if_data *sdata = IEEE80211_DEV_TO_SUB_IF(dev); int ret; + if (params->disable_11n != -1) + sdata->cfg_disable_11n = params->disable_11n; + ret = ieee80211_if_change_type(sdata, type); if (ret) return ret; diff --git a/net/mac80211/ieee80211_i.h b/net/mac80211/ieee80211_i.h index 4c3d1f5..72c6726 100644 --- a/net/mac80211/ieee80211_i.h +++ b/net/mac80211/ieee80211_i.h @@ -595,6 +595,8 @@ struct ieee80211_sub_if_data { /* to detect idle changes */ bool old_idle; + bool cfg_disable_11n; /* configured to disable 11n? */ + /* Fragment table for host-based reassembly */ struct ieee80211_fragment_entry fragments[IEEE80211_FRAGMENT_MAX]; unsigned int fragment_next; diff --git a/net/mac80211/mlme.c b/net/mac80211/mlme.c index 0e5d8da..393b480 100644 --- a/net/mac80211/mlme.c +++ b/net/mac80211/mlme.c @@ -2597,6 +2597,9 @@ int ieee80211_mgd_assoc(struct ieee80211_sub_if_data *sdata, ifmgd->flags |= IEEE80211_STA_DISABLE_11N; + if (sdata->cfg_disable_11n) + ifmgd->flags |= IEEE80211_STA_DISABLE_11N; + if (req->ie && req->ie_len) { memcpy(wk->ie, req->ie, req->ie_len); wk->ie_len = req->ie_len; diff --git a/net/wireless/nl80211.c b/net/wireless/nl80211.c index 48260c2..cb2eb67 100644 --- a/net/wireless/nl80211.c +++ b/net/wireless/nl80211.c @@ -1641,6 +1641,13 @@ static int nl80211_set_interface(struct sk_buff *skb, struct genl_info *info) change = true; } + if (info->attrs[NL80211_ATTR_DISABLE_11N]) { + params.disable_11n = !!nla_get_u8(info->attrs[NL80211_ATTR_DISABLE_11N]); + change = true; + } else { + params.disable_11n = -1; + } + if (change) err = cfg80211_change_iface(rdev, dev, ntype, flags, ¶ms); else -- 1.7.3.4 -- To unsubscribe from this list: send the line "unsubscribe linux-wireless" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html