diff options
Diffstat (limited to 'package/kernel/mac80211/patches/300-pending_work.patch')
-rw-r--r-- | package/kernel/mac80211/patches/300-pending_work.patch | 134 |
1 files changed, 6 insertions, 128 deletions
diff --git a/package/kernel/mac80211/patches/300-pending_work.patch b/package/kernel/mac80211/patches/300-pending_work.patch index 95d37af11d..796b34c97d 100644 --- a/package/kernel/mac80211/patches/300-pending_work.patch +++ b/package/kernel/mac80211/patches/300-pending_work.patch @@ -1,38 +1,3 @@ -commit 24028dc203af73088ab969c2b4236bf9bee99d85 -Author: Felix Fietkau <nbd@openwrt.org> -Date: Thu Nov 13 18:29:26 2014 +0100 - - ath9k: do not access hardware on IRQs during reset - - Instead of killing interrupts during reset when the first one happens, - kill them before issuing the reset. - This fixes an easy to reproduce crash with multiple cards sharing the - same IRQ. - - Cc: stable@vger.kernel.org - Signed-off-by: Felix Fietkau <nbd@openwrt.org> - -commit 8115a0d774754a1a01feb25fb436832d4f3be41b -Author: Felix Fietkau <nbd@openwrt.org> -Date: Thu Nov 13 18:29:00 2014 +0100 - - ath9k: set ATH_OP_INVALID before disabling hardware - - Closes another small IRQ handler race - - Signed-off-by: Felix Fietkau <nbd@openwrt.org> - -commit d10478d3983574c2bae11146ef6b01d0103a777d -Author: Felix Fietkau <nbd@openwrt.org> -Date: Thu Nov 13 18:27:47 2014 +0100 - - ath9k: prevent early IRQs from accessing hardware - - IRQs are suppressed if ah == NULL and ATH_OP_INVALID being set in - common->op_flags. Close a short time window between those two. - - Signed-off-by: Felix Fietkau <nbd@openwrt.org> - commit 77980bee5f1f743b46f8749185aca28b8ec69741 Author: Johannes Berg <johannes.berg@intel.com> Date: Mon Nov 3 14:29:09 2014 +0100 @@ -1723,66 +1688,7 @@ Date: Mon May 19 21:20:49 2014 +0200 ENTRY_DATA_IO_FAILED, --- a/drivers/net/wireless/ath/ath9k/main.c +++ b/drivers/net/wireless/ath/ath9k/main.c -@@ -582,16 +582,13 @@ irqreturn_t ath_isr(int irq, void *dev) - if (test_bit(ATH_OP_INVALID, &common->op_flags)) - return IRQ_NONE; - -- /* shared irq, not for us */ -+ if (test_bit(ATH_OP_HW_RESET, &common->op_flags)) -+ return IRQ_NONE; - -+ /* shared irq, not for us */ - if (!ath9k_hw_intrpend(ah)) - return IRQ_NONE; - -- if (test_bit(ATH_OP_HW_RESET, &common->op_flags)) { -- ath9k_hw_kill_interrupts(ah); -- return IRQ_HANDLED; -- } -- - /* - * Figure out the reason(s) for the interrupt. Note - * that the hal returns a pseudo-ISR that may include -@@ -677,8 +674,12 @@ chip_reset: - - int ath_reset(struct ath_softc *sc) - { -+ struct ath_common *common = ath9k_hw_common(sc->sc_ah); - int r; - -+ ath9k_hw_kill_interrupts(sc->sc_ah); -+ set_bit(ATH_OP_HW_RESET, &common->op_flags); -+ - ath9k_ps_wakeup(sc); - r = ath_reset_internal(sc, NULL); - ath9k_ps_restore(sc); -@@ -692,6 +693,7 @@ void ath9k_queue_reset(struct ath_softc - #ifdef CPTCFG_ATH9K_DEBUGFS - RESET_STAT_INC(sc, type); - #endif -+ ath9k_hw_kill_interrupts(sc->sc_ah); - set_bit(ATH_OP_HW_RESET, &common->op_flags); - ieee80211_queue_work(sc->hw, &sc->hw_reset_work); - } -@@ -937,6 +939,9 @@ static void ath9k_stop(struct ieee80211_ - ah->curchan = ath9k_cmn_get_channel(hw, ah, &hw->conf.chandef); - - ath9k_hw_reset(ah, ah->curchan, ah->caldata, false); -+ -+ set_bit(ATH_OP_INVALID, &common->op_flags); -+ - ath9k_hw_phy_disable(ah); - - ath9k_hw_configpcipowersave(ah, true); -@@ -945,7 +950,6 @@ static void ath9k_stop(struct ieee80211_ - - ath9k_ps_restore(sc); - -- set_bit(ATH_OP_INVALID, &common->op_flags); - sc->ps_idle = prev_idle; - - mutex_unlock(&sc->mutex); -@@ -1757,7 +1761,6 @@ out: +@@ -1757,7 +1757,6 @@ out: void ath9k_update_p2p_ps(struct ath_softc *sc, struct ieee80211_vif *vif) { struct ath_vif *avp = (void *)vif->drv_priv; @@ -1790,7 +1696,7 @@ Date: Mon May 19 21:20:49 2014 +0200 u32 tsf; if (!sc->p2p_ps_timer) -@@ -1767,14 +1770,9 @@ void ath9k_update_p2p_ps(struct ath_soft +@@ -1767,14 +1766,9 @@ void ath9k_update_p2p_ps(struct ath_soft return; sc->p2p_ps_vif = avp; @@ -1808,7 +1714,7 @@ Date: Mon May 19 21:20:49 2014 +0200 } static void ath9k_bss_info_changed(struct ieee80211_hw *hw, -@@ -1791,6 +1789,7 @@ static void ath9k_bss_info_changed(struc +@@ -1791,6 +1785,7 @@ static void ath9k_bss_info_changed(struc struct ath_hw *ah = sc->sc_ah; struct ath_common *common = ath9k_hw_common(ah); struct ath_vif *avp = (void *)vif->drv_priv; @@ -1816,7 +1722,7 @@ Date: Mon May 19 21:20:49 2014 +0200 int slottime; ath9k_ps_wakeup(sc); -@@ -1853,7 +1852,10 @@ static void ath9k_bss_info_changed(struc +@@ -1853,7 +1848,10 @@ static void ath9k_bss_info_changed(struc if (changed & BSS_CHANGED_P2P_PS) { spin_lock_bh(&sc->sc_pcu_lock); @@ -1828,7 +1734,7 @@ Date: Mon May 19 21:20:49 2014 +0200 spin_unlock_bh(&sc->sc_pcu_lock); } -@@ -2232,14 +2234,6 @@ static void ath9k_sw_scan_complete(struc +@@ -2232,14 +2230,6 @@ static void ath9k_sw_scan_complete(struc clear_bit(ATH_OP_SCANNING, &common->op_flags); } @@ -1843,7 +1749,7 @@ Date: Mon May 19 21:20:49 2014 +0200 struct ieee80211_ops ath9k_ops = { .tx = ath9k_tx, .start = ath9k_start, -@@ -2287,5 +2281,4 @@ struct ieee80211_ops ath9k_ops = { +@@ -2287,5 +2277,4 @@ struct ieee80211_ops ath9k_ops = { #endif .sw_scan_start = ath9k_sw_scan_start, .sw_scan_complete = ath9k_sw_scan_complete, @@ -3589,31 +3495,3 @@ Date: Mon May 19 21:20:49 2014 +0200 } void b43_phy_mask(struct b43_wldev *dev, u16 offset, u16 mask) ---- a/drivers/net/wireless/ath/ath9k/init.c -+++ b/drivers/net/wireless/ath/ath9k/init.c -@@ -500,10 +500,14 @@ static int ath9k_init_softc(u16 devid, s - ah->reg_ops.read = ath9k_ioread32; - ah->reg_ops.write = ath9k_iowrite32; - ah->reg_ops.rmw = ath9k_reg_rmw; -- sc->sc_ah = ah; - pCap = &ah->caps; - - common = ath9k_hw_common(ah); -+ -+ /* Will be cleared in ath9k_start() */ -+ set_bit(ATH_OP_INVALID, &common->op_flags); -+ -+ sc->sc_ah = ah; - sc->dfs_detector = dfs_pattern_detector_init(common, NL80211_DFS_UNSET); - sc->tx99_power = MAX_RATE_POWER + 1; - init_waitqueue_head(&sc->tx_wait); -@@ -787,9 +791,6 @@ int ath9k_init_device(u16 devid, struct - common = ath9k_hw_common(ah); - ath9k_set_hw_capab(sc, hw); - -- /* Will be cleared in ath9k_start() */ -- set_bit(ATH_OP_INVALID, &common->op_flags); -- - /* Initialize regulatory */ - error = ath_regd_init(&common->regulatory, sc->hw->wiphy, - ath9k_reg_notifier); |