|
@@ -528,6 +528,24 @@ int iwlagn_commit_rxon(struct iwl_priv *priv, struct iwl_rxon_context *ctx)
|
|
|
return 0;
|
|
|
}
|
|
|
|
|
|
+void iwlagn_config_ht40(struct ieee80211_conf *conf,
|
|
|
+ struct iwl_rxon_context *ctx)
|
|
|
+{
|
|
|
+ if (conf_is_ht40_minus(conf)) {
|
|
|
+ ctx->ht.extension_chan_offset =
|
|
|
+ IEEE80211_HT_PARAM_CHA_SEC_BELOW;
|
|
|
+ ctx->ht.is_40mhz = true;
|
|
|
+ } else if (conf_is_ht40_plus(conf)) {
|
|
|
+ ctx->ht.extension_chan_offset =
|
|
|
+ IEEE80211_HT_PARAM_CHA_SEC_ABOVE;
|
|
|
+ ctx->ht.is_40mhz = true;
|
|
|
+ } else {
|
|
|
+ ctx->ht.extension_chan_offset =
|
|
|
+ IEEE80211_HT_PARAM_CHA_SEC_NONE;
|
|
|
+ ctx->ht.is_40mhz = false;
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
int iwlagn_mac_config(struct ieee80211_hw *hw, u32 changed)
|
|
|
{
|
|
|
struct iwl_priv *priv = hw->priv;
|
|
@@ -586,19 +604,11 @@ int iwlagn_mac_config(struct ieee80211_hw *hw, u32 changed)
|
|
|
ctx->ht.enabled = conf_is_ht(conf);
|
|
|
|
|
|
if (ctx->ht.enabled) {
|
|
|
- if (conf_is_ht40_minus(conf)) {
|
|
|
- ctx->ht.extension_chan_offset =
|
|
|
- IEEE80211_HT_PARAM_CHA_SEC_BELOW;
|
|
|
- ctx->ht.is_40mhz = true;
|
|
|
- } else if (conf_is_ht40_plus(conf)) {
|
|
|
- ctx->ht.extension_chan_offset =
|
|
|
- IEEE80211_HT_PARAM_CHA_SEC_ABOVE;
|
|
|
- ctx->ht.is_40mhz = true;
|
|
|
- } else {
|
|
|
- ctx->ht.extension_chan_offset =
|
|
|
- IEEE80211_HT_PARAM_CHA_SEC_NONE;
|
|
|
- ctx->ht.is_40mhz = false;
|
|
|
- }
|
|
|
+ /* if HT40 is used, it should not change
|
|
|
+ * after associated except channel switch */
|
|
|
+ if (iwl_is_associated_ctx(ctx) &&
|
|
|
+ !ctx->ht.is_40mhz)
|
|
|
+ iwlagn_config_ht40(conf, ctx);
|
|
|
} else
|
|
|
ctx->ht.is_40mhz = false;
|
|
|
|