ath9k: fix missed error codes in the tx status check
My previous change added in:
commit 815833e7ec
ath9k: fix tx status reporting
was not checking all possible tx error conditions. This could possibly
lead to throughput issues due to slow rate control adaption or missed
retransmissions of failed A-MPDU frames.
This patch adds a mask for all possible error conditions and uses it
in the xmit ok check.
Cc: stable@kernel.org
Reported-by: Björn Smedman <bjorn.smedman@venatech.se>
Signed-off-by: Felix Fietkau <nbd@openwrt.org>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
This commit is contained in:
parent
8b685ba9de
commit
5b479a076d
2 changed files with 4 additions and 1 deletions
|
@ -77,6 +77,9 @@
|
||||||
#define ATH9K_TXERR_XTXOP 0x08
|
#define ATH9K_TXERR_XTXOP 0x08
|
||||||
#define ATH9K_TXERR_TIMER_EXPIRED 0x10
|
#define ATH9K_TXERR_TIMER_EXPIRED 0x10
|
||||||
#define ATH9K_TX_ACKED 0x20
|
#define ATH9K_TX_ACKED 0x20
|
||||||
|
#define ATH9K_TXERR_MASK \
|
||||||
|
(ATH9K_TXERR_XRETRY | ATH9K_TXERR_FILT | ATH9K_TXERR_FIFO | \
|
||||||
|
ATH9K_TXERR_XTXOP | ATH9K_TXERR_TIMER_EXPIRED)
|
||||||
|
|
||||||
#define ATH9K_TX_BA 0x01
|
#define ATH9K_TX_BA 0x01
|
||||||
#define ATH9K_TX_PWRMGMT 0x02
|
#define ATH9K_TX_PWRMGMT 0x02
|
||||||
|
|
|
@ -2072,7 +2072,7 @@ static void ath_tx_processq(struct ath_softc *sc, struct ath_txq *txq)
|
||||||
&txq->axq_q, lastbf->list.prev);
|
&txq->axq_q, lastbf->list.prev);
|
||||||
|
|
||||||
txq->axq_depth--;
|
txq->axq_depth--;
|
||||||
txok = !(ds->ds_txstat.ts_status & ATH9K_TXERR_FILT);
|
txok = !(ds->ds_txstat.ts_status & ATH9K_TXERR_MASK);
|
||||||
txq->axq_tx_inprogress = false;
|
txq->axq_tx_inprogress = false;
|
||||||
spin_unlock_bh(&txq->axq_lock);
|
spin_unlock_bh(&txq->axq_lock);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue