diff options
author | Reinette Chatre <reinette.chatre@intel.com> | 2010-04-19 13:46:31 -0400 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2010-04-19 16:34:11 -0400 |
commit | fe6f212ce12341df18ef9b890bea739b4547157b (patch) | |
tree | a8ac4d32c86d590b28e39866b1533d4a1b4ac1ba /net/mac80211 | |
parent | b4bb5c3fd9333024044362df67e23e96158489ed (diff) |
mac80211: pass HT changes to driver when off channel
Since "mac80211: make off-channel work generic" drivers have not been
notified of configuration changes after association or authentication. This
caused more dependence on current state to ensure driver will be notified
when configuration changes occur. One such problem arises if off-channel is
in progress when HT information changes. Since HT is only enabled on the
"oper_channel" the driver will never be notified of this change. Usually
the driver is notified soon after of a BSS information change
(BSS_CHANGED_HT) ... but since the driver did not get a notification that
this is a HT channel the new BSS information does not make sense.
Fix this by also changing the off-channel information when HT is enabled
and thus cause driver to be notified correctly.
This fixes a problem in 4965 when associated with 5GHz 40MHz channel.
Without this patch the system can associate but is unable to transfer any
data, not even ping.
See http://bugzilla.intellinuxwireless.org/show_bug.cgi?id=2158
Signed-off-by: Reinette Chatre <reinette.chatre@intel.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'net/mac80211')
-rw-r--r-- | net/mac80211/mlme.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/net/mac80211/mlme.c b/net/mac80211/mlme.c index be5f723d643a..8a9650343f26 100644 --- a/net/mac80211/mlme.c +++ b/net/mac80211/mlme.c | |||
@@ -167,6 +167,8 @@ static u32 ieee80211_enable_ht(struct ieee80211_sub_if_data *sdata, | |||
167 | ht_changed = conf_is_ht(&local->hw.conf) != enable_ht || | 167 | ht_changed = conf_is_ht(&local->hw.conf) != enable_ht || |
168 | channel_type != local->hw.conf.channel_type; | 168 | channel_type != local->hw.conf.channel_type; |
169 | 169 | ||
170 | if (local->tmp_channel) | ||
171 | local->tmp_channel_type = channel_type; | ||
170 | local->oper_channel_type = channel_type; | 172 | local->oper_channel_type = channel_type; |
171 | 173 | ||
172 | if (ht_changed) { | 174 | if (ht_changed) { |