diff options
author | Wey-Yi Guy <wey-yi.w.guy@intel.com> | 2009-09-17 13:43:44 -0400 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2009-10-07 16:39:33 -0400 |
commit | 47eef9bd1079edbc3e6606309c733a2316ca5a72 (patch) | |
tree | 9f7a144d3fccc22a95fe286a88df85f69c712d76 /drivers/net/wireless/iwlwifi/iwl-agn.c | |
parent | 02bb1bea85e6570b4e64825026382556970b9296 (diff) |
iwlwifi: Use RTS/CTS as the preferred protection mechanism for 6000 series
When 802.11g was introduced, we had RTS/CTS and CTS-to-Self protection
mechanisms. In an HT Beacon, HT stations use the "Operating Mode" field
in the HT Information Element to determine whether or not to use
protection.
The Operating Mode field has 4 possible settings: 0-3:
Mode 0: If all stations in the BSS are 20/40 MHz HT capable, or if the
BSS is 20/40 MHz capable, or if all stations in the BSS are 20 MHz HT
stations in a 20 MHz BSS
Mode 1: used if there are non-HT stations or APs using the primary or
secondary channels
Mode 2: if only HT stations are associated in the BSS and at least one
20 MHz HT station is associated.
Mode 3: used if one or more non-HT stations are associated in the BSS.
When in operating modes 1 or 3, and the Use_Protection field is 1 in the
Beacon's ERP IE, all HT transmissions must be protected using RTS/CTS or
CTS-to-Self.
By default, CTS-to-self is the preferred protection mechanism for less
overhead and higher throughput; but using the full RTS/CTS will better
protect the inner exchange from interference, especially in
highly-congested environment.
For 6000 series WIFI NIC, RTS/CTS protection mechanism is the
recommended choice for HT traffic based on the HW design.
Signed-off-by: Wey-Yi Guy <wey-yi.w.guy@intel.com>
Signed-off-by: Reinette Chatre <reinette.chatre@intel.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'drivers/net/wireless/iwlwifi/iwl-agn.c')
-rw-r--r-- | drivers/net/wireless/iwlwifi/iwl-agn.c | 10 |
1 files changed, 7 insertions, 3 deletions
diff --git a/drivers/net/wireless/iwlwifi/iwl-agn.c b/drivers/net/wireless/iwlwifi/iwl-agn.c index cdc07c477457..a3739628c1d6 100644 --- a/drivers/net/wireless/iwlwifi/iwl-agn.c +++ b/drivers/net/wireless/iwlwifi/iwl-agn.c | |||
@@ -115,9 +115,6 @@ int iwl_commit_rxon(struct iwl_priv *priv) | |||
115 | 115 | ||
116 | /* always get timestamp with Rx frame */ | 116 | /* always get timestamp with Rx frame */ |
117 | priv->staging_rxon.flags |= RXON_FLG_TSF2HOST_MSK; | 117 | priv->staging_rxon.flags |= RXON_FLG_TSF2HOST_MSK; |
118 | /* allow CTS-to-self if possible. this is relevant only for | ||
119 | * 5000, but will not damage 4965 */ | ||
120 | priv->staging_rxon.flags |= RXON_FLG_SELF_CTS_EN; | ||
121 | 118 | ||
122 | ret = iwl_check_rxon_cmd(priv); | 119 | ret = iwl_check_rxon_cmd(priv); |
123 | if (ret) { | 120 | if (ret) { |
@@ -217,6 +214,13 @@ int iwl_commit_rxon(struct iwl_priv *priv) | |||
217 | "Could not send WEP static key.\n"); | 214 | "Could not send WEP static key.\n"); |
218 | } | 215 | } |
219 | 216 | ||
217 | /* | ||
218 | * allow CTS-to-self if possible for new association. | ||
219 | * this is relevant only for 5000 series and up, | ||
220 | * but will not damage 4965 | ||
221 | */ | ||
222 | priv->staging_rxon.flags |= RXON_FLG_SELF_CTS_EN; | ||
223 | |||
220 | /* Apply the new configuration | 224 | /* Apply the new configuration |
221 | * RXON assoc doesn't clear the station table in uCode, | 225 | * RXON assoc doesn't clear the station table in uCode, |
222 | */ | 226 | */ |