diff options
Diffstat (limited to 'drivers/net')
-rw-r--r-- | drivers/net/wireless/ath/ath9k/rc.c | 50 | ||||
-rw-r--r-- | drivers/net/wireless/ath/ath9k/rc.h | 7 |
2 files changed, 27 insertions, 30 deletions
diff --git a/drivers/net/wireless/ath/ath9k/rc.c b/drivers/net/wireless/ath/ath9k/rc.c index a97dd7b6b706..a07efa22551e 100644 --- a/drivers/net/wireless/ath/ath9k/rc.c +++ b/drivers/net/wireless/ath/ath9k/rc.c | |||
@@ -636,7 +636,7 @@ static u8 ath_rc_get_highest_rix(struct ath_softc *sc, | |||
636 | * 10-15 and we would be worse off then staying | 636 | * 10-15 and we would be worse off then staying |
637 | * at the current rate. | 637 | * at the current rate. |
638 | */ | 638 | */ |
639 | per_thres = ath_rc_priv->state[rate].per; | 639 | per_thres = ath_rc_priv->per[rate]; |
640 | if (per_thres < 12) | 640 | if (per_thres < 12) |
641 | per_thres = 12; | 641 | per_thres = 12; |
642 | 642 | ||
@@ -881,13 +881,13 @@ static bool ath_rc_update_per(struct ath_softc *sc, | |||
881 | 100 * 9 / 10 | 881 | 100 * 9 / 10 |
882 | }; | 882 | }; |
883 | 883 | ||
884 | last_per = ath_rc_priv->state[tx_rate].per; | 884 | last_per = ath_rc_priv->per[tx_rate]; |
885 | 885 | ||
886 | if (xretries) { | 886 | if (xretries) { |
887 | if (xretries == 1) { | 887 | if (xretries == 1) { |
888 | ath_rc_priv->state[tx_rate].per += 30; | 888 | ath_rc_priv->per[tx_rate] += 30; |
889 | if (ath_rc_priv->state[tx_rate].per > 100) | 889 | if (ath_rc_priv->per[tx_rate] > 100) |
890 | ath_rc_priv->state[tx_rate].per = 100; | 890 | ath_rc_priv->per[tx_rate] = 100; |
891 | } else { | 891 | } else { |
892 | /* xretries == 2 */ | 892 | /* xretries == 2 */ |
893 | count = ARRAY_SIZE(nretry_to_per_lookup); | 893 | count = ARRAY_SIZE(nretry_to_per_lookup); |
@@ -895,7 +895,7 @@ static bool ath_rc_update_per(struct ath_softc *sc, | |||
895 | retries = count - 1; | 895 | retries = count - 1; |
896 | 896 | ||
897 | /* new_PER = 7/8*old_PER + 1/8*(currentPER) */ | 897 | /* new_PER = 7/8*old_PER + 1/8*(currentPER) */ |
898 | ath_rc_priv->state[tx_rate].per = | 898 | ath_rc_priv->per[tx_rate] = |
899 | (u8)(last_per - (last_per >> 3) + (100 >> 3)); | 899 | (u8)(last_per - (last_per >> 3) + (100 >> 3)); |
900 | } | 900 | } |
901 | 901 | ||
@@ -931,10 +931,10 @@ static bool ath_rc_update_per(struct ath_softc *sc, | |||
931 | n_frames = tx_info_priv->n_frames * (retries + 1); | 931 | n_frames = tx_info_priv->n_frames * (retries + 1); |
932 | cur_per = (100 * n_bad_frames / n_frames) >> 3; | 932 | cur_per = (100 * n_bad_frames / n_frames) >> 3; |
933 | new_per = (u8)(last_per - (last_per >> 3) + cur_per); | 933 | new_per = (u8)(last_per - (last_per >> 3) + cur_per); |
934 | ath_rc_priv->state[tx_rate].per = new_per; | 934 | ath_rc_priv->per[tx_rate] = new_per; |
935 | } | 935 | } |
936 | } else { | 936 | } else { |
937 | ath_rc_priv->state[tx_rate].per = | 937 | ath_rc_priv->per[tx_rate] = |
938 | (u8)(last_per - (last_per >> 3) + | 938 | (u8)(last_per - (last_per >> 3) + |
939 | (nretry_to_per_lookup[retries] >> 3)); | 939 | (nretry_to_per_lookup[retries] >> 3)); |
940 | } | 940 | } |
@@ -962,8 +962,8 @@ static bool ath_rc_update_per(struct ath_softc *sc, | |||
962 | ath_rc_priv->probe_rate; | 962 | ath_rc_priv->probe_rate; |
963 | probe_rate = ath_rc_priv->probe_rate; | 963 | probe_rate = ath_rc_priv->probe_rate; |
964 | 964 | ||
965 | if (ath_rc_priv->state[probe_rate].per > 30) | 965 | if (ath_rc_priv->per[probe_rate] > 30) |
966 | ath_rc_priv->state[probe_rate].per = 20; | 966 | ath_rc_priv->per[probe_rate] = 20; |
967 | 967 | ||
968 | ath_rc_priv->probe_rate = 0; | 968 | ath_rc_priv->probe_rate = 0; |
969 | 969 | ||
@@ -1018,7 +1018,7 @@ static void ath_rc_update_ht(struct ath_softc *sc, | |||
1018 | if ((tx_rate < 0) || (tx_rate > rate_table->rate_cnt)) | 1018 | if ((tx_rate < 0) || (tx_rate > rate_table->rate_cnt)) |
1019 | return; | 1019 | return; |
1020 | 1020 | ||
1021 | last_per = ath_rc_priv->state[tx_rate].per; | 1021 | last_per = ath_rc_priv->per[tx_rate]; |
1022 | 1022 | ||
1023 | /* Update PER first */ | 1023 | /* Update PER first */ |
1024 | state_change = ath_rc_update_per(sc, rate_table, ath_rc_priv, | 1024 | state_change = ath_rc_update_per(sc, rate_table, ath_rc_priv, |
@@ -1029,7 +1029,7 @@ static void ath_rc_update_ht(struct ath_softc *sc, | |||
1029 | * If this rate looks bad (high PER) then stop using it for | 1029 | * If this rate looks bad (high PER) then stop using it for |
1030 | * a while (except if we are probing). | 1030 | * a while (except if we are probing). |
1031 | */ | 1031 | */ |
1032 | if (ath_rc_priv->state[tx_rate].per >= 55 && tx_rate > 0 && | 1032 | if (ath_rc_priv->per[tx_rate] >= 55 && tx_rate > 0 && |
1033 | rate_table->info[tx_rate].ratekbps <= | 1033 | rate_table->info[tx_rate].ratekbps <= |
1034 | rate_table->info[ath_rc_priv->rate_max_phy].ratekbps) { | 1034 | rate_table->info[ath_rc_priv->rate_max_phy].ratekbps) { |
1035 | ath_rc_get_lower_rix(rate_table, ath_rc_priv, | 1035 | ath_rc_get_lower_rix(rate_table, ath_rc_priv, |
@@ -1041,26 +1041,26 @@ static void ath_rc_update_ht(struct ath_softc *sc, | |||
1041 | 1041 | ||
1042 | /* Make sure the rates below this have lower PER */ | 1042 | /* Make sure the rates below this have lower PER */ |
1043 | /* Monotonicity is kept only for rates below the current rate. */ | 1043 | /* Monotonicity is kept only for rates below the current rate. */ |
1044 | if (ath_rc_priv->state[tx_rate].per < last_per) { | 1044 | if (ath_rc_priv->per[tx_rate] < last_per) { |
1045 | for (rate = tx_rate - 1; rate >= 0; rate--) { | 1045 | for (rate = tx_rate - 1; rate >= 0; rate--) { |
1046 | if (rate_table->info[rate].phy != | 1046 | if (rate_table->info[rate].phy != |
1047 | rate_table->info[tx_rate].phy) | 1047 | rate_table->info[tx_rate].phy) |
1048 | break; | 1048 | break; |
1049 | 1049 | ||
1050 | if (ath_rc_priv->state[rate].per > | 1050 | if (ath_rc_priv->per[rate] > |
1051 | ath_rc_priv->state[rate+1].per) { | 1051 | ath_rc_priv->per[rate+1]) { |
1052 | ath_rc_priv->state[rate].per = | 1052 | ath_rc_priv->per[rate] = |
1053 | ath_rc_priv->state[rate+1].per; | 1053 | ath_rc_priv->per[rate+1]; |
1054 | } | 1054 | } |
1055 | } | 1055 | } |
1056 | } | 1056 | } |
1057 | 1057 | ||
1058 | /* Maintain monotonicity for rates above the current rate */ | 1058 | /* Maintain monotonicity for rates above the current rate */ |
1059 | for (rate = tx_rate; rate < size - 1; rate++) { | 1059 | for (rate = tx_rate; rate < size - 1; rate++) { |
1060 | if (ath_rc_priv->state[rate+1].per < | 1060 | if (ath_rc_priv->per[rate+1] < |
1061 | ath_rc_priv->state[rate].per) | 1061 | ath_rc_priv->per[rate]) |
1062 | ath_rc_priv->state[rate+1].per = | 1062 | ath_rc_priv->per[rate+1] = |
1063 | ath_rc_priv->state[rate].per; | 1063 | ath_rc_priv->per[rate]; |
1064 | } | 1064 | } |
1065 | 1065 | ||
1066 | /* Every so often, we reduce the thresholds | 1066 | /* Every so often, we reduce the thresholds |
@@ -1068,15 +1068,15 @@ static void ath_rc_update_ht(struct ath_softc *sc, | |||
1068 | if (now_msec - ath_rc_priv->per_down_time >= | 1068 | if (now_msec - ath_rc_priv->per_down_time >= |
1069 | rate_table->probe_interval) { | 1069 | rate_table->probe_interval) { |
1070 | for (rate = 0; rate < size; rate++) { | 1070 | for (rate = 0; rate < size; rate++) { |
1071 | ath_rc_priv->state[rate].per = | 1071 | ath_rc_priv->per[rate] = |
1072 | 7 * ath_rc_priv->state[rate].per / 8; | 1072 | 7 * ath_rc_priv->per[rate] / 8; |
1073 | } | 1073 | } |
1074 | 1074 | ||
1075 | ath_rc_priv->per_down_time = now_msec; | 1075 | ath_rc_priv->per_down_time = now_msec; |
1076 | } | 1076 | } |
1077 | 1077 | ||
1078 | ath_debug_stat_retries(sc, tx_rate, xretries, retries, | 1078 | ath_debug_stat_retries(sc, tx_rate, xretries, retries, |
1079 | ath_rc_priv->state[tx_rate].per); | 1079 | ath_rc_priv->per[tx_rate]); |
1080 | 1080 | ||
1081 | } | 1081 | } |
1082 | 1082 | ||
@@ -1213,7 +1213,7 @@ static void ath_rc_init(struct ath_softc *sc, | |||
1213 | 1213 | ||
1214 | /* Initialize thresholds according to the global rate table */ | 1214 | /* Initialize thresholds according to the global rate table */ |
1215 | for (i = 0 ; i < ath_rc_priv->rate_table_size; i++) { | 1215 | for (i = 0 ; i < ath_rc_priv->rate_table_size; i++) { |
1216 | ath_rc_priv->state[i].per = 0; | 1216 | ath_rc_priv->per[i] = 0; |
1217 | } | 1217 | } |
1218 | 1218 | ||
1219 | /* Determine the valid rates */ | 1219 | /* Determine the valid rates */ |
diff --git a/drivers/net/wireless/ath/ath9k/rc.h b/drivers/net/wireless/ath/ath9k/rc.h index c794d6c82ad4..fa21a628ddd0 100644 --- a/drivers/net/wireless/ath/ath9k/rc.h +++ b/drivers/net/wireless/ath/ath9k/rc.h | |||
@@ -122,10 +122,6 @@ struct ath_rate_table { | |||
122 | u8 initial_ratemax; | 122 | u8 initial_ratemax; |
123 | }; | 123 | }; |
124 | 124 | ||
125 | struct ath_tx_ratectrl_state { | ||
126 | u8 per; /* recent estimate of packet error rate (%) */ | ||
127 | }; | ||
128 | |||
129 | struct ath_rateset { | 125 | struct ath_rateset { |
130 | u8 rs_nrates; | 126 | u8 rs_nrates; |
131 | u8 rs_rates[ATH_RATE_MAX]; | 127 | u8 rs_rates[ATH_RATE_MAX]; |
@@ -141,6 +137,7 @@ struct ath_rateset { | |||
141 | * @per_down_time: msec timestamp for last PER down step | 137 | * @per_down_time: msec timestamp for last PER down step |
142 | * @valid_phy_ratecnt: valid rate count | 138 | * @valid_phy_ratecnt: valid rate count |
143 | * @rate_max_phy: phy index for the max rate | 139 | * @rate_max_phy: phy index for the max rate |
140 | * @per: PER for every valid rate in % | ||
144 | * @probe_interval: interval for ratectrl to probe for other rates | 141 | * @probe_interval: interval for ratectrl to probe for other rates |
145 | * @prev_data_rix: rate idx of last data frame | 142 | * @prev_data_rix: rate idx of last data frame |
146 | * @ht_cap: HT capabilities | 143 | * @ht_cap: HT capabilities |
@@ -157,12 +154,12 @@ struct ath_rate_priv { | |||
157 | u8 valid_phy_ratecnt[WLAN_RC_PHY_MAX]; | 154 | u8 valid_phy_ratecnt[WLAN_RC_PHY_MAX]; |
158 | u8 valid_phy_rateidx[WLAN_RC_PHY_MAX][RATE_TABLE_SIZE]; | 155 | u8 valid_phy_rateidx[WLAN_RC_PHY_MAX][RATE_TABLE_SIZE]; |
159 | u8 rate_max_phy; | 156 | u8 rate_max_phy; |
157 | u8 per[RATE_TABLE_SIZE]; | ||
160 | u32 probe_time; | 158 | u32 probe_time; |
161 | u32 per_down_time; | 159 | u32 per_down_time; |
162 | u32 probe_interval; | 160 | u32 probe_interval; |
163 | u32 prev_data_rix; | 161 | u32 prev_data_rix; |
164 | u32 tx_triglevel_max; | 162 | u32 tx_triglevel_max; |
165 | struct ath_tx_ratectrl_state state[RATE_TABLE_SIZE]; | ||
166 | struct ath_rateset neg_rates; | 163 | struct ath_rateset neg_rates; |
167 | struct ath_rateset neg_ht_rates; | 164 | struct ath_rateset neg_ht_rates; |
168 | struct ath_rate_softc *asc; | 165 | struct ath_rate_softc *asc; |