diff options
author | Thomas Pedersen <thomas@cozybit.com> | 2011-10-26 17:47:28 -0400 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2011-11-08 15:54:33 -0500 |
commit | 739522baa1d6804a3ff33e8c135db0e6b2165f75 (patch) | |
tree | f0b634273a0bec7b88008c7c07e42608e2552f81 /net/mac80211/mesh_plink.c | |
parent | 176f36086e8a00bdf701dc6e4c5a8784ef6529df (diff) |
mac80211: set HT capabilities for mesh peer
Set peer's HT capabilities, and disallow peering if we're on a different
channel type.
Signed-off-by: Thomas Pedersen <thomas@cozybit.com>
Signed-off-by: Ashok Nagarajan <anagar6@uic.edu>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'net/mac80211/mesh_plink.c')
-rw-r--r-- | net/mac80211/mesh_plink.c | 13 |
1 files changed, 10 insertions, 3 deletions
diff --git a/net/mac80211/mesh_plink.c b/net/mac80211/mesh_plink.c index 986af8acc49e..0140e88a8220 100644 --- a/net/mac80211/mesh_plink.c +++ b/net/mac80211/mesh_plink.c | |||
@@ -80,11 +80,15 @@ static inline void mesh_plink_fsm_restart(struct sta_info *sta) | |||
80 | * on it in the lifecycle management section! | 80 | * on it in the lifecycle management section! |
81 | */ | 81 | */ |
82 | static struct sta_info *mesh_plink_alloc(struct ieee80211_sub_if_data *sdata, | 82 | static struct sta_info *mesh_plink_alloc(struct ieee80211_sub_if_data *sdata, |
83 | u8 *hw_addr, u32 rates) | 83 | u8 *hw_addr, u32 rates, |
84 | struct ieee802_11_elems *elems) | ||
84 | { | 85 | { |
85 | struct ieee80211_local *local = sdata->local; | 86 | struct ieee80211_local *local = sdata->local; |
87 | struct ieee80211_supported_band *sband; | ||
86 | struct sta_info *sta; | 88 | struct sta_info *sta; |
87 | 89 | ||
90 | sband = local->hw.wiphy->bands[local->oper_channel->band]; | ||
91 | |||
88 | if (local->num_sta >= MESH_MAX_PLINKS) | 92 | if (local->num_sta >= MESH_MAX_PLINKS) |
89 | return NULL; | 93 | return NULL; |
90 | 94 | ||
@@ -96,6 +100,9 @@ static struct sta_info *mesh_plink_alloc(struct ieee80211_sub_if_data *sdata, | |||
96 | set_sta_flag(sta, WLAN_STA_AUTHORIZED); | 100 | set_sta_flag(sta, WLAN_STA_AUTHORIZED); |
97 | set_sta_flag(sta, WLAN_STA_WME); | 101 | set_sta_flag(sta, WLAN_STA_WME); |
98 | sta->sta.supp_rates[local->hw.conf.channel->band] = rates; | 102 | sta->sta.supp_rates[local->hw.conf.channel->band] = rates; |
103 | if (elems->ht_cap_elem) | ||
104 | ieee80211_ht_cap_ie_to_sta_ht_cap(sband, elems->ht_cap_elem, | ||
105 | &sta->sta.ht_cap); | ||
99 | rate_control_rate_init(sta); | 106 | rate_control_rate_init(sta); |
100 | 107 | ||
101 | return sta; | 108 | return sta; |
@@ -276,7 +283,7 @@ void mesh_neighbour_update(u8 *hw_addr, u32 rates, | |||
276 | elems->ie_start, elems->total_len, | 283 | elems->ie_start, elems->total_len, |
277 | GFP_KERNEL); | 284 | GFP_KERNEL); |
278 | else | 285 | else |
279 | sta = mesh_plink_alloc(sdata, hw_addr, rates); | 286 | sta = mesh_plink_alloc(sdata, hw_addr, rates, elems); |
280 | if (!sta) | 287 | if (!sta) |
281 | return; | 288 | return; |
282 | if (sta_info_insert_rcu(sta)) { | 289 | if (sta_info_insert_rcu(sta)) { |
@@ -567,7 +574,7 @@ void mesh_rx_plink_frame(struct ieee80211_sub_if_data *sdata, struct ieee80211_m | |||
567 | } | 574 | } |
568 | 575 | ||
569 | rates = ieee80211_sta_get_rates(local, &elems, rx_status->band); | 576 | rates = ieee80211_sta_get_rates(local, &elems, rx_status->band); |
570 | sta = mesh_plink_alloc(sdata, mgmt->sa, rates); | 577 | sta = mesh_plink_alloc(sdata, mgmt->sa, rates, &elems); |
571 | if (!sta) { | 578 | if (!sta) { |
572 | mpl_dbg("Mesh plink error: plink table full\n"); | 579 | mpl_dbg("Mesh plink error: plink table full\n"); |
573 | return; | 580 | return; |