diff options
author | Ron Rindjunsky <ron.rindjunsky@intel.com> | 2008-06-30 05:23:21 -0400 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2008-06-30 17:37:43 -0400 |
commit | 4977929304306b1b0712f9b99e3cbf95f75c31ea (patch) | |
tree | b0ab378f5108da3f85dcd5b3f2fbd55ad06ce341 | |
parent | da154e306eb04426a3693c947588d82c3da05337 (diff) |
iwlwifi: control 11n capabilities through module param
This patch adds module param 11n_disable to allow configuration of 11n
capabilities. The default value of this param is 11n enabled (value 0).
Signed-off-by: Ron Rindjunsky <ron.rindjunsky@intel.com>
Signed-off-by: Tomas Winkler <tomas.winkler@intel.com>
Signed-off-by: Zhu Yi <yi.zhu@intel.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
-rw-r--r-- | drivers/net/wireless/iwlwifi/iwl-4965.c | 8 | ||||
-rw-r--r-- | drivers/net/wireless/iwlwifi/iwl-5000.c | 2 | ||||
-rw-r--r-- | drivers/net/wireless/iwlwifi/iwl-core.c | 16 | ||||
-rw-r--r-- | drivers/net/wireless/iwlwifi/iwl-core.h | 1 |
4 files changed, 22 insertions, 5 deletions
diff --git a/drivers/net/wireless/iwlwifi/iwl-4965.c b/drivers/net/wireless/iwlwifi/iwl-4965.c index 7f6713f32c98..e4eab5196b7f 100644 --- a/drivers/net/wireless/iwlwifi/iwl-4965.c +++ b/drivers/net/wireless/iwlwifi/iwl-4965.c | |||
@@ -2075,6 +2075,9 @@ int iwl4965_mac_ampdu_action(struct ieee80211_hw *hw, | |||
2075 | IWL_DEBUG_HT("A-MPDU action on addr %s tid %d\n", | 2075 | IWL_DEBUG_HT("A-MPDU action on addr %s tid %d\n", |
2076 | print_mac(mac, addr), tid); | 2076 | print_mac(mac, addr), tid); |
2077 | 2077 | ||
2078 | if (!(priv->cfg->sku & IWL_SKU_N)) | ||
2079 | return -EACCES; | ||
2080 | |||
2078 | switch (action) { | 2081 | switch (action) { |
2079 | case IEEE80211_AMPDU_RX_START: | 2082 | case IEEE80211_AMPDU_RX_START: |
2080 | IWL_DEBUG_HT("start Rx\n"); | 2083 | IWL_DEBUG_HT("start Rx\n"); |
@@ -2457,11 +2460,14 @@ MODULE_PARM_DESC(disable_hw_scan, "disable hardware scanning (default 0)"); | |||
2457 | 2460 | ||
2458 | module_param_named(queues_num, iwl4965_mod_params.num_of_queues, int, 0444); | 2461 | module_param_named(queues_num, iwl4965_mod_params.num_of_queues, int, 0444); |
2459 | MODULE_PARM_DESC(queues_num, "number of hw queues."); | 2462 | MODULE_PARM_DESC(queues_num, "number of hw queues."); |
2460 | |||
2461 | /* QoS */ | 2463 | /* QoS */ |
2462 | module_param_named(qos_enable, iwl4965_mod_params.enable_qos, int, 0444); | 2464 | module_param_named(qos_enable, iwl4965_mod_params.enable_qos, int, 0444); |
2463 | MODULE_PARM_DESC(qos_enable, "enable all QoS functionality"); | 2465 | MODULE_PARM_DESC(qos_enable, "enable all QoS functionality"); |
2466 | /* 11n */ | ||
2467 | module_param_named(11n_disable, iwl4965_mod_params.disable_11n, int, 0444); | ||
2468 | MODULE_PARM_DESC(11n_disable, "disable 11n functionality"); | ||
2464 | module_param_named(amsdu_size_8K, iwl4965_mod_params.amsdu_size_8K, int, 0444); | 2469 | module_param_named(amsdu_size_8K, iwl4965_mod_params.amsdu_size_8K, int, 0444); |
2465 | MODULE_PARM_DESC(amsdu_size_8K, "enable 8K amsdu size"); | 2470 | MODULE_PARM_DESC(amsdu_size_8K, "enable 8K amsdu size"); |
2471 | |||
2466 | module_param_named(fw_restart4965, iwl4965_mod_params.restart_fw, int, 0444); | 2472 | module_param_named(fw_restart4965, iwl4965_mod_params.restart_fw, int, 0444); |
2467 | MODULE_PARM_DESC(fw_restart4965, "restart firmware in case of error"); | 2473 | MODULE_PARM_DESC(fw_restart4965, "restart firmware in case of error"); |
diff --git a/drivers/net/wireless/iwlwifi/iwl-5000.c b/drivers/net/wireless/iwlwifi/iwl-5000.c index 75283fb9d5a8..099983f7306a 100644 --- a/drivers/net/wireless/iwlwifi/iwl-5000.c +++ b/drivers/net/wireless/iwlwifi/iwl-5000.c | |||
@@ -1540,6 +1540,8 @@ module_param_named(queues_num50, iwl50_mod_params.num_of_queues, int, 0444); | |||
1540 | MODULE_PARM_DESC(queues_num50, "number of hw queues in 50xx series"); | 1540 | MODULE_PARM_DESC(queues_num50, "number of hw queues in 50xx series"); |
1541 | module_param_named(qos_enable50, iwl50_mod_params.enable_qos, int, 0444); | 1541 | module_param_named(qos_enable50, iwl50_mod_params.enable_qos, int, 0444); |
1542 | MODULE_PARM_DESC(qos_enable50, "enable all 50XX QoS functionality"); | 1542 | MODULE_PARM_DESC(qos_enable50, "enable all 50XX QoS functionality"); |
1543 | module_param_named(11n_disable50, iwl50_mod_params.disable_11n, int, 0444); | ||
1544 | MODULE_PARM_DESC(11n_disable50, "disable 50XX 11n functionality"); | ||
1543 | module_param_named(amsdu_size_8K50, iwl50_mod_params.amsdu_size_8K, int, 0444); | 1545 | module_param_named(amsdu_size_8K50, iwl50_mod_params.amsdu_size_8K, int, 0444); |
1544 | MODULE_PARM_DESC(amsdu_size_8K50, "enable 8K amsdu size in 50XX series"); | 1546 | MODULE_PARM_DESC(amsdu_size_8K50, "enable 8K amsdu size in 50XX series"); |
1545 | module_param_named(fw_restart50, iwl50_mod_params.restart_fw, int, 0444); | 1547 | module_param_named(fw_restart50, iwl50_mod_params.restart_fw, int, 0444); |
diff --git a/drivers/net/wireless/iwlwifi/iwl-core.c b/drivers/net/wireless/iwlwifi/iwl-core.c index 97447df94d14..08a42a70962e 100644 --- a/drivers/net/wireless/iwlwifi/iwl-core.c +++ b/drivers/net/wireless/iwlwifi/iwl-core.c | |||
@@ -495,7 +495,9 @@ static int iwlcore_init_geos(struct iwl_priv *priv) | |||
495 | sband->bitrates = &rates[IWL_FIRST_OFDM_RATE]; | 495 | sband->bitrates = &rates[IWL_FIRST_OFDM_RATE]; |
496 | sband->n_bitrates = IWL_RATE_COUNT - IWL_FIRST_OFDM_RATE; | 496 | sband->n_bitrates = IWL_RATE_COUNT - IWL_FIRST_OFDM_RATE; |
497 | 497 | ||
498 | iwlcore_init_ht_hw_capab(priv, &sband->ht_info, IEEE80211_BAND_5GHZ); | 498 | if (priv->cfg->sku & IWL_SKU_N) |
499 | iwlcore_init_ht_hw_capab(priv, &sband->ht_info, | ||
500 | IEEE80211_BAND_5GHZ); | ||
499 | 501 | ||
500 | sband = &priv->bands[IEEE80211_BAND_2GHZ]; | 502 | sband = &priv->bands[IEEE80211_BAND_2GHZ]; |
501 | sband->channels = channels; | 503 | sband->channels = channels; |
@@ -503,7 +505,9 @@ static int iwlcore_init_geos(struct iwl_priv *priv) | |||
503 | sband->bitrates = rates; | 505 | sband->bitrates = rates; |
504 | sband->n_bitrates = IWL_RATE_COUNT; | 506 | sband->n_bitrates = IWL_RATE_COUNT; |
505 | 507 | ||
506 | iwlcore_init_ht_hw_capab(priv, &sband->ht_info, IEEE80211_BAND_2GHZ); | 508 | if (priv->cfg->sku & IWL_SKU_N) |
509 | iwlcore_init_ht_hw_capab(priv, &sband->ht_info, | ||
510 | IEEE80211_BAND_2GHZ); | ||
507 | 511 | ||
508 | priv->ieee_channels = channels; | 512 | priv->ieee_channels = channels; |
509 | priv->ieee_rates = rates; | 513 | priv->ieee_rates = rates; |
@@ -819,8 +823,9 @@ int iwl_setup_mac(struct iwl_priv *priv) | |||
819 | IEEE80211_HW_NOISE_DBM; | 823 | IEEE80211_HW_NOISE_DBM; |
820 | /* Default value; 4 EDCA QOS priorities */ | 824 | /* Default value; 4 EDCA QOS priorities */ |
821 | hw->queues = 4; | 825 | hw->queues = 4; |
822 | /* Enhanced value; more queues, to support 11n aggregation */ | 826 | /* queues to support 11n aggregation */ |
823 | hw->ampdu_queues = 12; | 827 | if (priv->cfg->sku & IWL_SKU_N) |
828 | hw->ampdu_queues = 12; | ||
824 | 829 | ||
825 | hw->conf.beacon_int = 100; | 830 | hw->conf.beacon_int = 100; |
826 | 831 | ||
@@ -853,6 +858,9 @@ int iwl_set_hw_params(struct iwl_priv *priv) | |||
853 | priv->hw_params.rx_buf_size = IWL_RX_BUF_SIZE_4K; | 858 | priv->hw_params.rx_buf_size = IWL_RX_BUF_SIZE_4K; |
854 | priv->hw_params.max_pkt_size = priv->hw_params.rx_buf_size - 256; | 859 | priv->hw_params.max_pkt_size = priv->hw_params.rx_buf_size - 256; |
855 | 860 | ||
861 | if (priv->cfg->mod_params->disable_11n) | ||
862 | priv->cfg->sku &= ~IWL_SKU_N; | ||
863 | |||
856 | /* Device-specific setup */ | 864 | /* Device-specific setup */ |
857 | return priv->cfg->ops->lib->set_hw_params(priv); | 865 | return priv->cfg->ops->lib->set_hw_params(priv); |
858 | } | 866 | } |
diff --git a/drivers/net/wireless/iwlwifi/iwl-core.h b/drivers/net/wireless/iwlwifi/iwl-core.h index f156d27ee9a0..d7562c39dda7 100644 --- a/drivers/net/wireless/iwlwifi/iwl-core.h +++ b/drivers/net/wireless/iwlwifi/iwl-core.h | |||
@@ -159,6 +159,7 @@ struct iwl_mod_params { | |||
159 | int disable_hw_scan; /* def: 0 = use h/w scan */ | 159 | int disable_hw_scan; /* def: 0 = use h/w scan */ |
160 | int num_of_queues; /* def: HW dependent */ | 160 | int num_of_queues; /* def: HW dependent */ |
161 | int enable_qos; /* def: 1 = use quality of service */ | 161 | int enable_qos; /* def: 1 = use quality of service */ |
162 | int disable_11n; /* def: 0 = disable 11n capabilities */ | ||
162 | int amsdu_size_8K; /* def: 1 = enable 8K amsdu size */ | 163 | int amsdu_size_8K; /* def: 1 = enable 8K amsdu size */ |
163 | int antenna; /* def: 0 = both antennas (use diversity) */ | 164 | int antenna; /* def: 0 = both antennas (use diversity) */ |
164 | int restart_fw; /* def: 1 = restart firmware */ | 165 | int restart_fw; /* def: 1 = restart firmware */ |