Tested that the patch fix the kernel panic, thanks. For the fixed version: Tested-by: Pi-Hsun Shih <pihsun@xxxxxxxxxxxx> On Wed, Feb 12, 2020 at 2:47 PM Wen Gong <wgong@xxxxxxxxxxxxxx> wrote: > > On 2020-02-12 13:31, Pi-Hsun Shih wrote: > > > Output as follows: > > > > [ 10.747482] ath10k_sdio mmc1:0001:1: msg_type: 0 > > [ 10.749295] ath10k_sdio mmc1:0001:1: htt-ver 3.73 wmi-op 4 htt-op 3 > > cal otp max-sta 32 raw 0 hwcrypto 1 > > [ 10.752243] Unable to handle kernel paging request at virtual > > address 006b6b6b6b6b6b6b > > [ 10.769674] Mem abort info: > > [ 10.772514] ESR = 0x96000004 > > [ 10.775625] Exception class = DABT (current EL), IL = 32 bits > > [ 10.781609] SET = 0, FnV = 0 > > [ 10.784699] EA = 0, S1PTW = 0 > > [ 10.787889] Data abort info: > > [ 10.790839] ISV = 0, ISS = 0x00000004 > > [ 10.794711] CM = 0, WnR = 0 > > [ 10.797714] [006b6b6b6b6b6b6b] address between user and kernel > > address ranges > > [ 10.804911] Internal error: Oops: 96000004 [#1] PREEMPT SMP > > [ 10.810488] Modules linked in: asix usbnet mii ath10k_sdio > > ath10k_core ath lzo_rle mac80211 lzo_compress zram cfg80211 joydev > > [ 10.821800] Process kworker/u16:1 (pid: 140, stack limit = > > 0x0000000008a1ed57) > > [ 10.829017] CPU: 4 PID: 140 Comm: kworker/u16:1 Tainted: G W > > 4.19.102 #49 > > [ 10.837097] Hardware name: MediaTek krane sku176 board (DT) > > [ 10.842670] Workqueue: ath10k_sdio_wq ath10k_sdio_write_async_work > > [ath10k_sdio] > > [ 10.850059] pstate: 60000005 (nZCv daif -PAN -UAO) > > [ 10.854860] pc : ath10k_htt_htc_tx_complete+0x9c/0x134 [ath10k_core] > > [ 10.861225] lr : ath10k_htt_htc_tx_complete+0x8c/0x134 [ath10k_core] > > [ 10.867568] sp : ffffff800888bc90 > > [ 10.870874] x29: ffffff800888bca0 x28: fffffffd69548be8 > > [ 10.876177] x27: fffffffd695573f8 x26: fffffffd69548be8 > > [ 10.881480] x25: fffffffd742f1e40 x24: fffffffd69556b48 > > [ 10.886782] x23: fffffffd69556b10 x22: fffffffd695c7e80 > > [ 10.892084] x21: 6b6b6b6b6b6b6b6b x20: fffffffd742f1e40 > > [ 10.897386] x19: fffffffd69541960 x18: 0000000000000000 > > [ 10.902696] x17: 000000000000003c x16: ffffffa964a7d36c > > [ 10.908004] x15: fffffffd742f3e80 x14: 0000000000000280 > > [ 10.913306] x13: 0000000000000001 x12: 0000000000000000 > > [ 10.918607] x11: 0000000000000000 x10: 0000000000000000 > > [ 10.923908] x9 : 2edc72d89d761200 x8 : 0000000000000001 > > [ 10.929209] x7 : bbbbbbbbbbbbbbbb x6 : 0000000000000020 > > [ 10.934511] x5 : 000000000000005a x4 : 0000000000000000 > > [ 10.939812] x3 : 0000000000000010 x2 : 0000000000000008 > > [ 10.945122] x1 : 0000000000000000 x0 : 0000000000000000 > > [ 10.950439] Call trace: > > [ 10.952904] ath10k_htt_htc_tx_complete+0x9c/0x134 [ath10k_core] > > [ 10.958918] ath10k_htc_notify_tx_completion+0xe4/0x118 > > [ath10k_core] > > [ 10.965366] ath10k_sdio_write_async_work+0x158/0x1f4 [ath10k_sdio] > > [ 10.971637] process_one_work+0x208/0x408 > > [ 10.975638] worker_thread+0x23c/0x3e4 > > [ 10.979379] kthread+0x120/0x130 > > [ 10.982602] ret_from_fork+0x10/0x18 > > [ 10.986178] Code: 52820f08 38686a68 340003a8 f9406a95 (394002a8) > > [ 10.992266] ---[ end trace 3ed9b11cd8f60113 ]--- > > [ 11.004351] Kernel panic - not syncing: Fatal exception > > [ 11.009586] SMP: stopping secondary CPUs > > [ 11.013519] Kernel Offset: 0x295c200000 from 0xffffff8008000000 > > [ 11.019433] CPU features: 0x0,2188200c > > [ 11.023172] Memory Limit: none > Thanks. > I have made change again to fix the panic. > could you try again with this change? > (also apply 30382dd1cf3a141bfaa568ee183c1892090fa79a and ath10k: disable > TX complete indication of htt for sdio) > > diff --git a/drivers/net/wireless/ath/ath10k/htt_tx.c > b/drivers/net/wireless/ath/ath10k/htt_tx.c > index 51f060a00b95..7bfdeb1298a5 100644 > --- a/drivers/net/wireless/ath/ath10k/htt_tx.c > +++ b/drivers/net/wireless/ath/ath10k/htt_tx.c > @@ -554,20 +554,30 @@ void ath10k_htt_htc_tx_complete(struct ath10k *ar, > struct sk_buff *skb) > struct htt_cmd_hdr *htt_hdr; > struct htt_data_tx_desc *desc_hdr; > u16 flags1; > + u8 msg_type; > + > + if (htt->disable_tx_comp) { > + htt_hdr = (struct htt_cmd_hdr *)skb->data; > + msg_type = htt_hdr->msg_type; > + ath10k_warn(ar, "msg_type: %d\n", msg_type); > + > + if (htt_hdr->msg_type == HTT_H2T_MSG_TYPE_TX_FRM) { > + desc_hdr = (struct htt_data_tx_desc *) > + (skb->data + sizeof(*htt_hdr)); > + flags1 = __le16_to_cpu(desc_hdr->flags1); > + > + if (flags1 & > HTT_DATA_TX_DESC_FLAGS1_TX_COMPLETE) > + ath10k_warn(ar, "htt tx mgmt\n"); > + else > + ath10k_warn(ar, "htt tx data\n"); > + } > + } > > dev_kfree_skb_any(skb); > > - if (!htt->disable_tx_comp) > + if ((!htt->disable_tx_comp) || (msg_type != > HTT_H2T_MSG_TYPE_TX_FRM)) > return; > > - htt_hdr = (struct htt_cmd_hdr *)skb->data; > - if (htt_hdr->msg_type != HTT_H2T_MSG_TYPE_TX_FRM) > - return; > - > - desc_hdr = (struct htt_data_tx_desc *) > - (skb->data + sizeof(*htt_hdr)); > - flags1 = __le16_to_cpu(desc_hdr->flags1); > - > ath10k_dbg(ar, ATH10K_DBG_HTT, > "htt tx complete msdu id:%u ,flags1:%x\n", > __le16_to_cpu(desc_hdr->id), flags1);