Path: blob/main/sys/contrib/dev/athk/ath11k/hal.h
105420 views
/* SPDX-License-Identifier: BSD-3-Clause-Clear */1/*2* Copyright (c) 2018-2019 The Linux Foundation. All rights reserved.3* Copyright (c) 2021-2022, 2024 Qualcomm Innovation Center, Inc. All rights reserved.4*/56#ifndef ATH11K_HAL_H7#define ATH11K_HAL_H89#include "hal_desc.h"10#include "rx_desc.h"1112struct ath11k_base;1314#define HAL_LINK_DESC_SIZE (32 << 2)15#define HAL_LINK_DESC_ALIGN 12816#define HAL_NUM_MPDUS_PER_LINK_DESC 617#define HAL_NUM_TX_MSDUS_PER_LINK_DESC 718#define HAL_NUM_RX_MSDUS_PER_LINK_DESC 619#define HAL_NUM_MPDU_LINKS_PER_QUEUE_DESC 1220#define HAL_MAX_AVAIL_BLK_RES 32122#define HAL_RING_BASE_ALIGN 82324#define HAL_WBM_IDLE_SCATTER_BUF_SIZE_MAX 3270425/* TODO: Check with hw team on the supported scatter buf size */26#define HAL_WBM_IDLE_SCATTER_NEXT_PTR_SIZE 827#define HAL_WBM_IDLE_SCATTER_BUF_SIZE (HAL_WBM_IDLE_SCATTER_BUF_SIZE_MAX - \28HAL_WBM_IDLE_SCATTER_NEXT_PTR_SIZE)2930#define HAL_DSCP_TID_MAP_TBL_NUM_ENTRIES_MAX 4831#define HAL_DSCP_TID_TBL_SIZE 243233/* calculate the register address from bar0 of shadow register x */34#define HAL_SHADOW_BASE_ADDR(ab) ab->hw_params.regs->hal_shadow_base_addr35#define HAL_SHADOW_NUM_REGS 3636#define HAL_HP_OFFSET_IN_REG_START 137#define HAL_OFFSET_FROM_HP_TO_TP 43839#define HAL_SHADOW_REG(ab, x) (HAL_SHADOW_BASE_ADDR(ab) + (4 * (x)))4041/* WCSS Relative address */42#define HAL_SEQ_WCSS_UMAC_OFFSET 0x00a0000043#define HAL_SEQ_WCSS_UMAC_REO_REG 0x00a3800044#define HAL_SEQ_WCSS_UMAC_TCL_REG 0x00a4400045#define HAL_SEQ_WCSS_UMAC_CE0_SRC_REG(x) \46(ab->hw_params.regs->hal_seq_wcss_umac_ce0_src_reg)47#define HAL_SEQ_WCSS_UMAC_CE0_DST_REG(x) \48(ab->hw_params.regs->hal_seq_wcss_umac_ce0_dst_reg)49#define HAL_SEQ_WCSS_UMAC_CE1_SRC_REG(x) \50(ab->hw_params.regs->hal_seq_wcss_umac_ce1_src_reg)51#define HAL_SEQ_WCSS_UMAC_CE1_DST_REG(x) \52(ab->hw_params.regs->hal_seq_wcss_umac_ce1_dst_reg)53#define HAL_SEQ_WCSS_UMAC_WBM_REG 0x00a340005455#define HAL_CE_WFSS_CE_REG_BASE 0x01b8000056#define HAL_WLAON_REG_BASE 0x01f800005758/* SW2TCL(x) R0 ring configuration address */59#define HAL_TCL1_RING_CMN_CTRL_REG 0x0000001460#define HAL_TCL1_RING_DSCP_TID_MAP 0x0000002c61#define HAL_TCL1_RING_BASE_LSB(ab) ab->hw_params.regs->hal_tcl1_ring_base_lsb62#define HAL_TCL1_RING_BASE_MSB(ab) ab->hw_params.regs->hal_tcl1_ring_base_msb63#define HAL_TCL1_RING_ID(ab) ab->hw_params.regs->hal_tcl1_ring_id64#define HAL_TCL1_RING_MISC(ab) ab->hw_params.regs->hal_tcl1_ring_misc65#define HAL_TCL1_RING_TP_ADDR_LSB(ab) \66ab->hw_params.regs->hal_tcl1_ring_tp_addr_lsb67#define HAL_TCL1_RING_TP_ADDR_MSB(ab) \68ab->hw_params.regs->hal_tcl1_ring_tp_addr_msb69#define HAL_TCL1_RING_CONSUMER_INT_SETUP_IX0(ab) \70ab->hw_params.regs->hal_tcl1_ring_consumer_int_setup_ix071#define HAL_TCL1_RING_CONSUMER_INT_SETUP_IX1(ab) \72ab->hw_params.regs->hal_tcl1_ring_consumer_int_setup_ix173#define HAL_TCL1_RING_MSI1_BASE_LSB(ab) \74ab->hw_params.regs->hal_tcl1_ring_msi1_base_lsb75#define HAL_TCL1_RING_MSI1_BASE_MSB(ab) \76ab->hw_params.regs->hal_tcl1_ring_msi1_base_msb77#define HAL_TCL1_RING_MSI1_DATA(ab) \78ab->hw_params.regs->hal_tcl1_ring_msi1_data79#define HAL_TCL2_RING_BASE_LSB(ab) ab->hw_params.regs->hal_tcl2_ring_base_lsb80#define HAL_TCL_RING_BASE_LSB(ab) ab->hw_params.regs->hal_tcl_ring_base_lsb8182#define HAL_TCL1_RING_MSI1_BASE_LSB_OFFSET(ab) \83(HAL_TCL1_RING_MSI1_BASE_LSB(ab) - HAL_TCL1_RING_BASE_LSB(ab))84#define HAL_TCL1_RING_MSI1_BASE_MSB_OFFSET(ab) \85(HAL_TCL1_RING_MSI1_BASE_MSB(ab) - HAL_TCL1_RING_BASE_LSB(ab))86#define HAL_TCL1_RING_MSI1_DATA_OFFSET(ab) \87(HAL_TCL1_RING_MSI1_DATA(ab) - HAL_TCL1_RING_BASE_LSB(ab))88#define HAL_TCL1_RING_BASE_MSB_OFFSET(ab) \89(HAL_TCL1_RING_BASE_MSB(ab) - HAL_TCL1_RING_BASE_LSB(ab))90#define HAL_TCL1_RING_ID_OFFSET(ab) \91(HAL_TCL1_RING_ID(ab) - HAL_TCL1_RING_BASE_LSB(ab))92#define HAL_TCL1_RING_CONSR_INT_SETUP_IX0_OFFSET(ab) \93(HAL_TCL1_RING_CONSUMER_INT_SETUP_IX0(ab) - HAL_TCL1_RING_BASE_LSB(ab))94#define HAL_TCL1_RING_CONSR_INT_SETUP_IX1_OFFSET(ab) \95(HAL_TCL1_RING_CONSUMER_INT_SETUP_IX1(ab) - HAL_TCL1_RING_BASE_LSB(ab))96#define HAL_TCL1_RING_TP_ADDR_LSB_OFFSET(ab) \97(HAL_TCL1_RING_TP_ADDR_LSB(ab) - HAL_TCL1_RING_BASE_LSB(ab))98#define HAL_TCL1_RING_TP_ADDR_MSB_OFFSET(ab) \99(HAL_TCL1_RING_TP_ADDR_MSB(ab) - HAL_TCL1_RING_BASE_LSB(ab))100#define HAL_TCL1_RING_MISC_OFFSET(ab) \101(HAL_TCL1_RING_MISC(ab) - HAL_TCL1_RING_BASE_LSB(ab))102103/* SW2TCL(x) R2 ring pointers (head/tail) address */104#define HAL_TCL1_RING_HP 0x00002000105#define HAL_TCL1_RING_TP 0x00002004106#define HAL_TCL2_RING_HP 0x00002008107#define HAL_TCL_RING_HP 0x00002018108109#define HAL_TCL1_RING_TP_OFFSET \110(HAL_TCL1_RING_TP - HAL_TCL1_RING_HP)111112/* TCL STATUS ring address */113#define HAL_TCL_STATUS_RING_BASE_LSB(ab) \114ab->hw_params.regs->hal_tcl_status_ring_base_lsb115#define HAL_TCL_STATUS_RING_HP 0x00002030116117/* REO2SW(x) R0 ring configuration address */118#define HAL_REO1_GEN_ENABLE 0x00000000119#define HAL_REO1_DEST_RING_CTRL_IX_0 0x00000004120#define HAL_REO1_DEST_RING_CTRL_IX_1 0x00000008121#define HAL_REO1_DEST_RING_CTRL_IX_2 0x0000000c122#define HAL_REO1_DEST_RING_CTRL_IX_3 0x00000010123#define HAL_REO1_MISC_CTL(ab) ab->hw_params.regs->hal_reo1_misc_ctl124#define HAL_REO1_RING_BASE_LSB(ab) ab->hw_params.regs->hal_reo1_ring_base_lsb125#define HAL_REO1_RING_BASE_MSB(ab) ab->hw_params.regs->hal_reo1_ring_base_msb126#define HAL_REO1_RING_ID(ab) ab->hw_params.regs->hal_reo1_ring_id127#define HAL_REO1_RING_MISC(ab) ab->hw_params.regs->hal_reo1_ring_misc128#define HAL_REO1_RING_HP_ADDR_LSB(ab) \129ab->hw_params.regs->hal_reo1_ring_hp_addr_lsb130#define HAL_REO1_RING_HP_ADDR_MSB(ab) \131ab->hw_params.regs->hal_reo1_ring_hp_addr_msb132#define HAL_REO1_RING_PRODUCER_INT_SETUP(ab) \133ab->hw_params.regs->hal_reo1_ring_producer_int_setup134#define HAL_REO1_RING_MSI1_BASE_LSB(ab) \135ab->hw_params.regs->hal_reo1_ring_msi1_base_lsb136#define HAL_REO1_RING_MSI1_BASE_MSB(ab) \137ab->hw_params.regs->hal_reo1_ring_msi1_base_msb138#define HAL_REO1_RING_MSI1_DATA(ab) \139ab->hw_params.regs->hal_reo1_ring_msi1_data140#define HAL_REO2_RING_BASE_LSB(ab) ab->hw_params.regs->hal_reo2_ring_base_lsb141#define HAL_REO1_AGING_THRESH_IX_0(ab) \142ab->hw_params.regs->hal_reo1_aging_thresh_ix_0143#define HAL_REO1_AGING_THRESH_IX_1(ab) \144ab->hw_params.regs->hal_reo1_aging_thresh_ix_1145#define HAL_REO1_AGING_THRESH_IX_2(ab) \146ab->hw_params.regs->hal_reo1_aging_thresh_ix_2147#define HAL_REO1_AGING_THRESH_IX_3(ab) \148ab->hw_params.regs->hal_reo1_aging_thresh_ix_3149150#define HAL_REO1_RING_MSI1_BASE_LSB_OFFSET(ab) \151(HAL_REO1_RING_MSI1_BASE_LSB(ab) - HAL_REO1_RING_BASE_LSB(ab))152#define HAL_REO1_RING_MSI1_BASE_MSB_OFFSET(ab) \153(HAL_REO1_RING_MSI1_BASE_MSB(ab) - HAL_REO1_RING_BASE_LSB(ab))154#define HAL_REO1_RING_MSI1_DATA_OFFSET(ab) \155(HAL_REO1_RING_MSI1_DATA(ab) - HAL_REO1_RING_BASE_LSB(ab))156#define HAL_REO1_RING_BASE_MSB_OFFSET(ab) \157(HAL_REO1_RING_BASE_MSB(ab) - HAL_REO1_RING_BASE_LSB(ab))158#define HAL_REO1_RING_ID_OFFSET(ab) (HAL_REO1_RING_ID(ab) - HAL_REO1_RING_BASE_LSB(ab))159#define HAL_REO1_RING_PRODUCER_INT_SETUP_OFFSET(ab) \160(HAL_REO1_RING_PRODUCER_INT_SETUP(ab) - HAL_REO1_RING_BASE_LSB(ab))161#define HAL_REO1_RING_HP_ADDR_LSB_OFFSET(ab) \162(HAL_REO1_RING_HP_ADDR_LSB(ab) - HAL_REO1_RING_BASE_LSB(ab))163#define HAL_REO1_RING_HP_ADDR_MSB_OFFSET(ab) \164(HAL_REO1_RING_HP_ADDR_MSB(ab) - HAL_REO1_RING_BASE_LSB(ab))165#define HAL_REO1_RING_MISC_OFFSET(ab) \166(HAL_REO1_RING_MISC(ab) - HAL_REO1_RING_BASE_LSB(ab))167168/* REO2SW(x) R2 ring pointers (head/tail) address */169#define HAL_REO1_RING_HP(ab) ab->hw_params.regs->hal_reo1_ring_hp170#define HAL_REO1_RING_TP(ab) ab->hw_params.regs->hal_reo1_ring_tp171#define HAL_REO2_RING_HP(ab) ab->hw_params.regs->hal_reo2_ring_hp172173#define HAL_REO1_RING_TP_OFFSET(ab) (HAL_REO1_RING_TP(ab) - HAL_REO1_RING_HP(ab))174175/* REO2TCL R0 ring configuration address */176#define HAL_REO_TCL_RING_BASE_LSB(ab) \177ab->hw_params.regs->hal_reo_tcl_ring_base_lsb178179/* REO2TCL R2 ring pointer (head/tail) address */180#define HAL_REO_TCL_RING_HP(ab) ab->hw_params.regs->hal_reo_tcl_ring_hp181182/* REO CMD R0 address */183#define HAL_REO_CMD_RING_BASE_LSB(ab) \184ab->hw_params.regs->hal_reo_cmd_ring_base_lsb185186/* REO CMD R2 address */187#define HAL_REO_CMD_HP(ab) ab->hw_params.regs->hal_reo_cmd_ring_hp188189/* SW2REO R0 address */190#define HAL_SW2REO_RING_BASE_LSB(ab) \191ab->hw_params.regs->hal_sw2reo_ring_base_lsb192193/* SW2REO R2 address */194#define HAL_SW2REO_RING_HP(ab) ab->hw_params.regs->hal_sw2reo_ring_hp195196/* CE ring R0 address */197#define HAL_CE_DST_RING_BASE_LSB 0x00000000198#define HAL_CE_DST_STATUS_RING_BASE_LSB 0x00000058199#define HAL_CE_DST_RING_CTRL 0x000000b0200201/* CE ring R2 address */202#define HAL_CE_DST_RING_HP 0x00000400203#define HAL_CE_DST_STATUS_RING_HP 0x00000408204205/* REO status address */206#define HAL_REO_STATUS_RING_BASE_LSB(ab) \207ab->hw_params.regs->hal_reo_status_ring_base_lsb208#define HAL_REO_STATUS_HP(ab) ab->hw_params.regs->hal_reo_status_hp209210/* WBM Idle R0 address */211#define HAL_WBM_IDLE_LINK_RING_BASE_LSB(x) \212(ab->hw_params.regs->hal_wbm_idle_link_ring_base_lsb)213#define HAL_WBM_IDLE_LINK_RING_MISC_ADDR(x) \214(ab->hw_params.regs->hal_wbm_idle_link_ring_misc)215#define HAL_WBM_R0_IDLE_LIST_CONTROL_ADDR 0x00000048216#define HAL_WBM_R0_IDLE_LIST_SIZE_ADDR 0x0000004c217#define HAL_WBM_SCATTERED_RING_BASE_LSB 0x00000058218#define HAL_WBM_SCATTERED_RING_BASE_MSB 0x0000005c219#define HAL_WBM_SCATTERED_DESC_PTR_HEAD_INFO_IX0 0x00000068220#define HAL_WBM_SCATTERED_DESC_PTR_HEAD_INFO_IX1 0x0000006c221#define HAL_WBM_SCATTERED_DESC_PTR_TAIL_INFO_IX0 0x00000078222#define HAL_WBM_SCATTERED_DESC_PTR_TAIL_INFO_IX1 0x0000007c223#define HAL_WBM_SCATTERED_DESC_PTR_HP_ADDR 0x00000084224225/* WBM Idle R2 address */226#define HAL_WBM_IDLE_LINK_RING_HP 0x000030b0227228/* SW2WBM R0 release address */229#define HAL_WBM_RELEASE_RING_BASE_LSB(x) \230(ab->hw_params.regs->hal_wbm_release_ring_base_lsb)231232/* SW2WBM R2 release address */233#define HAL_WBM_RELEASE_RING_HP 0x00003018234235/* WBM2SW R0 release address */236#define HAL_WBM0_RELEASE_RING_BASE_LSB(x) \237(ab->hw_params.regs->hal_wbm0_release_ring_base_lsb)238#define HAL_WBM1_RELEASE_RING_BASE_LSB(x) \239(ab->hw_params.regs->hal_wbm1_release_ring_base_lsb)240241/* WBM2SW R2 release address */242#define HAL_WBM0_RELEASE_RING_HP 0x000030c0243#define HAL_WBM1_RELEASE_RING_HP 0x000030c8244245/* TCL ring field mask and offset */246#define HAL_TCL1_RING_BASE_MSB_RING_SIZE GENMASK(27, 8)247#define HAL_TCL1_RING_BASE_MSB_RING_BASE_ADDR_MSB GENMASK(7, 0)248#define HAL_TCL1_RING_ID_ENTRY_SIZE GENMASK(7, 0)249#define HAL_TCL1_RING_MISC_MSI_LOOPCNT_DISABLE BIT(1)250#define HAL_TCL1_RING_MISC_MSI_SWAP BIT(3)251#define HAL_TCL1_RING_MISC_HOST_FW_SWAP BIT(4)252#define HAL_TCL1_RING_MISC_DATA_TLV_SWAP BIT(5)253#define HAL_TCL1_RING_MISC_SRNG_ENABLE BIT(6)254#define HAL_TCL1_RING_CONSR_INT_SETUP_IX0_INTR_TMR_THOLD GENMASK(31, 16)255#define HAL_TCL1_RING_CONSR_INT_SETUP_IX0_BATCH_COUNTER_THOLD GENMASK(14, 0)256#define HAL_TCL1_RING_CONSR_INT_SETUP_IX1_LOW_THOLD GENMASK(15, 0)257#define HAL_TCL1_RING_MSI1_BASE_MSB_MSI1_ENABLE BIT(8)258#define HAL_TCL1_RING_MSI1_BASE_MSB_ADDR GENMASK(7, 0)259#define HAL_TCL1_RING_CMN_CTRL_DSCP_TID_MAP_PROG_EN BIT(17)260#define HAL_TCL1_RING_FIELD_DSCP_TID_MAP GENMASK(31, 0)261#define HAL_TCL1_RING_FIELD_DSCP_TID_MAP0 GENMASK(2, 0)262#define HAL_TCL1_RING_FIELD_DSCP_TID_MAP1 GENMASK(5, 3)263#define HAL_TCL1_RING_FIELD_DSCP_TID_MAP2 GENMASK(8, 6)264#define HAL_TCL1_RING_FIELD_DSCP_TID_MAP3 GENMASK(11, 9)265#define HAL_TCL1_RING_FIELD_DSCP_TID_MAP4 GENMASK(14, 12)266#define HAL_TCL1_RING_FIELD_DSCP_TID_MAP5 GENMASK(17, 15)267#define HAL_TCL1_RING_FIELD_DSCP_TID_MAP6 GENMASK(20, 18)268#define HAL_TCL1_RING_FIELD_DSCP_TID_MAP7 GENMASK(23, 21)269270/* REO ring field mask and offset */271#define HAL_REO1_RING_BASE_MSB_RING_SIZE GENMASK(27, 8)272#define HAL_REO1_RING_BASE_MSB_RING_BASE_ADDR_MSB GENMASK(7, 0)273#define HAL_REO1_RING_ID_RING_ID GENMASK(15, 8)274#define HAL_REO1_RING_ID_ENTRY_SIZE GENMASK(7, 0)275#define HAL_REO1_RING_MISC_MSI_SWAP BIT(3)276#define HAL_REO1_RING_MISC_HOST_FW_SWAP BIT(4)277#define HAL_REO1_RING_MISC_DATA_TLV_SWAP BIT(5)278#define HAL_REO1_RING_MISC_SRNG_ENABLE BIT(6)279#define HAL_REO1_RING_PRDR_INT_SETUP_INTR_TMR_THOLD GENMASK(31, 16)280#define HAL_REO1_RING_PRDR_INT_SETUP_BATCH_COUNTER_THOLD GENMASK(14, 0)281#define HAL_REO1_RING_MSI1_BASE_MSB_MSI1_ENABLE BIT(8)282#define HAL_REO1_RING_MSI1_BASE_MSB_ADDR GENMASK(7, 0)283#define HAL_REO1_GEN_ENABLE_FRAG_DST_RING GENMASK(25, 23)284#define HAL_REO1_GEN_ENABLE_AGING_LIST_ENABLE BIT(2)285#define HAL_REO1_GEN_ENABLE_AGING_FLUSH_ENABLE BIT(3)286#define HAL_REO1_MISC_CTL_FRAGMENT_DST_RING GENMASK(20, 17)287288/* CE ring bit field mask and shift */289#define HAL_CE_DST_R0_DEST_CTRL_MAX_LEN GENMASK(15, 0)290291#define HAL_ADDR_LSB_REG_MASK 0xffffffff292293#define HAL_ADDR_MSB_REG_SHIFT 32294295/* WBM ring bit field mask and shift */296#define HAL_WBM_LINK_DESC_IDLE_LIST_MODE BIT(1)297#define HAL_WBM_SCATTER_BUFFER_SIZE GENMASK(10, 2)298#define HAL_WBM_SCATTER_RING_SIZE_OF_IDLE_LINK_DESC_LIST GENMASK(31, 16)299#define HAL_WBM_SCATTERED_DESC_MSB_BASE_ADDR_39_32 GENMASK(7, 0)300#define HAL_WBM_SCATTERED_DESC_MSB_BASE_ADDR_MATCH_TAG GENMASK(31, 8)301302#define HAL_WBM_SCATTERED_DESC_HEAD_P_OFFSET_IX1 GENMASK(20, 8)303#define HAL_WBM_SCATTERED_DESC_TAIL_P_OFFSET_IX1 GENMASK(20, 8)304305#define BASE_ADDR_MATCH_TAG_VAL 0x5306307#define HAL_REO_REO2SW1_RING_BASE_MSB_RING_SIZE 0x000fffff308#define HAL_REO_REO2TCL_RING_BASE_MSB_RING_SIZE 0x000fffff309#define HAL_REO_SW2REO_RING_BASE_MSB_RING_SIZE 0x0000ffff310#define HAL_REO_CMD_RING_BASE_MSB_RING_SIZE 0x0000ffff311#define HAL_REO_STATUS_RING_BASE_MSB_RING_SIZE 0x0000ffff312#define HAL_SW2TCL1_RING_BASE_MSB_RING_SIZE 0x000fffff313#define HAL_SW2TCL1_CMD_RING_BASE_MSB_RING_SIZE 0x000fffff314#define HAL_TCL_STATUS_RING_BASE_MSB_RING_SIZE 0x0000ffff315#define HAL_CE_SRC_RING_BASE_MSB_RING_SIZE 0x0000ffff316#define HAL_CE_DST_RING_BASE_MSB_RING_SIZE 0x0000ffff317#define HAL_CE_DST_STATUS_RING_BASE_MSB_RING_SIZE 0x0000ffff318#define HAL_WBM_IDLE_LINK_RING_BASE_MSB_RING_SIZE 0x0000ffff319#define HAL_SW2WBM_RELEASE_RING_BASE_MSB_RING_SIZE 0x0000ffff320#define HAL_WBM2SW_RELEASE_RING_BASE_MSB_RING_SIZE 0x000fffff321#define HAL_RXDMA_RING_MAX_SIZE 0x0000ffff322323/* IPQ5018 ce registers */324#define HAL_IPQ5018_CE_WFSS_REG_BASE 0x08400000325#define HAL_IPQ5018_CE_SIZE 0x200000326327/* Add any other errors here and return them in328* ath11k_hal_rx_desc_get_err().329*/330331enum hal_srng_ring_id {332HAL_SRNG_RING_ID_REO2SW1 = 0,333HAL_SRNG_RING_ID_REO2SW2,334HAL_SRNG_RING_ID_REO2SW3,335HAL_SRNG_RING_ID_REO2SW4,336HAL_SRNG_RING_ID_REO2TCL,337HAL_SRNG_RING_ID_SW2REO,338339HAL_SRNG_RING_ID_REO_CMD = 8,340HAL_SRNG_RING_ID_REO_STATUS,341342HAL_SRNG_RING_ID_SW2TCL1 = 16,343HAL_SRNG_RING_ID_SW2TCL2,344HAL_SRNG_RING_ID_SW2TCL3,345HAL_SRNG_RING_ID_SW2TCL4,346347HAL_SRNG_RING_ID_SW2TCL_CMD = 24,348HAL_SRNG_RING_ID_TCL_STATUS,349350HAL_SRNG_RING_ID_CE0_SRC = 32,351HAL_SRNG_RING_ID_CE1_SRC,352HAL_SRNG_RING_ID_CE2_SRC,353HAL_SRNG_RING_ID_CE3_SRC,354HAL_SRNG_RING_ID_CE4_SRC,355HAL_SRNG_RING_ID_CE5_SRC,356HAL_SRNG_RING_ID_CE6_SRC,357HAL_SRNG_RING_ID_CE7_SRC,358HAL_SRNG_RING_ID_CE8_SRC,359HAL_SRNG_RING_ID_CE9_SRC,360HAL_SRNG_RING_ID_CE10_SRC,361HAL_SRNG_RING_ID_CE11_SRC,362363HAL_SRNG_RING_ID_CE0_DST = 56,364HAL_SRNG_RING_ID_CE1_DST,365HAL_SRNG_RING_ID_CE2_DST,366HAL_SRNG_RING_ID_CE3_DST,367HAL_SRNG_RING_ID_CE4_DST,368HAL_SRNG_RING_ID_CE5_DST,369HAL_SRNG_RING_ID_CE6_DST,370HAL_SRNG_RING_ID_CE7_DST,371HAL_SRNG_RING_ID_CE8_DST,372HAL_SRNG_RING_ID_CE9_DST,373HAL_SRNG_RING_ID_CE10_DST,374HAL_SRNG_RING_ID_CE11_DST,375376HAL_SRNG_RING_ID_CE0_DST_STATUS = 80,377HAL_SRNG_RING_ID_CE1_DST_STATUS,378HAL_SRNG_RING_ID_CE2_DST_STATUS,379HAL_SRNG_RING_ID_CE3_DST_STATUS,380HAL_SRNG_RING_ID_CE4_DST_STATUS,381HAL_SRNG_RING_ID_CE5_DST_STATUS,382HAL_SRNG_RING_ID_CE6_DST_STATUS,383HAL_SRNG_RING_ID_CE7_DST_STATUS,384HAL_SRNG_RING_ID_CE8_DST_STATUS,385HAL_SRNG_RING_ID_CE9_DST_STATUS,386HAL_SRNG_RING_ID_CE10_DST_STATUS,387HAL_SRNG_RING_ID_CE11_DST_STATUS,388389HAL_SRNG_RING_ID_WBM_IDLE_LINK = 104,390HAL_SRNG_RING_ID_WBM_SW_RELEASE,391HAL_SRNG_RING_ID_WBM2SW0_RELEASE,392HAL_SRNG_RING_ID_WBM2SW1_RELEASE,393HAL_SRNG_RING_ID_WBM2SW2_RELEASE,394HAL_SRNG_RING_ID_WBM2SW3_RELEASE,395HAL_SRNG_RING_ID_WBM2SW4_RELEASE,396397HAL_SRNG_RING_ID_UMAC_ID_END = 127,398HAL_SRNG_RING_ID_LMAC1_ID_START,399400HAL_SRNG_RING_ID_WMAC1_SW2RXDMA0_BUF = HAL_SRNG_RING_ID_LMAC1_ID_START,401HAL_SRNG_RING_ID_WMAC1_SW2RXDMA1_BUF,402HAL_SRNG_RING_ID_WMAC1_SW2RXDMA2_BUF,403HAL_SRNG_RING_ID_WMAC1_SW2RXDMA0_STATBUF,404HAL_SRNG_RING_ID_WMAC1_SW2RXDMA1_STATBUF,405HAL_SRNG_RING_ID_WMAC1_RXDMA2SW0,406HAL_SRNG_RING_ID_WMAC1_RXDMA2SW1,407HAL_SRNG_RING_ID_WMAC1_SW2RXDMA1_DESC,408HAL_SRNG_RING_ID_RXDMA_DIR_BUF,409410HAL_SRNG_RING_ID_LMAC1_ID_END = 143411};412413/* SRNG registers are split into two groups R0 and R2 */414#define HAL_SRNG_REG_GRP_R0 0415#define HAL_SRNG_REG_GRP_R2 1416#define HAL_SRNG_NUM_REG_GRP 2417418#define HAL_SRNG_NUM_LMACS 3419#define HAL_SRNG_REO_EXCEPTION HAL_SRNG_RING_ID_REO2SW1420#define HAL_SRNG_RINGS_PER_LMAC (HAL_SRNG_RING_ID_LMAC1_ID_END - \421HAL_SRNG_RING_ID_LMAC1_ID_START)422#define HAL_SRNG_NUM_LMAC_RINGS (HAL_SRNG_NUM_LMACS * HAL_SRNG_RINGS_PER_LMAC)423#define HAL_SRNG_RING_ID_MAX (HAL_SRNG_RING_ID_UMAC_ID_END + \424HAL_SRNG_NUM_LMAC_RINGS)425426enum hal_ring_type {427HAL_REO_DST,428HAL_REO_EXCEPTION,429HAL_REO_REINJECT,430HAL_REO_CMD,431HAL_REO_STATUS,432HAL_TCL_DATA,433HAL_TCL_CMD,434HAL_TCL_STATUS,435HAL_CE_SRC,436HAL_CE_DST,437HAL_CE_DST_STATUS,438HAL_WBM_IDLE_LINK,439HAL_SW2WBM_RELEASE,440HAL_WBM2SW_RELEASE,441HAL_RXDMA_BUF,442HAL_RXDMA_DST,443HAL_RXDMA_MONITOR_BUF,444HAL_RXDMA_MONITOR_STATUS,445HAL_RXDMA_MONITOR_DST,446HAL_RXDMA_MONITOR_DESC,447HAL_RXDMA_DIR_BUF,448HAL_MAX_RING_TYPES,449};450451#define HAL_RX_MAX_BA_WINDOW 256452453#define HAL_DEFAULT_REO_TIMEOUT_USEC (40 * 1000)454455/**456* enum hal_reo_cmd_type: Enum for REO command type457* @HAL_REO_CMD_GET_QUEUE_STATS: Get REO queue status/stats458* @HAL_REO_CMD_FLUSH_QUEUE: Flush all frames in REO queue459* @HAL_REO_CMD_FLUSH_CACHE: Flush descriptor entries in the cache460* @HAL_REO_CMD_UNBLOCK_CACHE: Unblock a descriptor's address that was blocked461* earlier with a 'REO_FLUSH_CACHE' command462* @HAL_REO_CMD_FLUSH_TIMEOUT_LIST: Flush buffers/descriptors from timeout list463* @HAL_REO_CMD_UPDATE_RX_QUEUE: Update REO queue settings464*/465enum hal_reo_cmd_type {466HAL_REO_CMD_GET_QUEUE_STATS = 0,467HAL_REO_CMD_FLUSH_QUEUE = 1,468HAL_REO_CMD_FLUSH_CACHE = 2,469HAL_REO_CMD_UNBLOCK_CACHE = 3,470HAL_REO_CMD_FLUSH_TIMEOUT_LIST = 4,471HAL_REO_CMD_UPDATE_RX_QUEUE = 5,472};473474/**475* enum hal_reo_cmd_status: Enum for execution status of REO command476* @HAL_REO_CMD_SUCCESS: Command has successfully executed477* @HAL_REO_CMD_BLOCKED: Command could not be executed as the queue478* or cache was blocked479* @HAL_REO_CMD_FAILED: Command execution failed, could be due to480* invalid queue desc481* @HAL_REO_CMD_RESOURCE_BLOCKED:482* @HAL_REO_CMD_DRAIN:483*/484enum hal_reo_cmd_status {485HAL_REO_CMD_SUCCESS = 0,486HAL_REO_CMD_BLOCKED = 1,487HAL_REO_CMD_FAILED = 2,488HAL_REO_CMD_RESOURCE_BLOCKED = 3,489HAL_REO_CMD_DRAIN = 0xff,490};491492struct hal_wbm_idle_scatter_list {493dma_addr_t paddr;494struct hal_wbm_link_desc *vaddr;495};496497struct hal_srng_params {498dma_addr_t ring_base_paddr;499u32 *ring_base_vaddr;500int num_entries;501u32 intr_batch_cntr_thres_entries;502u32 intr_timer_thres_us;503u32 flags;504u32 max_buffer_len;505u32 low_threshold;506dma_addr_t msi_addr;507u32 msi_data;508509/* Add more params as needed */510};511512enum hal_srng_dir {513HAL_SRNG_DIR_SRC,514HAL_SRNG_DIR_DST515};516517/* srng flags */518#define HAL_SRNG_FLAGS_MSI_SWAP 0x00000008519#define HAL_SRNG_FLAGS_RING_PTR_SWAP 0x00000010520#define HAL_SRNG_FLAGS_DATA_TLV_SWAP 0x00000020521#define HAL_SRNG_FLAGS_LOW_THRESH_INTR_EN 0x00010000522#define HAL_SRNG_FLAGS_MSI_INTR 0x00020000523#define HAL_SRNG_FLAGS_CACHED 0x20000000524#define HAL_SRNG_FLAGS_LMAC_RING 0x80000000525#define HAL_SRNG_FLAGS_REMAP_CE_RING 0x10000000526527#define HAL_SRNG_TLV_HDR_TAG GENMASK(9, 1)528#define HAL_SRNG_TLV_HDR_LEN GENMASK(25, 10)529530/* Common SRNG ring structure for source and destination rings */531struct hal_srng {532/* Unique SRNG ring ID */533u8 ring_id;534535/* Ring initialization done */536u8 initialized;537538/* Interrupt/MSI value assigned to this ring */539int irq;540541/* Physical base address of the ring */542dma_addr_t ring_base_paddr;543544/* Virtual base address of the ring */545u32 *ring_base_vaddr;546547/* Number of entries in ring */548u32 num_entries;549550/* Ring size */551u32 ring_size;552553/* Ring size mask */554u32 ring_size_mask;555556/* Size of ring entry */557u32 entry_size;558559/* Interrupt timer threshold - in micro seconds */560u32 intr_timer_thres_us;561562/* Interrupt batch counter threshold - in number of ring entries */563u32 intr_batch_cntr_thres_entries;564565/* MSI Address */566dma_addr_t msi_addr;567568/* MSI data */569u32 msi_data;570571/* Misc flags */572u32 flags;573574/* Lock for serializing ring index updates */575spinlock_t lock;576577/* Start offset of SRNG register groups for this ring578* TBD: See if this is required - register address can be derived579* from ring ID580*/581u32 hwreg_base[HAL_SRNG_NUM_REG_GRP];582583u64 timestamp;584585/* Source or Destination ring */586enum hal_srng_dir ring_dir;587588union {589struct {590/* SW tail pointer */591u32 tp;592593/* Shadow head pointer location to be updated by HW */594volatile u32 *hp_addr;595596/* Cached head pointer */597u32 cached_hp;598599/* Tail pointer location to be updated by SW - This600* will be a register address and need not be601* accessed through SW structure602*/603u32 *tp_addr;604605/* Current SW loop cnt */606u32 loop_cnt;607608/* max transfer size */609u16 max_buffer_length;610611/* head pointer at access end */612u32 last_hp;613} dst_ring;614615struct {616/* SW head pointer */617u32 hp;618619/* SW reap head pointer */620u32 reap_hp;621622/* Shadow tail pointer location to be updated by HW */623u32 *tp_addr;624625/* Cached tail pointer */626u32 cached_tp;627628/* Head pointer location to be updated by SW - This629* will be a register address and need not be accessed630* through SW structure631*/632u32 *hp_addr;633634/* Low threshold - in number of ring entries */635u32 low_threshold;636637/* tail pointer at access end */638u32 last_tp;639} src_ring;640} u;641};642643/* Interrupt mitigation - Batch threshold in terms of number of frames */644#define HAL_SRNG_INT_BATCH_THRESHOLD_TX 256645#define HAL_SRNG_INT_BATCH_THRESHOLD_RX 128646#define HAL_SRNG_INT_BATCH_THRESHOLD_OTHER 1647648/* Interrupt mitigation - timer threshold in us */649#define HAL_SRNG_INT_TIMER_THRESHOLD_TX 1000650#define HAL_SRNG_INT_TIMER_THRESHOLD_RX 500651#define HAL_SRNG_INT_TIMER_THRESHOLD_OTHER 256652653/* HW SRNG configuration table */654struct hal_srng_config {655int start_ring_id;656u16 max_rings;657u16 entry_size;658u32 reg_start[HAL_SRNG_NUM_REG_GRP];659u16 reg_size[HAL_SRNG_NUM_REG_GRP];660u8 lmac_ring;661enum hal_srng_dir ring_dir;662u32 max_size;663};664665/**666* enum hal_rx_buf_return_buf_manager - manager for returned rx buffers667*668* @HAL_RX_BUF_RBM_WBM_IDLE_BUF_LIST: Buffer returned to WBM idle buffer list669* @HAL_RX_BUF_RBM_WBM_IDLE_DESC_LIST: Descriptor returned to WBM idle670* descriptor list.671* @HAL_RX_BUF_RBM_FW_BM: Buffer returned to FW672* @HAL_RX_BUF_RBM_SW0_BM: For Tx completion -- returned to host673* @HAL_RX_BUF_RBM_SW1_BM: For Tx completion -- returned to host674* @HAL_RX_BUF_RBM_SW2_BM: For Tx completion -- returned to host675* @HAL_RX_BUF_RBM_SW3_BM: For Rx release -- returned to host676* @HAL_RX_BUF_RBM_SW4_BM: For Tx completion -- returned to host677*/678679enum hal_rx_buf_return_buf_manager {680HAL_RX_BUF_RBM_WBM_IDLE_BUF_LIST,681HAL_RX_BUF_RBM_WBM_IDLE_DESC_LIST,682HAL_RX_BUF_RBM_FW_BM,683HAL_RX_BUF_RBM_SW0_BM,684HAL_RX_BUF_RBM_SW1_BM,685HAL_RX_BUF_RBM_SW2_BM,686HAL_RX_BUF_RBM_SW3_BM,687HAL_RX_BUF_RBM_SW4_BM,688};689690#define HAL_SRNG_DESC_LOOP_CNT 0xf0000000691692#define HAL_REO_CMD_FLG_NEED_STATUS BIT(0)693#define HAL_REO_CMD_FLG_STATS_CLEAR BIT(1)694#define HAL_REO_CMD_FLG_FLUSH_BLOCK_LATER BIT(2)695#define HAL_REO_CMD_FLG_FLUSH_RELEASE_BLOCKING BIT(3)696#define HAL_REO_CMD_FLG_FLUSH_NO_INVAL BIT(4)697#define HAL_REO_CMD_FLG_FLUSH_FWD_ALL_MPDUS BIT(5)698#define HAL_REO_CMD_FLG_FLUSH_ALL BIT(6)699#define HAL_REO_CMD_FLG_UNBLK_RESOURCE BIT(7)700#define HAL_REO_CMD_FLG_UNBLK_CACHE BIT(8)701702/* Should be matching with HAL_REO_UPD_RX_QUEUE_INFO0_UPD_* fields */703#define HAL_REO_CMD_UPD0_RX_QUEUE_NUM BIT(8)704#define HAL_REO_CMD_UPD0_VLD BIT(9)705#define HAL_REO_CMD_UPD0_ALDC BIT(10)706#define HAL_REO_CMD_UPD0_DIS_DUP_DETECTION BIT(11)707#define HAL_REO_CMD_UPD0_SOFT_REORDER_EN BIT(12)708#define HAL_REO_CMD_UPD0_AC BIT(13)709#define HAL_REO_CMD_UPD0_BAR BIT(14)710#define HAL_REO_CMD_UPD0_RETRY BIT(15)711#define HAL_REO_CMD_UPD0_CHECK_2K_MODE BIT(16)712#define HAL_REO_CMD_UPD0_OOR_MODE BIT(17)713#define HAL_REO_CMD_UPD0_BA_WINDOW_SIZE BIT(18)714#define HAL_REO_CMD_UPD0_PN_CHECK BIT(19)715#define HAL_REO_CMD_UPD0_EVEN_PN BIT(20)716#define HAL_REO_CMD_UPD0_UNEVEN_PN BIT(21)717#define HAL_REO_CMD_UPD0_PN_HANDLE_ENABLE BIT(22)718#define HAL_REO_CMD_UPD0_PN_SIZE BIT(23)719#define HAL_REO_CMD_UPD0_IGNORE_AMPDU_FLG BIT(24)720#define HAL_REO_CMD_UPD0_SVLD BIT(25)721#define HAL_REO_CMD_UPD0_SSN BIT(26)722#define HAL_REO_CMD_UPD0_SEQ_2K_ERR BIT(27)723#define HAL_REO_CMD_UPD0_PN_ERR BIT(28)724#define HAL_REO_CMD_UPD0_PN_VALID BIT(29)725#define HAL_REO_CMD_UPD0_PN BIT(30)726727/* Should be matching with HAL_REO_UPD_RX_QUEUE_INFO1_* fields */728#define HAL_REO_CMD_UPD1_VLD BIT(16)729#define HAL_REO_CMD_UPD1_ALDC GENMASK(18, 17)730#define HAL_REO_CMD_UPD1_DIS_DUP_DETECTION BIT(19)731#define HAL_REO_CMD_UPD1_SOFT_REORDER_EN BIT(20)732#define HAL_REO_CMD_UPD1_AC GENMASK(22, 21)733#define HAL_REO_CMD_UPD1_BAR BIT(23)734#define HAL_REO_CMD_UPD1_RETRY BIT(24)735#define HAL_REO_CMD_UPD1_CHECK_2K_MODE BIT(25)736#define HAL_REO_CMD_UPD1_OOR_MODE BIT(26)737#define HAL_REO_CMD_UPD1_PN_CHECK BIT(27)738#define HAL_REO_CMD_UPD1_EVEN_PN BIT(28)739#define HAL_REO_CMD_UPD1_UNEVEN_PN BIT(29)740#define HAL_REO_CMD_UPD1_PN_HANDLE_ENABLE BIT(30)741#define HAL_REO_CMD_UPD1_IGNORE_AMPDU_FLG BIT(31)742743/* Should be matching with HAL_REO_UPD_RX_QUEUE_INFO2_* fields */744#define HAL_REO_CMD_UPD2_SVLD BIT(10)745#define HAL_REO_CMD_UPD2_SSN GENMASK(22, 11)746#define HAL_REO_CMD_UPD2_SEQ_2K_ERR BIT(23)747#define HAL_REO_CMD_UPD2_PN_ERR BIT(24)748749#define HAL_REO_DEST_RING_CTRL_HASH_RING_MAP GENMASK(31, 8)750751struct ath11k_hal_reo_cmd {752u32 addr_lo;753u32 flag;754u32 upd0;755u32 upd1;756u32 upd2;757u32 pn[4];758u16 rx_queue_num;759u16 min_rel;760u16 min_fwd;761u8 addr_hi;762u8 ac_list;763u8 blocking_idx;764u16 ba_window_size;765u8 pn_size;766};767768enum hal_pn_type {769HAL_PN_TYPE_NONE,770HAL_PN_TYPE_WPA,771HAL_PN_TYPE_WAPI_EVEN,772HAL_PN_TYPE_WAPI_UNEVEN,773};774775enum hal_ce_desc {776HAL_CE_DESC_SRC,777HAL_CE_DESC_DST,778HAL_CE_DESC_DST_STATUS,779};780781#define HAL_HASH_ROUTING_RING_TCL 0782#define HAL_HASH_ROUTING_RING_SW1 1783#define HAL_HASH_ROUTING_RING_SW2 2784#define HAL_HASH_ROUTING_RING_SW3 3785#define HAL_HASH_ROUTING_RING_SW4 4786#define HAL_HASH_ROUTING_RING_REL 5787#define HAL_HASH_ROUTING_RING_FW 6788789struct hal_reo_status_header {790u16 cmd_num;791enum hal_reo_cmd_status cmd_status;792u16 cmd_exe_time;793u32 timestamp;794};795796struct hal_reo_status_queue_stats {797u16 ssn;798u16 curr_idx;799u32 pn[4];800u32 last_rx_queue_ts;801u32 last_rx_dequeue_ts;802u32 rx_bitmap[8]; /* Bitmap from 0-255 */803u32 curr_mpdu_cnt;804u32 curr_msdu_cnt;805u16 fwd_due_to_bar_cnt;806u16 dup_cnt;807u32 frames_in_order_cnt;808u32 num_mpdu_processed_cnt;809u32 num_msdu_processed_cnt;810u32 total_num_processed_byte_cnt;811u32 late_rx_mpdu_cnt;812u32 reorder_hole_cnt;813u8 timeout_cnt;814u8 bar_rx_cnt;815u8 num_window_2k_jump_cnt;816};817818struct hal_reo_status_flush_queue {819bool err_detected;820};821822enum hal_reo_status_flush_cache_err_code {823HAL_REO_STATUS_FLUSH_CACHE_ERR_CODE_SUCCESS,824HAL_REO_STATUS_FLUSH_CACHE_ERR_CODE_IN_USE,825HAL_REO_STATUS_FLUSH_CACHE_ERR_CODE_NOT_FOUND,826};827828struct hal_reo_status_flush_cache {829bool err_detected;830enum hal_reo_status_flush_cache_err_code err_code;831bool cache_controller_flush_status_hit;832u8 cache_controller_flush_status_desc_type;833u8 cache_controller_flush_status_client_id;834u8 cache_controller_flush_status_err;835u8 cache_controller_flush_status_cnt;836};837838enum hal_reo_status_unblock_cache_type {839HAL_REO_STATUS_UNBLOCK_BLOCKING_RESOURCE,840HAL_REO_STATUS_UNBLOCK_ENTIRE_CACHE_USAGE,841};842843struct hal_reo_status_unblock_cache {844bool err_detected;845enum hal_reo_status_unblock_cache_type unblock_type;846};847848struct hal_reo_status_flush_timeout_list {849bool err_detected;850bool list_empty;851u16 release_desc_cnt;852u16 fwd_buf_cnt;853};854855enum hal_reo_threshold_idx {856HAL_REO_THRESHOLD_IDX_DESC_COUNTER0,857HAL_REO_THRESHOLD_IDX_DESC_COUNTER1,858HAL_REO_THRESHOLD_IDX_DESC_COUNTER2,859HAL_REO_THRESHOLD_IDX_DESC_COUNTER_SUM,860};861862struct hal_reo_status_desc_thresh_reached {863enum hal_reo_threshold_idx threshold_idx;864u32 link_desc_counter0;865u32 link_desc_counter1;866u32 link_desc_counter2;867u32 link_desc_counter_sum;868};869870struct hal_reo_status {871struct hal_reo_status_header uniform_hdr;872u8 loop_cnt;873union {874struct hal_reo_status_queue_stats queue_stats;875struct hal_reo_status_flush_queue flush_queue;876struct hal_reo_status_flush_cache flush_cache;877struct hal_reo_status_unblock_cache unblock_cache;878struct hal_reo_status_flush_timeout_list timeout_list;879struct hal_reo_status_desc_thresh_reached desc_thresh_reached;880} u;881};882883/* HAL context to be used to access SRNG APIs (currently used by data path884* and transport (CE) modules)885*/886struct ath11k_hal {887/* HAL internal state for all SRNG rings.888*/889struct hal_srng srng_list[HAL_SRNG_RING_ID_MAX];890891/* SRNG configuration table */892struct hal_srng_config *srng_config;893894/* Remote pointer memory for HW/FW updates */895struct {896u32 *vaddr;897dma_addr_t paddr;898} rdp;899900/* Shared memory for ring pointer updates from host to FW */901struct {902u32 *vaddr;903dma_addr_t paddr;904} wrp;905906/* Available REO blocking resources bitmap */907u8 avail_blk_resource;908909u8 current_blk_index;910911/* shadow register configuration */912u32 shadow_reg_addr[HAL_SHADOW_NUM_REGS];913int num_shadow_reg_configured;914915struct lock_class_key srng_key[HAL_SRNG_RING_ID_MAX];916};917918u32 ath11k_hal_reo_qdesc_size(u32 ba_window_size, u8 tid);919void ath11k_hal_reo_qdesc_setup(void *vaddr, int tid, u32 ba_window_size,920u32 start_seq, enum hal_pn_type type);921void ath11k_hal_reo_init_cmd_ring(struct ath11k_base *ab,922struct hal_srng *srng);923void ath11k_hal_setup_link_idle_list(struct ath11k_base *ab,924struct hal_wbm_idle_scatter_list *sbuf,925u32 nsbufs, u32 tot_link_desc,926u32 end_offset);927928dma_addr_t ath11k_hal_srng_get_tp_addr(struct ath11k_base *ab,929struct hal_srng *srng);930dma_addr_t ath11k_hal_srng_get_hp_addr(struct ath11k_base *ab,931struct hal_srng *srng);932void ath11k_hal_set_link_desc_addr(struct hal_wbm_link_desc *desc, u32 cookie,933dma_addr_t paddr);934u32 ath11k_hal_ce_get_desc_size(enum hal_ce_desc type);935void ath11k_hal_ce_src_set_desc(void *buf, dma_addr_t paddr, u32 len, u32 id,936u8 byte_swap_data);937void ath11k_hal_ce_dst_set_desc(void *buf, dma_addr_t paddr);938u32 ath11k_hal_ce_dst_status_get_length(void *buf);939int ath11k_hal_srng_get_entrysize(struct ath11k_base *ab, u32 ring_type);940int ath11k_hal_srng_get_max_entries(struct ath11k_base *ab, u32 ring_type);941void ath11k_hal_srng_get_params(struct ath11k_base *ab, struct hal_srng *srng,942struct hal_srng_params *params);943u32 *ath11k_hal_srng_dst_get_next_entry(struct ath11k_base *ab,944struct hal_srng *srng);945u32 *ath11k_hal_srng_dst_peek(struct ath11k_base *ab, struct hal_srng *srng);946int ath11k_hal_srng_dst_num_free(struct ath11k_base *ab, struct hal_srng *srng,947bool sync_hw_ptr);948u32 *ath11k_hal_srng_src_peek(struct ath11k_base *ab, struct hal_srng *srng);949u32 *ath11k_hal_srng_src_next_peek(struct ath11k_base *ab,950struct hal_srng *srng);951u32 *ath11k_hal_srng_src_get_next_reaped(struct ath11k_base *ab,952struct hal_srng *srng);953u32 *ath11k_hal_srng_src_reap_next(struct ath11k_base *ab,954struct hal_srng *srng);955u32 *ath11k_hal_srng_src_get_next_entry(struct ath11k_base *ab,956struct hal_srng *srng);957int ath11k_hal_srng_src_num_free(struct ath11k_base *ab, struct hal_srng *srng,958bool sync_hw_ptr);959void ath11k_hal_srng_access_begin(struct ath11k_base *ab,960struct hal_srng *srng);961void ath11k_hal_srng_access_end(struct ath11k_base *ab, struct hal_srng *srng);962int ath11k_hal_srng_setup(struct ath11k_base *ab, enum hal_ring_type type,963int ring_num, int mac_id,964struct hal_srng_params *params);965int ath11k_hal_srng_init(struct ath11k_base *ath11k);966void ath11k_hal_srng_deinit(struct ath11k_base *ath11k);967void ath11k_hal_srng_clear(struct ath11k_base *ab);968void ath11k_hal_dump_srng_stats(struct ath11k_base *ab);969void ath11k_hal_srng_get_shadow_config(struct ath11k_base *ab,970u32 **cfg, u32 *len);971int ath11k_hal_srng_update_shadow_config(struct ath11k_base *ab,972enum hal_ring_type ring_type,973int ring_num);974void ath11k_hal_srng_shadow_config(struct ath11k_base *ab);975void ath11k_hal_srng_shadow_update_hp_tp(struct ath11k_base *ab,976struct hal_srng *srng);977#endif978979980