rt2x00: Fix tx status reporting when falling back to the lowest rate

In some corner cases the reported tx rates/retries didn't match the really
used ones.

The hardware lowers the tx rate on each consecutive retry by 1 (but won't
fall back from MCS to legacy rates) _until_ it reaches the lowest one.

In case the frame wasn't sent succesful the number of retries is 7 and if
a rate index <7 was used the previous code reported negative rate indexes
which were then ignored by the rate control algorithm and mac80211.

Instead, report the remaining number of retries to have happened with
the lowest rate (index 0). This should give the rate control algorithm
slightly more accurate information about the used tx rates/retries.

Signed-off-by: Helmut Schaa <helmut.schaa@googlemail.com>
Acked-by: Gertjan van Wingerde <gwingerde@gmail.com>
Signed-off-by: Ivo van Doorn <IvDoorn@gmail.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
This commit is contained in:
Helmut Schaa 2010-06-14 22:12:26 +02:00 committed by John W. Linville
parent 3f2bee2499
commit 3d2bc1036a

View File

@ -258,11 +258,22 @@ void rt2x00lib_txdone(struct queue_entry *entry,
/* /*
* Frame was send with retries, hardware tried * Frame was send with retries, hardware tried
* different rates to send out the frame, at each * different rates to send out the frame, at each
* retry it lowered the rate 1 step. * retry it lowered the rate 1 step except when the
* lowest rate was used.
*/ */
for (i = 0; i < retry_rates && i < IEEE80211_TX_MAX_RATES; i++) { for (i = 0; i < retry_rates && i < IEEE80211_TX_MAX_RATES; i++) {
tx_info->status.rates[i].idx = rate_idx - i; tx_info->status.rates[i].idx = rate_idx - i;
tx_info->status.rates[i].flags = rate_flags; tx_info->status.rates[i].flags = rate_flags;
if (rate_idx - i == 0) {
/*
* The lowest rate (index 0) was used until the
* number of max retries was reached.
*/
tx_info->status.rates[i].count = retry_rates - i;
i++;
break;
}
tx_info->status.rates[i].count = 1; tx_info->status.rates[i].count = 1;
} }
if (i < (IEEE80211_TX_MAX_RATES - 1)) if (i < (IEEE80211_TX_MAX_RATES - 1))