Commit 1e9c27df authored by Thomas Huehn's avatar Thomas Huehn Committed by Johannes Berg

mac80211: extend minstrel's rate sampling to avoid unsampled rates

Minstrel's decision which rate should be directly sampled within the
1st mrr stage is limited to such rates faster than the current max
throughput rate. All rates below the current max. throughput rate
are indirectly sampled via the 2nd mrr stage.
This approach leads to deprecated per rate statistics and therfore
a deprecated mrr chain setup.

This patch uses the sampling approach from minstrel_ht. A counter is
added to sum all indirect sample attempts per rate. After 20 indirect
sampling attempts the rate is directly sampled within the 1st mrr stage.
Therefore more up-to-date statistics for all rates are maintained and
used to setup the mrr chain.
Acked-by: default avatarFelix Fietkau <nbd@openwrt.org>
Signed-off-by: default avatarThomas Huehn <thomas@net.t-labs.tu-berlin.de>
Signed-off-by: default avatarJohannes Berg <johannes.berg@intel.com>
parent 8f157611
...@@ -85,7 +85,8 @@ minstrel_update_stats(struct minstrel_priv *mp, struct minstrel_sta_info *mi) ...@@ -85,7 +85,8 @@ minstrel_update_stats(struct minstrel_priv *mp, struct minstrel_sta_info *mi)
if (!usecs) if (!usecs)
usecs = 1000000; usecs = 1000000;
if (mr->attempts) { if (unlikely(mr->attempts > 0)) {
mr->sample_skipped = 0;
mr->cur_prob = MINSTREL_FRAC(mr->success, mr->attempts); mr->cur_prob = MINSTREL_FRAC(mr->success, mr->attempts);
mr->succ_hist += mr->success; mr->succ_hist += mr->success;
mr->att_hist += mr->attempts; mr->att_hist += mr->attempts;
...@@ -93,7 +94,8 @@ minstrel_update_stats(struct minstrel_priv *mp, struct minstrel_sta_info *mi) ...@@ -93,7 +94,8 @@ minstrel_update_stats(struct minstrel_priv *mp, struct minstrel_sta_info *mi)
mr->cur_prob, mr->cur_prob,
EWMA_LEVEL); EWMA_LEVEL);
mr->cur_tp = mr->probability * (1000000 / usecs); mr->cur_tp = mr->probability * (1000000 / usecs);
} } else
mr->sample_skipped++;
mr->last_success = mr->success; mr->last_success = mr->success;
mr->last_attempts = mr->attempts; mr->last_attempts = mr->attempts;
...@@ -282,9 +284,12 @@ minstrel_get_rate(void *priv, struct ieee80211_sta *sta, ...@@ -282,9 +284,12 @@ minstrel_get_rate(void *priv, struct ieee80211_sta *sta,
rate_sampling = true; rate_sampling = true;
/* Decide if direct ( 1st mrr stage) or indirect (2nd mrr stage) /* Decide if direct ( 1st mrr stage) or indirect (2nd mrr stage)
* rate sampling method should be used */ * rate sampling method should be used.
* Respect such rates that are not sampled for 20 interations.
*/
if (mrr_capable && if (mrr_capable &&
msr->perfect_tx_time > mi->r[ndx].perfect_tx_time) msr->perfect_tx_time > mi->r[ndx].perfect_tx_time &&
msr->sample_skipped < 20)
indirect_rate_sampling = true; indirect_rate_sampling = true;
if (!indirect_rate_sampling) { if (!indirect_rate_sampling) {
......
...@@ -43,6 +43,7 @@ struct minstrel_rate { ...@@ -43,6 +43,7 @@ struct minstrel_rate {
u32 attempts; u32 attempts;
u32 last_attempts; u32 last_attempts;
u32 last_success; u32 last_success;
u8 sample_skipped;
/* parts per thousand */ /* parts per thousand */
u32 cur_prob; u32 cur_prob;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment