xref: /linux/drivers/net/wireless/ath/ath12k/wifi7/hal.c (revision 37a93dd5c49b5fda807fd204edf2547c3493319c)
174ed243dSPavankumar Nandeshwar // SPDX-License-Identifier: BSD-3-Clause-Clear
274ed243dSPavankumar Nandeshwar /*
374ed243dSPavankumar Nandeshwar  * Copyright (c) 2018-2021 The Linux Foundation. All rights reserved.
474ed243dSPavankumar Nandeshwar  * Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.
574ed243dSPavankumar Nandeshwar  */
674ed243dSPavankumar Nandeshwar #include "hw.h"
774ed243dSPavankumar Nandeshwar #include "hal_desc.h"
874ed243dSPavankumar Nandeshwar #include "../hal.h"
974ed243dSPavankumar Nandeshwar #include "hal.h"
10356942d3SPavankumar Nandeshwar #include "hal_tx.h"
11e9f00e22SPavankumar Nandeshwar #include "../debug.h"
12e9f00e22SPavankumar Nandeshwar #include "../hif.h"
13369cb192SPavankumar Nandeshwar #include "hal_qcn9274.h"
14369cb192SPavankumar Nandeshwar #include "hal_wcn7850.h"
15089e0e74SBaochen Qiang #include "hal_qcc2072.h"
1674ed243dSPavankumar Nandeshwar 
1774ed243dSPavankumar Nandeshwar static const struct ath12k_hw_version_map ath12k_wifi7_hw_ver_map[] = {
1874ed243dSPavankumar Nandeshwar 	[ATH12K_HW_QCN9274_HW10] = {
19369cb192SPavankumar Nandeshwar 		.hal_ops = &hal_qcn9274_ops,
2074ed243dSPavankumar Nandeshwar 		.hal_desc_sz = sizeof(struct hal_rx_desc_qcn9274_compact),
211c1d4b49SPavankumar Nandeshwar 		.tcl_to_wbm_rbm_map = ath12k_hal_tcl_to_wbm_rbm_map_qcn9274,
22492dea18SPavankumar Nandeshwar 		.hal_params = &ath12k_hw_hal_params_qcn9274,
23492dea18SPavankumar Nandeshwar 		.hw_regs = &qcn9274_v1_regs,
2474ed243dSPavankumar Nandeshwar 	},
2574ed243dSPavankumar Nandeshwar 	[ATH12K_HW_QCN9274_HW20] = {
26369cb192SPavankumar Nandeshwar 		.hal_ops = &hal_qcn9274_ops,
2774ed243dSPavankumar Nandeshwar 		.hal_desc_sz = sizeof(struct hal_rx_desc_qcn9274_compact),
281c1d4b49SPavankumar Nandeshwar 		.tcl_to_wbm_rbm_map = ath12k_hal_tcl_to_wbm_rbm_map_qcn9274,
29492dea18SPavankumar Nandeshwar 		.hal_params = &ath12k_hw_hal_params_qcn9274,
30492dea18SPavankumar Nandeshwar 		.hw_regs = &qcn9274_v2_regs,
3174ed243dSPavankumar Nandeshwar 	},
3274ed243dSPavankumar Nandeshwar 	[ATH12K_HW_WCN7850_HW20] = {
33369cb192SPavankumar Nandeshwar 		.hal_ops = &hal_wcn7850_ops,
3474ed243dSPavankumar Nandeshwar 		.hal_desc_sz = sizeof(struct hal_rx_desc_wcn7850),
351c1d4b49SPavankumar Nandeshwar 		.tcl_to_wbm_rbm_map = ath12k_hal_tcl_to_wbm_rbm_map_wcn7850,
36492dea18SPavankumar Nandeshwar 		.hal_params = &ath12k_hw_hal_params_wcn7850,
37492dea18SPavankumar Nandeshwar 		.hw_regs = &wcn7850_regs,
3874ed243dSPavankumar Nandeshwar 	},
3974ed243dSPavankumar Nandeshwar 	[ATH12K_HW_IPQ5332_HW10] = {
40369cb192SPavankumar Nandeshwar 		.hal_ops = &hal_qcn9274_ops,
4174ed243dSPavankumar Nandeshwar 		.hal_desc_sz = sizeof(struct hal_rx_desc_qcn9274_compact),
421c1d4b49SPavankumar Nandeshwar 		.tcl_to_wbm_rbm_map = ath12k_hal_tcl_to_wbm_rbm_map_qcn9274,
43492dea18SPavankumar Nandeshwar 		.hal_params = &ath12k_hw_hal_params_ipq5332,
44492dea18SPavankumar Nandeshwar 		.hw_regs = &ipq5332_regs,
4574ed243dSPavankumar Nandeshwar 	},
46089e0e74SBaochen Qiang 	[ATH12K_HW_QCC2072_HW10] = {
47*28badc78SBaochen Qiang 		.hal_ops = &hal_qcc2072_ops,
48*28badc78SBaochen Qiang 		.hal_desc_sz = sizeof(struct hal_rx_desc_qcc2072),
49089e0e74SBaochen Qiang 		.tcl_to_wbm_rbm_map = ath12k_hal_tcl_to_wbm_rbm_map_wcn7850,
50089e0e74SBaochen Qiang 		.hal_params = &ath12k_hw_hal_params_wcn7850,
51089e0e74SBaochen Qiang 		.hw_regs = &qcc2072_regs,
52089e0e74SBaochen Qiang 	},
5374ed243dSPavankumar Nandeshwar };
5474ed243dSPavankumar Nandeshwar 
5574ed243dSPavankumar Nandeshwar int ath12k_wifi7_hal_init(struct ath12k_base *ab)
5674ed243dSPavankumar Nandeshwar {
5774ed243dSPavankumar Nandeshwar 	struct ath12k_hal *hal = &ab->hal;
5874ed243dSPavankumar Nandeshwar 
5974ed243dSPavankumar Nandeshwar 	memset(hal, 0, sizeof(*hal));
6074ed243dSPavankumar Nandeshwar 
6149ba5debSRipan Deuri 	hal->ops = ath12k_wifi7_hw_ver_map[ab->hw_rev].hal_ops;
6274ed243dSPavankumar Nandeshwar 	hal->hal_desc_sz = ath12k_wifi7_hw_ver_map[ab->hw_rev].hal_desc_sz;
631c1d4b49SPavankumar Nandeshwar 	hal->tcl_to_wbm_rbm_map = ath12k_wifi7_hw_ver_map[ab->hw_rev].tcl_to_wbm_rbm_map;
64492dea18SPavankumar Nandeshwar 	hal->regs = ath12k_wifi7_hw_ver_map[ab->hw_rev].hw_regs;
65492dea18SPavankumar Nandeshwar 	hal->hal_params = ath12k_wifi7_hw_ver_map[ab->hw_rev].hal_params;
66951cca9cSPavankumar Nandeshwar 	hal->hal_wbm_release_ring_tx_size = sizeof(struct hal_wbm_release_ring_tx);
6774ed243dSPavankumar Nandeshwar 
6874ed243dSPavankumar Nandeshwar 	return 0;
6974ed243dSPavankumar Nandeshwar }
70e9f00e22SPavankumar Nandeshwar 
71e9f00e22SPavankumar Nandeshwar static unsigned int ath12k_wifi7_hal_reo1_ring_id_offset(struct ath12k_hal *hal)
72e9f00e22SPavankumar Nandeshwar {
73e9f00e22SPavankumar Nandeshwar 	return HAL_REO1_RING_ID(hal) - HAL_REO1_RING_BASE_LSB(hal);
74e9f00e22SPavankumar Nandeshwar }
75e9f00e22SPavankumar Nandeshwar 
76e9f00e22SPavankumar Nandeshwar static unsigned
77e9f00e22SPavankumar Nandeshwar int ath12k_wifi7_hal_reo1_ring_msi1_base_lsb_offset(struct ath12k_hal *hal)
78e9f00e22SPavankumar Nandeshwar {
79e9f00e22SPavankumar Nandeshwar 	return HAL_REO1_RING_MSI1_BASE_LSB(hal) - HAL_REO1_RING_BASE_LSB(hal);
80e9f00e22SPavankumar Nandeshwar }
81e9f00e22SPavankumar Nandeshwar 
82e9f00e22SPavankumar Nandeshwar static unsigned
83e9f00e22SPavankumar Nandeshwar int ath12k_wifi7_hal_reo1_ring_msi1_base_msb_offset(struct ath12k_hal *hal)
84e9f00e22SPavankumar Nandeshwar {
85e9f00e22SPavankumar Nandeshwar 	return HAL_REO1_RING_MSI1_BASE_MSB(hal) - HAL_REO1_RING_BASE_LSB(hal);
86e9f00e22SPavankumar Nandeshwar }
87e9f00e22SPavankumar Nandeshwar 
88e9f00e22SPavankumar Nandeshwar static unsigned int ath12k_wifi7_hal_reo1_ring_msi1_data_offset(struct ath12k_hal *hal)
89e9f00e22SPavankumar Nandeshwar {
90e9f00e22SPavankumar Nandeshwar 	return HAL_REO1_RING_MSI1_DATA(hal) - HAL_REO1_RING_BASE_LSB(hal);
91e9f00e22SPavankumar Nandeshwar }
92e9f00e22SPavankumar Nandeshwar 
93e9f00e22SPavankumar Nandeshwar static unsigned int ath12k_wifi7_hal_reo1_ring_base_msb_offset(struct ath12k_hal *hal)
94e9f00e22SPavankumar Nandeshwar {
95e9f00e22SPavankumar Nandeshwar 	return HAL_REO1_RING_BASE_MSB(hal) - HAL_REO1_RING_BASE_LSB(hal);
96e9f00e22SPavankumar Nandeshwar }
97e9f00e22SPavankumar Nandeshwar 
98e9f00e22SPavankumar Nandeshwar static unsigned
99e9f00e22SPavankumar Nandeshwar int ath12k_wifi7_hal_reo1_ring_producer_int_setup_offset(struct ath12k_hal *hal)
100e9f00e22SPavankumar Nandeshwar {
101e9f00e22SPavankumar Nandeshwar 	return HAL_REO1_RING_PRODUCER_INT_SETUP(hal) - HAL_REO1_RING_BASE_LSB(hal);
102e9f00e22SPavankumar Nandeshwar }
103e9f00e22SPavankumar Nandeshwar 
104e9f00e22SPavankumar Nandeshwar static unsigned int ath12k_wifi7_hal_reo1_ring_hp_addr_lsb_offset(struct ath12k_hal *hal)
105e9f00e22SPavankumar Nandeshwar {
106e9f00e22SPavankumar Nandeshwar 	return HAL_REO1_RING_HP_ADDR_LSB(hal) - HAL_REO1_RING_BASE_LSB(hal);
107e9f00e22SPavankumar Nandeshwar }
108e9f00e22SPavankumar Nandeshwar 
109e9f00e22SPavankumar Nandeshwar static unsigned int ath12k_wifi7_hal_reo1_ring_hp_addr_msb_offset(struct ath12k_hal *hal)
110e9f00e22SPavankumar Nandeshwar {
111e9f00e22SPavankumar Nandeshwar 	return HAL_REO1_RING_HP_ADDR_MSB(hal) - HAL_REO1_RING_BASE_LSB(hal);
112e9f00e22SPavankumar Nandeshwar }
113e9f00e22SPavankumar Nandeshwar 
114e9f00e22SPavankumar Nandeshwar static unsigned int ath12k_wifi7_hal_reo1_ring_misc_offset(struct ath12k_hal *hal)
115e9f00e22SPavankumar Nandeshwar {
116e9f00e22SPavankumar Nandeshwar 	return HAL_REO1_RING_MISC(hal) - HAL_REO1_RING_BASE_LSB(hal);
117e9f00e22SPavankumar Nandeshwar }
118e9f00e22SPavankumar Nandeshwar 
119e9f00e22SPavankumar Nandeshwar void ath12k_wifi7_hal_ce_dst_setup(struct ath12k_base *ab,
120e9f00e22SPavankumar Nandeshwar 				   struct hal_srng *srng, int ring_num)
121e9f00e22SPavankumar Nandeshwar {
122e9f00e22SPavankumar Nandeshwar 	struct hal_srng_config *srng_config = &ab->hal.srng_config[HAL_CE_DST];
123e9f00e22SPavankumar Nandeshwar 	u32 addr;
124e9f00e22SPavankumar Nandeshwar 	u32 val;
125e9f00e22SPavankumar Nandeshwar 
126e9f00e22SPavankumar Nandeshwar 	addr = HAL_CE_DST_RING_CTRL +
127e9f00e22SPavankumar Nandeshwar 	       srng_config->reg_start[HAL_SRNG_REG_GRP_R0] +
128e9f00e22SPavankumar Nandeshwar 	       ring_num * srng_config->reg_size[HAL_SRNG_REG_GRP_R0];
129e9f00e22SPavankumar Nandeshwar 
130e9f00e22SPavankumar Nandeshwar 	val = ath12k_hif_read32(ab, addr);
131e9f00e22SPavankumar Nandeshwar 	val &= ~HAL_CE_DST_R0_DEST_CTRL_MAX_LEN;
132e9f00e22SPavankumar Nandeshwar 	val |= u32_encode_bits(srng->u.dst_ring.max_buffer_length,
133e9f00e22SPavankumar Nandeshwar 			       HAL_CE_DST_R0_DEST_CTRL_MAX_LEN);
134e9f00e22SPavankumar Nandeshwar 	ath12k_hif_write32(ab, addr, val);
135e9f00e22SPavankumar Nandeshwar }
136e9f00e22SPavankumar Nandeshwar 
137e9f00e22SPavankumar Nandeshwar void ath12k_wifi7_hal_srng_dst_hw_init(struct ath12k_base *ab,
138e9f00e22SPavankumar Nandeshwar 				       struct hal_srng *srng)
139e9f00e22SPavankumar Nandeshwar {
140e9f00e22SPavankumar Nandeshwar 	struct ath12k_hal *hal = &ab->hal;
141e9f00e22SPavankumar Nandeshwar 	u32 val;
142e9f00e22SPavankumar Nandeshwar 	u64 hp_addr;
143e9f00e22SPavankumar Nandeshwar 	u32 reg_base;
144e9f00e22SPavankumar Nandeshwar 
145e9f00e22SPavankumar Nandeshwar 	reg_base = srng->hwreg_base[HAL_SRNG_REG_GRP_R0];
146e9f00e22SPavankumar Nandeshwar 
147e9f00e22SPavankumar Nandeshwar 	if (srng->flags & HAL_SRNG_FLAGS_MSI_INTR) {
148e9f00e22SPavankumar Nandeshwar 		ath12k_hif_write32(ab, reg_base +
149e9f00e22SPavankumar Nandeshwar 				   ath12k_wifi7_hal_reo1_ring_msi1_base_lsb_offset(hal),
150e9f00e22SPavankumar Nandeshwar 				   srng->msi_addr);
151e9f00e22SPavankumar Nandeshwar 
152e9f00e22SPavankumar Nandeshwar 		val = u32_encode_bits(((u64)srng->msi_addr >> HAL_ADDR_MSB_REG_SHIFT),
153e9f00e22SPavankumar Nandeshwar 				      HAL_REO1_RING_MSI1_BASE_MSB_ADDR) |
154e9f00e22SPavankumar Nandeshwar 				      HAL_REO1_RING_MSI1_BASE_MSB_MSI1_ENABLE;
155e9f00e22SPavankumar Nandeshwar 		ath12k_hif_write32(ab, reg_base +
156e9f00e22SPavankumar Nandeshwar 				   ath12k_wifi7_hal_reo1_ring_msi1_base_msb_offset(hal),
157e9f00e22SPavankumar Nandeshwar 				   val);
158e9f00e22SPavankumar Nandeshwar 
159e9f00e22SPavankumar Nandeshwar 		ath12k_hif_write32(ab,
160e9f00e22SPavankumar Nandeshwar 				   reg_base +
161e9f00e22SPavankumar Nandeshwar 				   ath12k_wifi7_hal_reo1_ring_msi1_data_offset(hal),
162e9f00e22SPavankumar Nandeshwar 				   srng->msi_data);
163e9f00e22SPavankumar Nandeshwar 	}
164e9f00e22SPavankumar Nandeshwar 
165e9f00e22SPavankumar Nandeshwar 	ath12k_hif_write32(ab, reg_base, srng->ring_base_paddr);
166e9f00e22SPavankumar Nandeshwar 
167e9f00e22SPavankumar Nandeshwar 	val = u32_encode_bits(((u64)srng->ring_base_paddr >> HAL_ADDR_MSB_REG_SHIFT),
168e9f00e22SPavankumar Nandeshwar 			      HAL_REO1_RING_BASE_MSB_RING_BASE_ADDR_MSB) |
169e9f00e22SPavankumar Nandeshwar 	      u32_encode_bits((srng->entry_size * srng->num_entries),
170e9f00e22SPavankumar Nandeshwar 			      HAL_REO1_RING_BASE_MSB_RING_SIZE);
171e9f00e22SPavankumar Nandeshwar 	ath12k_hif_write32(ab, reg_base + ath12k_wifi7_hal_reo1_ring_base_msb_offset(hal),
172e9f00e22SPavankumar Nandeshwar 			   val);
173e9f00e22SPavankumar Nandeshwar 
174e9f00e22SPavankumar Nandeshwar 	val = u32_encode_bits(srng->ring_id, HAL_REO1_RING_ID_RING_ID) |
175e9f00e22SPavankumar Nandeshwar 	      u32_encode_bits(srng->entry_size, HAL_REO1_RING_ID_ENTRY_SIZE);
176e9f00e22SPavankumar Nandeshwar 	ath12k_hif_write32(ab, reg_base + ath12k_wifi7_hal_reo1_ring_id_offset(hal), val);
177e9f00e22SPavankumar Nandeshwar 
178e9f00e22SPavankumar Nandeshwar 	/* interrupt setup */
179e9f00e22SPavankumar Nandeshwar 	val = u32_encode_bits((srng->intr_timer_thres_us >> 3),
180e9f00e22SPavankumar Nandeshwar 			      HAL_REO1_RING_PRDR_INT_SETUP_INTR_TMR_THOLD);
181e9f00e22SPavankumar Nandeshwar 
182e9f00e22SPavankumar Nandeshwar 	val |= u32_encode_bits((srng->intr_batch_cntr_thres_entries * srng->entry_size),
183e9f00e22SPavankumar Nandeshwar 				HAL_REO1_RING_PRDR_INT_SETUP_BATCH_COUNTER_THOLD);
184e9f00e22SPavankumar Nandeshwar 
185e9f00e22SPavankumar Nandeshwar 	ath12k_hif_write32(ab,
186e9f00e22SPavankumar Nandeshwar 			   reg_base +
187e9f00e22SPavankumar Nandeshwar 			   ath12k_wifi7_hal_reo1_ring_producer_int_setup_offset(hal),
188e9f00e22SPavankumar Nandeshwar 			   val);
189e9f00e22SPavankumar Nandeshwar 
190e9f00e22SPavankumar Nandeshwar 	hp_addr = hal->rdp.paddr +
191e9f00e22SPavankumar Nandeshwar 		  ((unsigned long)srng->u.dst_ring.hp_addr -
192e9f00e22SPavankumar Nandeshwar 		   (unsigned long)hal->rdp.vaddr);
193e9f00e22SPavankumar Nandeshwar 	ath12k_hif_write32(ab, reg_base +
194e9f00e22SPavankumar Nandeshwar 			   ath12k_wifi7_hal_reo1_ring_hp_addr_lsb_offset(hal),
195e9f00e22SPavankumar Nandeshwar 			   hp_addr & HAL_ADDR_LSB_REG_MASK);
196e9f00e22SPavankumar Nandeshwar 	ath12k_hif_write32(ab, reg_base +
197e9f00e22SPavankumar Nandeshwar 			   ath12k_wifi7_hal_reo1_ring_hp_addr_msb_offset(hal),
198e9f00e22SPavankumar Nandeshwar 			   hp_addr >> HAL_ADDR_MSB_REG_SHIFT);
199e9f00e22SPavankumar Nandeshwar 
200e9f00e22SPavankumar Nandeshwar 	/* Initialize head and tail pointers to indicate ring is empty */
201e9f00e22SPavankumar Nandeshwar 	reg_base = srng->hwreg_base[HAL_SRNG_REG_GRP_R2];
202e9f00e22SPavankumar Nandeshwar 	ath12k_hif_write32(ab, reg_base, 0);
203e9f00e22SPavankumar Nandeshwar 	ath12k_hif_write32(ab, reg_base + HAL_REO1_RING_TP_OFFSET, 0);
204e9f00e22SPavankumar Nandeshwar 	*srng->u.dst_ring.hp_addr = 0;
205e9f00e22SPavankumar Nandeshwar 
206e9f00e22SPavankumar Nandeshwar 	reg_base = srng->hwreg_base[HAL_SRNG_REG_GRP_R0];
207e9f00e22SPavankumar Nandeshwar 	val = 0;
208e9f00e22SPavankumar Nandeshwar 	if (srng->flags & HAL_SRNG_FLAGS_DATA_TLV_SWAP)
209e9f00e22SPavankumar Nandeshwar 		val |= HAL_REO1_RING_MISC_DATA_TLV_SWAP;
210e9f00e22SPavankumar Nandeshwar 	if (srng->flags & HAL_SRNG_FLAGS_RING_PTR_SWAP)
211e9f00e22SPavankumar Nandeshwar 		val |= HAL_REO1_RING_MISC_HOST_FW_SWAP;
212e9f00e22SPavankumar Nandeshwar 	if (srng->flags & HAL_SRNG_FLAGS_MSI_SWAP)
213e9f00e22SPavankumar Nandeshwar 		val |= HAL_REO1_RING_MISC_MSI_SWAP;
214e9f00e22SPavankumar Nandeshwar 	val |= HAL_REO1_RING_MISC_SRNG_ENABLE;
215e9f00e22SPavankumar Nandeshwar 
216e9f00e22SPavankumar Nandeshwar 	ath12k_hif_write32(ab, reg_base + ath12k_wifi7_hal_reo1_ring_misc_offset(hal),
217e9f00e22SPavankumar Nandeshwar 			   val);
218e9f00e22SPavankumar Nandeshwar }
219e9f00e22SPavankumar Nandeshwar 
220e9f00e22SPavankumar Nandeshwar void ath12k_wifi7_hal_srng_src_hw_init(struct ath12k_base *ab,
221e9f00e22SPavankumar Nandeshwar 				       struct hal_srng *srng)
222e9f00e22SPavankumar Nandeshwar {
223e9f00e22SPavankumar Nandeshwar 	struct ath12k_hal *hal = &ab->hal;
224e9f00e22SPavankumar Nandeshwar 	u32 val;
225e9f00e22SPavankumar Nandeshwar 	u64 tp_addr;
226e9f00e22SPavankumar Nandeshwar 	u32 reg_base;
227e9f00e22SPavankumar Nandeshwar 
228e9f00e22SPavankumar Nandeshwar 	reg_base = srng->hwreg_base[HAL_SRNG_REG_GRP_R0];
229e9f00e22SPavankumar Nandeshwar 
230e9f00e22SPavankumar Nandeshwar 	if (srng->flags & HAL_SRNG_FLAGS_MSI_INTR) {
231e9f00e22SPavankumar Nandeshwar 		ath12k_hif_write32(ab, reg_base +
232e9f00e22SPavankumar Nandeshwar 				   HAL_TCL1_RING_MSI1_BASE_LSB_OFFSET(hal),
233e9f00e22SPavankumar Nandeshwar 				   srng->msi_addr);
234e9f00e22SPavankumar Nandeshwar 
235e9f00e22SPavankumar Nandeshwar 		val = u32_encode_bits(((u64)srng->msi_addr >> HAL_ADDR_MSB_REG_SHIFT),
236e9f00e22SPavankumar Nandeshwar 				      HAL_TCL1_RING_MSI1_BASE_MSB_ADDR) |
237e9f00e22SPavankumar Nandeshwar 				      HAL_TCL1_RING_MSI1_BASE_MSB_MSI1_ENABLE;
238e9f00e22SPavankumar Nandeshwar 		ath12k_hif_write32(ab, reg_base +
239e9f00e22SPavankumar Nandeshwar 				       HAL_TCL1_RING_MSI1_BASE_MSB_OFFSET(hal),
240e9f00e22SPavankumar Nandeshwar 				   val);
241e9f00e22SPavankumar Nandeshwar 
242e9f00e22SPavankumar Nandeshwar 		ath12k_hif_write32(ab, reg_base +
243e9f00e22SPavankumar Nandeshwar 				       HAL_TCL1_RING_MSI1_DATA_OFFSET(hal),
244e9f00e22SPavankumar Nandeshwar 				   srng->msi_data);
245e9f00e22SPavankumar Nandeshwar 	}
246e9f00e22SPavankumar Nandeshwar 
247e9f00e22SPavankumar Nandeshwar 	ath12k_hif_write32(ab, reg_base, srng->ring_base_paddr);
248e9f00e22SPavankumar Nandeshwar 
249e9f00e22SPavankumar Nandeshwar 	val = u32_encode_bits(((u64)srng->ring_base_paddr >> HAL_ADDR_MSB_REG_SHIFT),
250e9f00e22SPavankumar Nandeshwar 			      HAL_TCL1_RING_BASE_MSB_RING_BASE_ADDR_MSB) |
251e9f00e22SPavankumar Nandeshwar 	      u32_encode_bits((srng->entry_size * srng->num_entries),
252e9f00e22SPavankumar Nandeshwar 			      HAL_TCL1_RING_BASE_MSB_RING_SIZE);
253e9f00e22SPavankumar Nandeshwar 	ath12k_hif_write32(ab, reg_base + HAL_TCL1_RING_BASE_MSB_OFFSET(hal), val);
254e9f00e22SPavankumar Nandeshwar 
255e9f00e22SPavankumar Nandeshwar 	val = u32_encode_bits(srng->entry_size, HAL_REO1_RING_ID_ENTRY_SIZE);
256e9f00e22SPavankumar Nandeshwar 	ath12k_hif_write32(ab, reg_base + HAL_TCL1_RING_ID_OFFSET(hal), val);
257e9f00e22SPavankumar Nandeshwar 
258e9f00e22SPavankumar Nandeshwar 	val = u32_encode_bits(srng->intr_timer_thres_us,
259e9f00e22SPavankumar Nandeshwar 			      HAL_TCL1_RING_CONSR_INT_SETUP_IX0_INTR_TMR_THOLD);
260e9f00e22SPavankumar Nandeshwar 
261e9f00e22SPavankumar Nandeshwar 	val |= u32_encode_bits((srng->intr_batch_cntr_thres_entries * srng->entry_size),
262e9f00e22SPavankumar Nandeshwar 			       HAL_TCL1_RING_CONSR_INT_SETUP_IX0_BATCH_COUNTER_THOLD);
263e9f00e22SPavankumar Nandeshwar 
264e9f00e22SPavankumar Nandeshwar 	ath12k_hif_write32(ab,
265e9f00e22SPavankumar Nandeshwar 			   reg_base + HAL_TCL1_RING_CONSR_INT_SETUP_IX0_OFFSET(hal),
266e9f00e22SPavankumar Nandeshwar 			   val);
267e9f00e22SPavankumar Nandeshwar 
268e9f00e22SPavankumar Nandeshwar 	val = 0;
269e9f00e22SPavankumar Nandeshwar 	if (srng->flags & HAL_SRNG_FLAGS_LOW_THRESH_INTR_EN) {
270e9f00e22SPavankumar Nandeshwar 		val |= u32_encode_bits(srng->u.src_ring.low_threshold,
271e9f00e22SPavankumar Nandeshwar 				       HAL_TCL1_RING_CONSR_INT_SETUP_IX1_LOW_THOLD);
272e9f00e22SPavankumar Nandeshwar 	}
273e9f00e22SPavankumar Nandeshwar 	ath12k_hif_write32(ab,
274e9f00e22SPavankumar Nandeshwar 			   reg_base + HAL_TCL1_RING_CONSR_INT_SETUP_IX1_OFFSET(hal),
275e9f00e22SPavankumar Nandeshwar 			   val);
276e9f00e22SPavankumar Nandeshwar 
277e9f00e22SPavankumar Nandeshwar 	if (srng->ring_id != HAL_SRNG_RING_ID_WBM_IDLE_LINK) {
278e9f00e22SPavankumar Nandeshwar 		tp_addr = hal->rdp.paddr +
279e9f00e22SPavankumar Nandeshwar 			  ((unsigned long)srng->u.src_ring.tp_addr -
280e9f00e22SPavankumar Nandeshwar 			   (unsigned long)hal->rdp.vaddr);
281e9f00e22SPavankumar Nandeshwar 		ath12k_hif_write32(ab,
282e9f00e22SPavankumar Nandeshwar 				   reg_base + HAL_TCL1_RING_TP_ADDR_LSB_OFFSET(hal),
283e9f00e22SPavankumar Nandeshwar 				   tp_addr & HAL_ADDR_LSB_REG_MASK);
284e9f00e22SPavankumar Nandeshwar 		ath12k_hif_write32(ab,
285e9f00e22SPavankumar Nandeshwar 				   reg_base + HAL_TCL1_RING_TP_ADDR_MSB_OFFSET(hal),
286e9f00e22SPavankumar Nandeshwar 				   tp_addr >> HAL_ADDR_MSB_REG_SHIFT);
287e9f00e22SPavankumar Nandeshwar 	}
288e9f00e22SPavankumar Nandeshwar 
289e9f00e22SPavankumar Nandeshwar 	/* Initialize head and tail pointers to indicate ring is empty */
290e9f00e22SPavankumar Nandeshwar 	reg_base = srng->hwreg_base[HAL_SRNG_REG_GRP_R2];
291e9f00e22SPavankumar Nandeshwar 	ath12k_hif_write32(ab, reg_base, 0);
292e9f00e22SPavankumar Nandeshwar 	ath12k_hif_write32(ab, reg_base + HAL_TCL1_RING_TP_OFFSET, 0);
293e9f00e22SPavankumar Nandeshwar 	*srng->u.src_ring.tp_addr = 0;
294e9f00e22SPavankumar Nandeshwar 
295e9f00e22SPavankumar Nandeshwar 	reg_base = srng->hwreg_base[HAL_SRNG_REG_GRP_R0];
296e9f00e22SPavankumar Nandeshwar 	val = 0;
297e9f00e22SPavankumar Nandeshwar 	if (srng->flags & HAL_SRNG_FLAGS_DATA_TLV_SWAP)
298e9f00e22SPavankumar Nandeshwar 		val |= HAL_TCL1_RING_MISC_DATA_TLV_SWAP;
299e9f00e22SPavankumar Nandeshwar 	if (srng->flags & HAL_SRNG_FLAGS_RING_PTR_SWAP)
300e9f00e22SPavankumar Nandeshwar 		val |= HAL_TCL1_RING_MISC_HOST_FW_SWAP;
301e9f00e22SPavankumar Nandeshwar 	if (srng->flags & HAL_SRNG_FLAGS_MSI_SWAP)
302e9f00e22SPavankumar Nandeshwar 		val |= HAL_TCL1_RING_MISC_MSI_SWAP;
303e9f00e22SPavankumar Nandeshwar 
304e9f00e22SPavankumar Nandeshwar 	/* Loop count is not used for SRC rings */
305e9f00e22SPavankumar Nandeshwar 	val |= HAL_TCL1_RING_MISC_MSI_LOOPCNT_DISABLE;
306e9f00e22SPavankumar Nandeshwar 
307e9f00e22SPavankumar Nandeshwar 	val |= HAL_TCL1_RING_MISC_SRNG_ENABLE;
308e9f00e22SPavankumar Nandeshwar 
309e9f00e22SPavankumar Nandeshwar 	if (srng->ring_id == HAL_SRNG_RING_ID_WBM_IDLE_LINK)
310e9f00e22SPavankumar Nandeshwar 		val |= HAL_TCL1_RING_MISC_MSI_RING_ID_DISABLE;
311e9f00e22SPavankumar Nandeshwar 
312e9f00e22SPavankumar Nandeshwar 	ath12k_hif_write32(ab, reg_base + HAL_TCL1_RING_MISC_OFFSET(hal), val);
313e9f00e22SPavankumar Nandeshwar }
314e9f00e22SPavankumar Nandeshwar 
315e9f00e22SPavankumar Nandeshwar void ath12k_wifi7_hal_set_umac_srng_ptr_addr(struct ath12k_base *ab,
316e9f00e22SPavankumar Nandeshwar 					     struct hal_srng *srng)
317e9f00e22SPavankumar Nandeshwar {
318e9f00e22SPavankumar Nandeshwar 	u32 reg_base = srng->hwreg_base[HAL_SRNG_REG_GRP_R2];
319e9f00e22SPavankumar Nandeshwar 
320e9f00e22SPavankumar Nandeshwar 	if (srng->ring_dir == HAL_SRNG_DIR_SRC) {
321e9f00e22SPavankumar Nandeshwar 		if (!ab->hw_params->supports_shadow_regs) {
322e9f00e22SPavankumar Nandeshwar 			srng->u.src_ring.hp_addr =
323e9f00e22SPavankumar Nandeshwar 				(u32 *)((unsigned long)ab->mem + reg_base);
324e9f00e22SPavankumar Nandeshwar 		} else {
325e9f00e22SPavankumar Nandeshwar 			ath12k_dbg(ab, ATH12K_DBG_HAL,
326e9f00e22SPavankumar Nandeshwar 				   "hal reg_base 0x%x shadow 0x%lx\n",
327e9f00e22SPavankumar Nandeshwar 				   reg_base,
328e9f00e22SPavankumar Nandeshwar 				   (unsigned long)srng->u.src_ring.hp_addr -
329e9f00e22SPavankumar Nandeshwar 				   (unsigned long)ab->mem);
330e9f00e22SPavankumar Nandeshwar 		}
331e9f00e22SPavankumar Nandeshwar 	} else  {
332e9f00e22SPavankumar Nandeshwar 		if (!ab->hw_params->supports_shadow_regs) {
333e9f00e22SPavankumar Nandeshwar 			srng->u.dst_ring.tp_addr =
334e9f00e22SPavankumar Nandeshwar 				(u32 *)((unsigned long)ab->mem + reg_base +
335e9f00e22SPavankumar Nandeshwar 						(HAL_REO1_RING_TP - HAL_REO1_RING_HP));
336e9f00e22SPavankumar Nandeshwar 		} else {
337e9f00e22SPavankumar Nandeshwar 			ath12k_dbg(ab, ATH12K_DBG_HAL,
338e9f00e22SPavankumar Nandeshwar 				   "target_reg 0x%x shadow 0x%lx\n",
339e9f00e22SPavankumar Nandeshwar 				   reg_base + HAL_REO1_RING_TP - HAL_REO1_RING_HP,
340e9f00e22SPavankumar Nandeshwar 				   (unsigned long)srng->u.dst_ring.tp_addr -
341e9f00e22SPavankumar Nandeshwar 				   (unsigned long)ab->mem);
342e9f00e22SPavankumar Nandeshwar 		}
343e9f00e22SPavankumar Nandeshwar 	}
344e9f00e22SPavankumar Nandeshwar }
345cb419f58SPavankumar Nandeshwar 
346cb419f58SPavankumar Nandeshwar int ath12k_wifi7_hal_srng_get_ring_id(struct ath12k_hal *hal,
347cb419f58SPavankumar Nandeshwar 				      enum hal_ring_type type,
348cb419f58SPavankumar Nandeshwar 				      int ring_num, int mac_id)
349cb419f58SPavankumar Nandeshwar {
350cb419f58SPavankumar Nandeshwar 	struct hal_srng_config *srng_config = &hal->srng_config[type];
351cb419f58SPavankumar Nandeshwar 	int ring_id;
352cb419f58SPavankumar Nandeshwar 
353cb419f58SPavankumar Nandeshwar 	if (ring_num >= srng_config->max_rings) {
354cb419f58SPavankumar Nandeshwar 		ath12k_warn(hal, "invalid ring number :%d\n", ring_num);
355cb419f58SPavankumar Nandeshwar 		return -EINVAL;
356cb419f58SPavankumar Nandeshwar 	}
357cb419f58SPavankumar Nandeshwar 
358cb419f58SPavankumar Nandeshwar 	ring_id = srng_config->start_ring_id + ring_num;
359cb419f58SPavankumar Nandeshwar 	if (srng_config->mac_type == ATH12K_HAL_SRNG_PMAC)
360cb419f58SPavankumar Nandeshwar 		ring_id += mac_id * HAL_SRNG_RINGS_PER_PMAC;
361cb419f58SPavankumar Nandeshwar 
362cb419f58SPavankumar Nandeshwar 	if (WARN_ON(ring_id >= HAL_SRNG_RING_ID_MAX))
363cb419f58SPavankumar Nandeshwar 		return -EINVAL;
364cb419f58SPavankumar Nandeshwar 
365cb419f58SPavankumar Nandeshwar 	return ring_id;
366cb419f58SPavankumar Nandeshwar }
367cb419f58SPavankumar Nandeshwar 
368cb419f58SPavankumar Nandeshwar static
369cb419f58SPavankumar Nandeshwar void ath12k_wifi7_hal_srng_update_hp_tp_addr(struct ath12k_base *ab,
370cb419f58SPavankumar Nandeshwar 					     int shadow_cfg_idx,
371cb419f58SPavankumar Nandeshwar 					     enum hal_ring_type ring_type,
372cb419f58SPavankumar Nandeshwar 					     int ring_num)
373cb419f58SPavankumar Nandeshwar {
374cb419f58SPavankumar Nandeshwar 	struct hal_srng *srng;
375cb419f58SPavankumar Nandeshwar 	struct ath12k_hal *hal = &ab->hal;
376cb419f58SPavankumar Nandeshwar 	int ring_id;
377cb419f58SPavankumar Nandeshwar 	struct hal_srng_config *srng_config = &hal->srng_config[ring_type];
378cb419f58SPavankumar Nandeshwar 
379cb419f58SPavankumar Nandeshwar 	ring_id = ath12k_wifi7_hal_srng_get_ring_id(hal, ring_type, ring_num,
380cb419f58SPavankumar Nandeshwar 						    0);
381cb419f58SPavankumar Nandeshwar 	if (ring_id < 0)
382cb419f58SPavankumar Nandeshwar 		return;
383cb419f58SPavankumar Nandeshwar 
384cb419f58SPavankumar Nandeshwar 	srng = &hal->srng_list[ring_id];
385cb419f58SPavankumar Nandeshwar 
386cb419f58SPavankumar Nandeshwar 	if (srng_config->ring_dir == HAL_SRNG_DIR_DST)
387cb419f58SPavankumar Nandeshwar 		srng->u.dst_ring.tp_addr = (u32 *)(HAL_SHADOW_REG(shadow_cfg_idx) +
388cb419f58SPavankumar Nandeshwar 						   (unsigned long)ab->mem);
389cb419f58SPavankumar Nandeshwar 	else
390cb419f58SPavankumar Nandeshwar 		srng->u.src_ring.hp_addr = (u32 *)(HAL_SHADOW_REG(shadow_cfg_idx) +
391cb419f58SPavankumar Nandeshwar 						   (unsigned long)ab->mem);
392cb419f58SPavankumar Nandeshwar }
393cb419f58SPavankumar Nandeshwar 
3943d947cefSPavankumar Nandeshwar u32 ath12k_wifi7_hal_ce_get_desc_size(enum hal_ce_desc type)
3953d947cefSPavankumar Nandeshwar {
3963d947cefSPavankumar Nandeshwar 	switch (type) {
3973d947cefSPavankumar Nandeshwar 	case HAL_CE_DESC_SRC:
3983d947cefSPavankumar Nandeshwar 		return sizeof(struct hal_ce_srng_src_desc);
3993d947cefSPavankumar Nandeshwar 	case HAL_CE_DESC_DST:
4003d947cefSPavankumar Nandeshwar 		return sizeof(struct hal_ce_srng_dest_desc);
4013d947cefSPavankumar Nandeshwar 	case HAL_CE_DESC_DST_STATUS:
4023d947cefSPavankumar Nandeshwar 		return sizeof(struct hal_ce_srng_dst_status_desc);
4033d947cefSPavankumar Nandeshwar 	}
4043d947cefSPavankumar Nandeshwar 
4053d947cefSPavankumar Nandeshwar 	return 0;
4063d947cefSPavankumar Nandeshwar }
4073d947cefSPavankumar Nandeshwar 
408cb419f58SPavankumar Nandeshwar int ath12k_wifi7_hal_srng_update_shadow_config(struct ath12k_base *ab,
409cb419f58SPavankumar Nandeshwar 					       enum hal_ring_type ring_type,
410cb419f58SPavankumar Nandeshwar 					       int ring_num)
411cb419f58SPavankumar Nandeshwar {
412cb419f58SPavankumar Nandeshwar 	struct ath12k_hal *hal = &ab->hal;
413cb419f58SPavankumar Nandeshwar 	struct hal_srng_config *srng_config = &hal->srng_config[ring_type];
414cb419f58SPavankumar Nandeshwar 	int shadow_cfg_idx = hal->num_shadow_reg_configured;
415cb419f58SPavankumar Nandeshwar 	u32 target_reg;
416cb419f58SPavankumar Nandeshwar 
4172bb41934SPavankumar Nandeshwar 	if (shadow_cfg_idx >= HAL_SHADOW_NUM_REGS_MAX)
418cb419f58SPavankumar Nandeshwar 		return -EINVAL;
419cb419f58SPavankumar Nandeshwar 
420cb419f58SPavankumar Nandeshwar 	hal->num_shadow_reg_configured++;
421cb419f58SPavankumar Nandeshwar 
422cb419f58SPavankumar Nandeshwar 	target_reg = srng_config->reg_start[HAL_HP_OFFSET_IN_REG_START];
423cb419f58SPavankumar Nandeshwar 	target_reg += srng_config->reg_size[HAL_HP_OFFSET_IN_REG_START] *
424cb419f58SPavankumar Nandeshwar 		ring_num;
425cb419f58SPavankumar Nandeshwar 
426cb419f58SPavankumar Nandeshwar 	/* For destination ring, shadow the TP */
427cb419f58SPavankumar Nandeshwar 	if (srng_config->ring_dir == HAL_SRNG_DIR_DST)
428cb419f58SPavankumar Nandeshwar 		target_reg += HAL_OFFSET_FROM_HP_TO_TP;
429cb419f58SPavankumar Nandeshwar 
430cb419f58SPavankumar Nandeshwar 	hal->shadow_reg_addr[shadow_cfg_idx] = target_reg;
431cb419f58SPavankumar Nandeshwar 
432cb419f58SPavankumar Nandeshwar 	/* update hp/tp addr to hal structure*/
433cb419f58SPavankumar Nandeshwar 	ath12k_wifi7_hal_srng_update_hp_tp_addr(ab, shadow_cfg_idx, ring_type,
434cb419f58SPavankumar Nandeshwar 						ring_num);
435cb419f58SPavankumar Nandeshwar 
436cb419f58SPavankumar Nandeshwar 	ath12k_dbg(ab, ATH12K_DBG_HAL,
437cb419f58SPavankumar Nandeshwar 		   "target_reg %x, shadow reg 0x%x shadow_idx 0x%x, ring_type %d, ring num %d",
438cb419f58SPavankumar Nandeshwar 		  target_reg,
439cb419f58SPavankumar Nandeshwar 		  HAL_SHADOW_REG(shadow_cfg_idx),
440cb419f58SPavankumar Nandeshwar 		  shadow_cfg_idx,
441cb419f58SPavankumar Nandeshwar 		  ring_type, ring_num);
442cb419f58SPavankumar Nandeshwar 
443cb419f58SPavankumar Nandeshwar 	return 0;
444cb419f58SPavankumar Nandeshwar }
4453d947cefSPavankumar Nandeshwar 
4463d947cefSPavankumar Nandeshwar void ath12k_wifi7_hal_ce_src_set_desc(struct hal_ce_srng_src_desc *desc,
4473d947cefSPavankumar Nandeshwar 				      dma_addr_t paddr,
4483d947cefSPavankumar Nandeshwar 				      u32 len, u32 id, u8 byte_swap_data)
4493d947cefSPavankumar Nandeshwar {
4503d947cefSPavankumar Nandeshwar 	desc->buffer_addr_low = cpu_to_le32(paddr & HAL_ADDR_LSB_REG_MASK);
4513d947cefSPavankumar Nandeshwar 	desc->buffer_addr_info =
4523d947cefSPavankumar Nandeshwar 		le32_encode_bits(((u64)paddr >> HAL_ADDR_MSB_REG_SHIFT),
4533d947cefSPavankumar Nandeshwar 				 HAL_CE_SRC_DESC_ADDR_INFO_ADDR_HI) |
4543d947cefSPavankumar Nandeshwar 		le32_encode_bits(byte_swap_data,
4553d947cefSPavankumar Nandeshwar 				 HAL_CE_SRC_DESC_ADDR_INFO_BYTE_SWAP) |
4563d947cefSPavankumar Nandeshwar 		le32_encode_bits(0, HAL_CE_SRC_DESC_ADDR_INFO_GATHER) |
4573d947cefSPavankumar Nandeshwar 		le32_encode_bits(len, HAL_CE_SRC_DESC_ADDR_INFO_LEN);
4583d947cefSPavankumar Nandeshwar 	desc->meta_info = le32_encode_bits(id, HAL_CE_SRC_DESC_META_INFO_DATA);
4593d947cefSPavankumar Nandeshwar }
4603d947cefSPavankumar Nandeshwar 
4613d947cefSPavankumar Nandeshwar void ath12k_wifi7_hal_ce_dst_set_desc(struct hal_ce_srng_dest_desc *desc,
4623d947cefSPavankumar Nandeshwar 				      dma_addr_t paddr)
4633d947cefSPavankumar Nandeshwar {
4643d947cefSPavankumar Nandeshwar 	desc->buffer_addr_low = cpu_to_le32(paddr & HAL_ADDR_LSB_REG_MASK);
4653d947cefSPavankumar Nandeshwar 	desc->buffer_addr_info =
4663d947cefSPavankumar Nandeshwar 		le32_encode_bits(((u64)paddr >> HAL_ADDR_MSB_REG_SHIFT),
4673d947cefSPavankumar Nandeshwar 				 HAL_CE_DEST_DESC_ADDR_INFO_ADDR_HI);
4683d947cefSPavankumar Nandeshwar }
469eba935ecSPavankumar Nandeshwar 
470eba935ecSPavankumar Nandeshwar void ath12k_wifi7_hal_set_link_desc_addr(struct hal_wbm_link_desc *desc,
471eba935ecSPavankumar Nandeshwar 					 u32 cookie, dma_addr_t paddr,
472eba935ecSPavankumar Nandeshwar 					 enum hal_rx_buf_return_buf_manager rbm)
473eba935ecSPavankumar Nandeshwar {
474eba935ecSPavankumar Nandeshwar 	desc->buf_addr_info.info0 = le32_encode_bits((paddr & HAL_ADDR_LSB_REG_MASK),
475eba935ecSPavankumar Nandeshwar 						     BUFFER_ADDR_INFO0_ADDR);
476eba935ecSPavankumar Nandeshwar 	desc->buf_addr_info.info1 =
477eba935ecSPavankumar Nandeshwar 			le32_encode_bits(((u64)paddr >> HAL_ADDR_MSB_REG_SHIFT),
478eba935ecSPavankumar Nandeshwar 					 BUFFER_ADDR_INFO1_ADDR) |
479eba935ecSPavankumar Nandeshwar 			le32_encode_bits(rbm, BUFFER_ADDR_INFO1_RET_BUF_MGR) |
480eba935ecSPavankumar Nandeshwar 			le32_encode_bits(cookie, BUFFER_ADDR_INFO1_SW_COOKIE);
481eba935ecSPavankumar Nandeshwar }
482eba935ecSPavankumar Nandeshwar 
483eba935ecSPavankumar Nandeshwar u32 ath12k_wifi7_hal_ce_dst_status_get_length(struct hal_ce_srng_dst_status_desc *desc)
484eba935ecSPavankumar Nandeshwar {
485eba935ecSPavankumar Nandeshwar 	u32 len;
486eba935ecSPavankumar Nandeshwar 
487eba935ecSPavankumar Nandeshwar 	len = le32_get_bits(READ_ONCE(desc->flags), HAL_CE_DST_STATUS_DESC_FLAGS_LEN);
488eba935ecSPavankumar Nandeshwar 	desc->flags &= ~cpu_to_le32(HAL_CE_DST_STATUS_DESC_FLAGS_LEN);
489eba935ecSPavankumar Nandeshwar 
490eba935ecSPavankumar Nandeshwar 	return len;
491eba935ecSPavankumar Nandeshwar }
492356942d3SPavankumar Nandeshwar 
493356942d3SPavankumar Nandeshwar void
494356942d3SPavankumar Nandeshwar ath12k_wifi7_hal_setup_link_idle_list(struct ath12k_base *ab,
495356942d3SPavankumar Nandeshwar 				      struct hal_wbm_idle_scatter_list *sbuf,
496356942d3SPavankumar Nandeshwar 				      u32 nsbufs, u32 tot_link_desc,
497356942d3SPavankumar Nandeshwar 				      u32 end_offset)
498356942d3SPavankumar Nandeshwar {
499356942d3SPavankumar Nandeshwar 	struct ath12k_hal *hal = &ab->hal;
500356942d3SPavankumar Nandeshwar 	struct ath12k_buffer_addr *link_addr;
501356942d3SPavankumar Nandeshwar 	int i;
502356942d3SPavankumar Nandeshwar 	u32 reg_scatter_buf_sz = HAL_WBM_IDLE_SCATTER_BUF_SIZE / 64;
503356942d3SPavankumar Nandeshwar 	u32 val;
504356942d3SPavankumar Nandeshwar 
505356942d3SPavankumar Nandeshwar 	link_addr = (void *)sbuf[0].vaddr + HAL_WBM_IDLE_SCATTER_BUF_SIZE;
506356942d3SPavankumar Nandeshwar 
507356942d3SPavankumar Nandeshwar 	for (i = 1; i < nsbufs; i++) {
508356942d3SPavankumar Nandeshwar 		link_addr->info0 = cpu_to_le32(sbuf[i].paddr & HAL_ADDR_LSB_REG_MASK);
509356942d3SPavankumar Nandeshwar 
510356942d3SPavankumar Nandeshwar 		link_addr->info1 =
511356942d3SPavankumar Nandeshwar 			le32_encode_bits((u64)sbuf[i].paddr >> HAL_ADDR_MSB_REG_SHIFT,
512356942d3SPavankumar Nandeshwar 					 HAL_WBM_SCATTERED_DESC_MSB_BASE_ADDR_39_32) |
513356942d3SPavankumar Nandeshwar 			le32_encode_bits(BASE_ADDR_MATCH_TAG_VAL,
514356942d3SPavankumar Nandeshwar 					 HAL_WBM_SCATTERED_DESC_MSB_BASE_ADDR_MATCH_TAG);
515356942d3SPavankumar Nandeshwar 
516356942d3SPavankumar Nandeshwar 		link_addr = (void *)sbuf[i].vaddr +
517356942d3SPavankumar Nandeshwar 			     HAL_WBM_IDLE_SCATTER_BUF_SIZE;
518356942d3SPavankumar Nandeshwar 	}
519356942d3SPavankumar Nandeshwar 
520356942d3SPavankumar Nandeshwar 	val = u32_encode_bits(reg_scatter_buf_sz, HAL_WBM_SCATTER_BUFFER_SIZE) |
521356942d3SPavankumar Nandeshwar 	      u32_encode_bits(0x1, HAL_WBM_LINK_DESC_IDLE_LIST_MODE);
522356942d3SPavankumar Nandeshwar 
523356942d3SPavankumar Nandeshwar 	ath12k_hif_write32(ab,
524356942d3SPavankumar Nandeshwar 			   HAL_SEQ_WCSS_UMAC_WBM_REG +
525356942d3SPavankumar Nandeshwar 			   HAL_WBM_R0_IDLE_LIST_CONTROL_ADDR(hal),
526356942d3SPavankumar Nandeshwar 			   val);
527356942d3SPavankumar Nandeshwar 
528356942d3SPavankumar Nandeshwar 	val = u32_encode_bits(reg_scatter_buf_sz * nsbufs,
529356942d3SPavankumar Nandeshwar 			      HAL_WBM_SCATTER_RING_SIZE_OF_IDLE_LINK_DESC_LIST);
530356942d3SPavankumar Nandeshwar 	ath12k_hif_write32(ab,
531356942d3SPavankumar Nandeshwar 			   HAL_SEQ_WCSS_UMAC_WBM_REG +
532356942d3SPavankumar Nandeshwar 			   HAL_WBM_R0_IDLE_LIST_SIZE_ADDR(hal),
533356942d3SPavankumar Nandeshwar 			   val);
534356942d3SPavankumar Nandeshwar 
535356942d3SPavankumar Nandeshwar 	val = u32_encode_bits(sbuf[0].paddr & HAL_ADDR_LSB_REG_MASK,
536356942d3SPavankumar Nandeshwar 			      BUFFER_ADDR_INFO0_ADDR);
537356942d3SPavankumar Nandeshwar 	ath12k_hif_write32(ab,
538356942d3SPavankumar Nandeshwar 			   HAL_SEQ_WCSS_UMAC_WBM_REG +
539356942d3SPavankumar Nandeshwar 			   HAL_WBM_SCATTERED_RING_BASE_LSB(hal),
540356942d3SPavankumar Nandeshwar 			   val);
541356942d3SPavankumar Nandeshwar 
542356942d3SPavankumar Nandeshwar 	val = u32_encode_bits(BASE_ADDR_MATCH_TAG_VAL,
543356942d3SPavankumar Nandeshwar 			      HAL_WBM_SCATTERED_DESC_MSB_BASE_ADDR_MATCH_TAG) |
544356942d3SPavankumar Nandeshwar 	      u32_encode_bits((u64)sbuf[0].paddr >> HAL_ADDR_MSB_REG_SHIFT,
545356942d3SPavankumar Nandeshwar 			      HAL_WBM_SCATTERED_DESC_MSB_BASE_ADDR_39_32);
546356942d3SPavankumar Nandeshwar 	ath12k_hif_write32(ab,
547356942d3SPavankumar Nandeshwar 			   HAL_SEQ_WCSS_UMAC_WBM_REG +
548356942d3SPavankumar Nandeshwar 			   HAL_WBM_SCATTERED_RING_BASE_MSB(hal),
549356942d3SPavankumar Nandeshwar 			   val);
550356942d3SPavankumar Nandeshwar 
551356942d3SPavankumar Nandeshwar 	/* Setup head and tail pointers for the idle list */
552356942d3SPavankumar Nandeshwar 	val = u32_encode_bits(sbuf[nsbufs - 1].paddr, BUFFER_ADDR_INFO0_ADDR);
553356942d3SPavankumar Nandeshwar 	ath12k_hif_write32(ab,
554356942d3SPavankumar Nandeshwar 			   HAL_SEQ_WCSS_UMAC_WBM_REG +
555356942d3SPavankumar Nandeshwar 			   HAL_WBM_SCATTERED_DESC_PTR_HEAD_INFO_IX0(hal),
556356942d3SPavankumar Nandeshwar 			   val);
557356942d3SPavankumar Nandeshwar 
558356942d3SPavankumar Nandeshwar 	val = u32_encode_bits(((u64)sbuf[nsbufs - 1].paddr >> HAL_ADDR_MSB_REG_SHIFT),
559356942d3SPavankumar Nandeshwar 			      HAL_WBM_SCATTERED_DESC_MSB_BASE_ADDR_39_32) |
560356942d3SPavankumar Nandeshwar 	       u32_encode_bits((end_offset >> 2),
561356942d3SPavankumar Nandeshwar 			       HAL_WBM_SCATTERED_DESC_HEAD_P_OFFSET_IX1);
562356942d3SPavankumar Nandeshwar 	ath12k_hif_write32(ab,
563356942d3SPavankumar Nandeshwar 			   HAL_SEQ_WCSS_UMAC_WBM_REG +
564356942d3SPavankumar Nandeshwar 			   HAL_WBM_SCATTERED_DESC_PTR_HEAD_INFO_IX1(hal),
565356942d3SPavankumar Nandeshwar 			   val);
566356942d3SPavankumar Nandeshwar 
567356942d3SPavankumar Nandeshwar 	val = u32_encode_bits(sbuf[0].paddr, BUFFER_ADDR_INFO0_ADDR);
568356942d3SPavankumar Nandeshwar 	ath12k_hif_write32(ab,
569356942d3SPavankumar Nandeshwar 			   HAL_SEQ_WCSS_UMAC_WBM_REG +
570356942d3SPavankumar Nandeshwar 			   HAL_WBM_SCATTERED_DESC_PTR_HEAD_INFO_IX0(hal),
571356942d3SPavankumar Nandeshwar 			   val);
572356942d3SPavankumar Nandeshwar 
573356942d3SPavankumar Nandeshwar 	val = u32_encode_bits(sbuf[0].paddr, BUFFER_ADDR_INFO0_ADDR);
574356942d3SPavankumar Nandeshwar 	ath12k_hif_write32(ab,
575356942d3SPavankumar Nandeshwar 			   HAL_SEQ_WCSS_UMAC_WBM_REG +
576356942d3SPavankumar Nandeshwar 			   HAL_WBM_SCATTERED_DESC_PTR_TAIL_INFO_IX0(hal),
577356942d3SPavankumar Nandeshwar 			   val);
578356942d3SPavankumar Nandeshwar 
579356942d3SPavankumar Nandeshwar 	val = u32_encode_bits(((u64)sbuf[0].paddr >> HAL_ADDR_MSB_REG_SHIFT),
580356942d3SPavankumar Nandeshwar 			      HAL_WBM_SCATTERED_DESC_MSB_BASE_ADDR_39_32) |
581356942d3SPavankumar Nandeshwar 	      u32_encode_bits(0, HAL_WBM_SCATTERED_DESC_TAIL_P_OFFSET_IX1);
582356942d3SPavankumar Nandeshwar 	ath12k_hif_write32(ab,
583356942d3SPavankumar Nandeshwar 			   HAL_SEQ_WCSS_UMAC_WBM_REG +
584356942d3SPavankumar Nandeshwar 			   HAL_WBM_SCATTERED_DESC_PTR_TAIL_INFO_IX1(hal),
585356942d3SPavankumar Nandeshwar 			   val);
586356942d3SPavankumar Nandeshwar 
587356942d3SPavankumar Nandeshwar 	val = 2 * tot_link_desc;
588356942d3SPavankumar Nandeshwar 	ath12k_hif_write32(ab, HAL_SEQ_WCSS_UMAC_WBM_REG +
589356942d3SPavankumar Nandeshwar 			   HAL_WBM_SCATTERED_DESC_PTR_HP_ADDR(hal),
590356942d3SPavankumar Nandeshwar 			   val);
591356942d3SPavankumar Nandeshwar 
592356942d3SPavankumar Nandeshwar 	/* Enable the SRNG */
593356942d3SPavankumar Nandeshwar 	val = u32_encode_bits(1, HAL_WBM_IDLE_LINK_RING_MISC_SRNG_ENABLE) |
594356942d3SPavankumar Nandeshwar 	      u32_encode_bits(1, HAL_WBM_IDLE_LINK_RING_MISC_RIND_ID_DISABLE);
595356942d3SPavankumar Nandeshwar 	ath12k_hif_write32(ab,
596356942d3SPavankumar Nandeshwar 			   HAL_SEQ_WCSS_UMAC_WBM_REG +
597356942d3SPavankumar Nandeshwar 			   HAL_WBM_IDLE_LINK_RING_MISC_ADDR(hal),
598356942d3SPavankumar Nandeshwar 			   val);
599356942d3SPavankumar Nandeshwar }
600356942d3SPavankumar Nandeshwar 
601356942d3SPavankumar Nandeshwar void ath12k_wifi7_hal_tx_configure_bank_register(struct ath12k_base *ab,
602356942d3SPavankumar Nandeshwar 						 u32 bank_config,
603356942d3SPavankumar Nandeshwar 						 u8 bank_id)
604356942d3SPavankumar Nandeshwar {
605356942d3SPavankumar Nandeshwar 	ath12k_hif_write32(ab, HAL_TCL_SW_CONFIG_BANK_ADDR + 4 * bank_id,
606356942d3SPavankumar Nandeshwar 			   bank_config);
607356942d3SPavankumar Nandeshwar }
608356942d3SPavankumar Nandeshwar 
609356942d3SPavankumar Nandeshwar void ath12k_wifi7_hal_reoq_lut_addr_read_enable(struct ath12k_base *ab)
610356942d3SPavankumar Nandeshwar {
611356942d3SPavankumar Nandeshwar 	struct ath12k_hal *hal = &ab->hal;
612356942d3SPavankumar Nandeshwar 
613356942d3SPavankumar Nandeshwar 	u32 val = ath12k_hif_read32(ab, HAL_SEQ_WCSS_UMAC_REO_REG +
614356942d3SPavankumar Nandeshwar 				    HAL_REO1_QDESC_ADDR(hal));
615356942d3SPavankumar Nandeshwar 
616356942d3SPavankumar Nandeshwar 	ath12k_hif_write32(ab, HAL_SEQ_WCSS_UMAC_REO_REG + HAL_REO1_QDESC_ADDR(hal),
617356942d3SPavankumar Nandeshwar 			   val | HAL_REO_QDESC_ADDR_READ_LUT_ENABLE);
618356942d3SPavankumar Nandeshwar }
619356942d3SPavankumar Nandeshwar 
620356942d3SPavankumar Nandeshwar void ath12k_wifi7_hal_reoq_lut_set_max_peerid(struct ath12k_base *ab)
621356942d3SPavankumar Nandeshwar {
622356942d3SPavankumar Nandeshwar 	struct ath12k_hal *hal = &ab->hal;
623356942d3SPavankumar Nandeshwar 
624356942d3SPavankumar Nandeshwar 	ath12k_hif_write32(ab, HAL_SEQ_WCSS_UMAC_REO_REG + HAL_REO1_QDESC_MAX_PEERID(hal),
625356942d3SPavankumar Nandeshwar 			   HAL_REO_QDESC_MAX_PEERID);
626356942d3SPavankumar Nandeshwar }
627356942d3SPavankumar Nandeshwar 
628356942d3SPavankumar Nandeshwar void ath12k_wifi7_hal_write_reoq_lut_addr(struct ath12k_base *ab,
629356942d3SPavankumar Nandeshwar 					  dma_addr_t paddr)
630356942d3SPavankumar Nandeshwar {
631356942d3SPavankumar Nandeshwar 	ath12k_hif_write32(ab, HAL_SEQ_WCSS_UMAC_REO_REG +
632356942d3SPavankumar Nandeshwar 			   HAL_REO1_QDESC_LUT_BASE0(&ab->hal), paddr);
633356942d3SPavankumar Nandeshwar }
634356942d3SPavankumar Nandeshwar 
635356942d3SPavankumar Nandeshwar void ath12k_wifi7_hal_write_ml_reoq_lut_addr(struct ath12k_base *ab,
636356942d3SPavankumar Nandeshwar 					     dma_addr_t paddr)
637356942d3SPavankumar Nandeshwar {
638356942d3SPavankumar Nandeshwar 	ath12k_hif_write32(ab, HAL_SEQ_WCSS_UMAC_REO_REG +
639356942d3SPavankumar Nandeshwar 			   HAL_REO1_QDESC_LUT_BASE1(&ab->hal), paddr);
640356942d3SPavankumar Nandeshwar }
641ea23813aSPavankumar Nandeshwar 
642ea23813aSPavankumar Nandeshwar void ath12k_wifi7_hal_cc_config(struct ath12k_base *ab)
643ea23813aSPavankumar Nandeshwar {
644ea23813aSPavankumar Nandeshwar 	u32 cmem_base = ab->qmi.dev_mem[ATH12K_QMI_DEVMEM_CMEM_INDEX].start;
645ea23813aSPavankumar Nandeshwar 	u32 reo_base = HAL_SEQ_WCSS_UMAC_REO_REG;
646ea23813aSPavankumar Nandeshwar 	u32 wbm_base = HAL_SEQ_WCSS_UMAC_WBM_REG;
647ea23813aSPavankumar Nandeshwar 	u32 val = 0;
648ea23813aSPavankumar Nandeshwar 	struct ath12k_hal *hal = &ab->hal;
649ea23813aSPavankumar Nandeshwar 
650ea23813aSPavankumar Nandeshwar 	if (ath12k_ftm_mode)
651ea23813aSPavankumar Nandeshwar 		return;
652ea23813aSPavankumar Nandeshwar 
653ea23813aSPavankumar Nandeshwar 	ath12k_hif_write32(ab, reo_base + HAL_REO1_SW_COOKIE_CFG0(hal), cmem_base);
654ea23813aSPavankumar Nandeshwar 
655ea23813aSPavankumar Nandeshwar 	val |= u32_encode_bits(ATH12K_CMEM_ADDR_MSB,
656ea23813aSPavankumar Nandeshwar 			       HAL_REO1_SW_COOKIE_CFG_CMEM_BASE_ADDR_MSB) |
657ea23813aSPavankumar Nandeshwar 		u32_encode_bits(ATH12K_CC_PPT_MSB,
658ea23813aSPavankumar Nandeshwar 				HAL_REO1_SW_COOKIE_CFG_COOKIE_PPT_MSB) |
659ea23813aSPavankumar Nandeshwar 		u32_encode_bits(ATH12K_CC_SPT_MSB,
660ea23813aSPavankumar Nandeshwar 				HAL_REO1_SW_COOKIE_CFG_COOKIE_SPT_MSB) |
661ea23813aSPavankumar Nandeshwar 		u32_encode_bits(1, HAL_REO1_SW_COOKIE_CFG_ALIGN) |
662ea23813aSPavankumar Nandeshwar 		u32_encode_bits(1, HAL_REO1_SW_COOKIE_CFG_ENABLE) |
663ea23813aSPavankumar Nandeshwar 		u32_encode_bits(1, HAL_REO1_SW_COOKIE_CFG_GLOBAL_ENABLE);
664ea23813aSPavankumar Nandeshwar 
665ea23813aSPavankumar Nandeshwar 	ath12k_hif_write32(ab, reo_base + HAL_REO1_SW_COOKIE_CFG1(hal), val);
666ea23813aSPavankumar Nandeshwar 
667ea23813aSPavankumar Nandeshwar 	/* Enable HW CC for WBM */
668ea23813aSPavankumar Nandeshwar 	ath12k_hif_write32(ab, wbm_base + HAL_WBM_SW_COOKIE_CFG0, cmem_base);
669ea23813aSPavankumar Nandeshwar 
670ea23813aSPavankumar Nandeshwar 	val = u32_encode_bits(ATH12K_CMEM_ADDR_MSB,
671ea23813aSPavankumar Nandeshwar 			      HAL_WBM_SW_COOKIE_CFG_CMEM_BASE_ADDR_MSB) |
672ea23813aSPavankumar Nandeshwar 		u32_encode_bits(ATH12K_CC_PPT_MSB,
673ea23813aSPavankumar Nandeshwar 				HAL_WBM_SW_COOKIE_CFG_COOKIE_PPT_MSB) |
674ea23813aSPavankumar Nandeshwar 		u32_encode_bits(ATH12K_CC_SPT_MSB,
675ea23813aSPavankumar Nandeshwar 				HAL_WBM_SW_COOKIE_CFG_COOKIE_SPT_MSB) |
676ea23813aSPavankumar Nandeshwar 		u32_encode_bits(1, HAL_WBM_SW_COOKIE_CFG_ALIGN);
677ea23813aSPavankumar Nandeshwar 
678ea23813aSPavankumar Nandeshwar 	ath12k_hif_write32(ab, wbm_base + HAL_WBM_SW_COOKIE_CFG1, val);
679ea23813aSPavankumar Nandeshwar 
680ea23813aSPavankumar Nandeshwar 	/* Enable conversion complete indication */
681ea23813aSPavankumar Nandeshwar 	val = ath12k_hif_read32(ab, wbm_base + HAL_WBM_SW_COOKIE_CFG2);
682ea23813aSPavankumar Nandeshwar 	val |= u32_encode_bits(1, HAL_WBM_SW_COOKIE_CFG_RELEASE_PATH_EN) |
683ea23813aSPavankumar Nandeshwar 		u32_encode_bits(1, HAL_WBM_SW_COOKIE_CFG_ERR_PATH_EN) |
684ea23813aSPavankumar Nandeshwar 		u32_encode_bits(1, HAL_WBM_SW_COOKIE_CFG_CONV_IND_EN);
685ea23813aSPavankumar Nandeshwar 
686ea23813aSPavankumar Nandeshwar 	ath12k_hif_write32(ab, wbm_base + HAL_WBM_SW_COOKIE_CFG2, val);
687ea23813aSPavankumar Nandeshwar 
688ea23813aSPavankumar Nandeshwar 	/* Enable Cookie conversion for WBM2SW Rings */
689ea23813aSPavankumar Nandeshwar 	val = ath12k_hif_read32(ab, wbm_base + HAL_WBM_SW_COOKIE_CONVERT_CFG);
690ea23813aSPavankumar Nandeshwar 	val |= u32_encode_bits(1, HAL_WBM_SW_COOKIE_CONV_CFG_GLOBAL_EN) |
691ea23813aSPavankumar Nandeshwar 	       hal->hal_params->wbm2sw_cc_enable;
692ea23813aSPavankumar Nandeshwar 
693ea23813aSPavankumar Nandeshwar 	ath12k_hif_write32(ab, wbm_base + HAL_WBM_SW_COOKIE_CONVERT_CFG, val);
694ea23813aSPavankumar Nandeshwar }
695ea23813aSPavankumar Nandeshwar 
696ea23813aSPavankumar Nandeshwar enum hal_rx_buf_return_buf_manager
697ea23813aSPavankumar Nandeshwar ath12k_wifi7_hal_get_idle_link_rbm(struct ath12k_hal *hal, u8 device_id)
698ea23813aSPavankumar Nandeshwar {
699ea23813aSPavankumar Nandeshwar 	switch (device_id) {
700ea23813aSPavankumar Nandeshwar 	case 0:
701ea23813aSPavankumar Nandeshwar 		return HAL_RX_BUF_RBM_WBM_DEV0_IDLE_DESC_LIST;
702ea23813aSPavankumar Nandeshwar 	case 1:
703ea23813aSPavankumar Nandeshwar 		return HAL_RX_BUF_RBM_WBM_DEV1_IDLE_DESC_LIST;
704ea23813aSPavankumar Nandeshwar 	case 2:
705ea23813aSPavankumar Nandeshwar 		return HAL_RX_BUF_RBM_WBM_DEV2_IDLE_DESC_LIST;
706ea23813aSPavankumar Nandeshwar 	default:
707ea23813aSPavankumar Nandeshwar 		ath12k_warn(hal,
708ea23813aSPavankumar Nandeshwar 			    "invalid %d device id, so choose default rbm\n",
709ea23813aSPavankumar Nandeshwar 			    device_id);
710ea23813aSPavankumar Nandeshwar 		WARN_ON(1);
711ea23813aSPavankumar Nandeshwar 		return HAL_RX_BUF_RBM_WBM_DEV0_IDLE_DESC_LIST;
712ea23813aSPavankumar Nandeshwar 	}
713ea23813aSPavankumar Nandeshwar }
714