aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/wireless/ath9k
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/net/wireless/ath9k')
-rw-r--r--drivers/net/wireless/ath9k/core.c5
-rw-r--r--drivers/net/wireless/ath9k/hw.c13
-rw-r--r--drivers/net/wireless/ath9k/rc.c159
3 files changed, 83 insertions, 94 deletions
diff --git a/drivers/net/wireless/ath9k/core.c b/drivers/net/wireless/ath9k/core.c
index a9e8ad053a30..e3682b6ccfb2 100644
--- a/drivers/net/wireless/ath9k/core.c
+++ b/drivers/net/wireless/ath9k/core.c
@@ -1025,7 +1025,6 @@ int ath_init(u16 devid, struct ath_softc *sc)
1025 int status; 1025 int status;
1026 int error = 0, i; 1026 int error = 0, i;
1027 int csz = 0; 1027 int csz = 0;
1028 u32 rd;
1029 1028
1030 /* XXX: hardware will not be ready until ath_open() being called */ 1029 /* XXX: hardware will not be ready until ath_open() being called */
1031 sc->sc_flags |= SC_OP_INVALID; 1030 sc->sc_flags |= SC_OP_INVALID;
@@ -1091,8 +1090,6 @@ int ath_init(u16 devid, struct ath_softc *sc)
1091 * is resposible for filtering this list based on settings 1090 * is resposible for filtering this list based on settings
1092 * like the phy mode. 1091 * like the phy mode.
1093 */ 1092 */
1094 rd = ah->ah_currentRD;
1095
1096 error = ath_setup_channels(sc); 1093 error = ath_setup_channels(sc);
1097 if (error) 1094 if (error)
1098 goto bad; 1095 goto bad;
@@ -1169,7 +1166,7 @@ int ath_init(u16 devid, struct ath_softc *sc)
1169 1166
1170 sc->sc_rc = ath_rate_attach(ah); 1167 sc->sc_rc = ath_rate_attach(ah);
1171 if (sc->sc_rc == NULL) { 1168 if (sc->sc_rc == NULL) {
1172 error = EIO; 1169 error = -EIO;
1173 goto bad2; 1170 goto bad2;
1174 } 1171 }
1175 1172
diff --git a/drivers/net/wireless/ath9k/hw.c b/drivers/net/wireless/ath9k/hw.c
index 24b78c2eb44b..7d8c908d69d5 100644
--- a/drivers/net/wireless/ath9k/hw.c
+++ b/drivers/net/wireless/ath9k/hw.c
@@ -7654,8 +7654,7 @@ bool ath9k_hw_resettxqueue(struct ath_hal *ah, u32 q)
7654 REG_WRITE(ah, AR_DRETRY_LIMIT(q), 7654 REG_WRITE(ah, AR_DRETRY_LIMIT(q),
7655 SM(INIT_SSH_RETRY, AR_D_RETRY_LIMIT_STA_SH) 7655 SM(INIT_SSH_RETRY, AR_D_RETRY_LIMIT_STA_SH)
7656 | SM(INIT_SLG_RETRY, AR_D_RETRY_LIMIT_STA_LG) 7656 | SM(INIT_SLG_RETRY, AR_D_RETRY_LIMIT_STA_LG)
7657 | SM(qi->tqi_shretry, AR_D_RETRY_LIMIT_FR_SH) 7657 | SM(qi->tqi_shretry, AR_D_RETRY_LIMIT_FR_SH));
7658 );
7659 7658
7660 REG_WRITE(ah, AR_QMISC(q), AR_Q_MISC_DCU_EARLY_TERM_REQ); 7659 REG_WRITE(ah, AR_QMISC(q), AR_Q_MISC_DCU_EARLY_TERM_REQ);
7661 REG_WRITE(ah, AR_DMISC(q), 7660 REG_WRITE(ah, AR_DMISC(q),
@@ -8300,15 +8299,7 @@ struct ath_hal *ath9k_hw_attach(u16 devid,
8300 *error = -ENXIO; 8299 *error = -ENXIO;
8301 break; 8300 break;
8302 } 8301 }
8303 if (ah != NULL) { 8302
8304 ah->ah_devid = ah->ah_devid;
8305 ah->ah_subvendorid = ah->ah_subvendorid;
8306 ah->ah_macVersion = ah->ah_macVersion;
8307 ah->ah_macRev = ah->ah_macRev;
8308 ah->ah_phyRev = ah->ah_phyRev;
8309 ah->ah_analog5GhzRev = ah->ah_analog5GhzRev;
8310 ah->ah_analog2GhzRev = ah->ah_analog2GhzRev;
8311 }
8312 return ah; 8303 return ah;
8313} 8304}
8314 8305
diff --git a/drivers/net/wireless/ath9k/rc.c b/drivers/net/wireless/ath9k/rc.c
index 1392361ef9a6..1dd7c71daf0a 100644
--- a/drivers/net/wireless/ath9k/rc.c
+++ b/drivers/net/wireless/ath9k/rc.c
@@ -653,8 +653,8 @@ ath_rc_sib_init_validrates(struct ath_rate_node *ath_rc_priv,
653 rate_ctrl = (struct ath_tx_ratectrl *)(ath_rc_priv); 653 rate_ctrl = (struct ath_tx_ratectrl *)(ath_rc_priv);
654 for (i = 0; i < rate_table->rate_cnt; i++) { 654 for (i = 0; i < rate_table->rate_cnt; i++) {
655 valid = (ath_rc_priv->single_stream ? 655 valid = (ath_rc_priv->single_stream ?
656 rate_table->info[i].valid_single_stream : 656 rate_table->info[i].valid_single_stream :
657 rate_table->info[i].valid); 657 rate_table->info[i].valid);
658 if (valid == TRUE) { 658 if (valid == TRUE) {
659 u32 phy = rate_table->info[i].phy; 659 u32 phy = rate_table->info[i].phy;
660 u8 valid_rate_count = 0; 660 u8 valid_rate_count = 0;
@@ -740,14 +740,14 @@ ath_rc_sib_setvalid_htrates(struct ath_rate_node *ath_rc_priv,
740 for (j = 0; j < rate_table->rate_cnt; j++) { 740 for (j = 0; j < rate_table->rate_cnt; j++) {
741 u32 phy = rate_table->info[j].phy; 741 u32 phy = rate_table->info[j].phy;
742 u32 valid = (ath_rc_priv->single_stream ? 742 u32 valid = (ath_rc_priv->single_stream ?
743 rate_table->info[j].valid_single_stream : 743 rate_table->info[j].valid_single_stream :
744 rate_table->info[j].valid); 744 rate_table->info[j].valid);
745 745
746 if (((((struct ath_rateset *) 746 if (((((struct ath_rateset *)
747 mcs_set)->rs_rates[i] & 0x7F) != 747 mcs_set)->rs_rates[i] & 0x7F) !=
748 (rate_table->info[j].dot11rate & 0x7F)) || 748 (rate_table->info[j].dot11rate & 0x7F)) ||
749 !WLAN_RC_PHY_HT(phy) || 749 !WLAN_RC_PHY_HT(phy) ||
750 !WLAN_RC_PHY_HT_VALID(valid, capflag)) 750 !WLAN_RC_PHY_HT_VALID(valid, capflag))
751 continue; 751 continue;
752 752
753 if (!ath_rc_valid_phyrate(phy, capflag, FALSE)) 753 if (!ath_rc_valid_phyrate(phy, capflag, FALSE))
@@ -866,10 +866,10 @@ void ath_rate_newstate(struct ath_softc *sc, struct ath_vap *avp)
866} 866}
867 867
868static u8 ath_rc_ratefind_ht(struct ath_softc *sc, 868static u8 ath_rc_ratefind_ht(struct ath_softc *sc,
869 struct ath_rate_node *ath_rc_priv, 869 struct ath_rate_node *ath_rc_priv,
870 const struct ath_rate_table *rate_table, 870 const struct ath_rate_table *rate_table,
871 int probe_allowed, int *is_probing, 871 int probe_allowed, int *is_probing,
872 int is_retry) 872 int is_retry)
873{ 873{
874 u32 dt, best_thruput, this_thruput, now_msec; 874 u32 dt, best_thruput, this_thruput, now_msec;
875 u8 rate, next_rate, best_rate, maxindex, minindex; 875 u8 rate, next_rate, best_rate, maxindex, minindex;
@@ -997,8 +997,8 @@ static u8 ath_rc_ratefind_ht(struct ath_softc *sc,
997 rate = rate_ctrl->rate_table_size - 1; 997 rate = rate_ctrl->rate_table_size - 1;
998 998
999 ASSERT((rate_table->info[rate].valid && !ath_rc_priv->single_stream) || 999 ASSERT((rate_table->info[rate].valid && !ath_rc_priv->single_stream) ||
1000 (rate_table->info[rate].valid_single_stream && 1000 (rate_table->info[rate].valid_single_stream &&
1001 ath_rc_priv->single_stream)); 1001 ath_rc_priv->single_stream));
1002 1002
1003 return rate; 1003 return rate;
1004} 1004}
@@ -1023,10 +1023,10 @@ static void ath_rc_rate_set_series(const struct ath_rate_table *rate_table ,
1023} 1023}
1024 1024
1025static u8 ath_rc_rate_getidx(struct ath_softc *sc, 1025static u8 ath_rc_rate_getidx(struct ath_softc *sc,
1026 struct ath_rate_node *ath_rc_priv, 1026 struct ath_rate_node *ath_rc_priv,
1027 const struct ath_rate_table *rate_table, 1027 const struct ath_rate_table *rate_table,
1028 u8 rix, u16 stepdown, 1028 u8 rix, u16 stepdown,
1029 u16 min_rate) 1029 u16 min_rate)
1030{ 1030{
1031 u32 j; 1031 u32 j;
1032 u8 nextindex; 1032 u8 nextindex;
@@ -1066,8 +1066,8 @@ static void ath_rc_ratefind(struct ath_softc *sc,
1066 rate_table = 1066 rate_table =
1067 (struct ath_rate_table *)asc->hw_rate_table[sc->sc_curmode]; 1067 (struct ath_rate_table *)asc->hw_rate_table[sc->sc_curmode];
1068 rix = ath_rc_ratefind_ht(sc, ath_rc_priv, rate_table, 1068 rix = ath_rc_ratefind_ht(sc, ath_rc_priv, rate_table,
1069 (rcflag & ATH_RC_PROBE_ALLOWED) ? 1 : 0, 1069 (rcflag & ATH_RC_PROBE_ALLOWED) ? 1 : 0,
1070 is_probe, is_retry); 1070 is_probe, is_retry);
1071 nrix = rix; 1071 nrix = rix;
1072 1072
1073 if ((rcflag & ATH_RC_PROBE_ALLOWED) && (*is_probe)) { 1073 if ((rcflag & ATH_RC_PROBE_ALLOWED) && (*is_probe)) {
@@ -1099,13 +1099,13 @@ static void ath_rc_ratefind(struct ath_softc *sc,
1099 try_num = ((i + 1) == num_rates) ? 1099 try_num = ((i + 1) == num_rates) ?
1100 num_tries - (try_per_rate * i) : try_per_rate ; 1100 num_tries - (try_per_rate * i) : try_per_rate ;
1101 min_rate = (((i + 1) == num_rates) && 1101 min_rate = (((i + 1) == num_rates) &&
1102 (rcflag & ATH_RC_MINRATE_LASTRATE)) ? 1 : 0; 1102 (rcflag & ATH_RC_MINRATE_LASTRATE)) ? 1 : 0;
1103 1103
1104 nrix = ath_rc_rate_getidx(sc, ath_rc_priv, 1104 nrix = ath_rc_rate_getidx(sc, ath_rc_priv,
1105 rate_table, nrix, 1, min_rate); 1105 rate_table, nrix, 1, min_rate);
1106 /* All other rates in the series have RTS enabled */ 1106 /* All other rates in the series have RTS enabled */
1107 ath_rc_rate_set_series(rate_table, 1107 ath_rc_rate_set_series(rate_table,
1108 &series[i], try_num, nrix, TRUE); 1108 &series[i], try_num, nrix, TRUE);
1109 } 1109 }
1110 1110
1111 /* 1111 /*
@@ -1124,13 +1124,13 @@ static void ath_rc_ratefind(struct ath_softc *sc,
1124 * above conditions. 1124 * above conditions.
1125 */ 1125 */
1126 if ((sc->sc_curmode == ATH9K_MODE_11NG_HT20) || 1126 if ((sc->sc_curmode == ATH9K_MODE_11NG_HT20) ||
1127 (sc->sc_curmode == ATH9K_MODE_11NG_HT40PLUS) || 1127 (sc->sc_curmode == ATH9K_MODE_11NG_HT40PLUS) ||
1128 (sc->sc_curmode == ATH9K_MODE_11NG_HT40MINUS)) { 1128 (sc->sc_curmode == ATH9K_MODE_11NG_HT40MINUS)) {
1129 u8 dot11rate = rate_table->info[rix].dot11rate; 1129 u8 dot11rate = rate_table->info[rix].dot11rate;
1130 u8 phy = rate_table->info[rix].phy; 1130 u8 phy = rate_table->info[rix].phy;
1131 if (i == 4 && 1131 if (i == 4 &&
1132 ((dot11rate == 2 && phy == WLAN_RC_PHY_HT_40_SS) || 1132 ((dot11rate == 2 && phy == WLAN_RC_PHY_HT_40_SS) ||
1133 (dot11rate == 3 && phy == WLAN_RC_PHY_HT_20_SS))) { 1133 (dot11rate == 3 && phy == WLAN_RC_PHY_HT_20_SS))) {
1134 series[3].rix = series[2].rix; 1134 series[3].rix = series[2].rix;
1135 series[3].flags = series[2].flags; 1135 series[3].flags = series[2].flags;
1136 series[3].max_4ms_framelen = series[2].max_4ms_framelen; 1136 series[3].max_4ms_framelen = series[2].max_4ms_framelen;
@@ -1152,7 +1152,8 @@ void ath_rate_findrate(struct ath_softc *sc,
1152{ 1152{
1153 struct ath_vap *avp = ath_rc_priv->avp; 1153 struct ath_vap *avp = ath_rc_priv->avp;
1154 1154
1155 DPRINTF(sc, ATH_DBG_RATE, "%s", __func__); 1155 DPRINTF(sc, ATH_DBG_RATE, "%s\n", __func__);
1156
1156 if (!num_rates || !num_tries) 1157 if (!num_rates || !num_tries)
1157 return; 1158 return;
1158 1159
@@ -1174,9 +1175,8 @@ void ath_rate_findrate(struct ath_softc *sc,
1174 unsigned int mcs; 1175 unsigned int mcs;
1175 u8 series_rix = 0; 1176 u8 series_rix = 0;
1176 1177
1177 series[idx].tries = 1178 series[idx].tries = IEEE80211_RATE_IDX_ENTRY(
1178 IEEE80211_RATE_IDX_ENTRY( 1179 avp->av_config.av_fixed_retryset, idx);
1179 avp->av_config.av_fixed_retryset, idx);
1180 1180
1181 mcs = IEEE80211_RATE_IDX_ENTRY( 1181 mcs = IEEE80211_RATE_IDX_ENTRY(
1182 avp->av_config.av_fixed_rateset, idx); 1182 avp->av_config.av_fixed_rateset, idx);
@@ -1228,7 +1228,7 @@ static void ath_rc_update_ht(struct ath_softc *sc,
1228 u32 now_msec = jiffies_to_msecs(jiffies); 1228 u32 now_msec = jiffies_to_msecs(jiffies);
1229 int state_change = FALSE, rate, count; 1229 int state_change = FALSE, rate, count;
1230 u8 last_per; 1230 u8 last_per;
1231 struct ath_rate_softc *asc = (struct ath_rate_softc *)sc->sc_rc; 1231 struct ath_rate_softc *asc = (struct ath_rate_softc *)sc->sc_rc;
1232 struct ath_rate_table *rate_table = 1232 struct ath_rate_table *rate_table =
1233 (struct ath_rate_table *)asc->hw_rate_table[sc->sc_curmode]; 1233 (struct ath_rate_table *)asc->hw_rate_table[sc->sc_curmode];
1234 1234
@@ -1272,14 +1272,14 @@ static void ath_rc_update_ht(struct ath_softc *sc,
1272 } else { 1272 } else {
1273 /* xretries == 2 */ 1273 /* xretries == 2 */
1274 count = sizeof(nretry_to_per_lookup) / 1274 count = sizeof(nretry_to_per_lookup) /
1275 sizeof(nretry_to_per_lookup[0]); 1275 sizeof(nretry_to_per_lookup[0]);
1276 if (retries >= count) 1276 if (retries >= count)
1277 retries = count - 1; 1277 retries = count - 1;
1278 /* new_PER = 7/8*old_PER + 1/8*(currentPER) */ 1278 /* new_PER = 7/8*old_PER + 1/8*(currentPER) */
1279 rate_ctrl->state[tx_rate].per = 1279 rate_ctrl->state[tx_rate].per =
1280 (u8)(rate_ctrl->state[tx_rate].per - 1280 (u8)(rate_ctrl->state[tx_rate].per -
1281 (rate_ctrl->state[tx_rate].per >> 3) + 1281 (rate_ctrl->state[tx_rate].per >> 3) +
1282 ((100) >> 3)); 1282 ((100) >> 3));
1283 } 1283 }
1284 1284
1285 /* xretries == 1 or 2 */ 1285 /* xretries == 1 or 2 */
@@ -1295,8 +1295,7 @@ static void ath_rc_update_ht(struct ath_softc *sc,
1295 if (retries >= count) 1295 if (retries >= count)
1296 retries = count - 1; 1296 retries = count - 1;
1297 if (info_priv->n_bad_frames) { 1297 if (info_priv->n_bad_frames) {
1298 /* new_PER = 7/8*old_PER + 1/8*(currentPER) */ 1298 /* new_PER = 7/8*old_PER + 1/8*(currentPER)
1299 /*
1300 * Assuming that n_frames is not 0. The current PER 1299 * Assuming that n_frames is not 0. The current PER
1301 * from the retries is 100 * retries / (retries+1), 1300 * from the retries is 100 * retries / (retries+1),
1302 * since the first retries attempts failed, and the 1301 * since the first retries attempts failed, and the
@@ -1386,7 +1385,7 @@ static void ath_rc_update_ht(struct ath_softc *sc,
1386 * rssi_ack values. 1385 * rssi_ack values.
1387 */ 1386 */
1388 if (tx_rate == rate_ctrl->rate_max_phy && 1387 if (tx_rate == rate_ctrl->rate_max_phy &&
1389 rate_ctrl->hw_maxretry_pktcnt < 255) { 1388 rate_ctrl->hw_maxretry_pktcnt < 255) {
1390 rate_ctrl->hw_maxretry_pktcnt++; 1389 rate_ctrl->hw_maxretry_pktcnt++;
1391 } 1390 }
1392 1391
@@ -1418,7 +1417,7 @@ static void ath_rc_update_ht(struct ath_softc *sc,
1418 /* Now reduce the current 1417 /* Now reduce the current
1419 * rssi threshold. */ 1418 * rssi threshold. */
1420 if ((rssi_ackAvg < rssi_thres + 2) && 1419 if ((rssi_ackAvg < rssi_thres + 2) &&
1421 (rssi_thres > rssi_ack_vmin)) { 1420 (rssi_thres > rssi_ack_vmin)) {
1422 rate_ctrl->state[tx_rate]. 1421 rate_ctrl->state[tx_rate].
1423 rssi_thres--; 1422 rssi_thres--;
1424 } 1423 }
@@ -1436,10 +1435,10 @@ static void ath_rc_update_ht(struct ath_softc *sc,
1436 * a while (except if we are probing). 1435 * a while (except if we are probing).
1437 */ 1436 */
1438 if (rate_ctrl->state[tx_rate].per >= 55 && tx_rate > 0 && 1437 if (rate_ctrl->state[tx_rate].per >= 55 && tx_rate > 0 &&
1439 rate_table->info[tx_rate].ratekbps <= 1438 rate_table->info[tx_rate].ratekbps <=
1440 rate_table->info[rate_ctrl->rate_max_phy].ratekbps) { 1439 rate_table->info[rate_ctrl->rate_max_phy].ratekbps) {
1441 ath_rc_get_nextlowervalid_txrate(rate_table, rate_ctrl, 1440 ath_rc_get_nextlowervalid_txrate(rate_table, rate_ctrl,
1442 (u8) tx_rate, &rate_ctrl->rate_max_phy); 1441 (u8) tx_rate, &rate_ctrl->rate_max_phy);
1443 1442
1444 /* Don't probe for a little while. */ 1443 /* Don't probe for a little while. */
1445 rate_ctrl->probe_time = now_msec; 1444 rate_ctrl->probe_time = now_msec;
@@ -1460,43 +1459,43 @@ static void ath_rc_update_ht(struct ath_softc *sc,
1460 break; 1459 break;
1461 1460
1462 if (rate_ctrl->state[rate].rssi_thres + 1461 if (rate_ctrl->state[rate].rssi_thres +
1463 rate_table->info[rate].rssi_ack_deltamin > 1462 rate_table->info[rate].rssi_ack_deltamin >
1464 rate_ctrl->state[rate+1].rssi_thres) { 1463 rate_ctrl->state[rate+1].rssi_thres) {
1465 rate_ctrl->state[rate+1].rssi_thres = 1464 rate_ctrl->state[rate+1].rssi_thres =
1466 rate_ctrl->state[rate]. 1465 rate_ctrl->state[rate].
1467 rssi_thres + 1466 rssi_thres +
1468 rate_table->info[rate]. 1467 rate_table->info[rate].
1469 rssi_ack_deltamin; 1468 rssi_ack_deltamin;
1470 } 1469 }
1471 } 1470 }
1472 1471
1473 /* Make sure the rates below this have lower rssi thresholds. */ 1472 /* Make sure the rates below this have lower rssi thresholds. */
1474 for (rate = tx_rate - 1; rate >= 0; rate--) { 1473 for (rate = tx_rate - 1; rate >= 0; rate--) {
1475 if (rate_table->info[rate].phy != 1474 if (rate_table->info[rate].phy !=
1476 rate_table->info[tx_rate].phy) 1475 rate_table->info[tx_rate].phy)
1477 break; 1476 break;
1478 1477
1479 if (rate_ctrl->state[rate].rssi_thres + 1478 if (rate_ctrl->state[rate].rssi_thres +
1480 rate_table->info[rate].rssi_ack_deltamin > 1479 rate_table->info[rate].rssi_ack_deltamin >
1481 rate_ctrl->state[rate+1].rssi_thres) { 1480 rate_ctrl->state[rate+1].rssi_thres) {
1482 if (rate_ctrl->state[rate+1].rssi_thres < 1481 if (rate_ctrl->state[rate+1].rssi_thres <
1483 rate_table->info[rate]. 1482 rate_table->info[rate].
1484 rssi_ack_deltamin) 1483 rssi_ack_deltamin)
1485 rate_ctrl->state[rate].rssi_thres = 0; 1484 rate_ctrl->state[rate].rssi_thres = 0;
1486 else { 1485 else {
1487 rate_ctrl->state[rate].rssi_thres = 1486 rate_ctrl->state[rate].rssi_thres =
1488 rate_ctrl->state[rate+1]. 1487 rate_ctrl->state[rate+1].
1489 rssi_thres - 1488 rssi_thres -
1490 rate_table->info[rate]. 1489 rate_table->info[rate].
1491 rssi_ack_deltamin; 1490 rssi_ack_deltamin;
1492 } 1491 }
1493 1492
1494 if (rate_ctrl->state[rate].rssi_thres < 1493 if (rate_ctrl->state[rate].rssi_thres <
1495 rate_table->info[rate]. 1494 rate_table->info[rate].
1496 rssi_ack_validmin) { 1495 rssi_ack_validmin) {
1497 rate_ctrl->state[rate].rssi_thres = 1496 rate_ctrl->state[rate].rssi_thres =
1498 rate_table->info[rate]. 1497 rate_table->info[rate].
1499 rssi_ack_validmin; 1498 rssi_ack_validmin;
1500 } 1499 }
1501 } 1500 }
1502 } 1501 }
@@ -1507,11 +1506,11 @@ static void ath_rc_update_ht(struct ath_softc *sc,
1507 if (rate_ctrl->state[tx_rate].per < last_per) { 1506 if (rate_ctrl->state[tx_rate].per < last_per) {
1508 for (rate = tx_rate - 1; rate >= 0; rate--) { 1507 for (rate = tx_rate - 1; rate >= 0; rate--) {
1509 if (rate_table->info[rate].phy != 1508 if (rate_table->info[rate].phy !=
1510 rate_table->info[tx_rate].phy) 1509 rate_table->info[tx_rate].phy)
1511 break; 1510 break;
1512 1511
1513 if (rate_ctrl->state[rate].per > 1512 if (rate_ctrl->state[rate].per >
1514 rate_ctrl->state[rate+1].per) { 1513 rate_ctrl->state[rate+1].per) {
1515 rate_ctrl->state[rate].per = 1514 rate_ctrl->state[rate].per =
1516 rate_ctrl->state[rate+1].per; 1515 rate_ctrl->state[rate+1].per;
1517 } 1516 }
@@ -1528,11 +1527,11 @@ static void ath_rc_update_ht(struct ath_softc *sc,
1528 /* Every so often, we reduce the thresholds and 1527 /* Every so often, we reduce the thresholds and
1529 * PER (different for CCK and OFDM). */ 1528 * PER (different for CCK and OFDM). */
1530 if (now_msec - rate_ctrl->rssi_down_time >= 1529 if (now_msec - rate_ctrl->rssi_down_time >=
1531 rate_table->rssi_reduce_interval) { 1530 rate_table->rssi_reduce_interval) {
1532 1531
1533 for (rate = 0; rate < rate_ctrl->rate_table_size; rate++) { 1532 for (rate = 0; rate < rate_ctrl->rate_table_size; rate++) {
1534 if (rate_ctrl->state[rate].rssi_thres > 1533 if (rate_ctrl->state[rate].rssi_thres >
1535 rate_table->info[rate].rssi_ack_validmin) 1534 rate_table->info[rate].rssi_ack_validmin)
1536 rate_ctrl->state[rate].rssi_thres -= 1; 1535 rate_ctrl->state[rate].rssi_thres -= 1;
1537 } 1536 }
1538 rate_ctrl->rssi_down_time = now_msec; 1537 rate_ctrl->rssi_down_time = now_msec;
@@ -1541,7 +1540,7 @@ static void ath_rc_update_ht(struct ath_softc *sc,
1541 /* Every so often, we reduce the thresholds 1540 /* Every so often, we reduce the thresholds
1542 * and PER (different for CCK and OFDM). */ 1541 * and PER (different for CCK and OFDM). */
1543 if (now_msec - rate_ctrl->per_down_time >= 1542 if (now_msec - rate_ctrl->per_down_time >=
1544 rate_table->rssi_reduce_interval) { 1543 rate_table->rssi_reduce_interval) {
1545 for (rate = 0; rate < rate_ctrl->rate_table_size; rate++) { 1544 for (rate = 0; rate < rate_ctrl->rate_table_size; rate++) {
1546 rate_ctrl->state[rate].per = 1545 rate_ctrl->state[rate].per =
1547 7 * rate_ctrl->state[rate].per / 8; 1546 7 * rate_ctrl->state[rate].per / 8;
@@ -1560,7 +1559,7 @@ static void ath_rc_update(struct ath_softc *sc,
1560 struct ath_tx_info_priv *info_priv, int final_ts_idx, 1559 struct ath_tx_info_priv *info_priv, int final_ts_idx,
1561 int xretries, int long_retry) 1560 int xretries, int long_retry)
1562{ 1561{
1563 struct ath_rate_softc *asc = (struct ath_rate_softc *)sc->sc_rc; 1562 struct ath_rate_softc *asc = (struct ath_rate_softc *)sc->sc_rc;
1564 struct ath_rate_table *rate_table; 1563 struct ath_rate_table *rate_table;
1565 struct ath_tx_ratectrl *rate_ctrl; 1564 struct ath_tx_ratectrl *rate_ctrl;
1566 struct ath_rc_series rcs[4]; 1565 struct ath_rc_series rcs[4];
@@ -1637,7 +1636,6 @@ static void ath_rc_update(struct ath_softc *sc,
1637 xretries, long_retry); 1636 xretries, long_retry);
1638} 1637}
1639 1638
1640
1641/* 1639/*
1642 * Process a tx descriptor for a completed transmit (success or failure). 1640 * Process a tx descriptor for a completed transmit (success or failure).
1643 */ 1641 */
@@ -1651,13 +1649,13 @@ static void ath_rate_tx_complete(struct ath_softc *sc,
1651 struct ath_vap *avp; 1649 struct ath_vap *avp;
1652 1650
1653 avp = rc_priv->avp; 1651 avp = rc_priv->avp;
1654 if ((avp->av_config.av_fixed_rateset != IEEE80211_FIXED_RATE_NONE) 1652 if ((avp->av_config.av_fixed_rateset != IEEE80211_FIXED_RATE_NONE) ||
1655 || info_priv->tx.ts_status & ATH9K_TXERR_FILT) 1653 (info_priv->tx.ts_status & ATH9K_TXERR_FILT))
1656 return; 1654 return;
1657 1655
1658 if (info_priv->tx.ts_rssi > 0) { 1656 if (info_priv->tx.ts_rssi > 0) {
1659 ATH_RSSI_LPF(an->an_chainmask_sel.tx_avgrssi, 1657 ATH_RSSI_LPF(an->an_chainmask_sel.tx_avgrssi,
1660 info_priv->tx.ts_rssi); 1658 info_priv->tx.ts_rssi);
1661 } 1659 }
1662 1660
1663 /* 1661 /*
@@ -1682,7 +1680,6 @@ static void ath_rate_tx_complete(struct ath_softc *sc,
1682 info_priv->tx.ts_longretry); 1680 info_priv->tx.ts_longretry);
1683} 1681}
1684 1682
1685
1686/* 1683/*
1687 * Update the SIB's rate control information 1684 * Update the SIB's rate control information
1688 * 1685 *
@@ -1701,8 +1698,8 @@ static void ath_rc_sib_update(struct ath_softc *sc,
1701 struct ath_rate_softc *asc = (struct ath_rate_softc *)sc->sc_rc; 1698 struct ath_rate_softc *asc = (struct ath_rate_softc *)sc->sc_rc;
1702 struct ath_rateset *rateset = negotiated_rates; 1699 struct ath_rateset *rateset = negotiated_rates;
1703 u8 *ht_mcs = (u8 *)negotiated_htrates; 1700 u8 *ht_mcs = (u8 *)negotiated_htrates;
1704 struct ath_tx_ratectrl *rate_ctrl = (struct ath_tx_ratectrl *) 1701 struct ath_tx_ratectrl *rate_ctrl =
1705 (ath_rc_priv); 1702 (struct ath_tx_ratectrl *)ath_rc_priv;
1706 u8 i, j, k, hi = 0, hthi = 0; 1703 u8 i, j, k, hi = 0, hthi = 0;
1707 1704
1708 rate_table = (struct ath_rate_table *) 1705 rate_table = (struct ath_rate_table *)
@@ -1824,7 +1821,8 @@ static void ath_setup_rates(struct ieee80211_local *local, struct sta_info *sta)
1824 struct ath_rate_node *rc_priv = sta->rate_ctrl_priv; 1821 struct ath_rate_node *rc_priv = sta->rate_ctrl_priv;
1825 int i, j = 0; 1822 int i, j = 0;
1826 1823
1827 DPRINTF(sc, ATH_DBG_RATE, "%s", __func__); 1824 DPRINTF(sc, ATH_DBG_RATE, "%s\n", __func__);
1825
1828 sband = local->hw.wiphy->bands[local->hw.conf.channel->band]; 1826 sband = local->hw.wiphy->bands[local->hw.conf.channel->band];
1829 for (i = 0; i < sband->n_bitrates; i++) { 1827 for (i = 0; i < sband->n_bitrates; i++) {
1830 if (sta->supp_rates[local->hw.conf.channel->band] & BIT(i)) { 1828 if (sta->supp_rates[local->hw.conf.channel->band] & BIT(i)) {
@@ -1962,7 +1960,7 @@ static void ath_get_rate(void *priv, struct net_device *dev,
1962 tx_info_priv->min_rate = (sband->bitrates[lowest_idx].bitrate * 2) / 10; 1960 tx_info_priv->min_rate = (sband->bitrates[lowest_idx].bitrate * 2) / 10;
1963 /* lowest rate for management and multicast/broadcast frames */ 1961 /* lowest rate for management and multicast/broadcast frames */
1964 if (!ieee80211_is_data(fc) || 1962 if (!ieee80211_is_data(fc) ||
1965 is_multicast_ether_addr(hdr->addr1) || !sta) { 1963 is_multicast_ether_addr(hdr->addr1) || !sta) {
1966 sel->rate_idx = lowest_idx; 1964 sel->rate_idx = lowest_idx;
1967 return; 1965 return;
1968 } 1966 }
@@ -1978,7 +1976,7 @@ static void ath_get_rate(void *priv, struct net_device *dev,
1978 false); 1976 false);
1979 if (is_probe) 1977 if (is_probe)
1980 sel->probe_idx = ((struct ath_tx_ratectrl *) 1978 sel->probe_idx = ((struct ath_tx_ratectrl *)
1981 sta->rate_ctrl_priv)->probe_rate; 1979 sta->rate_ctrl_priv)->probe_rate;
1982 1980
1983 /* Ratecontrol sometimes returns invalid rate index */ 1981 /* Ratecontrol sometimes returns invalid rate index */
1984 if (tx_info_priv->rcs[0].rix != 0xff) 1982 if (tx_info_priv->rcs[0].rix != 0xff)
@@ -2035,6 +2033,7 @@ static void ath_rate_init(void *priv, void *priv_sta,
2035 struct ieee80211_hw *hw = local_to_hw(local); 2033 struct ieee80211_hw *hw = local_to_hw(local);
2036 struct ieee80211_conf *conf = &local->hw.conf; 2034 struct ieee80211_conf *conf = &local->hw.conf;
2037 struct ath_softc *sc = hw->priv; 2035 struct ath_softc *sc = hw->priv;
2036 struct ath_rate_node *ath_rc_priv = priv_sta;
2038 int i, j = 0; 2037 int i, j = 0;
2039 2038
2040 DPRINTF(sc, ATH_DBG_RATE, "%s\n", __func__); 2039 DPRINTF(sc, ATH_DBG_RATE, "%s\n", __func__);
@@ -2046,12 +2045,11 @@ static void ath_rate_init(void *priv, void *priv_sta,
2046 if (conf->flags & IEEE80211_CONF_SUPPORT_HT_MODE) { 2045 if (conf->flags & IEEE80211_CONF_SUPPORT_HT_MODE) {
2047 for (i = 0; i < MCS_SET_SIZE; i++) { 2046 for (i = 0; i < MCS_SET_SIZE; i++) {
2048 if (conf->ht_conf.supp_mcs_set[i/8] & (1<<(i%8))) 2047 if (conf->ht_conf.supp_mcs_set[i/8] & (1<<(i%8)))
2049 ((struct ath_rate_node *) 2048 ath_rc_priv->neg_ht_rates.rs_rates[j++] = i;
2050 priv_sta)->neg_ht_rates.rs_rates[j++] = i;
2051 if (j == ATH_RATE_MAX) 2049 if (j == ATH_RATE_MAX)
2052 break; 2050 break;
2053 } 2051 }
2054 ((struct ath_rate_node *)priv_sta)->neg_ht_rates.rs_nrates = j; 2052 ath_rc_priv->neg_ht_rates.rs_nrates = j;
2055 } 2053 }
2056 ath_rc_node_update(hw, priv_sta); 2054 ath_rc_node_update(hw, priv_sta);
2057} 2055}
@@ -2066,7 +2064,7 @@ static void *ath_rate_alloc(struct ieee80211_local *local)
2066 struct ieee80211_hw *hw = local_to_hw(local); 2064 struct ieee80211_hw *hw = local_to_hw(local);
2067 struct ath_softc *sc = hw->priv; 2065 struct ath_softc *sc = hw->priv;
2068 2066
2069 DPRINTF(sc, ATH_DBG_RATE, "%s", __func__); 2067 DPRINTF(sc, ATH_DBG_RATE, "%s\n", __func__);
2070 return local->hw.priv; 2068 return local->hw.priv;
2071} 2069}
2072 2070
@@ -2081,14 +2079,17 @@ static void *ath_rate_alloc_sta(void *priv, gfp_t gfp)
2081 struct ath_vap *avp = sc->sc_vaps[0]; 2079 struct ath_vap *avp = sc->sc_vaps[0];
2082 struct ath_rate_node *rate_priv; 2080 struct ath_rate_node *rate_priv;
2083 2081
2084 DPRINTF(sc, ATH_DBG_RATE, "%s", __func__); 2082 DPRINTF(sc, ATH_DBG_RATE, "%s\n", __func__);
2083
2085 rate_priv = ath_rate_node_alloc(avp, sc->sc_rc, gfp); 2084 rate_priv = ath_rate_node_alloc(avp, sc->sc_rc, gfp);
2086 if (!rate_priv) { 2085 if (!rate_priv) {
2087 DPRINTF(sc, ATH_DBG_FATAL, "%s:Unable to allocate" 2086 DPRINTF(sc, ATH_DBG_FATAL,
2088 "private rate control structure", __func__); 2087 "%s: Unable to allocate private rc structure\n",
2088 __func__);
2089 return NULL; 2089 return NULL;
2090 } 2090 }
2091 ath_rc_sib_init(rate_priv); 2091 ath_rc_sib_init(rate_priv);
2092
2092 return rate_priv; 2093 return rate_priv;
2093} 2094}
2094 2095