mirror of
https://github.com/edk2-porting/linux-next.git
synced 2024-12-22 12:14:01 +08:00
ath9k: resume aggregation immediately after a hardware reset
Since aggregation is usually triggered by tx completion, a hardware reset (because of beacon stuck, tx hang or baseband hang) can significantly delay the transmission of the next AMPDU (until the next tx completion event). Fix this by rescheduling aggregation after such a reset. Signed-off-by: Felix Fietkau <nbd@openwrt.org> Cc: stable@kernel.org Signed-off-by: John W. Linville <linville@tuxdriver.com>
This commit is contained in:
parent
dafeac387d
commit
fac6b6a065
@ -370,7 +370,7 @@ void ath_beacon_tasklet(unsigned long data)
|
||||
ath_print(common, ATH_DBG_BSTUCK,
|
||||
"beacon is officially stuck\n");
|
||||
sc->sc_flags |= SC_OP_TSF_RESET;
|
||||
ath_reset(sc, false);
|
||||
ath_reset(sc, true);
|
||||
}
|
||||
|
||||
return;
|
||||
|
@ -580,7 +580,7 @@ void ath_hw_check(struct work_struct *work)
|
||||
|
||||
msleep(1);
|
||||
}
|
||||
ath_reset(sc, false);
|
||||
ath_reset(sc, true);
|
||||
|
||||
out:
|
||||
ath9k_ps_restore(sc);
|
||||
@ -598,7 +598,7 @@ void ath9k_tasklet(unsigned long data)
|
||||
ath9k_ps_wakeup(sc);
|
||||
|
||||
if (status & ATH9K_INT_FATAL) {
|
||||
ath_reset(sc, false);
|
||||
ath_reset(sc, true);
|
||||
ath9k_ps_restore(sc);
|
||||
return;
|
||||
}
|
||||
|
@ -2163,7 +2163,7 @@ static void ath_tx_complete_poll_work(struct work_struct *work)
|
||||
ath_print(ath9k_hw_common(sc->sc_ah), ATH_DBG_RESET,
|
||||
"tx hung, resetting the chip\n");
|
||||
ath9k_ps_wakeup(sc);
|
||||
ath_reset(sc, false);
|
||||
ath_reset(sc, true);
|
||||
ath9k_ps_restore(sc);
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user