diff options
author | Ashok Nagarajan <ashok@cozybit.com> | 2012-04-30 17:20:32 -0400 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2012-05-08 21:53:59 -0400 |
commit | 70c33eaae79e53f9e48324736c0cb85534d3f093 (patch) | |
tree | 103c59d0356e55341052adca0624b6256525ddbb /net/mac80211 | |
parent | b91e64aad2c78b0477b9eb3a26335668b4032002 (diff) |
{nl,cfg,mac}80211: Allow user to see/configure HT protection mode
This patch introduces a new mesh configuration parameter "ht_opmode" and will
allow user to check the current HT protection mode selected. Users could
configure the protection mode by the command "iw mesh_iface set mesh_param
mesh_ht_protection_mode=2". The default protection mode of mesh is set to
non-HT mixed mode.
Signed-off-by: Ashok Nagarajan <ashok@cozybit.com>
Reviewed-by: Thomas Pedersen <thomas@cozybit.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'net/mac80211')
-rw-r--r-- | net/mac80211/cfg.c | 5 | ||||
-rw-r--r-- | net/mac80211/mesh.c | 3 | ||||
-rw-r--r-- | net/mac80211/mesh_plink.c | 1 |
3 files changed, 9 insertions, 0 deletions
diff --git a/net/mac80211/cfg.c b/net/mac80211/cfg.c index 39b1fffb24f4..0221270c0ddf 100644 --- a/net/mac80211/cfg.c +++ b/net/mac80211/cfg.c | |||
@@ -1538,6 +1538,11 @@ static int ieee80211_update_mesh_config(struct wiphy *wiphy, | |||
1538 | return -ENOTSUPP; | 1538 | return -ENOTSUPP; |
1539 | conf->rssi_threshold = nconf->rssi_threshold; | 1539 | conf->rssi_threshold = nconf->rssi_threshold; |
1540 | } | 1540 | } |
1541 | if (_chg_mesh_attr(NL80211_MESHCONF_HT_OPMODE, mask)) { | ||
1542 | conf->ht_opmode = nconf->ht_opmode; | ||
1543 | sdata->vif.bss_conf.ht_operation_mode = nconf->ht_opmode; | ||
1544 | ieee80211_bss_info_change_notify(sdata, BSS_CHANGED_HT); | ||
1545 | } | ||
1541 | return 0; | 1546 | return 0; |
1542 | } | 1547 | } |
1543 | 1548 | ||
diff --git a/net/mac80211/mesh.c b/net/mac80211/mesh.c index 0fabb8bae9fb..0a21e4e55f43 100644 --- a/net/mac80211/mesh.c +++ b/net/mac80211/mesh.c | |||
@@ -595,12 +595,15 @@ void ieee80211_start_mesh(struct ieee80211_sub_if_data *sdata) | |||
595 | set_bit(MESH_WORK_HOUSEKEEPING, &ifmsh->wrkq_flags); | 595 | set_bit(MESH_WORK_HOUSEKEEPING, &ifmsh->wrkq_flags); |
596 | ieee80211_mesh_root_setup(ifmsh); | 596 | ieee80211_mesh_root_setup(ifmsh); |
597 | ieee80211_queue_work(&local->hw, &sdata->work); | 597 | ieee80211_queue_work(&local->hw, &sdata->work); |
598 | sdata->vif.bss_conf.ht_operation_mode = | ||
599 | ifmsh->mshcfg.ht_opmode; | ||
598 | sdata->vif.bss_conf.beacon_int = MESH_DEFAULT_BEACON_INTERVAL; | 600 | sdata->vif.bss_conf.beacon_int = MESH_DEFAULT_BEACON_INTERVAL; |
599 | sdata->vif.bss_conf.basic_rates = | 601 | sdata->vif.bss_conf.basic_rates = |
600 | ieee80211_mandatory_rates(sdata->local, | 602 | ieee80211_mandatory_rates(sdata->local, |
601 | sdata->local->hw.conf.channel->band); | 603 | sdata->local->hw.conf.channel->band); |
602 | ieee80211_bss_info_change_notify(sdata, BSS_CHANGED_BEACON | | 604 | ieee80211_bss_info_change_notify(sdata, BSS_CHANGED_BEACON | |
603 | BSS_CHANGED_BEACON_ENABLED | | 605 | BSS_CHANGED_BEACON_ENABLED | |
606 | BSS_CHANGED_HT | | ||
604 | BSS_CHANGED_BASIC_RATES | | 607 | BSS_CHANGED_BASIC_RATES | |
605 | BSS_CHANGED_BEACON_INT); | 608 | BSS_CHANGED_BEACON_INT); |
606 | } | 609 | } |
diff --git a/net/mac80211/mesh_plink.c b/net/mac80211/mesh_plink.c index 2e0ae7310697..8cc8461b48a0 100644 --- a/net/mac80211/mesh_plink.c +++ b/net/mac80211/mesh_plink.c | |||
@@ -157,6 +157,7 @@ out: | |||
157 | 157 | ||
158 | if (sdata->vif.bss_conf.ht_operation_mode != ht_opmode) { | 158 | if (sdata->vif.bss_conf.ht_operation_mode != ht_opmode) { |
159 | sdata->vif.bss_conf.ht_operation_mode = ht_opmode; | 159 | sdata->vif.bss_conf.ht_operation_mode = ht_opmode; |
160 | sdata->u.mesh.mshcfg.ht_opmode = ht_opmode; | ||
160 | changed = BSS_CHANGED_HT; | 161 | changed = BSS_CHANGED_HT; |
161 | mpl_dbg("mesh_plink %pM: protection mode changed to %d", | 162 | mpl_dbg("mesh_plink %pM: protection mode changed to %d", |
162 | sdata->vif.addr, ht_opmode); | 163 | sdata->vif.addr, ht_opmode); |