Lines Matching full:ab

16 static void ath11k_dp_htt_htc_tx_complete(struct ath11k_base *ab,  in ath11k_dp_htt_htc_tx_complete()  argument
24 struct ath11k_base *ab = ar->ab; in ath11k_dp_peer_cleanup() local
29 spin_lock_bh(&ab->base_lock); in ath11k_dp_peer_cleanup()
30 peer = ath11k_peer_find(ab, vdev_id, addr); in ath11k_dp_peer_cleanup()
32 ath11k_warn(ab, "failed to lookup peer %pM on vdev %d\n", in ath11k_dp_peer_cleanup()
34 spin_unlock_bh(&ab->base_lock); in ath11k_dp_peer_cleanup()
41 spin_unlock_bh(&ab->base_lock); in ath11k_dp_peer_cleanup()
46 struct ath11k_base *ab = ar->ab; in ath11k_dp_peer_setup() local
58 ath11k_warn(ab, "failed to set default routing %d peer :%pM vdev_id :%d\n", in ath11k_dp_peer_setup()
67 ath11k_warn(ab, "failed to setup rxd tid queue for tid %d: %d\n", in ath11k_dp_peer_setup()
75 ath11k_warn(ab, "failed to setup rx defrag context\n"); in ath11k_dp_peer_setup()
85 spin_lock_bh(&ab->base_lock); in ath11k_dp_peer_setup()
87 peer = ath11k_peer_find(ab, vdev_id, addr); in ath11k_dp_peer_setup()
89 ath11k_warn(ab, "failed to find the peer to del rx tid\n"); in ath11k_dp_peer_setup()
90 spin_unlock_bh(&ab->base_lock); in ath11k_dp_peer_setup()
97 spin_unlock_bh(&ab->base_lock); in ath11k_dp_peer_setup()
102 void ath11k_dp_srng_cleanup(struct ath11k_base *ab, struct dp_srng *ring) in ath11k_dp_srng_cleanup() argument
108 dma_free_noncoherent(ab->dev, ring->size, ring->vaddr_unaligned, in ath11k_dp_srng_cleanup()
111 dma_free_coherent(ab->dev, ring->size, ring->vaddr_unaligned, in ath11k_dp_srng_cleanup()
131 static int ath11k_dp_srng_calculate_msi_group(struct ath11k_base *ab, in ath11k_dp_srng_calculate_msi_group() argument
139 grp_mask = &ab->hw_params.ring_mask->rx_wbm_rel[0]; in ath11k_dp_srng_calculate_msi_group()
142 grp_mask = &ab->hw_params.ring_mask->tx[0]; in ath11k_dp_srng_calculate_msi_group()
146 grp_mask = &ab->hw_params.ring_mask->rx_err[0]; in ath11k_dp_srng_calculate_msi_group()
149 grp_mask = &ab->hw_params.ring_mask->rx[0]; in ath11k_dp_srng_calculate_msi_group()
152 grp_mask = &ab->hw_params.ring_mask->reo_status[0]; in ath11k_dp_srng_calculate_msi_group()
156 grp_mask = &ab->hw_params.ring_mask->rx_mon_status[0]; in ath11k_dp_srng_calculate_msi_group()
159 grp_mask = &ab->hw_params.ring_mask->rxdma2host[0]; in ath11k_dp_srng_calculate_msi_group()
162 grp_mask = &ab->hw_params.ring_mask->host2rxdma[0]; in ath11k_dp_srng_calculate_msi_group()
182 static void ath11k_dp_srng_msi_setup(struct ath11k_base *ab, in ath11k_dp_srng_msi_setup() argument
190 ret = ath11k_get_user_msi_vector(ab, "DP", in ath11k_dp_srng_msi_setup()
196 msi_group_number = ath11k_dp_srng_calculate_msi_group(ab, type, in ath11k_dp_srng_msi_setup()
199 ath11k_dbg(ab, ATH11K_DBG_PCI, in ath11k_dp_srng_msi_setup()
208 ath11k_dbg(ab, ATH11K_DBG_PCI, in ath11k_dp_srng_msi_setup()
213 ath11k_get_msi_address(ab, &addr_lo, &addr_hi); in ath11k_dp_srng_msi_setup()
222 int ath11k_dp_srng_setup(struct ath11k_base *ab, struct dp_srng *ring, in ath11k_dp_srng_setup() argument
227 int entry_sz = ath11k_hal_srng_get_entrysize(ab, type); in ath11k_dp_srng_setup()
228 int max_entries = ath11k_hal_srng_get_max_entries(ab, type); in ath11k_dp_srng_setup()
240 if (ab->hw_params.alloc_cacheable_memory) { in ath11k_dp_srng_setup()
253 ring->vaddr_unaligned = dma_alloc_noncoherent(ab->dev, ring->size, in ath11k_dp_srng_setup()
258 ring->vaddr_unaligned = dma_alloc_coherent(ab->dev, ring->size, in ath11k_dp_srng_setup()
272 ath11k_dp_srng_msi_setup(ab, &params, type, ring_num + mac_id); in ath11k_dp_srng_setup()
317 ath11k_warn(ab, "Not a valid ring type in dp :%d\n", type); in ath11k_dp_srng_setup()
326 ret = ath11k_hal_srng_setup(ab, type, ring_num, mac_id, &params); in ath11k_dp_srng_setup()
328 ath11k_warn(ab, "failed to setup srng: %d ring_id %d\n", in ath11k_dp_srng_setup()
338 void ath11k_dp_stop_shadow_timers(struct ath11k_base *ab) in ath11k_dp_stop_shadow_timers() argument
342 if (!ab->hw_params.supports_shadow_regs) in ath11k_dp_stop_shadow_timers()
345 for (i = 0; i < ab->hw_params.max_tx_ring; i++) in ath11k_dp_stop_shadow_timers()
346 ath11k_dp_shadow_stop_timer(ab, &ab->dp.tx_ring_timer[i]); in ath11k_dp_stop_shadow_timers()
348 ath11k_dp_shadow_stop_timer(ab, &ab->dp.reo_cmd_timer); in ath11k_dp_stop_shadow_timers()
351 static void ath11k_dp_srng_common_cleanup(struct ath11k_base *ab) in ath11k_dp_srng_common_cleanup() argument
353 struct ath11k_dp *dp = &ab->dp; in ath11k_dp_srng_common_cleanup()
356 ath11k_dp_stop_shadow_timers(ab); in ath11k_dp_srng_common_cleanup()
357 ath11k_dp_srng_cleanup(ab, &dp->wbm_desc_rel_ring); in ath11k_dp_srng_common_cleanup()
358 ath11k_dp_srng_cleanup(ab, &dp->tcl_cmd_ring); in ath11k_dp_srng_common_cleanup()
359 ath11k_dp_srng_cleanup(ab, &dp->tcl_status_ring); in ath11k_dp_srng_common_cleanup()
360 for (i = 0; i < ab->hw_params.max_tx_ring; i++) { in ath11k_dp_srng_common_cleanup()
361 ath11k_dp_srng_cleanup(ab, &dp->tx_ring[i].tcl_data_ring); in ath11k_dp_srng_common_cleanup()
362 ath11k_dp_srng_cleanup(ab, &dp->tx_ring[i].tcl_comp_ring); in ath11k_dp_srng_common_cleanup()
364 ath11k_dp_srng_cleanup(ab, &dp->reo_reinject_ring); in ath11k_dp_srng_common_cleanup()
365 ath11k_dp_srng_cleanup(ab, &dp->rx_rel_ring); in ath11k_dp_srng_common_cleanup()
366 ath11k_dp_srng_cleanup(ab, &dp->reo_except_ring); in ath11k_dp_srng_common_cleanup()
367 ath11k_dp_srng_cleanup(ab, &dp->reo_cmd_ring); in ath11k_dp_srng_common_cleanup()
368 ath11k_dp_srng_cleanup(ab, &dp->reo_status_ring); in ath11k_dp_srng_common_cleanup()
371 static int ath11k_dp_srng_common_setup(struct ath11k_base *ab) in ath11k_dp_srng_common_setup() argument
373 struct ath11k_dp *dp = &ab->dp; in ath11k_dp_srng_common_setup()
378 ret = ath11k_dp_srng_setup(ab, &dp->wbm_desc_rel_ring, in ath11k_dp_srng_common_setup()
382 ath11k_warn(ab, "failed to set up wbm2sw_release ring :%d\n", in ath11k_dp_srng_common_setup()
387 ret = ath11k_dp_srng_setup(ab, &dp->tcl_cmd_ring, HAL_TCL_CMD, 0, 0, in ath11k_dp_srng_common_setup()
390 ath11k_warn(ab, "failed to set up tcl_cmd ring :%d\n", ret); in ath11k_dp_srng_common_setup()
394 ret = ath11k_dp_srng_setup(ab, &dp->tcl_status_ring, HAL_TCL_STATUS, in ath11k_dp_srng_common_setup()
397 ath11k_warn(ab, "failed to set up tcl_status ring :%d\n", ret); in ath11k_dp_srng_common_setup()
401 for (i = 0; i < ab->hw_params.max_tx_ring; i++) { in ath11k_dp_srng_common_setup()
402 tcl_num = ab->hw_params.hal_params->tcl2wbm_rbm_map[i].tcl_ring_num; in ath11k_dp_srng_common_setup()
403 wbm_num = ab->hw_params.hal_params->tcl2wbm_rbm_map[i].wbm_ring_num; in ath11k_dp_srng_common_setup()
405 ret = ath11k_dp_srng_setup(ab, &dp->tx_ring[i].tcl_data_ring, in ath11k_dp_srng_common_setup()
407 ab->hw_params.tx_ring_size); in ath11k_dp_srng_common_setup()
409 ath11k_warn(ab, "failed to set up tcl_data ring (%d) :%d\n", in ath11k_dp_srng_common_setup()
414 ret = ath11k_dp_srng_setup(ab, &dp->tx_ring[i].tcl_comp_ring, in ath11k_dp_srng_common_setup()
418 ath11k_warn(ab, "failed to set up tcl_comp ring (%d) :%d\n", in ath11k_dp_srng_common_setup()
423 srng = &ab->hal.srng_list[dp->tx_ring[i].tcl_data_ring.ring_id]; in ath11k_dp_srng_common_setup()
424 ath11k_hal_tx_init_data_ring(ab, srng); in ath11k_dp_srng_common_setup()
426 ath11k_dp_shadow_init_timer(ab, &dp->tx_ring_timer[i], in ath11k_dp_srng_common_setup()
431 ret = ath11k_dp_srng_setup(ab, &dp->reo_reinject_ring, HAL_REO_REINJECT, in ath11k_dp_srng_common_setup()
434 ath11k_warn(ab, "failed to set up reo_reinject ring :%d\n", in ath11k_dp_srng_common_setup()
439 ret = ath11k_dp_srng_setup(ab, &dp->rx_rel_ring, HAL_WBM2SW_RELEASE, in ath11k_dp_srng_common_setup()
442 ath11k_warn(ab, "failed to set up rx_rel ring :%d\n", ret); in ath11k_dp_srng_common_setup()
446 ret = ath11k_dp_srng_setup(ab, &dp->reo_except_ring, HAL_REO_EXCEPTION, in ath11k_dp_srng_common_setup()
449 ath11k_warn(ab, "failed to set up reo_exception ring :%d\n", in ath11k_dp_srng_common_setup()
454 ret = ath11k_dp_srng_setup(ab, &dp->reo_cmd_ring, HAL_REO_CMD, in ath11k_dp_srng_common_setup()
457 ath11k_warn(ab, "failed to set up reo_cmd ring :%d\n", ret); in ath11k_dp_srng_common_setup()
461 srng = &ab->hal.srng_list[dp->reo_cmd_ring.ring_id]; in ath11k_dp_srng_common_setup()
462 ath11k_hal_reo_init_cmd_ring(ab, srng); in ath11k_dp_srng_common_setup()
464 ath11k_dp_shadow_init_timer(ab, &dp->reo_cmd_timer, in ath11k_dp_srng_common_setup()
468 ret = ath11k_dp_srng_setup(ab, &dp->reo_status_ring, HAL_REO_STATUS, in ath11k_dp_srng_common_setup()
471 ath11k_warn(ab, "failed to set up reo_status ring :%d\n", ret); in ath11k_dp_srng_common_setup()
478 ab->hw_params.hw_ops->reo_setup(ab); in ath11k_dp_srng_common_setup()
483 ath11k_dp_srng_common_cleanup(ab); in ath11k_dp_srng_common_setup()
488 static void ath11k_dp_scatter_idle_link_desc_cleanup(struct ath11k_base *ab) in ath11k_dp_scatter_idle_link_desc_cleanup() argument
490 struct ath11k_dp *dp = &ab->dp; in ath11k_dp_scatter_idle_link_desc_cleanup()
498 dma_free_coherent(ab->dev, HAL_WBM_IDLE_SCATTER_BUF_SIZE_MAX, in ath11k_dp_scatter_idle_link_desc_cleanup()
504 static int ath11k_dp_scatter_idle_link_desc_setup(struct ath11k_base *ab, in ath11k_dp_scatter_idle_link_desc_setup() argument
510 struct ath11k_dp *dp = &ab->dp; in ath11k_dp_scatter_idle_link_desc_setup()
524 ath11k_hal_srng_get_entrysize(ab, HAL_WBM_IDLE_LINK); in ath11k_dp_scatter_idle_link_desc_setup()
531 slist[i].vaddr = dma_alloc_coherent(ab->dev, in ath11k_dp_scatter_idle_link_desc_setup()
568 ath11k_hal_setup_link_idle_list(ab, slist, num_scatter_buf, in ath11k_dp_scatter_idle_link_desc_setup()
574 ath11k_dp_scatter_idle_link_desc_cleanup(ab); in ath11k_dp_scatter_idle_link_desc_setup()
580 ath11k_dp_link_desc_bank_free(struct ath11k_base *ab, in ath11k_dp_link_desc_bank_free() argument
587 dma_free_coherent(ab->dev, in ath11k_dp_link_desc_bank_free()
596 static int ath11k_dp_link_desc_bank_alloc(struct ath11k_base *ab, in ath11k_dp_link_desc_bank_alloc() argument
601 struct ath11k_dp *dp = &ab->dp; in ath11k_dp_link_desc_bank_alloc()
611 dma_alloc_coherent(ab->dev, desc_sz, in ath11k_dp_link_desc_bank_alloc()
630 ath11k_dp_link_desc_bank_free(ab, dp->link_desc_banks); in ath11k_dp_link_desc_bank_alloc()
635 void ath11k_dp_link_desc_cleanup(struct ath11k_base *ab, in ath11k_dp_link_desc_cleanup() argument
639 ath11k_dp_link_desc_bank_free(ab, desc_bank); in ath11k_dp_link_desc_cleanup()
642 ath11k_dp_srng_cleanup(ab, ring); in ath11k_dp_link_desc_cleanup()
643 ath11k_dp_scatter_idle_link_desc_cleanup(ab); in ath11k_dp_link_desc_cleanup()
647 static int ath11k_wbm_idle_ring_setup(struct ath11k_base *ab, u32 *n_link_desc) in ath11k_wbm_idle_ring_setup() argument
649 struct ath11k_dp *dp = &ab->dp; in ath11k_wbm_idle_ring_setup()
674 ret = ath11k_dp_srng_setup(ab, &dp->wbm_idle_ring, in ath11k_wbm_idle_ring_setup()
677 ath11k_warn(ab, "failed to setup wbm_idle_ring: %d\n", ret); in ath11k_wbm_idle_ring_setup()
683 int ath11k_dp_link_desc_setup(struct ath11k_base *ab, in ath11k_dp_link_desc_setup() argument
716 ret = ath11k_dp_link_desc_bank_alloc(ab, link_desc_banks, in ath11k_dp_link_desc_setup()
722 entry_sz = ath11k_hal_srng_get_entrysize(ab, ring_type); in ath11k_dp_link_desc_setup()
728 ret = ath11k_dp_scatter_idle_link_desc_setup(ab, tot_mem_sz, in ath11k_dp_link_desc_setup()
733 ath11k_warn(ab, "failed to setup scatting idle list descriptor :%d\n", in ath11k_dp_link_desc_setup()
743 ath11k_hal_srng_access_begin(ab, srng); in ath11k_dp_link_desc_setup()
752 (desc = ath11k_hal_srng_src_get_next_entry(ab, srng))) { in ath11k_dp_link_desc_setup()
760 ath11k_hal_srng_access_end(ab, srng); in ath11k_dp_link_desc_setup()
767 ath11k_dp_link_desc_bank_free(ab, link_desc_banks); in ath11k_dp_link_desc_setup()
772 int ath11k_dp_service_srng(struct ath11k_base *ab, in ath11k_dp_service_srng() argument
783 for (i = 0; i < ab->hw_params.max_tx_ring; i++) { in ath11k_dp_service_srng()
784 if (BIT(ab->hw_params.hal_params->tcl2wbm_rbm_map[i].wbm_ring_num) & in ath11k_dp_service_srng()
785 ab->hw_params.ring_mask->tx[grp_id]) in ath11k_dp_service_srng()
786 ath11k_dp_tx_completion_handler(ab, i); in ath11k_dp_service_srng()
789 if (ab->hw_params.ring_mask->rx_err[grp_id]) { in ath11k_dp_service_srng()
790 work_done = ath11k_dp_process_rx_err(ab, napi, budget); in ath11k_dp_service_srng()
797 if (ab->hw_params.ring_mask->rx_wbm_rel[grp_id]) { in ath11k_dp_service_srng()
798 work_done = ath11k_dp_rx_process_wbm_err(ab, in ath11k_dp_service_srng()
808 if (ab->hw_params.ring_mask->rx[grp_id]) { in ath11k_dp_service_srng()
809 i = fls(ab->hw_params.ring_mask->rx[grp_id]) - 1; in ath11k_dp_service_srng()
810 work_done = ath11k_dp_process_rx(ab, i, napi, in ath11k_dp_service_srng()
818 if (ab->hw_params.ring_mask->rx_mon_status[grp_id]) { in ath11k_dp_service_srng()
819 for (i = 0; i < ab->num_radios; i++) { in ath11k_dp_service_srng()
820 for (j = 0; j < ab->hw_params.num_rxdma_per_pdev; j++) { in ath11k_dp_service_srng()
821 int id = i * ab->hw_params.num_rxdma_per_pdev + j; in ath11k_dp_service_srng()
823 if (ab->hw_params.ring_mask->rx_mon_status[grp_id] & in ath11k_dp_service_srng()
826 ath11k_dp_rx_process_mon_rings(ab, in ath11k_dp_service_srng()
839 if (ab->hw_params.ring_mask->reo_status[grp_id]) in ath11k_dp_service_srng()
840 ath11k_dp_process_reo_status(ab); in ath11k_dp_service_srng()
842 for (i = 0; i < ab->num_radios; i++) { in ath11k_dp_service_srng()
843 for (j = 0; j < ab->hw_params.num_rxdma_per_pdev; j++) { in ath11k_dp_service_srng()
844 int id = i * ab->hw_params.num_rxdma_per_pdev + j; in ath11k_dp_service_srng()
846 if (ab->hw_params.ring_mask->rxdma2host[grp_id] & BIT(id)) { in ath11k_dp_service_srng()
847 work_done = ath11k_dp_process_rxdma_err(ab, id, budget); in ath11k_dp_service_srng()
855 if (ab->hw_params.ring_mask->host2rxdma[grp_id] & BIT(id)) { in ath11k_dp_service_srng()
856 struct ath11k *ar = ath11k_ab_to_ar(ab, id); in ath11k_dp_service_srng()
860 hal_params = ab->hw_params.hal_params; in ath11k_dp_service_srng()
861 ath11k_dp_rxbufs_replenish(ab, id, rx_ring, 0, in ath11k_dp_service_srng()
873 void ath11k_dp_pdev_free(struct ath11k_base *ab) in ath11k_dp_pdev_free() argument
878 del_timer_sync(&ab->mon_reap_timer); in ath11k_dp_pdev_free()
880 for (i = 0; i < ab->num_radios; i++) { in ath11k_dp_pdev_free()
881 ar = ab->pdevs[i].ar; in ath11k_dp_pdev_free()
882 ath11k_dp_rx_pdev_free(ab, i); in ath11k_dp_pdev_free()
888 void ath11k_dp_pdev_pre_alloc(struct ath11k_base *ab) in ath11k_dp_pdev_pre_alloc() argument
895 for (i = 0; i < ab->num_radios; i++) { in ath11k_dp_pdev_pre_alloc()
896 ar = ab->pdevs[i].ar; in ath11k_dp_pdev_pre_alloc()
903 for (j = 0; j < ab->hw_params.num_rxdma_per_pdev; j++) { in ath11k_dp_pdev_pre_alloc()
912 int ath11k_dp_pdev_alloc(struct ath11k_base *ab) in ath11k_dp_pdev_alloc() argument
919 for (i = 0; i < ab->num_radios; i++) { in ath11k_dp_pdev_alloc()
920 ar = ab->pdevs[i].ar; in ath11k_dp_pdev_alloc()
921 ret = ath11k_dp_rx_pdev_alloc(ab, i); in ath11k_dp_pdev_alloc()
923 ath11k_warn(ab, "failed to allocate pdev rx for pdev_id :%d\n", in ath11k_dp_pdev_alloc()
929 ath11k_warn(ab, "failed to initialize mon pdev %d\n", in ath11k_dp_pdev_alloc()
938 ath11k_dp_pdev_free(ab); in ath11k_dp_pdev_alloc()
958 status = ath11k_htc_connect_service(&dp->ab->htc, &conn_req, in ath11k_dp_htt_connect()
978 if (arvif->ar->ab->hw_params.htt_peer_map_v2) { in ath11k_dp_update_vdev_search()
1013 struct ath11k_base *ab = ctx; in ath11k_dp_tx_pending_cleanup() local
1016 dma_unmap_single(ab->dev, ATH11K_SKB_CB(msdu)->paddr, msdu->len, in ath11k_dp_tx_pending_cleanup()
1024 void ath11k_dp_free(struct ath11k_base *ab) in ath11k_dp_free() argument
1026 struct ath11k_dp *dp = &ab->dp; in ath11k_dp_free()
1029 ath11k_dp_link_desc_cleanup(ab, dp->link_desc_banks, in ath11k_dp_free()
1032 ath11k_dp_srng_common_cleanup(ab); in ath11k_dp_free()
1034 ath11k_dp_reo_cmd_list_cleanup(ab); in ath11k_dp_free()
1036 for (i = 0; i < ab->hw_params.max_tx_ring; i++) { in ath11k_dp_free()
1039 ath11k_dp_tx_pending_cleanup, ab); in ath11k_dp_free()
1048 int ath11k_dp_alloc(struct ath11k_base *ab) in ath11k_dp_alloc() argument
1050 struct ath11k_dp *dp = &ab->dp; in ath11k_dp_alloc()
1057 dp->ab = ab; in ath11k_dp_alloc()
1066 ret = ath11k_wbm_idle_ring_setup(ab, &n_link_desc); in ath11k_dp_alloc()
1068 ath11k_warn(ab, "failed to setup wbm_idle_ring: %d\n", ret); in ath11k_dp_alloc()
1072 srng = &ab->hal.srng_list[dp->wbm_idle_ring.ring_id]; in ath11k_dp_alloc()
1074 ret = ath11k_dp_link_desc_setup(ab, dp->link_desc_banks, in ath11k_dp_alloc()
1077 ath11k_warn(ab, "failed to setup link desc: %d\n", ret); in ath11k_dp_alloc()
1081 ret = ath11k_dp_srng_common_setup(ab); in ath11k_dp_alloc()
1087 for (i = 0; i < ab->hw_params.max_tx_ring; i++) { in ath11k_dp_alloc()
1102 ath11k_hal_tx_set_dscp_tid_map(ab, i); in ath11k_dp_alloc()
1109 ath11k_dp_srng_common_cleanup(ab); in ath11k_dp_alloc()
1112 ath11k_dp_link_desc_cleanup(ab, dp->link_desc_banks, in ath11k_dp_alloc()
1122 struct ath11k_base *ab = update_timer->ab; in ath11k_dp_shadow_timer_handler() local
1123 struct hal_srng *srng = &ab->hal.srng_list[update_timer->ring_id]; in ath11k_dp_shadow_timer_handler()
1138 ath11k_hal_srng_shadow_update_hp_tp(ab, srng); in ath11k_dp_shadow_timer_handler()
1144 void ath11k_dp_shadow_start_timer(struct ath11k_base *ab, in ath11k_dp_shadow_start_timer() argument
1150 if (!ab->hw_params.supports_shadow_regs) in ath11k_dp_shadow_start_timer()
1164 void ath11k_dp_shadow_stop_timer(struct ath11k_base *ab, in ath11k_dp_shadow_stop_timer() argument
1167 if (!ab->hw_params.supports_shadow_regs) in ath11k_dp_shadow_stop_timer()
1176 void ath11k_dp_shadow_init_timer(struct ath11k_base *ab, in ath11k_dp_shadow_init_timer() argument
1180 if (!ab->hw_params.supports_shadow_regs) in ath11k_dp_shadow_init_timer()
1185 update_timer->ab = ab; in ath11k_dp_shadow_init_timer()