aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
authorDaniel C Halperin <daniel.c.halperin@intel.com>2009-08-13 16:30:58 -0400
committerJohn W. Linville <linville@tuxdriver.com>2009-08-20 11:33:12 -0400
commit28e6f48953f44f7eb615383efe6e7f17624a11bb (patch)
treeab22bdd91b0f064ed654dbb6f559dae3520fe840 /drivers
parent28bd723bbaddba4e145d25117649bb6da5fafad7 (diff)
iwlwifi: check short GI support per-station rather than globally
Short guard interval support is a local per-station parameter not a global per-NIC parameter. (mac80211 will correctly remove SGI support from station capabilities if the BSS does not permit it). This patch removes the short GI support bitfield from the global iwl_ht_info struct and properly uses per-station HT capabilities during rate selection. Signed-off-by: Daniel C Halperin <daniel.c.halperin@intel.com> Acked-by: Johannes Berg <johannes@sipsolutions.net> Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'drivers')
-rw-r--r--drivers/net/wireless/iwlwifi/iwl-agn-rs.c69
-rw-r--r--drivers/net/wireless/iwlwifi/iwl-core.c5
-rw-r--r--drivers/net/wireless/iwlwifi/iwl-dev.h4
3 files changed, 15 insertions, 63 deletions
diff --git a/drivers/net/wireless/iwlwifi/iwl-agn-rs.c b/drivers/net/wireless/iwlwifi/iwl-agn-rs.c
index 551c4ba3f178..3b1bbc394a49 100644
--- a/drivers/net/wireless/iwlwifi/iwl-agn-rs.c
+++ b/drivers/net/wireless/iwlwifi/iwl-agn-rs.c
@@ -1225,18 +1225,6 @@ static int rs_switch_to_mimo2(struct iwl_priv *priv,
1225 else 1225 else
1226 tbl->is_ht40 = 0; 1226 tbl->is_ht40 = 0;
1227 1227
1228 /* FIXME: - don't toggle SGI here
1229 if (tbl->is_ht40) {
1230 if (priv->current_ht_config.sgf & HT_SHORT_GI_40MHZ_ONLY)
1231 tbl->is_SGI = 1;
1232 else
1233 tbl->is_SGI = 0;
1234 } else if (priv->current_ht_config.sgf & HT_SHORT_GI_20MHZ_ONLY)
1235 tbl->is_SGI = 1;
1236 else
1237 tbl->is_SGI = 0;
1238 */
1239
1240 rs_set_expected_tpt_table(lq_sta, tbl); 1228 rs_set_expected_tpt_table(lq_sta, tbl);
1241 1229
1242 rate = rs_get_best_rate(priv, lq_sta, tbl, rate_mask, index); 1230 rate = rs_get_best_rate(priv, lq_sta, tbl, rate_mask, index);
@@ -1291,18 +1279,6 @@ static int rs_switch_to_mimo3(struct iwl_priv *priv,
1291 else 1279 else
1292 tbl->is_ht40 = 0; 1280 tbl->is_ht40 = 0;
1293 1281
1294 /* FIXME: - don't toggle SGI here
1295 if (tbl->is_ht40) {
1296 if (priv->current_ht_config.sgf & HT_SHORT_GI_40MHZ_ONLY)
1297 tbl->is_SGI = 1;
1298 else
1299 tbl->is_SGI = 0;
1300 } else if (priv->current_ht_config.sgf & HT_SHORT_GI_20MHZ_ONLY)
1301 tbl->is_SGI = 1;
1302 else
1303 tbl->is_SGI = 0;
1304 */
1305
1306 rs_set_expected_tpt_table(lq_sta, tbl); 1282 rs_set_expected_tpt_table(lq_sta, tbl);
1307 1283
1308 rate = rs_get_best_rate(priv, lq_sta, tbl, rate_mask, index); 1284 rate = rs_get_best_rate(priv, lq_sta, tbl, rate_mask, index);
@@ -1350,18 +1326,6 @@ static int rs_switch_to_siso(struct iwl_priv *priv,
1350 else 1326 else
1351 tbl->is_ht40 = 0; 1327 tbl->is_ht40 = 0;
1352 1328
1353 /* FIXME: - don't toggle SGI here
1354 if (tbl->is_ht40) {
1355 if (priv->current_ht_config.sgf & HT_SHORT_GI_40MHZ_ONLY)
1356 tbl->is_SGI = 1;
1357 else
1358 tbl->is_SGI = 0;
1359 } else if (priv->current_ht_config.sgf & HT_SHORT_GI_20MHZ_ONLY)
1360 tbl->is_SGI = 1;
1361 else
1362 tbl->is_SGI = 0;
1363 */
1364
1365 if (is_green) 1329 if (is_green)
1366 tbl->is_SGI = 0; /*11n spec: no SGI in SISO+Greenfield*/ 1330 tbl->is_SGI = 0; /*11n spec: no SGI in SISO+Greenfield*/
1367 1331
@@ -1530,6 +1494,7 @@ static int rs_move_siso_to_other(struct iwl_priv *priv,
1530 struct iwl_scale_tbl_info *search_tbl = 1494 struct iwl_scale_tbl_info *search_tbl =
1531 &(lq_sta->lq_info[(1 - lq_sta->active_tbl)]); 1495 &(lq_sta->lq_info[(1 - lq_sta->active_tbl)]);
1532 struct iwl_rate_scale_data *window = &(tbl->win[index]); 1496 struct iwl_rate_scale_data *window = &(tbl->win[index]);
1497 struct ieee80211_sta_ht_cap *ht_cap = &sta->ht_cap;
1533 u32 sz = (sizeof(struct iwl_scale_tbl_info) - 1498 u32 sz = (sizeof(struct iwl_scale_tbl_info) -
1534 (sizeof(struct iwl_rate_scale_data) * IWL_RATE_COUNT)); 1499 (sizeof(struct iwl_rate_scale_data) * IWL_RATE_COUNT));
1535 u8 start_action = tbl->action; 1500 u8 start_action = tbl->action;
@@ -1589,13 +1554,11 @@ static int rs_move_siso_to_other(struct iwl_priv *priv,
1589 goto out; 1554 goto out;
1590 break; 1555 break;
1591 case IWL_SISO_SWITCH_GI: 1556 case IWL_SISO_SWITCH_GI:
1592 if (!tbl->is_ht40 && 1557 if (!tbl->is_ht40 && !(ht_cap->cap &
1593 !(priv->current_ht_config.sgf & 1558 IEEE80211_HT_CAP_SGI_20))
1594 HT_SHORT_GI_20MHZ))
1595 break; 1559 break;
1596 if (tbl->is_ht40 && 1560 if (tbl->is_ht40 && !(ht_cap->cap &
1597 !(priv->current_ht_config.sgf & 1561 IEEE80211_HT_CAP_SGI_40))
1598 HT_SHORT_GI_40MHZ))
1599 break; 1562 break;
1600 1563
1601 IWL_DEBUG_RATE(priv, "LQ: SISO toggle SGI/NGI\n"); 1564 IWL_DEBUG_RATE(priv, "LQ: SISO toggle SGI/NGI\n");
@@ -1669,6 +1632,7 @@ static int rs_move_mimo2_to_other(struct iwl_priv *priv,
1669 struct iwl_scale_tbl_info *search_tbl = 1632 struct iwl_scale_tbl_info *search_tbl =
1670 &(lq_sta->lq_info[(1 - lq_sta->active_tbl)]); 1633 &(lq_sta->lq_info[(1 - lq_sta->active_tbl)]);
1671 struct iwl_rate_scale_data *window = &(tbl->win[index]); 1634 struct iwl_rate_scale_data *window = &(tbl->win[index]);
1635 struct ieee80211_sta_ht_cap *ht_cap = &sta->ht_cap;
1672 u32 sz = (sizeof(struct iwl_scale_tbl_info) - 1636 u32 sz = (sizeof(struct iwl_scale_tbl_info) -
1673 (sizeof(struct iwl_rate_scale_data) * IWL_RATE_COUNT)); 1637 (sizeof(struct iwl_rate_scale_data) * IWL_RATE_COUNT));
1674 u8 start_action = tbl->action; 1638 u8 start_action = tbl->action;
@@ -1729,13 +1693,11 @@ static int rs_move_mimo2_to_other(struct iwl_priv *priv,
1729 break; 1693 break;
1730 1694
1731 case IWL_MIMO2_SWITCH_GI: 1695 case IWL_MIMO2_SWITCH_GI:
1732 if (!tbl->is_ht40 && 1696 if (!tbl->is_ht40 && !(ht_cap->cap &
1733 !(priv->current_ht_config.sgf & 1697 IEEE80211_HT_CAP_SGI_20))
1734 HT_SHORT_GI_20MHZ))
1735 break; 1698 break;
1736 if (tbl->is_ht40 && 1699 if (tbl->is_ht40 && !(ht_cap->cap &
1737 !(priv->current_ht_config.sgf & 1700 IEEE80211_HT_CAP_SGI_40))
1738 HT_SHORT_GI_40MHZ))
1739 break; 1701 break;
1740 1702
1741 IWL_DEBUG_RATE(priv, "LQ: MIMO2 toggle SGI/NGI\n"); 1703 IWL_DEBUG_RATE(priv, "LQ: MIMO2 toggle SGI/NGI\n");
@@ -1811,6 +1773,7 @@ static int rs_move_mimo3_to_other(struct iwl_priv *priv,
1811 struct iwl_scale_tbl_info *search_tbl = 1773 struct iwl_scale_tbl_info *search_tbl =
1812 &(lq_sta->lq_info[(1 - lq_sta->active_tbl)]); 1774 &(lq_sta->lq_info[(1 - lq_sta->active_tbl)]);
1813 struct iwl_rate_scale_data *window = &(tbl->win[index]); 1775 struct iwl_rate_scale_data *window = &(tbl->win[index]);
1776 struct ieee80211_sta_ht_cap *ht_cap = &sta->ht_cap;
1814 u32 sz = (sizeof(struct iwl_scale_tbl_info) - 1777 u32 sz = (sizeof(struct iwl_scale_tbl_info) -
1815 (sizeof(struct iwl_rate_scale_data) * IWL_RATE_COUNT)); 1778 (sizeof(struct iwl_rate_scale_data) * IWL_RATE_COUNT));
1816 u8 start_action = tbl->action; 1779 u8 start_action = tbl->action;
@@ -1893,13 +1856,11 @@ static int rs_move_mimo3_to_other(struct iwl_priv *priv,
1893 break; 1856 break;
1894 1857
1895 case IWL_MIMO3_SWITCH_GI: 1858 case IWL_MIMO3_SWITCH_GI:
1896 if (!tbl->is_ht40 && 1859 if (!tbl->is_ht40 && !(ht_cap->cap &
1897 !(priv->current_ht_config.sgf & 1860 IEEE80211_HT_CAP_SGI_20))
1898 HT_SHORT_GI_20MHZ))
1899 break; 1861 break;
1900 if (tbl->is_ht40 && 1862 if (tbl->is_ht40 && !(ht_cap->cap &
1901 !(priv->current_ht_config.sgf & 1863 IEEE80211_HT_CAP_SGI_40))
1902 HT_SHORT_GI_40MHZ))
1903 break; 1864 break;
1904 1865
1905 IWL_DEBUG_RATE(priv, "LQ: MIMO3 toggle SGI/NGI\n"); 1866 IWL_DEBUG_RATE(priv, "LQ: MIMO3 toggle SGI/NGI\n");
diff --git a/drivers/net/wireless/iwlwifi/iwl-core.c b/drivers/net/wireless/iwlwifi/iwl-core.c
index 104fd95dfad6..b845cf30e1bc 100644
--- a/drivers/net/wireless/iwlwifi/iwl-core.c
+++ b/drivers/net/wireless/iwlwifi/iwl-core.c
@@ -2391,11 +2391,6 @@ static void iwl_ht_conf(struct iwl_priv *priv,
2391 } 2391 }
2392 ht_conf = &sta->ht_cap; 2392 ht_conf = &sta->ht_cap;
2393 2393
2394 if (ht_conf->cap & IEEE80211_HT_CAP_SGI_20)
2395 iwl_conf->sgf |= HT_SHORT_GI_20MHZ;
2396 if (ht_conf->cap & IEEE80211_HT_CAP_SGI_40)
2397 iwl_conf->sgf |= HT_SHORT_GI_40MHZ;
2398
2399 iwl_conf->is_green_field = !!(ht_conf->cap & IEEE80211_HT_CAP_GRN_FLD); 2394 iwl_conf->is_green_field = !!(ht_conf->cap & IEEE80211_HT_CAP_GRN_FLD);
2400 2395
2401 iwl_conf->sm_ps = (u8)((ht_conf->cap & IEEE80211_HT_CAP_SM_PS) >> 2); 2396 iwl_conf->sm_ps = (u8)((ht_conf->cap & IEEE80211_HT_CAP_SM_PS) >> 2);
diff --git a/drivers/net/wireless/iwlwifi/iwl-dev.h b/drivers/net/wireless/iwlwifi/iwl-dev.h
index db745343d360..e6a1c6ff44de 100644
--- a/drivers/net/wireless/iwlwifi/iwl-dev.h
+++ b/drivers/net/wireless/iwlwifi/iwl-dev.h
@@ -508,7 +508,6 @@ struct iwl_ht_info {
508 u8 supported_chan_width; 508 u8 supported_chan_width;
509 u8 sm_ps; 509 u8 sm_ps;
510 u8 is_green_field; 510 u8 is_green_field;
511 u8 sgf; /* HT_SHORT_GI_* short guard interval */
512 struct ieee80211_mcs_info mcs; 511 struct ieee80211_mcs_info mcs;
513 /* BSS related data */ 512 /* BSS related data */
514 u8 extension_chan_offset; 513 u8 extension_chan_offset;
@@ -728,9 +727,6 @@ struct iwl_dma_ptr {
728 size_t size; 727 size_t size;
729}; 728};
730 729
731#define HT_SHORT_GI_20MHZ (1 << 0)
732#define HT_SHORT_GI_40MHZ (1 << 1)
733
734#define IWL_CHANNEL_WIDTH_20MHZ 0 730#define IWL_CHANNEL_WIDTH_20MHZ 0
735#define IWL_CHANNEL_WIDTH_40MHZ 1 731#define IWL_CHANNEL_WIDTH_40MHZ 1
736 732