| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552 |
- /* SPDX-License-Identifier: BSD-3-Clause-Clear */
- /*
- * Copyright (c) 2018-2021 The Linux Foundation. All rights reserved.
- * Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.
- */
- #ifndef ATH12K_HAL_H
- #define ATH12K_HAL_H
- #include "hw.h"
- struct ath12k_base;
- #define HAL_DESC_REO_NON_QOS_TID 16
- #define HAL_INVALID_PEERID 0x3fff
- #define VHT_SIG_SU_NSS_MASK 0x7
- #define HAL_TX_ADDRX_EN 1
- #define HAL_TX_ADDRY_EN 2
- #define HAL_TX_ADDR_SEARCH_DEFAULT 0
- #define HAL_TX_ADDR_SEARCH_INDEX 1
- #define HAL_RX_MAX_MPDU 256
- #define HAL_RX_NUM_WORDS_PER_PPDU_BITMAP (HAL_RX_MAX_MPDU >> 5)
- /* TODO: 16 entries per radio times MAX_VAPS_SUPPORTED */
- #define HAL_DSCP_TID_MAP_TBL_NUM_ENTRIES_MAX 32
- #define HAL_DSCP_TID_TBL_SIZE 24
- #define EHT_MAX_USER_INFO 4
- #define HAL_RX_MON_MAX_AGGR_SIZE 128
- #define HAL_MAX_UL_MU_USERS 37
- #define MAX_USER_POS 8
- #define MAX_MU_GROUP_ID 64
- #define MAX_MU_GROUP_SHOW 16
- #define MAX_MU_GROUP_LENGTH (6 * MAX_MU_GROUP_SHOW)
- #define HAL_CE_REMAP_REG_BASE (ab->ce_remap_base_addr)
- #define HAL_LINK_DESC_SIZE (32 << 2)
- #define HAL_LINK_DESC_ALIGN 128
- #define HAL_NUM_MPDUS_PER_LINK_DESC 6
- #define HAL_NUM_TX_MSDUS_PER_LINK_DESC 7
- #define HAL_NUM_RX_MSDUS_PER_LINK_DESC 6
- #define HAL_NUM_MPDU_LINKS_PER_QUEUE_DESC 12
- #define HAL_MAX_AVAIL_BLK_RES 3
- #define HAL_RING_BASE_ALIGN 8
- #define HAL_REO_QLUT_ADDR_ALIGN 256
- #define HAL_ADDR_LSB_REG_MASK 0xffffffff
- #define HAL_ADDR_MSB_REG_SHIFT 32
- #define HAL_WBM2SW_REL_ERR_RING_NUM 3
- #define HAL_SHADOW_NUM_REGS_MAX 40
- #define HAL_WBM_IDLE_SCATTER_BUF_SIZE_MAX 32704
- /* TODO: Check with hw team on the supported scatter buf size */
- #define HAL_WBM_IDLE_SCATTER_NEXT_PTR_SIZE 8
- #define HAL_WBM_IDLE_SCATTER_BUF_SIZE (HAL_WBM_IDLE_SCATTER_BUF_SIZE_MAX - \
- HAL_WBM_IDLE_SCATTER_NEXT_PTR_SIZE)
- #define HAL_AST_IDX_INVALID 0xFFFF
- #define HAL_RX_MAX_MCS 12
- #define HAL_RX_MAX_MCS_HT 31
- #define HAL_RX_MAX_MCS_VHT 9
- #define HAL_RX_MAX_MCS_HE 11
- #define HAL_RX_MAX_MCS_BE 15
- #define HAL_RX_MAX_NSS 8
- #define HAL_RX_MAX_NUM_LEGACY_RATES 12
- #define HAL_RX_UL_OFDMA_USER_INFO_V0_W0_VALID BIT(30)
- #define HAL_RX_UL_OFDMA_USER_INFO_V0_W0_VER BIT(31)
- #define HAL_RX_UL_OFDMA_USER_INFO_V0_W1_NSS GENMASK(2, 0)
- #define HAL_RX_UL_OFDMA_USER_INFO_V0_W1_MCS GENMASK(6, 3)
- #define HAL_RX_UL_OFDMA_USER_INFO_V0_W1_LDPC BIT(7)
- #define HAL_RX_UL_OFDMA_USER_INFO_V0_W1_DCM BIT(8)
- #define HAL_RX_UL_OFDMA_USER_INFO_V0_W1_RU_START GENMASK(15, 9)
- #define HAL_RX_UL_OFDMA_USER_INFO_V0_W1_RU_SIZE GENMASK(18, 16)
- #define HAL_RX_FCS_LEN 4
- enum hal_srng_ring_id {
- HAL_SRNG_RING_ID_REO2SW0 = 0,
- HAL_SRNG_RING_ID_REO2SW1,
- HAL_SRNG_RING_ID_REO2SW2,
- HAL_SRNG_RING_ID_REO2SW3,
- HAL_SRNG_RING_ID_REO2SW4,
- HAL_SRNG_RING_ID_REO2SW5,
- HAL_SRNG_RING_ID_REO2SW6,
- HAL_SRNG_RING_ID_REO2SW7,
- HAL_SRNG_RING_ID_REO2SW8,
- HAL_SRNG_RING_ID_REO2TCL,
- HAL_SRNG_RING_ID_REO2PPE,
- HAL_SRNG_RING_ID_SW2REO = 16,
- HAL_SRNG_RING_ID_SW2REO1,
- HAL_SRNG_RING_ID_SW2REO2,
- HAL_SRNG_RING_ID_SW2REO3,
- HAL_SRNG_RING_ID_REO_CMD,
- HAL_SRNG_RING_ID_REO_STATUS,
- HAL_SRNG_RING_ID_SW2TCL1 = 24,
- HAL_SRNG_RING_ID_SW2TCL2,
- HAL_SRNG_RING_ID_SW2TCL3,
- HAL_SRNG_RING_ID_SW2TCL4,
- HAL_SRNG_RING_ID_SW2TCL5,
- HAL_SRNG_RING_ID_SW2TCL6,
- HAL_SRNG_RING_ID_PPE2TCL1 = 30,
- HAL_SRNG_RING_ID_SW2TCL_CMD = 40,
- HAL_SRNG_RING_ID_SW2TCL1_CMD,
- HAL_SRNG_RING_ID_TCL_STATUS,
- HAL_SRNG_RING_ID_CE0_SRC = 64,
- HAL_SRNG_RING_ID_CE1_SRC,
- HAL_SRNG_RING_ID_CE2_SRC,
- HAL_SRNG_RING_ID_CE3_SRC,
- HAL_SRNG_RING_ID_CE4_SRC,
- HAL_SRNG_RING_ID_CE5_SRC,
- HAL_SRNG_RING_ID_CE6_SRC,
- HAL_SRNG_RING_ID_CE7_SRC,
- HAL_SRNG_RING_ID_CE8_SRC,
- HAL_SRNG_RING_ID_CE9_SRC,
- HAL_SRNG_RING_ID_CE10_SRC,
- HAL_SRNG_RING_ID_CE11_SRC,
- HAL_SRNG_RING_ID_CE12_SRC,
- HAL_SRNG_RING_ID_CE13_SRC,
- HAL_SRNG_RING_ID_CE14_SRC,
- HAL_SRNG_RING_ID_CE15_SRC,
- HAL_SRNG_RING_ID_CE0_DST = 81,
- HAL_SRNG_RING_ID_CE1_DST,
- HAL_SRNG_RING_ID_CE2_DST,
- HAL_SRNG_RING_ID_CE3_DST,
- HAL_SRNG_RING_ID_CE4_DST,
- HAL_SRNG_RING_ID_CE5_DST,
- HAL_SRNG_RING_ID_CE6_DST,
- HAL_SRNG_RING_ID_CE7_DST,
- HAL_SRNG_RING_ID_CE8_DST,
- HAL_SRNG_RING_ID_CE9_DST,
- HAL_SRNG_RING_ID_CE10_DST,
- HAL_SRNG_RING_ID_CE11_DST,
- HAL_SRNG_RING_ID_CE12_DST,
- HAL_SRNG_RING_ID_CE13_DST,
- HAL_SRNG_RING_ID_CE14_DST,
- HAL_SRNG_RING_ID_CE15_DST,
- HAL_SRNG_RING_ID_CE0_DST_STATUS = 100,
- HAL_SRNG_RING_ID_CE1_DST_STATUS,
- HAL_SRNG_RING_ID_CE2_DST_STATUS,
- HAL_SRNG_RING_ID_CE3_DST_STATUS,
- HAL_SRNG_RING_ID_CE4_DST_STATUS,
- HAL_SRNG_RING_ID_CE5_DST_STATUS,
- HAL_SRNG_RING_ID_CE6_DST_STATUS,
- HAL_SRNG_RING_ID_CE7_DST_STATUS,
- HAL_SRNG_RING_ID_CE8_DST_STATUS,
- HAL_SRNG_RING_ID_CE9_DST_STATUS,
- HAL_SRNG_RING_ID_CE10_DST_STATUS,
- HAL_SRNG_RING_ID_CE11_DST_STATUS,
- HAL_SRNG_RING_ID_CE12_DST_STATUS,
- HAL_SRNG_RING_ID_CE13_DST_STATUS,
- HAL_SRNG_RING_ID_CE14_DST_STATUS,
- HAL_SRNG_RING_ID_CE15_DST_STATUS,
- HAL_SRNG_RING_ID_WBM_IDLE_LINK = 120,
- HAL_SRNG_RING_ID_WBM_SW0_RELEASE,
- HAL_SRNG_RING_ID_WBM_SW1_RELEASE,
- HAL_SRNG_RING_ID_WBM_PPE_RELEASE = 123,
- HAL_SRNG_RING_ID_WBM2SW0_RELEASE = 128,
- HAL_SRNG_RING_ID_WBM2SW1_RELEASE,
- HAL_SRNG_RING_ID_WBM2SW2_RELEASE,
- HAL_SRNG_RING_ID_WBM2SW3_RELEASE, /* RX ERROR RING */
- HAL_SRNG_RING_ID_WBM2SW4_RELEASE,
- HAL_SRNG_RING_ID_WBM2SW5_RELEASE,
- HAL_SRNG_RING_ID_WBM2SW6_RELEASE,
- HAL_SRNG_RING_ID_WBM2SW7_RELEASE,
- HAL_SRNG_RING_ID_UMAC_ID_END = 159,
- /* Common DMAC rings shared by all LMACs */
- HAL_SRNG_RING_ID_DMAC_CMN_ID_START = 160,
- HAL_SRNG_SW2RXDMA_BUF0 = HAL_SRNG_RING_ID_DMAC_CMN_ID_START,
- HAL_SRNG_SW2RXDMA_BUF1 = 161,
- HAL_SRNG_SW2RXDMA_BUF2 = 162,
- HAL_SRNG_SW2RXMON_BUF0 = 168,
- HAL_SRNG_SW2TXMON_BUF0 = 176,
- HAL_SRNG_RING_ID_DMAC_CMN_ID_END = 183,
- HAL_SRNG_RING_ID_PMAC1_ID_START = 184,
- HAL_SRNG_RING_ID_WMAC1_SW2RXMON_BUF0 = HAL_SRNG_RING_ID_PMAC1_ID_START,
- HAL_SRNG_RING_ID_WMAC1_SW2RXDMA1_STATBUF,
- HAL_SRNG_RING_ID_WMAC1_RXDMA2SW0,
- HAL_SRNG_RING_ID_WMAC1_RXDMA2SW1,
- HAL_SRNG_RING_ID_WMAC1_RXMON2SW0 = HAL_SRNG_RING_ID_WMAC1_RXDMA2SW1,
- HAL_SRNG_RING_ID_WMAC1_SW2RXDMA1_DESC,
- HAL_SRNG_RING_ID_RXDMA_DIR_BUF,
- HAL_SRNG_RING_ID_WMAC1_TXMON2SW0_BUF0,
- HAL_SRNG_RING_ID_WMAC1_SW2TXMON_BUF0,
- HAL_SRNG_RING_ID_PMAC1_ID_END,
- };
- /* SRNG registers are split into two groups R0 and R2 */
- #define HAL_SRNG_REG_GRP_R0 0
- #define HAL_SRNG_REG_GRP_R2 1
- #define HAL_SRNG_NUM_REG_GRP 2
- /* TODO: number of PMACs */
- #define HAL_SRNG_NUM_PMACS 3
- #define HAL_SRNG_NUM_DMAC_RINGS (HAL_SRNG_RING_ID_DMAC_CMN_ID_END - \
- HAL_SRNG_RING_ID_DMAC_CMN_ID_START)
- #define HAL_SRNG_RINGS_PER_PMAC (HAL_SRNG_RING_ID_PMAC1_ID_END - \
- HAL_SRNG_RING_ID_PMAC1_ID_START)
- #define HAL_SRNG_NUM_PMAC_RINGS (HAL_SRNG_NUM_PMACS * HAL_SRNG_RINGS_PER_PMAC)
- #define HAL_SRNG_RING_ID_MAX (HAL_SRNG_RING_ID_DMAC_CMN_ID_END + \
- HAL_SRNG_NUM_PMAC_RINGS)
- enum hal_rx_su_mu_coding {
- HAL_RX_SU_MU_CODING_BCC,
- HAL_RX_SU_MU_CODING_LDPC,
- HAL_RX_SU_MU_CODING_MAX,
- };
- enum hal_rx_gi {
- HAL_RX_GI_0_8_US,
- HAL_RX_GI_0_4_US,
- HAL_RX_GI_1_6_US,
- HAL_RX_GI_3_2_US,
- HAL_RX_GI_MAX,
- };
- enum hal_rx_bw {
- HAL_RX_BW_20MHZ,
- HAL_RX_BW_40MHZ,
- HAL_RX_BW_80MHZ,
- HAL_RX_BW_160MHZ,
- HAL_RX_BW_320MHZ,
- HAL_RX_BW_MAX,
- };
- enum hal_rx_preamble {
- HAL_RX_PREAMBLE_11A,
- HAL_RX_PREAMBLE_11B,
- HAL_RX_PREAMBLE_11N,
- HAL_RX_PREAMBLE_11AC,
- HAL_RX_PREAMBLE_11AX,
- HAL_RX_PREAMBLE_11BA,
- HAL_RX_PREAMBLE_11BE,
- HAL_RX_PREAMBLE_MAX,
- };
- enum hal_rx_reception_type {
- HAL_RX_RECEPTION_TYPE_SU,
- HAL_RX_RECEPTION_TYPE_MU_MIMO,
- HAL_RX_RECEPTION_TYPE_MU_OFDMA,
- HAL_RX_RECEPTION_TYPE_MU_OFDMA_MIMO,
- HAL_RX_RECEPTION_TYPE_MAX,
- };
- enum hal_rx_legacy_rate {
- HAL_RX_LEGACY_RATE_1_MBPS,
- HAL_RX_LEGACY_RATE_2_MBPS,
- HAL_RX_LEGACY_RATE_5_5_MBPS,
- HAL_RX_LEGACY_RATE_6_MBPS,
- HAL_RX_LEGACY_RATE_9_MBPS,
- HAL_RX_LEGACY_RATE_11_MBPS,
- HAL_RX_LEGACY_RATE_12_MBPS,
- HAL_RX_LEGACY_RATE_18_MBPS,
- HAL_RX_LEGACY_RATE_24_MBPS,
- HAL_RX_LEGACY_RATE_36_MBPS,
- HAL_RX_LEGACY_RATE_48_MBPS,
- HAL_RX_LEGACY_RATE_54_MBPS,
- HAL_RX_LEGACY_RATE_INVALID,
- };
- enum hal_ring_type {
- HAL_REO_DST,
- HAL_REO_EXCEPTION,
- HAL_REO_REINJECT,
- HAL_REO_CMD,
- HAL_REO_STATUS,
- HAL_TCL_DATA,
- HAL_TCL_CMD,
- HAL_TCL_STATUS,
- HAL_CE_SRC,
- HAL_CE_DST,
- HAL_CE_DST_STATUS,
- HAL_WBM_IDLE_LINK,
- HAL_SW2WBM_RELEASE,
- HAL_WBM2SW_RELEASE,
- HAL_RXDMA_BUF,
- HAL_RXDMA_DST,
- HAL_RXDMA_MONITOR_BUF,
- HAL_RXDMA_MONITOR_STATUS,
- HAL_RXDMA_MONITOR_DST,
- HAL_RXDMA_MONITOR_DESC,
- HAL_RXDMA_DIR_BUF,
- HAL_PPE2TCL,
- HAL_PPE_RELEASE,
- HAL_TX_MONITOR_BUF,
- HAL_TX_MONITOR_DST,
- HAL_MAX_RING_TYPES,
- };
- /**
- * enum hal_reo_cmd_type: Enum for REO command type
- * @HAL_REO_CMD_GET_QUEUE_STATS: Get REO queue status/stats
- * @HAL_REO_CMD_FLUSH_QUEUE: Flush all frames in REO queue
- * @HAL_REO_CMD_FLUSH_CACHE: Flush descriptor entries in the cache
- * @HAL_REO_CMD_UNBLOCK_CACHE: Unblock a descriptor's address that was blocked
- * earlier with a 'REO_FLUSH_CACHE' command
- * @HAL_REO_CMD_FLUSH_TIMEOUT_LIST: Flush buffers/descriptors from timeout list
- * @HAL_REO_CMD_UPDATE_RX_QUEUE: Update REO queue settings
- */
- enum hal_reo_cmd_type {
- HAL_REO_CMD_GET_QUEUE_STATS = 0,
- HAL_REO_CMD_FLUSH_QUEUE = 1,
- HAL_REO_CMD_FLUSH_CACHE = 2,
- HAL_REO_CMD_UNBLOCK_CACHE = 3,
- HAL_REO_CMD_FLUSH_TIMEOUT_LIST = 4,
- HAL_REO_CMD_UPDATE_RX_QUEUE = 5,
- };
- /**
- * enum hal_reo_cmd_status: Enum for execution status of REO command
- * @HAL_REO_CMD_SUCCESS: Command has successfully executed
- * @HAL_REO_CMD_BLOCKED: Command could not be executed as the queue
- * or cache was blocked
- * @HAL_REO_CMD_FAILED: Command execution failed, could be due to
- * invalid queue desc
- * @HAL_REO_CMD_RESOURCE_BLOCKED: Command could not be executed because
- * one or more descriptors were blocked
- * @HAL_REO_CMD_DRAIN:
- */
- enum hal_reo_cmd_status {
- HAL_REO_CMD_SUCCESS = 0,
- HAL_REO_CMD_BLOCKED = 1,
- HAL_REO_CMD_FAILED = 2,
- HAL_REO_CMD_RESOURCE_BLOCKED = 3,
- HAL_REO_CMD_DRAIN = 0xff,
- };
- enum hal_tcl_encap_type {
- HAL_TCL_ENCAP_TYPE_RAW,
- HAL_TCL_ENCAP_TYPE_NATIVE_WIFI,
- HAL_TCL_ENCAP_TYPE_ETHERNET,
- HAL_TCL_ENCAP_TYPE_802_3 = 3,
- HAL_TCL_ENCAP_TYPE_MAX
- };
- enum hal_tcl_desc_type {
- HAL_TCL_DESC_TYPE_BUFFER,
- HAL_TCL_DESC_TYPE_EXT_DESC,
- HAL_TCL_DESC_TYPE_MAX,
- };
- enum hal_reo_dest_ring_buffer_type {
- HAL_REO_DEST_RING_BUFFER_TYPE_MSDU,
- HAL_REO_DEST_RING_BUFFER_TYPE_LINK_DESC,
- };
- enum hal_reo_dest_ring_push_reason {
- HAL_REO_DEST_RING_PUSH_REASON_ERR_DETECTED,
- HAL_REO_DEST_RING_PUSH_REASON_ROUTING_INSTRUCTION,
- };
- enum hal_reo_entr_rxdma_push_reason {
- HAL_REO_ENTR_RING_RXDMA_PUSH_REASON_ERR_DETECTED,
- HAL_REO_ENTR_RING_RXDMA_PUSH_REASON_ROUTING_INSTRUCTION,
- HAL_REO_ENTR_RING_RXDMA_PUSH_REASON_RX_FLUSH,
- };
- enum hal_reo_dest_ring_error_code {
- HAL_REO_DEST_RING_ERROR_CODE_DESC_ADDR_ZERO,
- HAL_REO_DEST_RING_ERROR_CODE_DESC_INVALID,
- HAL_REO_DEST_RING_ERROR_CODE_AMPDU_IN_NON_BA,
- HAL_REO_DEST_RING_ERROR_CODE_NON_BA_DUPLICATE,
- HAL_REO_DEST_RING_ERROR_CODE_BA_DUPLICATE,
- HAL_REO_DEST_RING_ERROR_CODE_FRAME_2K_JUMP,
- HAL_REO_DEST_RING_ERROR_CODE_BAR_2K_JUMP,
- HAL_REO_DEST_RING_ERROR_CODE_FRAME_OOR,
- HAL_REO_DEST_RING_ERROR_CODE_BAR_OOR,
- HAL_REO_DEST_RING_ERROR_CODE_NO_BA_SESSION,
- HAL_REO_DEST_RING_ERROR_CODE_FRAME_SN_EQUALS_SSN,
- HAL_REO_DEST_RING_ERROR_CODE_PN_CHECK_FAILED,
- HAL_REO_DEST_RING_ERROR_CODE_2K_ERR_FLAG_SET,
- HAL_REO_DEST_RING_ERROR_CODE_PN_ERR_FLAG_SET,
- HAL_REO_DEST_RING_ERROR_CODE_DESC_BLOCKED,
- HAL_REO_DEST_RING_ERROR_CODE_MAX,
- };
- enum hal_reo_entr_rxdma_ecode {
- HAL_REO_ENTR_RING_RXDMA_ECODE_OVERFLOW_ERR,
- HAL_REO_ENTR_RING_RXDMA_ECODE_MPDU_LEN_ERR,
- HAL_REO_ENTR_RING_RXDMA_ECODE_FCS_ERR,
- HAL_REO_ENTR_RING_RXDMA_ECODE_DECRYPT_ERR,
- HAL_REO_ENTR_RING_RXDMA_ECODE_TKIP_MIC_ERR,
- HAL_REO_ENTR_RING_RXDMA_ECODE_UNECRYPTED_ERR,
- HAL_REO_ENTR_RING_RXDMA_ECODE_MSDU_LEN_ERR,
- HAL_REO_ENTR_RING_RXDMA_ECODE_MSDU_LIMIT_ERR,
- HAL_REO_ENTR_RING_RXDMA_ECODE_WIFI_PARSE_ERR,
- HAL_REO_ENTR_RING_RXDMA_ECODE_AMSDU_PARSE_ERR,
- HAL_REO_ENTR_RING_RXDMA_ECODE_SA_TIMEOUT_ERR,
- HAL_REO_ENTR_RING_RXDMA_ECODE_DA_TIMEOUT_ERR,
- HAL_REO_ENTR_RING_RXDMA_ECODE_FLOW_TIMEOUT_ERR,
- HAL_REO_ENTR_RING_RXDMA_ECODE_FLUSH_REQUEST_ERR,
- HAL_REO_ENTR_RING_RXDMA_ECODE_AMSDU_FRAG_ERR,
- HAL_REO_ENTR_RING_RXDMA_ECODE_MULTICAST_ECHO_ERR,
- HAL_REO_ENTR_RING_RXDMA_ECODE_AMSDU_MISMATCH_ERR,
- HAL_REO_ENTR_RING_RXDMA_ECODE_UNAUTH_WDS_ERR,
- HAL_REO_ENTR_RING_RXDMA_ECODE_GRPCAST_AMSDU_WDS_ERR,
- HAL_REO_ENTR_RING_RXDMA_ECODE_MAX,
- };
- enum hal_wbm_htt_tx_comp_status {
- HAL_WBM_REL_HTT_TX_COMP_STATUS_OK,
- HAL_WBM_REL_HTT_TX_COMP_STATUS_DROP,
- HAL_WBM_REL_HTT_TX_COMP_STATUS_TTL,
- HAL_WBM_REL_HTT_TX_COMP_STATUS_REINJ,
- HAL_WBM_REL_HTT_TX_COMP_STATUS_INSPECT,
- HAL_WBM_REL_HTT_TX_COMP_STATUS_MEC_NOTIFY,
- HAL_WBM_REL_HTT_TX_COMP_STATUS_VDEVID_MISMATCH,
- HAL_WBM_REL_HTT_TX_COMP_STATUS_MAX,
- };
- enum hal_encrypt_type {
- HAL_ENCRYPT_TYPE_WEP_40,
- HAL_ENCRYPT_TYPE_WEP_104,
- HAL_ENCRYPT_TYPE_TKIP_NO_MIC,
- HAL_ENCRYPT_TYPE_WEP_128,
- HAL_ENCRYPT_TYPE_TKIP_MIC,
- HAL_ENCRYPT_TYPE_WAPI,
- HAL_ENCRYPT_TYPE_CCMP_128,
- HAL_ENCRYPT_TYPE_OPEN,
- HAL_ENCRYPT_TYPE_CCMP_256,
- HAL_ENCRYPT_TYPE_GCMP_128,
- HAL_ENCRYPT_TYPE_AES_GCMP_256,
- HAL_ENCRYPT_TYPE_WAPI_GCM_SM4,
- };
- enum hal_tx_rate_stats_bw {
- HAL_TX_RATE_STATS_BW_20,
- HAL_TX_RATE_STATS_BW_40,
- HAL_TX_RATE_STATS_BW_80,
- HAL_TX_RATE_STATS_BW_160,
- };
- enum hal_tx_rate_stats_pkt_type {
- HAL_TX_RATE_STATS_PKT_TYPE_11A,
- HAL_TX_RATE_STATS_PKT_TYPE_11B,
- HAL_TX_RATE_STATS_PKT_TYPE_11N,
- HAL_TX_RATE_STATS_PKT_TYPE_11AC,
- HAL_TX_RATE_STATS_PKT_TYPE_11AX,
- HAL_TX_RATE_STATS_PKT_TYPE_11BA,
- HAL_TX_RATE_STATS_PKT_TYPE_11BE,
- };
- enum hal_tx_rate_stats_sgi {
- HAL_TX_RATE_STATS_SGI_08US,
- HAL_TX_RATE_STATS_SGI_04US,
- HAL_TX_RATE_STATS_SGI_16US,
- HAL_TX_RATE_STATS_SGI_32US,
- };
- struct hal_wbm_idle_scatter_list {
- dma_addr_t paddr;
- struct hal_wbm_link_desc *vaddr;
- };
- struct hal_srng_params {
- dma_addr_t ring_base_paddr;
- u32 *ring_base_vaddr;
- int num_entries;
- u32 intr_batch_cntr_thres_entries;
- u32 intr_timer_thres_us;
- u32 flags;
- u32 max_buffer_len;
- u32 low_threshold;
- u32 high_threshold;
- dma_addr_t msi_addr;
- dma_addr_t msi2_addr;
- u32 msi_data;
- u32 msi2_data;
- /* Add more params as needed */
- };
- enum hal_srng_dir {
- HAL_SRNG_DIR_SRC,
- HAL_SRNG_DIR_DST
- };
- enum rx_msdu_start_pkt_type {
- RX_MSDU_START_PKT_TYPE_11A,
- RX_MSDU_START_PKT_TYPE_11B,
- RX_MSDU_START_PKT_TYPE_11N,
- RX_MSDU_START_PKT_TYPE_11AC,
- RX_MSDU_START_PKT_TYPE_11AX,
- RX_MSDU_START_PKT_TYPE_11BA,
- RX_MSDU_START_PKT_TYPE_11BE,
- };
- enum rx_msdu_start_sgi {
- RX_MSDU_START_SGI_0_8_US,
- RX_MSDU_START_SGI_0_4_US,
- RX_MSDU_START_SGI_1_6_US,
- RX_MSDU_START_SGI_3_2_US,
- };
- enum rx_msdu_start_recv_bw {
- RX_MSDU_START_RECV_BW_20MHZ,
- RX_MSDU_START_RECV_BW_40MHZ,
- RX_MSDU_START_RECV_BW_80MHZ,
- RX_MSDU_START_RECV_BW_160MHZ,
- };
- enum rx_msdu_start_reception_type {
- RX_MSDU_START_RECEPTION_TYPE_SU,
- RX_MSDU_START_RECEPTION_TYPE_DL_MU_MIMO,
- RX_MSDU_START_RECEPTION_TYPE_DL_MU_OFDMA,
- RX_MSDU_START_RECEPTION_TYPE_DL_MU_OFDMA_MIMO,
- RX_MSDU_START_RECEPTION_TYPE_UL_MU_MIMO,
- RX_MSDU_START_RECEPTION_TYPE_UL_MU_OFDMA,
- RX_MSDU_START_RECEPTION_TYPE_UL_MU_OFDMA_MIMO,
- };
- enum rx_desc_decap_type {
- RX_DESC_DECAP_TYPE_RAW,
- RX_DESC_DECAP_TYPE_NATIVE_WIFI,
- RX_DESC_DECAP_TYPE_ETHERNET2_DIX,
- RX_DESC_DECAP_TYPE_8023,
- };
- struct hal_rx_user_status {
- u32 mcs:4,
- nss:3,
- ofdma_info_valid:1,
- ul_ofdma_ru_start_index:7,
- ul_ofdma_ru_width:7,
- ul_ofdma_ru_size:8;
- u32 ul_ofdma_user_v0_word0;
- u32 ul_ofdma_user_v0_word1;
- u32 ast_index;
- u32 tid;
- u16 tcp_msdu_count;
- u16 tcp_ack_msdu_count;
- u16 udp_msdu_count;
- u16 other_msdu_count;
- u16 frame_control;
- u8 frame_control_info_valid;
- u8 data_sequence_control_info_valid;
- u16 first_data_seq_ctrl;
- u32 preamble_type;
- u16 ht_flags;
- u16 vht_flags;
- u16 he_flags;
- u8 rs_flags;
- u8 ldpc;
- u32 mpdu_cnt_fcs_ok;
- u32 mpdu_cnt_fcs_err;
- u32 mpdu_fcs_ok_bitmap[HAL_RX_NUM_WORDS_PER_PPDU_BITMAP];
- u32 mpdu_ok_byte_count;
- u32 mpdu_err_byte_count;
- bool ampdu_present;
- u16 ampdu_id;
- };
- struct hal_rx_u_sig_info {
- bool ul_dl;
- u8 bw;
- u8 ppdu_type_comp_mode;
- u8 eht_sig_mcs;
- u8 num_eht_sig_sym;
- struct ieee80211_radiotap_eht_usig usig;
- };
- struct hal_rx_tlv_aggr_info {
- bool in_progress;
- u16 cur_len;
- u16 tlv_tag;
- u8 buf[HAL_RX_MON_MAX_AGGR_SIZE];
- };
- struct hal_rx_radiotap_eht {
- __le32 known;
- __le32 data[9];
- };
- struct hal_rx_eht_info {
- u8 num_user_info;
- struct hal_rx_radiotap_eht eht;
- u32 user_info[EHT_MAX_USER_INFO];
- };
- struct hal_rx_msdu_desc_info {
- u32 msdu_flags;
- u16 msdu_len; /* 14 bits for length */
- };
- /* hal_mon_buf_ring
- * Producer : SW
- * Consumer : Monitor
- *
- * paddr_lo
- * Lower 32-bit physical address of the buffer pointer from the source ring.
- * paddr_hi
- * bit range 7-0 : upper 8 bit of the physical address.
- * bit range 31-8 : reserved.
- * cookie
- * Consumer: RxMon/TxMon 64 bit cookie of the buffers.
- */
- struct hal_mon_buf_ring {
- __le32 paddr_lo;
- __le32 paddr_hi;
- __le64 cookie;
- };
- struct hal_rx_mon_ppdu_info {
- u32 ppdu_id;
- u32 last_ppdu_id;
- u64 ppdu_ts;
- u32 num_mpdu_fcs_ok;
- u32 num_mpdu_fcs_err;
- u32 preamble_type;
- u32 mpdu_len;
- u16 chan_num;
- u16 freq;
- u16 tcp_msdu_count;
- u16 tcp_ack_msdu_count;
- u16 udp_msdu_count;
- u16 other_msdu_count;
- u16 peer_id;
- u8 rate;
- u8 mcs;
- u8 nss;
- u8 bw;
- u8 vht_flag_values1;
- u8 vht_flag_values2;
- u8 vht_flag_values3[4];
- u8 vht_flag_values4;
- u8 vht_flag_values5;
- u16 vht_flag_values6;
- u8 is_stbc;
- u8 gi;
- u8 sgi;
- u8 ldpc;
- u8 beamformed;
- u8 rssi_comb;
- u16 tid;
- u8 fc_valid;
- u16 ht_flags;
- u16 vht_flags;
- u16 he_flags;
- u16 he_mu_flags;
- u8 dcm;
- u8 ru_alloc;
- u8 reception_type;
- u64 tsft;
- u64 rx_duration;
- u16 frame_control;
- u32 ast_index;
- u8 rs_fcs_err;
- u8 rs_flags;
- u8 cck_flag;
- u8 ofdm_flag;
- u8 ulofdma_flag;
- u8 frame_control_info_valid;
- u16 he_per_user_1;
- u16 he_per_user_2;
- u8 he_per_user_position;
- u8 he_per_user_known;
- u16 he_flags1;
- u16 he_flags2;
- u8 he_RU[4];
- u16 he_data1;
- u16 he_data2;
- u16 he_data3;
- u16 he_data4;
- u16 he_data5;
- u16 he_data6;
- u32 ppdu_len;
- u32 prev_ppdu_id;
- u32 device_id;
- u16 first_data_seq_ctrl;
- u8 monitor_direct_used;
- u8 data_sequence_control_info_valid;
- u8 ltf_size;
- u8 rxpcu_filter_pass;
- s8 rssi_chain[8][8];
- u32 num_users;
- u32 mpdu_fcs_ok_bitmap[HAL_RX_NUM_WORDS_PER_PPDU_BITMAP];
- u8 addr1[ETH_ALEN];
- u8 addr2[ETH_ALEN];
- u8 addr3[ETH_ALEN];
- u8 addr4[ETH_ALEN];
- struct hal_rx_user_status userstats[HAL_MAX_UL_MU_USERS];
- u8 userid;
- bool first_msdu_in_mpdu;
- bool is_ampdu;
- u8 medium_prot_type;
- bool ppdu_continuation;
- bool eht_usig;
- struct hal_rx_u_sig_info u_sig_info;
- bool is_eht;
- struct hal_rx_eht_info eht_info;
- struct hal_rx_tlv_aggr_info tlv_aggr;
- };
- struct hal_rx_desc_data {
- struct ieee80211_rx_status *rx_status;
- u32 phy_meta_data;
- u32 err_bitmap;
- u32 enctype;
- u32 msdu_done:1,
- is_decrypted:1,
- ip_csum_fail:1,
- l4_csum_fail:1,
- is_first_msdu:1,
- is_last_msdu:1,
- mesh_ctrl_present:1,
- addr2_present:1,
- is_mcbc:1,
- seq_ctl_valid:1,
- fc_valid:1;
- u16 msdu_len;
- u16 peer_id;
- u16 seq_no;
- u8 *addr2;
- u8 pkt_type;
- u8 l3_pad_bytes;
- u8 decap_type;
- u8 bw;
- u8 rate_mcs;
- u8 nss;
- u8 sgi;
- u8 tid;
- };
- #define BUFFER_ADDR_INFO0_ADDR GENMASK(31, 0)
- #define BUFFER_ADDR_INFO1_ADDR GENMASK(7, 0)
- #define BUFFER_ADDR_INFO1_RET_BUF_MGR GENMASK(11, 8)
- #define BUFFER_ADDR_INFO1_SW_COOKIE GENMASK(31, 12)
- struct ath12k_buffer_addr {
- __le32 info0;
- __le32 info1;
- } __packed;
- /* ath12k_buffer_addr
- *
- * buffer_addr_31_0
- * Address (lower 32 bits) of the MSDU buffer or MSDU_EXTENSION
- * descriptor or Link descriptor
- *
- * buffer_addr_39_32
- * Address (upper 8 bits) of the MSDU buffer or MSDU_EXTENSION
- * descriptor or Link descriptor
- *
- * return_buffer_manager (RBM)
- * Consumer: WBM
- * Producer: SW/FW
- * Indicates to which buffer manager the buffer or MSDU_EXTENSION
- * descriptor or link descriptor that is being pointed to shall be
- * returned after the frame has been processed. It is used by WBM
- * for routing purposes.
- *
- * Values are defined in enum %HAL_RX_BUF_RBM_
- *
- * sw_buffer_cookie
- * Cookie field exclusively used by SW. HW ignores the contents,
- * accept that it passes the programmed value on to other
- * descriptors together with the physical address.
- *
- * Field can be used by SW to for example associate the buffers
- * physical address with the virtual address.
- *
- * NOTE1:
- * The three most significant bits can have a special meaning
- * in case this struct is embedded in a TX_MPDU_DETAILS STRUCT,
- * and field transmit_bw_restriction is set
- *
- * In case of NON punctured transmission:
- * Sw_buffer_cookie[19:17] = 3'b000: 20 MHz TX only
- * Sw_buffer_cookie[19:17] = 3'b001: 40 MHz TX only
- * Sw_buffer_cookie[19:17] = 3'b010: 80 MHz TX only
- * Sw_buffer_cookie[19:17] = 3'b011: 160 MHz TX only
- * Sw_buffer_cookie[19:17] = 3'b101: 240 MHz TX only
- * Sw_buffer_cookie[19:17] = 3'b100: 320 MHz TX only
- * Sw_buffer_cookie[19:18] = 2'b11: reserved
- *
- * In case of punctured transmission:
- * Sw_buffer_cookie[19:16] = 4'b0000: pattern 0 only
- * Sw_buffer_cookie[19:16] = 4'b0001: pattern 1 only
- * Sw_buffer_cookie[19:16] = 4'b0010: pattern 2 only
- * Sw_buffer_cookie[19:16] = 4'b0011: pattern 3 only
- * Sw_buffer_cookie[19:16] = 4'b0100: pattern 4 only
- * Sw_buffer_cookie[19:16] = 4'b0101: pattern 5 only
- * Sw_buffer_cookie[19:16] = 4'b0110: pattern 6 only
- * Sw_buffer_cookie[19:16] = 4'b0111: pattern 7 only
- * Sw_buffer_cookie[19:16] = 4'b1000: pattern 8 only
- * Sw_buffer_cookie[19:16] = 4'b1001: pattern 9 only
- * Sw_buffer_cookie[19:16] = 4'b1010: pattern 10 only
- * Sw_buffer_cookie[19:16] = 4'b1011: pattern 11 only
- * Sw_buffer_cookie[19:18] = 2'b11: reserved
- *
- * Note: a punctured transmission is indicated by the presence
- * of TLV TX_PUNCTURE_SETUP embedded in the scheduler TLV
- *
- * Sw_buffer_cookie[20:17]: Tid: The TID field in the QoS control
- * field
- *
- * Sw_buffer_cookie[16]: Mpdu_qos_control_valid: This field
- * indicates MPDUs with a QoS control field.
- *
- */
- struct hal_ce_srng_dest_desc;
- struct hal_ce_srng_dst_status_desc;
- struct hal_ce_srng_src_desc;
- struct hal_wbm_link_desc {
- struct ath12k_buffer_addr buf_addr_info;
- } __packed;
- /* srng flags */
- #define HAL_SRNG_FLAGS_MSI_SWAP 0x00000008
- #define HAL_SRNG_FLAGS_RING_PTR_SWAP 0x00000010
- #define HAL_SRNG_FLAGS_DATA_TLV_SWAP 0x00000020
- #define HAL_SRNG_FLAGS_LOW_THRESH_INTR_EN 0x00010000
- #define HAL_SRNG_FLAGS_MSI_INTR 0x00020000
- #define HAL_SRNG_FLAGS_HIGH_THRESH_INTR_EN 0x00080000
- #define HAL_SRNG_FLAGS_LMAC_RING 0x80000000
- /* Common SRNG ring structure for source and destination rings */
- struct hal_srng {
- /* Unique SRNG ring ID */
- u8 ring_id;
- /* Ring initialization done */
- u8 initialized;
- /* Interrupt/MSI value assigned to this ring */
- int irq;
- /* Physical base address of the ring */
- dma_addr_t ring_base_paddr;
- /* Virtual base address of the ring */
- u32 *ring_base_vaddr;
- /* Number of entries in ring */
- u32 num_entries;
- /* Ring size */
- u32 ring_size;
- /* Ring size mask */
- u32 ring_size_mask;
- /* Size of ring entry */
- u32 entry_size;
- /* Interrupt timer threshold - in micro seconds */
- u32 intr_timer_thres_us;
- /* Interrupt batch counter threshold - in number of ring entries */
- u32 intr_batch_cntr_thres_entries;
- /* MSI Address */
- dma_addr_t msi_addr;
- /* MSI data */
- u32 msi_data;
- /* MSI2 Address */
- dma_addr_t msi2_addr;
- /* MSI2 data */
- u32 msi2_data;
- /* Misc flags */
- u32 flags;
- /* Lock for serializing ring index updates */
- spinlock_t lock;
- struct lock_class_key lock_key;
- /* Start offset of SRNG register groups for this ring
- * TBD: See if this is required - register address can be derived
- * from ring ID
- */
- u32 hwreg_base[HAL_SRNG_NUM_REG_GRP];
- u64 timestamp;
- /* Source or Destination ring */
- enum hal_srng_dir ring_dir;
- union {
- struct {
- /* SW tail pointer */
- u32 tp;
- /* Shadow head pointer location to be updated by HW */
- volatile u32 *hp_addr;
- /* Cached head pointer */
- u32 cached_hp;
- /* Tail pointer location to be updated by SW - This
- * will be a register address and need not be
- * accessed through SW structure
- */
- u32 *tp_addr;
- /* Current SW loop cnt */
- u32 loop_cnt;
- /* max transfer size */
- u16 max_buffer_length;
- /* head pointer at access end */
- u32 last_hp;
- } dst_ring;
- struct {
- /* SW head pointer */
- u32 hp;
- /* SW reap head pointer */
- u32 reap_hp;
- /* Shadow tail pointer location to be updated by HW */
- u32 *tp_addr;
- /* Cached tail pointer */
- u32 cached_tp;
- /* Head pointer location to be updated by SW - This
- * will be a register address and need not be accessed
- * through SW structure
- */
- u32 *hp_addr;
- /* Low threshold - in number of ring entries */
- u32 low_threshold;
- /* tail pointer at access end */
- u32 last_tp;
- } src_ring;
- } u;
- };
- /* hal_wbm_link_desc
- *
- * Producer: WBM
- * Consumer: WBM
- *
- * buf_addr_info
- * Details of the physical address of a buffer or MSDU
- * link descriptor.
- */
- enum hal_wbm_rel_src_module {
- HAL_WBM_REL_SRC_MODULE_TQM,
- HAL_WBM_REL_SRC_MODULE_RXDMA,
- HAL_WBM_REL_SRC_MODULE_REO,
- HAL_WBM_REL_SRC_MODULE_FW,
- HAL_WBM_REL_SRC_MODULE_SW,
- HAL_WBM_REL_SRC_MODULE_MAX,
- };
- /* hal_wbm_rel_desc_type
- *
- * msdu_buffer
- * The address points to an MSDU buffer
- *
- * msdu_link_descriptor
- * The address points to an Tx MSDU link descriptor
- *
- * mpdu_link_descriptor
- * The address points to an MPDU link descriptor
- *
- * msdu_ext_descriptor
- * The address points to an MSDU extension descriptor
- *
- * queue_ext_descriptor
- * The address points to an TQM queue extension descriptor. WBM should
- * treat this is the same way as a link descriptor.
- */
- enum hal_wbm_rel_desc_type {
- HAL_WBM_REL_DESC_TYPE_REL_MSDU,
- HAL_WBM_REL_DESC_TYPE_MSDU_LINK,
- HAL_WBM_REL_DESC_TYPE_MPDU_LINK,
- HAL_WBM_REL_DESC_TYPE_MSDU_EXT,
- HAL_WBM_REL_DESC_TYPE_QUEUE_EXT,
- };
- /* Interrupt mitigation - Batch threshold in terms of number of frames */
- #define HAL_SRNG_INT_BATCH_THRESHOLD_TX 256
- #define HAL_SRNG_INT_BATCH_THRESHOLD_RX 128
- #define HAL_SRNG_INT_BATCH_THRESHOLD_OTHER 1
- /* Interrupt mitigation - timer threshold in us */
- #define HAL_SRNG_INT_TIMER_THRESHOLD_TX 1000
- #define HAL_SRNG_INT_TIMER_THRESHOLD_RX 500
- #define HAL_SRNG_INT_TIMER_THRESHOLD_OTHER 256
- enum hal_srng_mac_type {
- ATH12K_HAL_SRNG_UMAC,
- ATH12K_HAL_SRNG_DMAC,
- ATH12K_HAL_SRNG_PMAC
- };
- /* HW SRNG configuration table */
- struct hal_srng_config {
- int start_ring_id;
- u16 max_rings;
- u16 entry_size;
- u32 reg_start[HAL_SRNG_NUM_REG_GRP];
- u16 reg_size[HAL_SRNG_NUM_REG_GRP];
- enum hal_srng_mac_type mac_type;
- enum hal_srng_dir ring_dir;
- u32 max_size;
- };
- /**
- * enum hal_rx_buf_return_buf_manager - manager for returned rx buffers
- *
- * @HAL_RX_BUF_RBM_WBM_IDLE_BUF_LIST: Buffer returned to WBM idle buffer list
- * @HAL_RX_BUF_RBM_WBM_DEV0_IDLE_DESC_LIST: Descriptor returned to WBM idle
- * descriptor list, where the device 0 WBM is chosen in case of a multi-device config
- * @HAL_RX_BUF_RBM_WBM_DEV1_IDLE_DESC_LIST: Descriptor returned to WBM idle
- * descriptor list, where the device 1 WBM is chosen in case of a multi-device config
- * @HAL_RX_BUF_RBM_WBM_DEV2_IDLE_DESC_LIST: Descriptor returned to WBM idle
- * descriptor list, where the device 2 WBM is chosen in case of a multi-device config
- * @HAL_RX_BUF_RBM_FW_BM: Buffer returned to FW
- * @HAL_RX_BUF_RBM_SW0_BM: For ring 0 -- returned to host
- * @HAL_RX_BUF_RBM_SW1_BM: For ring 1 -- returned to host
- * @HAL_RX_BUF_RBM_SW2_BM: For ring 2 -- returned to host
- * @HAL_RX_BUF_RBM_SW3_BM: For ring 3 -- returned to host
- * @HAL_RX_BUF_RBM_SW4_BM: For ring 4 -- returned to host
- * @HAL_RX_BUF_RBM_SW5_BM: For ring 5 -- returned to host
- * @HAL_RX_BUF_RBM_SW6_BM: For ring 6 -- returned to host
- */
- enum hal_rx_buf_return_buf_manager {
- HAL_RX_BUF_RBM_WBM_IDLE_BUF_LIST,
- HAL_RX_BUF_RBM_WBM_DEV0_IDLE_DESC_LIST,
- HAL_RX_BUF_RBM_WBM_DEV1_IDLE_DESC_LIST,
- HAL_RX_BUF_RBM_WBM_DEV2_IDLE_DESC_LIST,
- HAL_RX_BUF_RBM_FW_BM,
- HAL_RX_BUF_RBM_SW0_BM,
- HAL_RX_BUF_RBM_SW1_BM,
- HAL_RX_BUF_RBM_SW2_BM,
- HAL_RX_BUF_RBM_SW3_BM,
- HAL_RX_BUF_RBM_SW4_BM,
- HAL_RX_BUF_RBM_SW5_BM,
- HAL_RX_BUF_RBM_SW6_BM,
- };
- struct ath12k_hal_reo_cmd {
- u32 addr_lo;
- u32 flag;
- u32 upd0;
- u32 upd1;
- u32 upd2;
- u32 pn[4];
- u16 rx_queue_num;
- u16 min_rel;
- u16 min_fwd;
- u8 addr_hi;
- u8 ac_list;
- u8 blocking_idx;
- u16 ba_window_size;
- u8 pn_size;
- };
- enum hal_pn_type {
- HAL_PN_TYPE_NONE,
- HAL_PN_TYPE_WPA,
- HAL_PN_TYPE_WAPI_EVEN,
- HAL_PN_TYPE_WAPI_UNEVEN,
- };
- enum hal_ce_desc {
- HAL_CE_DESC_SRC,
- HAL_CE_DESC_DST,
- HAL_CE_DESC_DST_STATUS,
- };
- #define HAL_HASH_ROUTING_RING_TCL 0
- #define HAL_HASH_ROUTING_RING_SW1 1
- #define HAL_HASH_ROUTING_RING_SW2 2
- #define HAL_HASH_ROUTING_RING_SW3 3
- #define HAL_HASH_ROUTING_RING_SW4 4
- #define HAL_HASH_ROUTING_RING_REL 5
- #define HAL_HASH_ROUTING_RING_FW 6
- struct hal_reo_status_header {
- u16 cmd_num;
- enum hal_reo_cmd_status cmd_status;
- u16 cmd_exe_time;
- u32 timestamp;
- };
- struct ath12k_hw_hal_params {
- enum hal_rx_buf_return_buf_manager rx_buf_rbm;
- u32 wbm2sw_cc_enable;
- };
- #define ATH12K_HW_REG_UNDEFINED 0xdeadbeaf
- struct ath12k_hw_regs {
- u32 tcl1_ring_id;
- u32 tcl1_ring_misc;
- u32 tcl1_ring_tp_addr_lsb;
- u32 tcl1_ring_tp_addr_msb;
- u32 tcl1_ring_consumer_int_setup_ix0;
- u32 tcl1_ring_consumer_int_setup_ix1;
- u32 tcl1_ring_msi1_base_lsb;
- u32 tcl1_ring_msi1_base_msb;
- u32 tcl1_ring_msi1_data;
- u32 tcl_ring_base_lsb;
- u32 tcl1_ring_base_lsb;
- u32 tcl1_ring_base_msb;
- u32 tcl2_ring_base_lsb;
- u32 tcl_status_ring_base_lsb;
- u32 reo1_qdesc_addr;
- u32 reo1_qdesc_max_peerid;
- u32 wbm_idle_ring_base_lsb;
- u32 wbm_idle_ring_misc_addr;
- u32 wbm_r0_idle_list_cntl_addr;
- u32 wbm_r0_idle_list_size_addr;
- u32 wbm_scattered_ring_base_lsb;
- u32 wbm_scattered_ring_base_msb;
- u32 wbm_scattered_desc_head_info_ix0;
- u32 wbm_scattered_desc_head_info_ix1;
- u32 wbm_scattered_desc_tail_info_ix0;
- u32 wbm_scattered_desc_tail_info_ix1;
- u32 wbm_scattered_desc_ptr_hp_addr;
- u32 wbm_sw_release_ring_base_lsb;
- u32 wbm_sw1_release_ring_base_lsb;
- u32 wbm0_release_ring_base_lsb;
- u32 wbm1_release_ring_base_lsb;
- u32 pcie_qserdes_sysclk_en_sel;
- u32 pcie_pcs_osc_dtct_config_base;
- u32 umac_ce0_src_reg_base;
- u32 umac_ce0_dest_reg_base;
- u32 umac_ce1_src_reg_base;
- u32 umac_ce1_dest_reg_base;
- u32 ppe_rel_ring_base;
- u32 reo2_ring_base;
- u32 reo1_misc_ctrl_addr;
- u32 reo1_sw_cookie_cfg0;
- u32 reo1_sw_cookie_cfg1;
- u32 reo1_qdesc_lut_base0;
- u32 reo1_qdesc_lut_base1;
- u32 reo1_ring_base_lsb;
- u32 reo1_ring_base_msb;
- u32 reo1_ring_id;
- u32 reo1_ring_misc;
- u32 reo1_ring_hp_addr_lsb;
- u32 reo1_ring_hp_addr_msb;
- u32 reo1_ring_producer_int_setup;
- u32 reo1_ring_msi1_base_lsb;
- u32 reo1_ring_msi1_base_msb;
- u32 reo1_ring_msi1_data;
- u32 reo1_aging_thres_ix0;
- u32 reo1_aging_thres_ix1;
- u32 reo1_aging_thres_ix2;
- u32 reo1_aging_thres_ix3;
- u32 reo2_sw0_ring_base;
- u32 sw2reo_ring_base;
- u32 sw2reo1_ring_base;
- u32 reo_cmd_ring_base;
- u32 reo_status_ring_base;
- u32 gcc_gcc_pcie_hot_rst;
- u32 qrtr_node_id;
- };
- /* HAL context to be used to access SRNG APIs (currently used by data path
- * and transport (CE) modules)
- */
- struct ath12k_hal {
- /* HAL internal state for all SRNG rings.
- */
- struct hal_srng srng_list[HAL_SRNG_RING_ID_MAX];
- /* SRNG configuration table */
- struct hal_srng_config *srng_config;
- /* Remote pointer memory for HW/FW updates */
- struct {
- u32 *vaddr;
- dma_addr_t paddr;
- } rdp;
- /* Shared memory for ring pointer updates from host to FW */
- struct {
- u32 *vaddr;
- dma_addr_t paddr;
- } wrp;
- struct device *dev;
- const struct hal_ops *ops;
- const struct ath12k_hw_regs *regs;
- const struct ath12k_hw_hal_params *hal_params;
- /* Available REO blocking resources bitmap */
- u8 avail_blk_resource;
- u8 current_blk_index;
- /* shadow register configuration */
- u32 shadow_reg_addr[HAL_SHADOW_NUM_REGS_MAX];
- int num_shadow_reg_configured;
- u32 hal_desc_sz;
- u32 hal_wbm_release_ring_tx_size;
- const struct ath12k_hal_tcl_to_wbm_rbm_map *tcl_to_wbm_rbm_map;
- };
- /* Maps WBM ring number and Return Buffer Manager Id per TCL ring */
- struct ath12k_hal_tcl_to_wbm_rbm_map {
- u8 wbm_ring_num;
- u8 rbm_id;
- };
- enum hal_wbm_rel_bm_act {
- HAL_WBM_REL_BM_ACT_PUT_IN_IDLE,
- HAL_WBM_REL_BM_ACT_REL_MSDU,
- };
- /* hal_wbm_rel_bm_act
- *
- * put_in_idle_list
- * Put the buffer or descriptor back in the idle list. In case of MSDU or
- * MDPU link descriptor, BM does not need to check to release any
- * individual MSDU buffers.
- *
- * release_msdu_list
- * This BM action can only be used in combination with desc_type being
- * msdu_link_descriptor. Field first_msdu_index points out which MSDU
- * pointer in the MSDU link descriptor is the first of an MPDU that is
- * released. BM shall release all the MSDU buffers linked to this first
- * MSDU buffer pointer. All related MSDU buffer pointer entries shall be
- * set to value 0, which represents the 'NULL' pointer. When all MSDU
- * buffer pointers in the MSDU link descriptor are 'NULL', the MSDU link
- * descriptor itself shall also be released.
- */
- #define RU_INVALID 0
- #define RU_26 1
- #define RU_52 2
- #define RU_106 4
- #define RU_242 9
- #define RU_484 18
- #define RU_996 37
- #define RU_2X996 74
- #define RU_3X996 111
- #define RU_4X996 148
- #define RU_52_26 (RU_52 + RU_26)
- #define RU_106_26 (RU_106 + RU_26)
- #define RU_484_242 (RU_484 + RU_242)
- #define RU_996_484 (RU_996 + RU_484)
- #define RU_996_484_242 (RU_996 + RU_484_242)
- #define RU_2X996_484 (RU_2X996 + RU_484)
- #define RU_3X996_484 (RU_3X996 + RU_484)
- enum ath12k_eht_ru_size {
- ATH12K_EHT_RU_26,
- ATH12K_EHT_RU_52,
- ATH12K_EHT_RU_106,
- ATH12K_EHT_RU_242,
- ATH12K_EHT_RU_484,
- ATH12K_EHT_RU_996,
- ATH12K_EHT_RU_996x2,
- ATH12K_EHT_RU_996x4,
- ATH12K_EHT_RU_52_26,
- ATH12K_EHT_RU_106_26,
- ATH12K_EHT_RU_484_242,
- ATH12K_EHT_RU_996_484,
- ATH12K_EHT_RU_996_484_242,
- ATH12K_EHT_RU_996x2_484,
- ATH12K_EHT_RU_996x3,
- ATH12K_EHT_RU_996x3_484,
- /* Keep last */
- ATH12K_EHT_RU_INVALID,
- };
- #define HAL_RX_RU_ALLOC_TYPE_MAX ATH12K_EHT_RU_INVALID
- static inline
- enum nl80211_he_ru_alloc ath12k_he_ru_tones_to_nl80211_he_ru_alloc(u16 ru_tones)
- {
- enum nl80211_he_ru_alloc ret;
- switch (ru_tones) {
- case RU_52:
- ret = NL80211_RATE_INFO_HE_RU_ALLOC_52;
- break;
- case RU_106:
- ret = NL80211_RATE_INFO_HE_RU_ALLOC_106;
- break;
- case RU_242:
- ret = NL80211_RATE_INFO_HE_RU_ALLOC_242;
- break;
- case RU_484:
- ret = NL80211_RATE_INFO_HE_RU_ALLOC_484;
- break;
- case RU_996:
- ret = NL80211_RATE_INFO_HE_RU_ALLOC_996;
- break;
- case RU_2X996:
- ret = NL80211_RATE_INFO_HE_RU_ALLOC_2x996;
- break;
- case RU_26:
- fallthrough;
- default:
- ret = NL80211_RATE_INFO_HE_RU_ALLOC_26;
- break;
- }
- return ret;
- }
- struct ath12k_hw_version_map {
- const struct hal_ops *hal_ops;
- u32 hal_desc_sz;
- const struct ath12k_hal_tcl_to_wbm_rbm_map *tcl_to_wbm_rbm_map;
- const struct ath12k_hw_hal_params *hal_params;
- const struct ath12k_hw_regs *hw_regs;
- };
- struct hal_ops {
- int (*create_srng_config)(struct ath12k_hal *hal);
- void (*rx_desc_set_msdu_len)(struct hal_rx_desc *desc, u16 len);
- void (*rx_desc_get_dot11_hdr)(struct hal_rx_desc *desc,
- struct ieee80211_hdr *hdr);
- void (*rx_desc_get_crypto_header)(struct hal_rx_desc *desc,
- u8 *crypto_hdr,
- enum hal_encrypt_type enctype);
- void (*rx_desc_copy_end_tlv)(struct hal_rx_desc *fdesc,
- struct hal_rx_desc *ldesc);
- u8 (*rx_desc_get_msdu_src_link_id)(struct hal_rx_desc *desc);
- void (*extract_rx_desc_data)(struct hal_rx_desc_data *rx_desc_data,
- struct hal_rx_desc *rx_desc,
- struct hal_rx_desc *ldesc);
- u32 (*rx_desc_get_mpdu_start_tag)(struct hal_rx_desc *desc);
- u32 (*rx_desc_get_mpdu_ppdu_id)(struct hal_rx_desc *desc);
- u8 (*rx_desc_get_l3_pad_bytes)(struct hal_rx_desc *desc);
- u8 *(*rx_desc_get_msdu_payload)(struct hal_rx_desc *desc);
- void (*ce_dst_setup)(struct ath12k_base *ab,
- struct hal_srng *srng, int ring_num);
- void (*set_umac_srng_ptr_addr)(struct ath12k_base *ab,
- struct hal_srng *srng);
- void (*srng_src_hw_init)(struct ath12k_base *ab, struct hal_srng *srng);
- void (*srng_dst_hw_init)(struct ath12k_base *ab, struct hal_srng *srng);
- int (*srng_update_shadow_config)(struct ath12k_base *ab,
- enum hal_ring_type ring_type,
- int ring_num);
- int (*srng_get_ring_id)(struct ath12k_hal *hal, enum hal_ring_type type,
- int ring_num, int mac_id);
- u32 (*ce_get_desc_size)(enum hal_ce_desc type);
- void (*ce_src_set_desc)(struct hal_ce_srng_src_desc *desc,
- dma_addr_t paddr, u32 len, u32 id,
- u8 byte_swap_data);
- void (*ce_dst_set_desc)(struct hal_ce_srng_dest_desc *desc,
- dma_addr_t paddr);
- u32 (*ce_dst_status_get_length)(struct hal_ce_srng_dst_status_desc *desc);
- void (*set_link_desc_addr)(struct hal_wbm_link_desc *desc, u32 cookie,
- dma_addr_t paddr,
- enum hal_rx_buf_return_buf_manager rbm);
- void (*tx_set_dscp_tid_map)(struct ath12k_base *ab, int id);
- void (*tx_configure_bank_register)(struct ath12k_base *ab,
- u32 bank_config, u8 bank_id);
- void (*reoq_lut_addr_read_enable)(struct ath12k_base *ab);
- void (*reoq_lut_set_max_peerid)(struct ath12k_base *ab);
- void (*write_ml_reoq_lut_addr)(struct ath12k_base *ab,
- dma_addr_t paddr);
- void (*write_reoq_lut_addr)(struct ath12k_base *ab, dma_addr_t paddr);
- void (*setup_link_idle_list)(struct ath12k_base *ab,
- struct hal_wbm_idle_scatter_list *sbuf,
- u32 nsbufs, u32 tot_link_desc,
- u32 end_offset);
- void (*reo_init_cmd_ring)(struct ath12k_base *ab,
- struct hal_srng *srng);
- void (*reo_shared_qaddr_cache_clear)(struct ath12k_base *ab);
- void (*reo_hw_setup)(struct ath12k_base *ab, u32 ring_hash_map);
- void (*rx_buf_addr_info_set)(struct ath12k_buffer_addr *binfo,
- dma_addr_t paddr, u32 cookie, u8 manager);
- void (*rx_buf_addr_info_get)(struct ath12k_buffer_addr *binfo,
- dma_addr_t *paddr, u32 *msdu_cookies,
- u8 *rbm);
- void (*cc_config)(struct ath12k_base *ab);
- enum hal_rx_buf_return_buf_manager
- (*get_idle_link_rbm)(struct ath12k_hal *hal, u8 device_id);
- void (*rx_msdu_list_get)(struct ath12k *ar,
- void *link_desc,
- void *msdu_list,
- u16 *num_msdus);
- void (*rx_reo_ent_buf_paddr_get)(void *rx_desc, dma_addr_t *paddr,
- u32 *sw_cookie,
- struct ath12k_buffer_addr **pp_buf_addr,
- u8 *rbm, u32 *msdu_cnt);
- void *(*reo_cmd_enc_tlv_hdr)(void *tlv, u64 tag, u64 len);
- u16 (*reo_status_dec_tlv_hdr)(void *tlv, void **desc);
- };
- #define HAL_TLV_HDR_TAG GENMASK(9, 1)
- #define HAL_TLV_HDR_LEN GENMASK(25, 10)
- #define HAL_TLV_USR_ID GENMASK(31, 26)
- #define HAL_TLV_ALIGN 4
- struct hal_tlv_hdr {
- __le32 tl;
- u8 value[];
- } __packed;
- #define HAL_TLV_64_HDR_TAG GENMASK(9, 1)
- #define HAL_TLV_64_HDR_LEN GENMASK(21, 10)
- #define HAL_TLV_64_USR_ID GENMASK(31, 26)
- #define HAL_TLV_64_ALIGN 8
- struct hal_tlv_64_hdr {
- __le64 tl;
- u8 value[];
- } __packed;
- #define HAL_SRNG_TLV_HDR_TAG GENMASK(9, 1)
- #define HAL_SRNG_TLV_HDR_LEN GENMASK(25, 10)
- dma_addr_t ath12k_hal_srng_get_tp_addr(struct ath12k_base *ab,
- struct hal_srng *srng);
- dma_addr_t ath12k_hal_srng_get_hp_addr(struct ath12k_base *ab,
- struct hal_srng *srng);
- u32 ath12k_hal_ce_get_desc_size(struct ath12k_hal *hal, enum hal_ce_desc type);
- void ath12k_hal_ce_dst_set_desc(struct ath12k_hal *hal,
- struct hal_ce_srng_dest_desc *desc,
- dma_addr_t paddr);
- void ath12k_hal_ce_src_set_desc(struct ath12k_hal *hal,
- struct hal_ce_srng_src_desc *desc,
- dma_addr_t paddr, u32 len, u32 id,
- u8 byte_swap_data);
- int ath12k_hal_srng_get_entrysize(struct ath12k_base *ab, u32 ring_type);
- int ath12k_hal_srng_get_max_entries(struct ath12k_base *ab, u32 ring_type);
- void ath12k_hal_srng_get_params(struct ath12k_base *ab, struct hal_srng *srng,
- struct hal_srng_params *params);
- void *ath12k_hal_srng_dst_get_next_entry(struct ath12k_base *ab,
- struct hal_srng *srng);
- void *ath12k_hal_srng_src_peek(struct ath12k_base *ab, struct hal_srng *srng);
- void *ath12k_hal_srng_dst_peek(struct ath12k_base *ab, struct hal_srng *srng);
- int ath12k_hal_srng_dst_num_free(struct ath12k_base *ab, struct hal_srng *srng,
- bool sync_hw_ptr);
- void *ath12k_hal_srng_src_get_next_reaped(struct ath12k_base *ab,
- struct hal_srng *srng);
- void *ath12k_hal_srng_src_reap_next(struct ath12k_base *ab,
- struct hal_srng *srng);
- void *ath12k_hal_srng_src_next_peek(struct ath12k_base *ab,
- struct hal_srng *srng);
- void *ath12k_hal_srng_src_get_next_entry(struct ath12k_base *ab,
- struct hal_srng *srng);
- int ath12k_hal_srng_src_num_free(struct ath12k_base *ab, struct hal_srng *srng,
- bool sync_hw_ptr);
- void ath12k_hal_srng_access_begin(struct ath12k_base *ab,
- struct hal_srng *srng);
- void ath12k_hal_srng_access_end(struct ath12k_base *ab, struct hal_srng *srng);
- int ath12k_hal_srng_setup(struct ath12k_base *ab, enum hal_ring_type type,
- int ring_num, int mac_id,
- struct hal_srng_params *params);
- int ath12k_hal_srng_init(struct ath12k_base *ath12k);
- void ath12k_hal_srng_deinit(struct ath12k_base *ath12k);
- void ath12k_hal_dump_srng_stats(struct ath12k_base *ab);
- void ath12k_hal_srng_get_shadow_config(struct ath12k_base *ab,
- u32 **cfg, u32 *len);
- int ath12k_hal_srng_update_shadow_config(struct ath12k_base *ab,
- enum hal_ring_type ring_type,
- int ring_num);
- void ath12k_hal_srng_shadow_config(struct ath12k_base *ab);
- void ath12k_hal_srng_shadow_update_hp_tp(struct ath12k_base *ab,
- struct hal_srng *srng);
- void ath12k_hal_reo_shared_qaddr_cache_clear(struct ath12k_base *ab);
- void ath12k_hal_set_link_desc_addr(struct ath12k_hal *hal,
- struct hal_wbm_link_desc *desc, u32 cookie,
- dma_addr_t paddr, int rbm);
- void ath12k_hal_setup_link_idle_list(struct ath12k_base *ab,
- struct hal_wbm_idle_scatter_list *sbuf,
- u32 nsbufs, u32 tot_link_desc,
- u32 end_offset);
- u32
- ath12k_hal_ce_dst_status_get_length(struct ath12k_hal *hal,
- struct hal_ce_srng_dst_status_desc *desc);
- void ath12k_hal_tx_set_dscp_tid_map(struct ath12k_base *ab, int id);
- void ath12k_hal_tx_configure_bank_register(struct ath12k_base *ab,
- u32 bank_config, u8 bank_id);
- void ath12k_hal_reoq_lut_addr_read_enable(struct ath12k_base *ab);
- void ath12k_hal_reoq_lut_set_max_peerid(struct ath12k_base *ab);
- void ath12k_hal_write_reoq_lut_addr(struct ath12k_base *ab, dma_addr_t paddr);
- void
- ath12k_hal_write_ml_reoq_lut_addr(struct ath12k_base *ab, dma_addr_t paddr);
- void ath12k_hal_reo_init_cmd_ring(struct ath12k_base *ab, struct hal_srng *srng);
- void ath12k_hal_reo_hw_setup(struct ath12k_base *ab, u32 ring_hash_map);
- void ath12k_hal_rx_buf_addr_info_set(struct ath12k_hal *hal,
- struct ath12k_buffer_addr *binfo,
- dma_addr_t paddr, u32 cookie, u8 manager);
- void ath12k_hal_rx_buf_addr_info_get(struct ath12k_hal *hal,
- struct ath12k_buffer_addr *binfo,
- dma_addr_t *paddr, u32 *msdu_cookies,
- u8 *rbm);
- void ath12k_hal_cc_config(struct ath12k_base *ab);
- enum hal_rx_buf_return_buf_manager
- ath12k_hal_get_idle_link_rbm(struct ath12k_hal *hal, u8 device_id);
- void ath12k_hal_rx_msdu_list_get(struct ath12k_hal *hal, struct ath12k *ar,
- void *link_desc, void *msdu_list,
- u16 *num_msdus);
- void ath12k_hal_rx_reo_ent_buf_paddr_get(struct ath12k_hal *hal, void *rx_desc,
- dma_addr_t *paddr, u32 *sw_cookie,
- struct ath12k_buffer_addr **pp_buf_addr,
- u8 *rbm, u32 *msdu_cnt);
- void *ath12k_hal_encode_tlv64_hdr(void *tlv, u64 tag, u64 len);
- void *ath12k_hal_encode_tlv32_hdr(void *tlv, u64 tag, u64 len);
- u16 ath12k_hal_decode_tlv64_hdr(void *tlv, void **desc);
- u16 ath12k_hal_decode_tlv32_hdr(void *tlv, void **desc);
- #endif
|