aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/wireless
diff options
context:
space:
mode:
authorTomas Winkler <tomas.winkler@intel.com>2008-03-28 19:33:33 -0400
committerJohn W. Linville <linville@tuxdriver.com>2008-04-08 15:05:56 -0400
commit98952d5decf8195b2cbb96d47572278335a8a8d8 (patch)
treed30ca579fd41eb76633dc1bce93ee15b740e7874 /drivers/net/wireless
parent38668c059f5202f5fd9612391f9aa1b38a97241b (diff)
iwlwifi: eliminate conf_ht
This patch eliminates the use of conf_ht in iwlwifi driver, replacing it with bss_info_changed. Signed-off-by: Tomas Winkler <tomas.winkler@intel.com> Signed-off-by: Ron Rindjunsky <ron.rindjunsky@intel.com> Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'drivers/net/wireless')
-rw-r--r--drivers/net/wireless/iwlwifi/iwl4965-base.c146
1 files changed, 63 insertions, 83 deletions
diff --git a/drivers/net/wireless/iwlwifi/iwl4965-base.c b/drivers/net/wireless/iwlwifi/iwl4965-base.c
index 8d49ff4bd4db..826c912aea9a 100644
--- a/drivers/net/wireless/iwlwifi/iwl4965-base.c
+++ b/drivers/net/wireless/iwlwifi/iwl4965-base.c
@@ -6941,6 +6941,64 @@ static void iwl4965_mac_remove_interface(struct ieee80211_hw *hw,
6941 6941
6942} 6942}
6943 6943
6944
6945#ifdef CONFIG_IWL4965_HT
6946static void iwl4965_ht_conf(struct iwl_priv *priv,
6947 struct ieee80211_bss_conf *bss_conf)
6948{
6949 struct ieee80211_ht_info *ht_conf = bss_conf->ht_conf;
6950 struct ieee80211_ht_bss_info *ht_bss_conf = bss_conf->ht_bss_conf;
6951 struct iwl_ht_info *iwl_conf = &priv->current_ht_config;
6952
6953 IWL_DEBUG_MAC80211("enter: \n");
6954
6955 iwl_conf->is_ht = bss_conf->assoc_ht;
6956
6957 if (!iwl_conf->is_ht)
6958 return;
6959
6960 priv->ps_mode = (u8)((ht_conf->cap & IEEE80211_HT_CAP_MIMO_PS) >> 2);
6961
6962 if (ht_conf->cap & IEEE80211_HT_CAP_SGI_20)
6963 iwl_conf->sgf |= 0x1;
6964 if (ht_conf->cap & IEEE80211_HT_CAP_SGI_40)
6965 iwl_conf->sgf |= 0x2;
6966
6967 iwl_conf->is_green_field = !!(ht_conf->cap & IEEE80211_HT_CAP_GRN_FLD);
6968 iwl_conf->max_amsdu_size =
6969 !!(ht_conf->cap & IEEE80211_HT_CAP_MAX_AMSDU);
6970
6971 iwl_conf->supported_chan_width =
6972 !!(ht_conf->cap & IEEE80211_HT_CAP_SUP_WIDTH);
6973 iwl_conf->extension_chan_offset =
6974 ht_bss_conf->bss_cap & IEEE80211_HT_IE_CHA_SEC_OFFSET;
6975 /* If no above or below channel supplied disable FAT channel */
6976 if (iwl_conf->extension_chan_offset != IWL_EXT_CHANNEL_OFFSET_ABOVE &&
6977 iwl_conf->extension_chan_offset != IWL_EXT_CHANNEL_OFFSET_BELOW)
6978 iwl_conf->supported_chan_width = 0;
6979
6980 iwl_conf->tx_mimo_ps_mode =
6981 (u8)((ht_conf->cap & IEEE80211_HT_CAP_MIMO_PS) >> 2);
6982 memcpy(iwl_conf->supp_mcs_set, ht_conf->supp_mcs_set, 16);
6983
6984 iwl_conf->control_channel = ht_bss_conf->primary_channel;
6985 iwl_conf->tx_chan_width =
6986 !!(ht_bss_conf->bss_cap & IEEE80211_HT_IE_CHA_WIDTH);
6987 iwl_conf->ht_protection =
6988 ht_bss_conf->bss_op_mode & IEEE80211_HT_IE_HT_PROTECTION;
6989 iwl_conf->non_GF_STA_present =
6990 !!(ht_bss_conf->bss_op_mode & IEEE80211_HT_IE_NON_GF_STA_PRSNT);
6991
6992 IWL_DEBUG_MAC80211("control channel %d\n", iwl_conf->control_channel);
6993 IWL_DEBUG_MAC80211("leave\n");
6994}
6995#else
6996static inline void iwl4965_ht_conf(struct iwl_priv *priv,
6997 struct ieee80211_bss_conf *bss_conf)
6998{
6999}
7000#endif
7001
6944static void iwl4965_bss_info_changed(struct ieee80211_hw *hw, 7002static void iwl4965_bss_info_changed(struct ieee80211_hw *hw,
6945 struct ieee80211_vif *vif, 7003 struct ieee80211_vif *vif,
6946 struct ieee80211_bss_conf *bss_conf, 7004 struct ieee80211_bss_conf *bss_conf,
@@ -6962,6 +7020,11 @@ static void iwl4965_bss_info_changed(struct ieee80211_hw *hw,
6962 priv->staging_rxon.flags &= ~RXON_FLG_TGG_PROTECT_MSK; 7020 priv->staging_rxon.flags &= ~RXON_FLG_TGG_PROTECT_MSK;
6963 } 7021 }
6964 7022
7023 if (changes & BSS_CHANGED_HT) {
7024 iwl4965_ht_conf(priv, bss_conf);
7025 iwl4965_set_rxon_chain(priv);
7026 }
7027
6965 if (changes & BSS_CHANGED_ASSOC) { 7028 if (changes & BSS_CHANGED_ASSOC) {
6966 /* 7029 /*
6967 * TODO: 7030 * TODO:
@@ -7358,88 +7421,6 @@ static int iwl4965_mac_beacon_update(struct ieee80211_hw *hw, struct sk_buff *sk
7358 return 0; 7421 return 0;
7359} 7422}
7360 7423
7361#ifdef CONFIG_IWL4965_HT
7362
7363static void iwl4965_ht_info_fill(struct ieee80211_conf *conf,
7364 struct iwl_priv *priv)
7365{
7366 struct iwl_ht_info *iwl_conf = &priv->current_ht_config;
7367 struct ieee80211_ht_info *ht_conf = &conf->ht_conf;
7368 struct ieee80211_ht_bss_info *ht_bss_conf = &conf->ht_bss_conf;
7369
7370 IWL_DEBUG_MAC80211("enter: \n");
7371
7372 if (!(conf->flags & IEEE80211_CONF_SUPPORT_HT_MODE)) {
7373 iwl_conf->is_ht = 0;
7374 return;
7375 }
7376
7377 iwl_conf->is_ht = 1;
7378 priv->ps_mode = (u8)((ht_conf->cap & IEEE80211_HT_CAP_MIMO_PS) >> 2);
7379
7380 if (ht_conf->cap & IEEE80211_HT_CAP_SGI_20)
7381 iwl_conf->sgf |= 0x1;
7382 if (ht_conf->cap & IEEE80211_HT_CAP_SGI_40)
7383 iwl_conf->sgf |= 0x2;
7384
7385 iwl_conf->is_green_field = !!(ht_conf->cap & IEEE80211_HT_CAP_GRN_FLD);
7386 iwl_conf->max_amsdu_size =
7387 !!(ht_conf->cap & IEEE80211_HT_CAP_MAX_AMSDU);
7388
7389 iwl_conf->supported_chan_width =
7390 !!(ht_conf->cap & IEEE80211_HT_CAP_SUP_WIDTH);
7391 iwl_conf->extension_chan_offset =
7392 ht_bss_conf->bss_cap & IEEE80211_HT_IE_CHA_SEC_OFFSET;
7393 /* If no above or below channel supplied disable FAT channel */
7394 if (iwl_conf->extension_chan_offset != IWL_EXT_CHANNEL_OFFSET_ABOVE &&
7395 iwl_conf->extension_chan_offset != IWL_EXT_CHANNEL_OFFSET_BELOW)
7396 iwl_conf->supported_chan_width = 0;
7397
7398 iwl_conf->tx_mimo_ps_mode =
7399 (u8)((ht_conf->cap & IEEE80211_HT_CAP_MIMO_PS) >> 2);
7400 memcpy(iwl_conf->supp_mcs_set, ht_conf->supp_mcs_set, 16);
7401
7402 iwl_conf->control_channel = ht_bss_conf->primary_channel;
7403 iwl_conf->tx_chan_width =
7404 !!(ht_bss_conf->bss_cap & IEEE80211_HT_IE_CHA_WIDTH);
7405 iwl_conf->ht_protection =
7406 ht_bss_conf->bss_op_mode & IEEE80211_HT_IE_HT_PROTECTION;
7407 iwl_conf->non_GF_STA_present =
7408 !!(ht_bss_conf->bss_op_mode & IEEE80211_HT_IE_NON_GF_STA_PRSNT);
7409
7410 IWL_DEBUG_MAC80211("control channel %d\n",
7411 iwl_conf->control_channel);
7412 IWL_DEBUG_MAC80211("leave\n");
7413}
7414
7415static int iwl4965_mac_conf_ht(struct ieee80211_hw *hw,
7416 struct ieee80211_conf *conf)
7417{
7418 struct iwl_priv *priv = hw->priv;
7419
7420 IWL_DEBUG_MAC80211("enter: \n");
7421
7422 iwl4965_ht_info_fill(conf, priv);
7423 iwl4965_set_rxon_chain(priv);
7424
7425 if (priv && priv->assoc_id &&
7426 (priv->iw_mode == IEEE80211_IF_TYPE_STA)) {
7427 unsigned long flags;
7428
7429 spin_lock_irqsave(&priv->lock, flags);
7430 if (priv->beacon_int)
7431 queue_work(priv->workqueue, &priv->post_associate.work);
7432 else
7433 priv->call_post_assoc_from_beacon = 1;
7434 spin_unlock_irqrestore(&priv->lock, flags);
7435 }
7436
7437 IWL_DEBUG_MAC80211("leave:\n");
7438 return 0;
7439}
7440
7441#endif /*CONFIG_IWL4965_HT*/
7442
7443/***************************************************************************** 7424/*****************************************************************************
7444 * 7425 *
7445 * sysfs attributes 7426 * sysfs attributes
@@ -7999,7 +7980,6 @@ static struct ieee80211_ops iwl4965_hw_ops = {
7999 .beacon_update = iwl4965_mac_beacon_update, 7980 .beacon_update = iwl4965_mac_beacon_update,
8000 .bss_info_changed = iwl4965_bss_info_changed, 7981 .bss_info_changed = iwl4965_bss_info_changed,
8001#ifdef CONFIG_IWL4965_HT 7982#ifdef CONFIG_IWL4965_HT
8002 .conf_ht = iwl4965_mac_conf_ht,
8003 .ampdu_action = iwl4965_mac_ampdu_action, 7983 .ampdu_action = iwl4965_mac_ampdu_action,
8004#endif /* CONFIG_IWL4965_HT */ 7984#endif /* CONFIG_IWL4965_HT */
8005 .hw_scan = iwl4965_mac_hw_scan 7985 .hw_scan = iwl4965_mac_hw_scan