aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRajkumar Manoharan <rmanohar@qca.qualcomm.com>2011-08-13 00:58:09 -0400
committerJohn W. Linville <linville@tuxdriver.com>2011-08-24 13:59:44 -0400
commit0682c9b52bf51fbc67c4e79fcbdadcf70bd600f8 (patch)
treed66c5caf9383cc8f366db6313f4b25382b07a353
parent7a12dfdbf508fed2cbd1a9142c6e19341a55527b (diff)
ath9k: Fix rx overrun interrupt storm
Whenever RXEOL is received, both RXORN and RXEOL got cleared to avoid rx overrun interrupt storm. This was handled only for edma chips. The same scenario was also observered with AR9280, doing frequent channel type switch b/w HT20/40 with bidi traffic that is causing failure to stop rx dma. This patch clears the RXEOL & RXORN interrupts for all chips. ath: DMA failed to stop in 10 ms AR_CR=0x00000024 AR_DIAG_SW=0x42000020 DMADBG_7=0x000062c0 ath: Could not stop RX, we could be confusing the DMA engine when we start RX up ------------[ cut here ]------------ WARNING: at drivers/net/wireless/ath/ath9k/recv.c:532 ath_stoprecv+0x110/0x120 [ath9k]() Call Trace: [<ffffffff8104a55a>] warn_slowpath_common+0x7a/0xb0 [<ffffffff8104a5a5>] warn_slowpath_null+0x15/0x20 [<ffffffffa0560380>] ath_stoprecv+0x110/0x120 [ath9k] [<ffffffffa055e6fa>] ath_reset+0x6a/0x200 [ath9k] Signed-off-by: Rajkumar Manoharan <rmanohar@qca.qualcomm.com> Signed-off-by: John W. Linville <linville@tuxdriver.com>
-rw-r--r--drivers/net/wireless/ath/ath9k/main.c8
1 files changed, 3 insertions, 5 deletions
diff --git a/drivers/net/wireless/ath/ath9k/main.c b/drivers/net/wireless/ath/ath9k/main.c
index 781af25f440d..3c5db3063877 100644
--- a/drivers/net/wireless/ath/ath9k/main.c
+++ b/drivers/net/wireless/ath/ath9k/main.c
@@ -826,11 +826,9 @@ irqreturn_t ath_isr(int irq, void *dev)
826 if (status & ATH9K_INT_TXURN) 826 if (status & ATH9K_INT_TXURN)
827 ath9k_hw_updatetxtriglevel(ah, true); 827 ath9k_hw_updatetxtriglevel(ah, true);
828 828
829 if (ah->caps.hw_caps & ATH9K_HW_CAP_EDMA) { 829 if (status & ATH9K_INT_RXEOL) {
830 if (status & ATH9K_INT_RXEOL) { 830 ah->imask &= ~(ATH9K_INT_RXEOL | ATH9K_INT_RXORN);
831 ah->imask &= ~(ATH9K_INT_RXEOL | ATH9K_INT_RXORN); 831 ath9k_hw_set_interrupts(ah, ah->imask);
832 ath9k_hw_set_interrupts(ah, ah->imask);
833 }
834 } 832 }
835 833
836 if (status & ATH9K_INT_MIB) { 834 if (status & ATH9K_INT_MIB) {