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