[PATCH] ath11k: dp_rx: fix monitor status dma unmap direction

Kalle Valo kvalo at codeaurora.org
Wed Dec 2 13:34:18 EST 2020


Kalle Valo <kvalo at codeaurora.org> wrote:

> After enabling CONFIG_DMA_API_DEBUG there was a warning about using
> dma_unmap_single() in wrong direction from ath11k_dp_rx_process_mon_status().
> 
> [  140.279477] ------------[ cut here ]------------
> [  140.279908] DMA-API: ath11k_pci 0000:06:00.0: device driver syncs DMA memory with different direction [device address=0x00000000fac08a40] [size=2176 bytes] [mapped with DMA_FROM_DEVICE] [s
> [  140.279925] WARNING: CPU: 7 PID: 97 at kernel/dma/debug.c:1120 check_sync+0x494/0x730
> [  140.279939] Modules linked in: ath11k_pci ath11k mac80211 libarc4 cfg80211 qmi_helpers qrtr_mhi mhi qrtr ns nvme nvme_core
> [  140.279958] CPU: 7 PID: 97 Comm: kworker/u16:1 Not tainted 5.10.0-rc4+ #262
> [  140.279968] Hardware name: Intel(R) Client Systems NUC8i7HVK/NUC8i7HVB, BIOS HNKBLi70.86A.0049.2018.0801.1601 08/01/2018
> [  140.279995] Workqueue: phy0 ieee80211_scan_work [mac80211]
> [  140.280009] RIP: 0010:check_sync+0x494/0x730
> [  140.280022] Code: 8b 4c 24 10 4c 8b 44 24 18 4c 8b 54 24 20 48 89 c6 4c 89 54 24 10 4c 89 f9 4c 89 ea 48 c7 c7 40 b9 74 9c 41 56 e8 2f a0 ab 00 <0f> 0b 48 89 ef e8 e5 17 ac 00 41 58 4c 8b
> [  140.280033] RSP: 0018:ffff9f588024cbd8 EFLAGS: 00010086
> [  140.280046] RAX: 0000000000000000 RBX: ffff9f588024cc40 RCX: ffff8eed18dd9f98
> [  140.280057] RDX: 00000000ffffffd8 RSI: 0000000000000027 RDI: ffff8eed18dd9f90
> [  140.280067] RBP: ffff8eebc1407800 R08: 00000000ffffffea R09: 0000000000000000
> [  140.280082] R10: 0000000000000003 R11: 3fffffffffffffff R12: ffffffff9e081060
> [  140.280093] R13: ffff8eebc43908b0 R14: ffffffff9c74c104 R15: 00000000fac08a40
> [  140.280104] FS:  0000000000000000(0000) GS:ffff8eed18c00000(0000) knlGS:0000000000000000
> [  140.280115] CS:  0010 DS: 0000 ES: 0000 CR0: 0000000080050033
> [  140.280127] CR2: 00007f6feafb12a0 CR3: 00000001604ca001 CR4: 00000000003706e0
> [  140.280138] Call Trace:
> [  140.280149]  <IRQ>
> [  140.280161]  debug_dma_sync_single_for_cpu+0x79/0x80
> [  140.280173]  ? mark_held_locks+0x50/0x80
> [  140.280185]  ? lockdep_hardirqs_on_prepare.part.0+0x65/0x130
> [  140.280197]  ? __local_bh_enable_ip+0x6f/0xb0
> [  140.280215]  ? ath11k_dp_rx_reap_mon_status_ring+0x202/0x340 [ath11k]
> [  140.280231]  ath11k_dp_rx_reap_mon_status_ring+0x22c/0x340 [ath11k]
> [  140.280249]  ? ath11k_dp_rx_process_mon_rings+0x1a0/0x1a0 [ath11k]
> [  140.280265]  ath11k_dp_rx_process_mon_status+0x83/0x3c0 [ath11k]
> [  140.280278]  ? __lock_acquire+0x3bd/0x6d0
> [  140.280296]  ? ath11k_dp_rx_process_mon_rings+0x1a0/0x1a0 [ath11k]
> [  140.280311]  ? ath11k_dp_rx_process_mon_rings+0x1a0/0x1a0 [ath11k]
> [  140.280326]  ? ath11k_hw_mac_id_to_srng_id_qca6390+0x10/0x10 [ath11k]
> [  140.280341]  ? ath11k_dp_rx_process_mon_rings+0x4a/0x1a0 [ath11k]
> [  140.280353]  ? timer_fixup_init+0x30/0x30
> [  140.280367]  ? ath11k_dp_rx_process_mon_rings+0x1a0/0x1a0 [ath11k]
> [  140.280385]  ath11k_dp_service_mon_ring+0x2b/0x50 [ath11k]
> [  140.280400]  ? ath11k_dp_rx_process_mon_rings+0x1a0/0x1a0 [ath11k]
> [  140.280413]  call_timer_fn+0xb1/0x2d0
> [  140.280426]  __run_timers.part.0+0x205/0x2f0
> [  140.280439]  run_timer_softirq+0x21/0x50
> [  140.280450]  __do_softirq+0xc2/0x454
> [  140.280463]  asm_call_irq_on_stack+0x12/0x20
> [  140.280476]  </IRQ>
> [  140.280488]  do_softirq_own_stack+0x56/0x60
> [  140.280500]  irq_exit_rcu+0x9a/0xd0
> [  140.280511]  sysvec_apic_timer_interrupt+0x43/0xa0
> [  140.280526]  asm_sysvec_apic_timer_interrupt+0x12/0x20
> [  140.280540] RIP: 0010:_raw_spin_unlock_irqrestore+0x25/0x40
> [  140.280551] Code: 80 00 00 00 00 55 48 89 fd 48 83 c7 18 53 48 89 f3 48 8b 74 24 10 e8 ca 8f 4b ff 48 89 ef e8 22 dc 4b ff f6 c7 02 75 0c 53 9d <65> ff 0d 04 51 20 64 5b 5d c3 e8 9c 08 56
> [  140.280563] RSP: 0018:ffff9f58802e7878 EFLAGS: 00000246
> [  140.280578] RAX: 00000000000435ef RBX: 0000000000000246 RCX: 0000000000000040
> [  140.280592] RDX: 0000000000000000 RSI: 0000000000000000 RDI: ffffffff9be13e84
> [  140.280603] RBP: ffff8eed18dde480 R08: 0000000000000001 R09: ffff8eebc2292760
> [  140.280614] R10: 0000000000000005 R11: ffff8eebc2292760 R12: 0000000000000000
> [  140.280625] R13: ffff9f58802e7900 R14: ffff8eed18dde480 R15: ffff8eed18dde480
> [  140.280637]  ? _raw_spin_unlock_irqrestore+0x34/0x40
> [  140.280649]  __mod_timer+0x274/0x400
> [  140.280661]  ? wait_for_completion_timeout+0x76/0x110
> [  140.280675]  schedule_timeout+0xa8/0x140
> [  140.280687]  ? __next_timer_interrupt+0x100/0x100
> [  140.280698]  wait_for_completion_timeout+0xa2/0x110
> [  140.280714]  ath11k_start_scan+0x4c/0xf0 [ath11k]
> [  140.280730]  ath11k_mac_op_hw_scan+0x1e9/0x2c0 [ath11k]
> [  140.280763]  drv_hw_scan+0x79/0x260 [mac80211]
> [  140.280789]  __ieee80211_scan_completed+0x379/0x440 [mac80211]
> [  140.280816]  ieee80211_scan_work+0x12f/0x330 [mac80211]
> [  140.280830]  process_one_work+0x279/0x5b0
> [  140.280842]  worker_thread+0x49/0x300
> [  140.280854]  ? process_one_work+0x5b0/0x5b0
> [  140.280868]  kthread+0x135/0x150
> [  140.280880]  ? __kthread_bind_mask+0x60/0x60
> [  140.280891]  ret_from_fork+0x22/0x30
> [  140.280903] irq event stamp: 275961
> [  140.280918] hardirqs last  enabled at (275960): [<ffffffff9b270f1f>] __local_bh_enable_ip+0x6f/0xb0
> [  140.280931] hardirqs last disabled at (275961): [<ffffffff9be13ca3>] _raw_spin_lock_irqsave+0x63/0x80
> [  140.280946] softirqs last  enabled at (275944): [<ffffffffc055288d>] ath11k_ce_send+0x14d/0x260 [ath11k]
> [  140.280958] softirqs last disabled at (275953): [<ffffffff9c000f72>] asm_call_irq_on_stack+0x12/0x20
> [  140.280971] ---[ end trace 31cb94e18d401398 ]---
> 
> Tested-on: QCA6390 hw2.0 PCI WLAN.HST.1.0.1-01740-QCAHSTSWPLZ_V2_TO_X86-1
> 
> Signed-off-by: Kalle Valo <kvalo at codeaurora.org>

Patch applied to ath-next branch of ath.git, thanks.

cd6181ff7e93 ath11k: dp_rx: fix monitor status dma unmap direction

-- 
https://patchwork.kernel.org/project/linux-wireless/patch/1606156046-24764-1-git-send-email-kvalo@codeaurora.org/

https://wireless.wiki.kernel.org/en/developers/documentation/submittingpatches




More information about the ath11k mailing list