提交 e60ac9c7 编写于 作者: F Felix Fietkau 提交者: Kalle Valo

ath9k: make DMA stop related messages debug-only

A long time ago, ath9k had issues during reset where the DMA engine
would stay active and could potentially corrupt memory.
To debug those issues, the driver would print warnings whenever they
occur.

Nowadays, these issues are gone and the primary cause of these messages
is if the MAC is stuck during reset or busy processing a long
transmission. This is fairly harmless, yet these messages continue to
worry users.

To reduce the number of bogus bug reports, turn these messages into
debug messages and count their occurence in the "reset" debugfs file.
Signed-off-by: NFelix Fietkau <nbd@openwrt.org>
Signed-off-by: NKalle Valo <kvalo@codeaurora.org>
上级 cf7d5a80
...@@ -765,6 +765,8 @@ static int read_file_reset(struct seq_file *file, void *data) ...@@ -765,6 +765,8 @@ static int read_file_reset(struct seq_file *file, void *data)
[RESET_TYPE_BEACON_STUCK] = "Stuck Beacon", [RESET_TYPE_BEACON_STUCK] = "Stuck Beacon",
[RESET_TYPE_MCI] = "MCI Reset", [RESET_TYPE_MCI] = "MCI Reset",
[RESET_TYPE_CALIBRATION] = "Calibration error", [RESET_TYPE_CALIBRATION] = "Calibration error",
[RESET_TX_DMA_ERROR] = "Tx DMA stop error",
[RESET_RX_DMA_ERROR] = "Rx DMA stop error",
}; };
int i; int i;
......
...@@ -50,6 +50,8 @@ enum ath_reset_type { ...@@ -50,6 +50,8 @@ enum ath_reset_type {
RESET_TYPE_BEACON_STUCK, RESET_TYPE_BEACON_STUCK,
RESET_TYPE_MCI, RESET_TYPE_MCI,
RESET_TYPE_CALIBRATION, RESET_TYPE_CALIBRATION,
RESET_TX_DMA_ERROR,
RESET_RX_DMA_ERROR,
__RESET_TYPE_MAX __RESET_TYPE_MAX
}; };
......
...@@ -491,10 +491,9 @@ bool ath_stoprecv(struct ath_softc *sc) ...@@ -491,10 +491,9 @@ bool ath_stoprecv(struct ath_softc *sc)
if (!(ah->ah_flags & AH_UNPLUGGED) && if (!(ah->ah_flags & AH_UNPLUGGED) &&
unlikely(!stopped)) { unlikely(!stopped)) {
ath_err(ath9k_hw_common(sc->sc_ah), ath_dbg(ath9k_hw_common(sc->sc_ah), RESET,
"Could not stop RX, we could be " "Failed to stop Rx DMA\n");
"confusing the DMA engine when we start RX up\n"); RESET_STAT_INC(sc, RESET_RX_DMA_ERROR);
ATH_DBG_WARN_ON_ONCE(!stopped);
} }
return stopped && !reset; return stopped && !reset;
} }
......
...@@ -1883,8 +1883,11 @@ bool ath_drain_all_txq(struct ath_softc *sc) ...@@ -1883,8 +1883,11 @@ bool ath_drain_all_txq(struct ath_softc *sc)
npend |= BIT(i); npend |= BIT(i);
} }
if (npend) if (npend) {
ath_err(common, "Failed to stop TX DMA, queues=0x%03x!\n", npend); RESET_STAT_INC(sc, RESET_TX_DMA_ERROR);
ath_dbg(common, RESET,
"Failed to stop TX DMA, queues=0x%03x!\n", npend);
}
for (i = 0; i < ATH9K_NUM_TX_QUEUES; i++) { for (i = 0; i < ATH9K_NUM_TX_QUEUES; i++) {
if (!ATH_TXQ_SETUP(sc, i)) if (!ATH_TXQ_SETUP(sc, i))
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册