| 123456789101112131415161718192021222324252627282930313233 |
- From: Felix Fietkau <[email protected]>
- Date: Sat, 18 Oct 2014 13:31:52 +0200
- Subject: [PATCH] ath9k: fix processing RXORN interrupts
- The "goto chip_reset" is a bit misleading, because it does not actually
- issue a chip reset. Instead it is bypassing processing of other
- interrupts and assumes that the tasklet will issue a chip reset.
- In the case of RXORN this does not happen, so bypassing processing of
- other interrupts will simply allow them to fire again. Even if RXORN
- was triggering a reset, it is not critical enough to need the bypass
- here.
- Signed-off-by: Felix Fietkau <[email protected]>
- ---
- --- a/drivers/net/wireless/ath/ath9k/main.c
- +++ b/drivers/net/wireless/ath/ath9k/main.c
- @@ -545,11 +545,10 @@ irqreturn_t ath_isr(int irq, void *dev)
- sched = true;
-
- /*
- - * If a FATAL or RXORN interrupt is received, we have to reset the
- - * chip immediately.
- + * If a FATAL interrupt is received, we have to reset the chip
- + * immediately.
- */
- - if ((status & ATH9K_INT_FATAL) || ((status & ATH9K_INT_RXORN) &&
- - !(ah->caps.hw_caps & ATH9K_HW_CAP_EDMA)))
- + if (status & ATH9K_INT_FATAL)
- goto chip_reset;
-
- if ((ah->config.hw_hang_checks & HW_BB_WATCHDOG) &&
|