diff options
author | Emmanuel Grumbach <emmanuel.grumbach@intel.com> | 2008-05-15 01:54:08 -0400 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2008-05-21 21:48:00 -0400 |
commit | a98410139a2ef6553ae5d73bf12bb9a68d0b38b9 (patch) | |
tree | 55401ad30cf0ecc3f007704e6d523567f040124b /drivers | |
parent | fd4abac54a7a7f1c0acad5ddc1fbf4af22f92569 (diff) |
iwlwifi: don't switch to SGI if not supported by AP
This patch fixes SGI support. RS didn't look at the capabilities of the AP
before switching to SGI, this should lead to a stall in the traffic with an
AP that doesn't support SGI.
Signed-off-by: Emmanuel Grumbach <emmanuel.grumbach@intel.com>
Signed-off-by: Guy Cohen <guy.cohen@intel.com>
Signed-off-by: Tomas Winkler <tomas.winkler@intel.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/net/wireless/iwlwifi/iwl-4965-rs.c | 18 | ||||
-rw-r--r-- | drivers/net/wireless/iwlwifi/iwl-dev.h | 4 | ||||
-rw-r--r-- | drivers/net/wireless/iwlwifi/iwl4965-base.c | 4 |
3 files changed, 22 insertions, 4 deletions
diff --git a/drivers/net/wireless/iwlwifi/iwl-4965-rs.c b/drivers/net/wireless/iwlwifi/iwl-4965-rs.c index 071c7b6ebef2..2adc2281c77c 100644 --- a/drivers/net/wireless/iwlwifi/iwl-4965-rs.c +++ b/drivers/net/wireless/iwlwifi/iwl-4965-rs.c | |||
@@ -1439,6 +1439,15 @@ static int rs_move_siso_to_other(struct iwl_priv *priv, | |||
1439 | } | 1439 | } |
1440 | break; | 1440 | break; |
1441 | case IWL_SISO_SWITCH_GI: | 1441 | case IWL_SISO_SWITCH_GI: |
1442 | if (!tbl->is_fat && | ||
1443 | !(priv->current_ht_config.sgf & | ||
1444 | HT_SHORT_GI_20MHZ)) | ||
1445 | break; | ||
1446 | if (tbl->is_fat && | ||
1447 | !(priv->current_ht_config.sgf & | ||
1448 | HT_SHORT_GI_40MHZ)) | ||
1449 | break; | ||
1450 | |||
1442 | IWL_DEBUG_RATE("LQ: SISO toggle SGI/NGI\n"); | 1451 | IWL_DEBUG_RATE("LQ: SISO toggle SGI/NGI\n"); |
1443 | 1452 | ||
1444 | memcpy(search_tbl, tbl, sz); | 1453 | memcpy(search_tbl, tbl, sz); |
@@ -1521,6 +1530,15 @@ static int rs_move_mimo_to_other(struct iwl_priv *priv, | |||
1521 | break; | 1530 | break; |
1522 | 1531 | ||
1523 | case IWL_MIMO_SWITCH_GI: | 1532 | case IWL_MIMO_SWITCH_GI: |
1533 | if (!tbl->is_fat && | ||
1534 | !(priv->current_ht_config.sgf & | ||
1535 | HT_SHORT_GI_20MHZ)) | ||
1536 | break; | ||
1537 | if (tbl->is_fat && | ||
1538 | !(priv->current_ht_config.sgf & | ||
1539 | HT_SHORT_GI_40MHZ)) | ||
1540 | break; | ||
1541 | |||
1524 | IWL_DEBUG_RATE("LQ: MIMO toggle SGI/NGI\n"); | 1542 | IWL_DEBUG_RATE("LQ: MIMO toggle SGI/NGI\n"); |
1525 | 1543 | ||
1526 | /* Set up new search table for MIMO */ | 1544 | /* Set up new search table for MIMO */ |
diff --git a/drivers/net/wireless/iwlwifi/iwl-dev.h b/drivers/net/wireless/iwlwifi/iwl-dev.h index 4106efd194e4..7a54682a3d86 100644 --- a/drivers/net/wireless/iwlwifi/iwl-dev.h +++ b/drivers/net/wireless/iwlwifi/iwl-dev.h | |||
@@ -610,8 +610,8 @@ struct iwl_hw_params { | |||
610 | #endif | 610 | #endif |
611 | }; | 611 | }; |
612 | 612 | ||
613 | #define HT_SHORT_GI_20MHZ_ONLY (1 << 0) | 613 | #define HT_SHORT_GI_20MHZ (1 << 0) |
614 | #define HT_SHORT_GI_40MHZ_ONLY (1 << 1) | 614 | #define HT_SHORT_GI_40MHZ (1 << 1) |
615 | 615 | ||
616 | 616 | ||
617 | #define IWL_RX_HDR(x) ((struct iwl4965_rx_frame_hdr *)(\ | 617 | #define IWL_RX_HDR(x) ((struct iwl4965_rx_frame_hdr *)(\ |
diff --git a/drivers/net/wireless/iwlwifi/iwl4965-base.c b/drivers/net/wireless/iwlwifi/iwl4965-base.c index dd2fd4055306..a532a9e576dc 100644 --- a/drivers/net/wireless/iwlwifi/iwl4965-base.c +++ b/drivers/net/wireless/iwlwifi/iwl4965-base.c | |||
@@ -700,9 +700,9 @@ static void iwl4965_ht_conf(struct iwl_priv *priv, | |||
700 | priv->ps_mode = (u8)((ht_conf->cap & IEEE80211_HT_CAP_MIMO_PS) >> 2); | 700 | priv->ps_mode = (u8)((ht_conf->cap & IEEE80211_HT_CAP_MIMO_PS) >> 2); |
701 | 701 | ||
702 | if (ht_conf->cap & IEEE80211_HT_CAP_SGI_20) | 702 | if (ht_conf->cap & IEEE80211_HT_CAP_SGI_20) |
703 | iwl_conf->sgf |= 0x1; | 703 | iwl_conf->sgf |= HT_SHORT_GI_20MHZ; |
704 | if (ht_conf->cap & IEEE80211_HT_CAP_SGI_40) | 704 | if (ht_conf->cap & IEEE80211_HT_CAP_SGI_40) |
705 | iwl_conf->sgf |= 0x2; | 705 | iwl_conf->sgf |= HT_SHORT_GI_40MHZ; |
706 | 706 | ||
707 | iwl_conf->is_green_field = !!(ht_conf->cap & IEEE80211_HT_CAP_GRN_FLD); | 707 | iwl_conf->is_green_field = !!(ht_conf->cap & IEEE80211_HT_CAP_GRN_FLD); |
708 | iwl_conf->max_amsdu_size = | 708 | iwl_conf->max_amsdu_size = |