diff options
author | Felix Fietkau <nbd@openwrt.org> | 2015-07-22 12:45:03 +0000 |
---|---|---|
committer | Felix Fietkau <nbd@openwrt.org> | 2015-07-22 12:45:03 +0000 |
commit | 9384cc59512c6974908289b67c3321d40ee4f19b (patch) | |
tree | 2efda9ebe3be4fa220e11d6c8c2b26299a3f00c8 /package/kernel/mac80211/patches/307-ath10k-Delay-device-access-after-cold-reset.patch | |
parent | 3b17e2ab6853f78989b7cea4a2cf412938881ac2 (diff) | |
download | mtk-20170518-9384cc59512c6974908289b67c3321d40ee4f19b.zip mtk-20170518-9384cc59512c6974908289b67c3321d40ee4f19b.tar.gz mtk-20170518-9384cc59512c6974908289b67c3321d40ee4f19b.tar.bz2 |
mac80211: update to wireless-testing 2015-07-21
Signed-off-by: Felix Fietkau <nbd@openwrt.org>
SVN-Revision: 46436
Diffstat (limited to 'package/kernel/mac80211/patches/307-ath10k-Delay-device-access-after-cold-reset.patch')
-rw-r--r-- | package/kernel/mac80211/patches/307-ath10k-Delay-device-access-after-cold-reset.patch | 56 |
1 files changed, 0 insertions, 56 deletions
diff --git a/package/kernel/mac80211/patches/307-ath10k-Delay-device-access-after-cold-reset.patch b/package/kernel/mac80211/patches/307-ath10k-Delay-device-access-after-cold-reset.patch deleted file mode 100644 index 51998c2..0000000 --- a/package/kernel/mac80211/patches/307-ath10k-Delay-device-access-after-cold-reset.patch +++ /dev/null @@ -1,56 +0,0 @@ -From: Vasanthakumar Thiagarajan <vthiagar@qti.qualcomm.com> -Date: Fri, 3 Jul 2015 11:45:42 +0530 -Subject: [PATCH] ath10k: Delay device access after cold reset - -It is observed that during cold reset pcie access right -after a write operation to SOC_GLOBAL_RESET_ADDRESS causes -Data Bus Error and system hard lockup. The reason -for bus error is that pcie needs some time to get -back to stable state for any transaction during cold reset. Add -delay of 20 msecs after write of SOC_GLOBAL_RESET_ADDRESS -to fix this issue. - -Signed-off-by: Vasanthakumar Thiagarajan <vthiagar@qti.qualcomm.com> ---- - ---- a/drivers/net/wireless/ath/ath10k/pci.c -+++ b/drivers/net/wireless/ath/ath10k/pci.c -@@ -2602,7 +2602,6 @@ static int ath10k_pci_wait_for_target_in - - static int ath10k_pci_cold_reset(struct ath10k *ar) - { -- int i; - u32 val; - - ath10k_dbg(ar, ATH10K_DBG_BOOT, "boot cold reset\n"); -@@ -2618,23 +2617,18 @@ static int ath10k_pci_cold_reset(struct - val |= 1; - ath10k_pci_reg_write32(ar, SOC_GLOBAL_RESET_ADDRESS, val); - -- for (i = 0; i < ATH_PCI_RESET_WAIT_MAX; i++) { -- if (ath10k_pci_reg_read32(ar, RTC_STATE_ADDRESS) & -- RTC_STATE_COLD_RESET_MASK) -- break; -- msleep(1); -- } -+ /* After writing into SOC_GLOBAL_RESET to put device into -+ * reset and pulling out of reset pcie may not be stable -+ * for any immediate pcie register access and cause bus error, -+ * add delay before any pcie access request to fix this issue. -+ */ -+ msleep(20); - - /* Pull Target, including PCIe, out of RESET. */ - val &= ~1; - ath10k_pci_reg_write32(ar, SOC_GLOBAL_RESET_ADDRESS, val); - -- for (i = 0; i < ATH_PCI_RESET_WAIT_MAX; i++) { -- if (!(ath10k_pci_reg_read32(ar, RTC_STATE_ADDRESS) & -- RTC_STATE_COLD_RESET_MASK)) -- break; -- msleep(1); -- } -+ msleep(20); - - ath10k_dbg(ar, ATH10K_DBG_BOOT, "boot cold reset complete\n"); - |