1*5c1def83SBjoern A. Zeeb /* SPDX-License-Identifier: BSD-3-Clause-Clear */ 2*5c1def83SBjoern A. Zeeb /* 3*5c1def83SBjoern A. Zeeb * Copyright (c) 2018-2021 The Linux Foundation. All rights reserved. 4*5c1def83SBjoern A. Zeeb * Copyright (c) 2021-2022 Qualcomm Innovation Center, Inc. All rights reserved. 5*5c1def83SBjoern A. Zeeb */ 6*5c1def83SBjoern A. Zeeb #include "core.h" 7*5c1def83SBjoern A. Zeeb 8*5c1def83SBjoern A. Zeeb #ifndef ATH12K_HAL_DESC_H 9*5c1def83SBjoern A. Zeeb #define ATH12K_HAL_DESC_H 10*5c1def83SBjoern A. Zeeb 11*5c1def83SBjoern A. Zeeb #define BUFFER_ADDR_INFO0_ADDR GENMASK(31, 0) 12*5c1def83SBjoern A. Zeeb 13*5c1def83SBjoern A. Zeeb #define BUFFER_ADDR_INFO1_ADDR GENMASK(7, 0) 14*5c1def83SBjoern A. Zeeb #define BUFFER_ADDR_INFO1_RET_BUF_MGR GENMASK(11, 8) 15*5c1def83SBjoern A. Zeeb #define BUFFER_ADDR_INFO1_SW_COOKIE GENMASK(31, 12) 16*5c1def83SBjoern A. Zeeb 17*5c1def83SBjoern A. Zeeb struct ath12k_buffer_addr { 18*5c1def83SBjoern A. Zeeb __le32 info0; 19*5c1def83SBjoern A. Zeeb __le32 info1; 20*5c1def83SBjoern A. Zeeb } __packed; 21*5c1def83SBjoern A. Zeeb 22*5c1def83SBjoern A. Zeeb /* ath12k_buffer_addr 23*5c1def83SBjoern A. Zeeb * 24*5c1def83SBjoern A. Zeeb * buffer_addr_31_0 25*5c1def83SBjoern A. Zeeb * Address (lower 32 bits) of the MSDU buffer or MSDU_EXTENSION 26*5c1def83SBjoern A. Zeeb * descriptor or Link descriptor 27*5c1def83SBjoern A. Zeeb * 28*5c1def83SBjoern A. Zeeb * buffer_addr_39_32 29*5c1def83SBjoern A. Zeeb * Address (upper 8 bits) of the MSDU buffer or MSDU_EXTENSION 30*5c1def83SBjoern A. Zeeb * descriptor or Link descriptor 31*5c1def83SBjoern A. Zeeb * 32*5c1def83SBjoern A. Zeeb * return_buffer_manager (RBM) 33*5c1def83SBjoern A. Zeeb * Consumer: WBM 34*5c1def83SBjoern A. Zeeb * Producer: SW/FW 35*5c1def83SBjoern A. Zeeb * Indicates to which buffer manager the buffer or MSDU_EXTENSION 36*5c1def83SBjoern A. Zeeb * descriptor or link descriptor that is being pointed to shall be 37*5c1def83SBjoern A. Zeeb * returned after the frame has been processed. It is used by WBM 38*5c1def83SBjoern A. Zeeb * for routing purposes. 39*5c1def83SBjoern A. Zeeb * 40*5c1def83SBjoern A. Zeeb * Values are defined in enum %HAL_RX_BUF_RBM_ 41*5c1def83SBjoern A. Zeeb * 42*5c1def83SBjoern A. Zeeb * sw_buffer_cookie 43*5c1def83SBjoern A. Zeeb * Cookie field exclusively used by SW. HW ignores the contents, 44*5c1def83SBjoern A. Zeeb * accept that it passes the programmed value on to other 45*5c1def83SBjoern A. Zeeb * descriptors together with the physical address. 46*5c1def83SBjoern A. Zeeb * 47*5c1def83SBjoern A. Zeeb * Field can be used by SW to for example associate the buffers 48*5c1def83SBjoern A. Zeeb * physical address with the virtual address. 49*5c1def83SBjoern A. Zeeb * 50*5c1def83SBjoern A. Zeeb * NOTE1: 51*5c1def83SBjoern A. Zeeb * The three most significant bits can have a special meaning 52*5c1def83SBjoern A. Zeeb * in case this struct is embedded in a TX_MPDU_DETAILS STRUCT, 53*5c1def83SBjoern A. Zeeb * and field transmit_bw_restriction is set 54*5c1def83SBjoern A. Zeeb * 55*5c1def83SBjoern A. Zeeb * In case of NON punctured transmission: 56*5c1def83SBjoern A. Zeeb * Sw_buffer_cookie[19:17] = 3'b000: 20 MHz TX only 57*5c1def83SBjoern A. Zeeb * Sw_buffer_cookie[19:17] = 3'b001: 40 MHz TX only 58*5c1def83SBjoern A. Zeeb * Sw_buffer_cookie[19:17] = 3'b010: 80 MHz TX only 59*5c1def83SBjoern A. Zeeb * Sw_buffer_cookie[19:17] = 3'b011: 160 MHz TX only 60*5c1def83SBjoern A. Zeeb * Sw_buffer_cookie[19:17] = 3'b101: 240 MHz TX only 61*5c1def83SBjoern A. Zeeb * Sw_buffer_cookie[19:17] = 3'b100: 320 MHz TX only 62*5c1def83SBjoern A. Zeeb * Sw_buffer_cookie[19:18] = 2'b11: reserved 63*5c1def83SBjoern A. Zeeb * 64*5c1def83SBjoern A. Zeeb * In case of punctured transmission: 65*5c1def83SBjoern A. Zeeb * Sw_buffer_cookie[19:16] = 4'b0000: pattern 0 only 66*5c1def83SBjoern A. Zeeb * Sw_buffer_cookie[19:16] = 4'b0001: pattern 1 only 67*5c1def83SBjoern A. Zeeb * Sw_buffer_cookie[19:16] = 4'b0010: pattern 2 only 68*5c1def83SBjoern A. Zeeb * Sw_buffer_cookie[19:16] = 4'b0011: pattern 3 only 69*5c1def83SBjoern A. Zeeb * Sw_buffer_cookie[19:16] = 4'b0100: pattern 4 only 70*5c1def83SBjoern A. Zeeb * Sw_buffer_cookie[19:16] = 4'b0101: pattern 5 only 71*5c1def83SBjoern A. Zeeb * Sw_buffer_cookie[19:16] = 4'b0110: pattern 6 only 72*5c1def83SBjoern A. Zeeb * Sw_buffer_cookie[19:16] = 4'b0111: pattern 7 only 73*5c1def83SBjoern A. Zeeb * Sw_buffer_cookie[19:16] = 4'b1000: pattern 8 only 74*5c1def83SBjoern A. Zeeb * Sw_buffer_cookie[19:16] = 4'b1001: pattern 9 only 75*5c1def83SBjoern A. Zeeb * Sw_buffer_cookie[19:16] = 4'b1010: pattern 10 only 76*5c1def83SBjoern A. Zeeb * Sw_buffer_cookie[19:16] = 4'b1011: pattern 11 only 77*5c1def83SBjoern A. Zeeb * Sw_buffer_cookie[19:18] = 2'b11: reserved 78*5c1def83SBjoern A. Zeeb * 79*5c1def83SBjoern A. Zeeb * Note: a punctured transmission is indicated by the presence 80*5c1def83SBjoern A. Zeeb * of TLV TX_PUNCTURE_SETUP embedded in the scheduler TLV 81*5c1def83SBjoern A. Zeeb * 82*5c1def83SBjoern A. Zeeb * Sw_buffer_cookie[20:17]: Tid: The TID field in the QoS control 83*5c1def83SBjoern A. Zeeb * field 84*5c1def83SBjoern A. Zeeb * 85*5c1def83SBjoern A. Zeeb * Sw_buffer_cookie[16]: Mpdu_qos_control_valid: This field 86*5c1def83SBjoern A. Zeeb * indicates MPDUs with a QoS control field. 87*5c1def83SBjoern A. Zeeb * 88*5c1def83SBjoern A. Zeeb */ 89*5c1def83SBjoern A. Zeeb 90*5c1def83SBjoern A. Zeeb enum hal_tlv_tag { 91*5c1def83SBjoern A. Zeeb HAL_MACTX_CBF_START = 0 /* 0x0 */, 92*5c1def83SBjoern A. Zeeb HAL_PHYRX_DATA = 1 /* 0x1 */, 93*5c1def83SBjoern A. Zeeb HAL_PHYRX_CBF_DATA_RESP = 2 /* 0x2 */, 94*5c1def83SBjoern A. Zeeb HAL_PHYRX_ABORT_REQUEST = 3 /* 0x3 */, 95*5c1def83SBjoern A. Zeeb HAL_PHYRX_USER_ABORT_NOTIFICATION = 4 /* 0x4 */, 96*5c1def83SBjoern A. Zeeb HAL_MACTX_DATA_RESP = 5 /* 0x5 */, 97*5c1def83SBjoern A. Zeeb HAL_MACTX_CBF_DATA = 6 /* 0x6 */, 98*5c1def83SBjoern A. Zeeb HAL_MACTX_CBF_DONE = 7 /* 0x7 */, 99*5c1def83SBjoern A. Zeeb HAL_PHYRX_LMR_DATA_RESP = 8 /* 0x8 */, 100*5c1def83SBjoern A. Zeeb HAL_RXPCU_TO_UCODE_START = 9 /* 0x9 */, 101*5c1def83SBjoern A. Zeeb HAL_RXPCU_TO_UCODE_DELIMITER_FOR_FULL_MPDU = 10 /* 0xa */, 102*5c1def83SBjoern A. Zeeb HAL_RXPCU_TO_UCODE_FULL_MPDU_DATA = 11 /* 0xb */, 103*5c1def83SBjoern A. Zeeb HAL_RXPCU_TO_UCODE_FCS_STATUS = 12 /* 0xc */, 104*5c1def83SBjoern A. Zeeb HAL_RXPCU_TO_UCODE_MPDU_DELIMITER = 13 /* 0xd */, 105*5c1def83SBjoern A. Zeeb HAL_RXPCU_TO_UCODE_DELIMITER_FOR_MPDU_HEADER = 14 /* 0xe */, 106*5c1def83SBjoern A. Zeeb HAL_RXPCU_TO_UCODE_MPDU_HEADER_DATA = 15 /* 0xf */, 107*5c1def83SBjoern A. Zeeb HAL_RXPCU_TO_UCODE_END = 16 /* 0x10 */, 108*5c1def83SBjoern A. Zeeb HAL_MACRX_CBF_READ_REQUEST = 32 /* 0x20 */, 109*5c1def83SBjoern A. Zeeb HAL_MACRX_CBF_DATA_REQUEST = 33 /* 0x21 */, 110*5c1def83SBjoern A. Zeeb HAL_MACRXXPECT_NDP_RECEPTION = 34 /* 0x22 */, 111*5c1def83SBjoern A. Zeeb HAL_MACRX_FREEZE_CAPTURE_CHANNEL = 35 /* 0x23 */, 112*5c1def83SBjoern A. Zeeb HAL_MACRX_NDP_TIMEOUT = 36 /* 0x24 */, 113*5c1def83SBjoern A. Zeeb HAL_MACRX_ABORT_ACK = 37 /* 0x25 */, 114*5c1def83SBjoern A. Zeeb HAL_MACRX_REQ_IMPLICIT_FB = 38 /* 0x26 */, 115*5c1def83SBjoern A. Zeeb HAL_MACRX_CHAIN_MASK = 39 /* 0x27 */, 116*5c1def83SBjoern A. Zeeb HAL_MACRX_NAP_USER = 40 /* 0x28 */, 117*5c1def83SBjoern A. Zeeb HAL_MACRX_ABORT_REQUEST = 41 /* 0x29 */, 118*5c1def83SBjoern A. Zeeb HAL_PHYTX_OTHER_TRANSMIT_INFO16 = 42 /* 0x2a */, 119*5c1def83SBjoern A. Zeeb HAL_PHYTX_ABORT_ACK = 43 /* 0x2b */, 120*5c1def83SBjoern A. Zeeb HAL_PHYTX_ABORT_REQUEST = 44 /* 0x2c */, 121*5c1def83SBjoern A. Zeeb HAL_PHYTX_PKT_END = 45 /* 0x2d */, 122*5c1def83SBjoern A. Zeeb HAL_PHYTX_PPDU_HEADER_INFO_REQUEST = 46 /* 0x2e */, 123*5c1def83SBjoern A. Zeeb HAL_PHYTX_REQUEST_CTRL_INFO = 47 /* 0x2f */, 124*5c1def83SBjoern A. Zeeb HAL_PHYTX_DATA_REQUEST = 48 /* 0x30 */, 125*5c1def83SBjoern A. Zeeb HAL_PHYTX_BF_CV_LOADING_DONE = 49 /* 0x31 */, 126*5c1def83SBjoern A. Zeeb HAL_PHYTX_NAP_ACK = 50 /* 0x32 */, 127*5c1def83SBjoern A. Zeeb HAL_PHYTX_NAP_DONE = 51 /* 0x33 */, 128*5c1def83SBjoern A. Zeeb HAL_PHYTX_OFF_ACK = 52 /* 0x34 */, 129*5c1def83SBjoern A. Zeeb HAL_PHYTX_ON_ACK = 53 /* 0x35 */, 130*5c1def83SBjoern A. Zeeb HAL_PHYTX_SYNTH_OFF_ACK = 54 /* 0x36 */, 131*5c1def83SBjoern A. Zeeb HAL_PHYTX_DEBUG16 = 55 /* 0x37 */, 132*5c1def83SBjoern A. Zeeb HAL_MACTX_ABORT_REQUEST = 56 /* 0x38 */, 133*5c1def83SBjoern A. Zeeb HAL_MACTX_ABORT_ACK = 57 /* 0x39 */, 134*5c1def83SBjoern A. Zeeb HAL_MACTX_PKT_END = 58 /* 0x3a */, 135*5c1def83SBjoern A. Zeeb HAL_MACTX_PRE_PHY_DESC = 59 /* 0x3b */, 136*5c1def83SBjoern A. Zeeb HAL_MACTX_BF_PARAMS_COMMON = 60 /* 0x3c */, 137*5c1def83SBjoern A. Zeeb HAL_MACTX_BF_PARAMS_PER_USER = 61 /* 0x3d */, 138*5c1def83SBjoern A. Zeeb HAL_MACTX_PREFETCH_CV = 62 /* 0x3e */, 139*5c1def83SBjoern A. Zeeb HAL_MACTX_USER_DESC_COMMON = 63 /* 0x3f */, 140*5c1def83SBjoern A. Zeeb HAL_MACTX_USER_DESC_PER_USER = 64 /* 0x40 */, 141*5c1def83SBjoern A. Zeeb HAL_XAMPLE_USER_TLV_16 = 65 /* 0x41 */, 142*5c1def83SBjoern A. Zeeb HAL_XAMPLE_TLV_16 = 66 /* 0x42 */, 143*5c1def83SBjoern A. Zeeb HAL_MACTX_PHY_OFF = 67 /* 0x43 */, 144*5c1def83SBjoern A. Zeeb HAL_MACTX_PHY_ON = 68 /* 0x44 */, 145*5c1def83SBjoern A. Zeeb HAL_MACTX_SYNTH_OFF = 69 /* 0x45 */, 146*5c1def83SBjoern A. Zeeb HAL_MACTXXPECT_CBF_COMMON = 70 /* 0x46 */, 147*5c1def83SBjoern A. Zeeb HAL_MACTXXPECT_CBF_PER_USER = 71 /* 0x47 */, 148*5c1def83SBjoern A. Zeeb HAL_MACTX_PHY_DESC = 72 /* 0x48 */, 149*5c1def83SBjoern A. Zeeb HAL_MACTX_L_SIG_A = 73 /* 0x49 */, 150*5c1def83SBjoern A. Zeeb HAL_MACTX_L_SIG_B = 74 /* 0x4a */, 151*5c1def83SBjoern A. Zeeb HAL_MACTX_HT_SIG = 75 /* 0x4b */, 152*5c1def83SBjoern A. Zeeb HAL_MACTX_VHT_SIG_A = 76 /* 0x4c */, 153*5c1def83SBjoern A. Zeeb HAL_MACTX_VHT_SIG_B_SU20 = 77 /* 0x4d */, 154*5c1def83SBjoern A. Zeeb HAL_MACTX_VHT_SIG_B_SU40 = 78 /* 0x4e */, 155*5c1def83SBjoern A. Zeeb HAL_MACTX_VHT_SIG_B_SU80 = 79 /* 0x4f */, 156*5c1def83SBjoern A. Zeeb HAL_MACTX_VHT_SIG_B_SU160 = 80 /* 0x50 */, 157*5c1def83SBjoern A. Zeeb HAL_MACTX_VHT_SIG_B_MU20 = 81 /* 0x51 */, 158*5c1def83SBjoern A. Zeeb HAL_MACTX_VHT_SIG_B_MU40 = 82 /* 0x52 */, 159*5c1def83SBjoern A. Zeeb HAL_MACTX_VHT_SIG_B_MU80 = 83 /* 0x53 */, 160*5c1def83SBjoern A. Zeeb HAL_MACTX_VHT_SIG_B_MU160 = 84 /* 0x54 */, 161*5c1def83SBjoern A. Zeeb HAL_MACTX_SERVICE = 85 /* 0x55 */, 162*5c1def83SBjoern A. Zeeb HAL_MACTX_HE_SIG_A_SU = 86 /* 0x56 */, 163*5c1def83SBjoern A. Zeeb HAL_MACTX_HE_SIG_A_MU_DL = 87 /* 0x57 */, 164*5c1def83SBjoern A. Zeeb HAL_MACTX_HE_SIG_A_MU_UL = 88 /* 0x58 */, 165*5c1def83SBjoern A. Zeeb HAL_MACTX_HE_SIG_B1_MU = 89 /* 0x59 */, 166*5c1def83SBjoern A. Zeeb HAL_MACTX_HE_SIG_B2_MU = 90 /* 0x5a */, 167*5c1def83SBjoern A. Zeeb HAL_MACTX_HE_SIG_B2_OFDMA = 91 /* 0x5b */, 168*5c1def83SBjoern A. Zeeb HAL_MACTX_DELETE_CV = 92 /* 0x5c */, 169*5c1def83SBjoern A. Zeeb HAL_MACTX_MU_UPLINK_COMMON = 93 /* 0x5d */, 170*5c1def83SBjoern A. Zeeb HAL_MACTX_MU_UPLINK_USER_SETUP = 94 /* 0x5e */, 171*5c1def83SBjoern A. Zeeb HAL_MACTX_OTHER_TRANSMIT_INFO = 95 /* 0x5f */, 172*5c1def83SBjoern A. Zeeb HAL_MACTX_PHY_NAP = 96 /* 0x60 */, 173*5c1def83SBjoern A. Zeeb HAL_MACTX_DEBUG = 97 /* 0x61 */, 174*5c1def83SBjoern A. Zeeb HAL_PHYRX_ABORT_ACK = 98 /* 0x62 */, 175*5c1def83SBjoern A. Zeeb HAL_PHYRX_GENERATED_CBF_DETAILS = 99 /* 0x63 */, 176*5c1def83SBjoern A. Zeeb HAL_PHYRX_RSSI_LEGACY = 100 /* 0x64 */, 177*5c1def83SBjoern A. Zeeb HAL_PHYRX_RSSI_HT = 101 /* 0x65 */, 178*5c1def83SBjoern A. Zeeb HAL_PHYRX_USER_INFO = 102 /* 0x66 */, 179*5c1def83SBjoern A. Zeeb HAL_PHYRX_PKT_END = 103 /* 0x67 */, 180*5c1def83SBjoern A. Zeeb HAL_PHYRX_DEBUG = 104 /* 0x68 */, 181*5c1def83SBjoern A. Zeeb HAL_PHYRX_CBF_TRANSFER_DONE = 105 /* 0x69 */, 182*5c1def83SBjoern A. Zeeb HAL_PHYRX_CBF_TRANSFER_ABORT = 106 /* 0x6a */, 183*5c1def83SBjoern A. Zeeb HAL_PHYRX_L_SIG_A = 107 /* 0x6b */, 184*5c1def83SBjoern A. Zeeb HAL_PHYRX_L_SIG_B = 108 /* 0x6c */, 185*5c1def83SBjoern A. Zeeb HAL_PHYRX_HT_SIG = 109 /* 0x6d */, 186*5c1def83SBjoern A. Zeeb HAL_PHYRX_VHT_SIG_A = 110 /* 0x6e */, 187*5c1def83SBjoern A. Zeeb HAL_PHYRX_VHT_SIG_B_SU20 = 111 /* 0x6f */, 188*5c1def83SBjoern A. Zeeb HAL_PHYRX_VHT_SIG_B_SU40 = 112 /* 0x70 */, 189*5c1def83SBjoern A. Zeeb HAL_PHYRX_VHT_SIG_B_SU80 = 113 /* 0x71 */, 190*5c1def83SBjoern A. Zeeb HAL_PHYRX_VHT_SIG_B_SU160 = 114 /* 0x72 */, 191*5c1def83SBjoern A. Zeeb HAL_PHYRX_VHT_SIG_B_MU20 = 115 /* 0x73 */, 192*5c1def83SBjoern A. Zeeb HAL_PHYRX_VHT_SIG_B_MU40 = 116 /* 0x74 */, 193*5c1def83SBjoern A. Zeeb HAL_PHYRX_VHT_SIG_B_MU80 = 117 /* 0x75 */, 194*5c1def83SBjoern A. Zeeb HAL_PHYRX_VHT_SIG_B_MU160 = 118 /* 0x76 */, 195*5c1def83SBjoern A. Zeeb HAL_PHYRX_HE_SIG_A_SU = 119 /* 0x77 */, 196*5c1def83SBjoern A. Zeeb HAL_PHYRX_HE_SIG_A_MU_DL = 120 /* 0x78 */, 197*5c1def83SBjoern A. Zeeb HAL_PHYRX_HE_SIG_A_MU_UL = 121 /* 0x79 */, 198*5c1def83SBjoern A. Zeeb HAL_PHYRX_HE_SIG_B1_MU = 122 /* 0x7a */, 199*5c1def83SBjoern A. Zeeb HAL_PHYRX_HE_SIG_B2_MU = 123 /* 0x7b */, 200*5c1def83SBjoern A. Zeeb HAL_PHYRX_HE_SIG_B2_OFDMA = 124 /* 0x7c */, 201*5c1def83SBjoern A. Zeeb HAL_PHYRX_OTHER_RECEIVE_INFO = 125 /* 0x7d */, 202*5c1def83SBjoern A. Zeeb HAL_PHYRX_COMMON_USER_INFO = 126 /* 0x7e */, 203*5c1def83SBjoern A. Zeeb HAL_PHYRX_DATA_DONE = 127 /* 0x7f */, 204*5c1def83SBjoern A. Zeeb HAL_COEX_TX_REQ = 128 /* 0x80 */, 205*5c1def83SBjoern A. Zeeb HAL_DUMMY = 129 /* 0x81 */, 206*5c1def83SBjoern A. Zeeb HALXAMPLE_TLV_32_NAME = 130 /* 0x82 */, 207*5c1def83SBjoern A. Zeeb HAL_MPDU_LIMIT = 131 /* 0x83 */, 208*5c1def83SBjoern A. Zeeb HAL_NA_LENGTH_END = 132 /* 0x84 */, 209*5c1def83SBjoern A. Zeeb HAL_OLE_BUF_STATUS = 133 /* 0x85 */, 210*5c1def83SBjoern A. Zeeb HAL_PCU_PPDU_SETUP_DONE = 134 /* 0x86 */, 211*5c1def83SBjoern A. Zeeb HAL_PCU_PPDU_SETUP_END = 135 /* 0x87 */, 212*5c1def83SBjoern A. Zeeb HAL_PCU_PPDU_SETUP_INIT = 136 /* 0x88 */, 213*5c1def83SBjoern A. Zeeb HAL_PCU_PPDU_SETUP_START = 137 /* 0x89 */, 214*5c1def83SBjoern A. Zeeb HAL_PDG_FES_SETUP = 138 /* 0x8a */, 215*5c1def83SBjoern A. Zeeb HAL_PDG_RESPONSE = 139 /* 0x8b */, 216*5c1def83SBjoern A. Zeeb HAL_PDG_TX_REQ = 140 /* 0x8c */, 217*5c1def83SBjoern A. Zeeb HAL_SCH_WAIT_INSTR = 141 /* 0x8d */, 218*5c1def83SBjoern A. Zeeb HAL_TQM_FLOWMPTY_STATUS = 143 /* 0x8f */, 219*5c1def83SBjoern A. Zeeb HAL_TQM_FLOW_NOTMPTY_STATUS = 144 /* 0x90 */, 220*5c1def83SBjoern A. Zeeb HAL_TQM_GEN_MPDU_LENGTH_LIST = 145 /* 0x91 */, 221*5c1def83SBjoern A. Zeeb HAL_TQM_GEN_MPDU_LENGTH_LIST_STATUS = 146 /* 0x92 */, 222*5c1def83SBjoern A. Zeeb HAL_TQM_GEN_MPDUS = 147 /* 0x93 */, 223*5c1def83SBjoern A. Zeeb HAL_TQM_GEN_MPDUS_STATUS = 148 /* 0x94 */, 224*5c1def83SBjoern A. Zeeb HAL_TQM_REMOVE_MPDU = 149 /* 0x95 */, 225*5c1def83SBjoern A. Zeeb HAL_TQM_REMOVE_MPDU_STATUS = 150 /* 0x96 */, 226*5c1def83SBjoern A. Zeeb HAL_TQM_REMOVE_MSDU = 151 /* 0x97 */, 227*5c1def83SBjoern A. Zeeb HAL_TQM_REMOVE_MSDU_STATUS = 152 /* 0x98 */, 228*5c1def83SBjoern A. Zeeb HAL_TQM_UPDATE_TX_MPDU_COUNT = 153 /* 0x99 */, 229*5c1def83SBjoern A. Zeeb HAL_TQM_WRITE_CMD = 154 /* 0x9a */, 230*5c1def83SBjoern A. Zeeb HAL_OFDMA_TRIGGER_DETAILS = 155 /* 0x9b */, 231*5c1def83SBjoern A. Zeeb HAL_TX_DATA = 156 /* 0x9c */, 232*5c1def83SBjoern A. Zeeb HAL_TX_FES_SETUP = 157 /* 0x9d */, 233*5c1def83SBjoern A. Zeeb HAL_RX_PACKET = 158 /* 0x9e */, 234*5c1def83SBjoern A. Zeeb HALXPECTED_RESPONSE = 159 /* 0x9f */, 235*5c1def83SBjoern A. Zeeb HAL_TX_MPDU_END = 160 /* 0xa0 */, 236*5c1def83SBjoern A. Zeeb HAL_TX_MPDU_START = 161 /* 0xa1 */, 237*5c1def83SBjoern A. Zeeb HAL_TX_MSDU_END = 162 /* 0xa2 */, 238*5c1def83SBjoern A. Zeeb HAL_TX_MSDU_START = 163 /* 0xa3 */, 239*5c1def83SBjoern A. Zeeb HAL_TX_SW_MODE_SETUP = 164 /* 0xa4 */, 240*5c1def83SBjoern A. Zeeb HAL_TXPCU_BUFFER_STATUS = 165 /* 0xa5 */, 241*5c1def83SBjoern A. Zeeb HAL_TXPCU_USER_BUFFER_STATUS = 166 /* 0xa6 */, 242*5c1def83SBjoern A. Zeeb HAL_DATA_TO_TIME_CONFIG = 167 /* 0xa7 */, 243*5c1def83SBjoern A. Zeeb HALXAMPLE_USER_TLV_32 = 168 /* 0xa8 */, 244*5c1def83SBjoern A. Zeeb HAL_MPDU_INFO = 169 /* 0xa9 */, 245*5c1def83SBjoern A. Zeeb HAL_PDG_USER_SETUP = 170 /* 0xaa */, 246*5c1def83SBjoern A. Zeeb HAL_TX_11AH_SETUP = 171 /* 0xab */, 247*5c1def83SBjoern A. Zeeb HAL_REO_UPDATE_RX_REO_QUEUE_STATUS = 172 /* 0xac */, 248*5c1def83SBjoern A. Zeeb HAL_TX_PEER_ENTRY = 173 /* 0xad */, 249*5c1def83SBjoern A. Zeeb HAL_TX_RAW_OR_NATIVE_FRAME_SETUP = 174 /* 0xae */, 250*5c1def83SBjoern A. Zeeb HALXAMPLE_USER_TLV_44 = 175 /* 0xaf */, 251*5c1def83SBjoern A. Zeeb HAL_TX_FLUSH = 176 /* 0xb0 */, 252*5c1def83SBjoern A. Zeeb HAL_TX_FLUSH_REQ = 177 /* 0xb1 */, 253*5c1def83SBjoern A. Zeeb HAL_TQM_WRITE_CMD_STATUS = 178 /* 0xb2 */, 254*5c1def83SBjoern A. Zeeb HAL_TQM_GET_MPDU_QUEUE_STATS = 179 /* 0xb3 */, 255*5c1def83SBjoern A. Zeeb HAL_TQM_GET_MSDU_FLOW_STATS = 180 /* 0xb4 */, 256*5c1def83SBjoern A. Zeeb HALXAMPLE_USER_CTLV_44 = 181 /* 0xb5 */, 257*5c1def83SBjoern A. Zeeb HAL_TX_FES_STATUS_START = 182 /* 0xb6 */, 258*5c1def83SBjoern A. Zeeb HAL_TX_FES_STATUS_USER_PPDU = 183 /* 0xb7 */, 259*5c1def83SBjoern A. Zeeb HAL_TX_FES_STATUS_USER_RESPONSE = 184 /* 0xb8 */, 260*5c1def83SBjoern A. Zeeb HAL_TX_FES_STATUS_END = 185 /* 0xb9 */, 261*5c1def83SBjoern A. Zeeb HAL_RX_TRIG_INFO = 186 /* 0xba */, 262*5c1def83SBjoern A. Zeeb HAL_RXPCU_TX_SETUP_CLEAR = 187 /* 0xbb */, 263*5c1def83SBjoern A. Zeeb HAL_RX_FRAME_BITMAP_REQ = 188 /* 0xbc */, 264*5c1def83SBjoern A. Zeeb HAL_RX_FRAME_BITMAP_ACK = 189 /* 0xbd */, 265*5c1def83SBjoern A. Zeeb HAL_COEX_RX_STATUS = 190 /* 0xbe */, 266*5c1def83SBjoern A. Zeeb HAL_RX_START_PARAM = 191 /* 0xbf */, 267*5c1def83SBjoern A. Zeeb HAL_RX_PPDU_START = 192 /* 0xc0 */, 268*5c1def83SBjoern A. Zeeb HAL_RX_PPDU_END = 193 /* 0xc1 */, 269*5c1def83SBjoern A. Zeeb HAL_RX_MPDU_START = 194 /* 0xc2 */, 270*5c1def83SBjoern A. Zeeb HAL_RX_MPDU_END = 195 /* 0xc3 */, 271*5c1def83SBjoern A. Zeeb HAL_RX_MSDU_START = 196 /* 0xc4 */, 272*5c1def83SBjoern A. Zeeb HAL_RX_MSDU_END = 197 /* 0xc5 */, 273*5c1def83SBjoern A. Zeeb HAL_RX_ATTENTION = 198 /* 0xc6 */, 274*5c1def83SBjoern A. Zeeb HAL_RECEIVED_RESPONSE_INFO = 199 /* 0xc7 */, 275*5c1def83SBjoern A. Zeeb HAL_RX_PHY_SLEEP = 200 /* 0xc8 */, 276*5c1def83SBjoern A. Zeeb HAL_RX_HEADER = 201 /* 0xc9 */, 277*5c1def83SBjoern A. Zeeb HAL_RX_PEER_ENTRY = 202 /* 0xca */, 278*5c1def83SBjoern A. Zeeb HAL_RX_FLUSH = 203 /* 0xcb */, 279*5c1def83SBjoern A. Zeeb HAL_RX_RESPONSE_REQUIRED_INFO = 204 /* 0xcc */, 280*5c1def83SBjoern A. Zeeb HAL_RX_FRAMELESS_BAR_DETAILS = 205 /* 0xcd */, 281*5c1def83SBjoern A. Zeeb HAL_TQM_GET_MPDU_QUEUE_STATS_STATUS = 206 /* 0xce */, 282*5c1def83SBjoern A. Zeeb HAL_TQM_GET_MSDU_FLOW_STATS_STATUS = 207 /* 0xcf */, 283*5c1def83SBjoern A. Zeeb HAL_TX_CBF_INFO = 208 /* 0xd0 */, 284*5c1def83SBjoern A. Zeeb HAL_PCU_PPDU_SETUP_USER = 209 /* 0xd1 */, 285*5c1def83SBjoern A. Zeeb HAL_RX_MPDU_PCU_START = 210 /* 0xd2 */, 286*5c1def83SBjoern A. Zeeb HAL_RX_PM_INFO = 211 /* 0xd3 */, 287*5c1def83SBjoern A. Zeeb HAL_RX_USER_PPDU_END = 212 /* 0xd4 */, 288*5c1def83SBjoern A. Zeeb HAL_RX_PRE_PPDU_START = 213 /* 0xd5 */, 289*5c1def83SBjoern A. Zeeb HAL_RX_PREAMBLE = 214 /* 0xd6 */, 290*5c1def83SBjoern A. Zeeb HAL_TX_FES_SETUP_COMPLETE = 215 /* 0xd7 */, 291*5c1def83SBjoern A. Zeeb HAL_TX_LAST_MPDU_FETCHED = 216 /* 0xd8 */, 292*5c1def83SBjoern A. Zeeb HAL_TXDMA_STOP_REQUEST = 217 /* 0xd9 */, 293*5c1def83SBjoern A. Zeeb HAL_RXPCU_SETUP = 218 /* 0xda */, 294*5c1def83SBjoern A. Zeeb HAL_RXPCU_USER_SETUP = 219 /* 0xdb */, 295*5c1def83SBjoern A. Zeeb HAL_TX_FES_STATUS_ACK_OR_BA = 220 /* 0xdc */, 296*5c1def83SBjoern A. Zeeb HAL_TQM_ACKED_MPDU = 221 /* 0xdd */, 297*5c1def83SBjoern A. Zeeb HAL_COEX_TX_RESP = 222 /* 0xde */, 298*5c1def83SBjoern A. Zeeb HAL_COEX_TX_STATUS = 223 /* 0xdf */, 299*5c1def83SBjoern A. Zeeb HAL_MACTX_COEX_PHY_CTRL = 224 /* 0xe0 */, 300*5c1def83SBjoern A. Zeeb HAL_COEX_STATUS_BROADCAST = 225 /* 0xe1 */, 301*5c1def83SBjoern A. Zeeb HAL_RESPONSE_START_STATUS = 226 /* 0xe2 */, 302*5c1def83SBjoern A. Zeeb HAL_RESPONSEND_STATUS = 227 /* 0xe3 */, 303*5c1def83SBjoern A. Zeeb HAL_CRYPTO_STATUS = 228 /* 0xe4 */, 304*5c1def83SBjoern A. Zeeb HAL_RECEIVED_TRIGGER_INFO = 229 /* 0xe5 */, 305*5c1def83SBjoern A. Zeeb HAL_COEX_TX_STOP_CTRL = 230 /* 0xe6 */, 306*5c1def83SBjoern A. Zeeb HAL_RX_PPDU_ACK_REPORT = 231 /* 0xe7 */, 307*5c1def83SBjoern A. Zeeb HAL_RX_PPDU_NO_ACK_REPORT = 232 /* 0xe8 */, 308*5c1def83SBjoern A. Zeeb HAL_SCH_COEX_STATUS = 233 /* 0xe9 */, 309*5c1def83SBjoern A. Zeeb HAL_SCHEDULER_COMMAND_STATUS = 234 /* 0xea */, 310*5c1def83SBjoern A. Zeeb HAL_SCHEDULER_RX_PPDU_NO_RESPONSE_STATUS = 235 /* 0xeb */, 311*5c1def83SBjoern A. Zeeb HAL_TX_FES_STATUS_PROT = 236 /* 0xec */, 312*5c1def83SBjoern A. Zeeb HAL_TX_FES_STATUS_START_PPDU = 237 /* 0xed */, 313*5c1def83SBjoern A. Zeeb HAL_TX_FES_STATUS_START_PROT = 238 /* 0xee */, 314*5c1def83SBjoern A. Zeeb HAL_TXPCU_PHYTX_DEBUG32 = 239 /* 0xef */, 315*5c1def83SBjoern A. Zeeb HAL_TXPCU_PHYTX_OTHER_TRANSMIT_INFO32 = 240 /* 0xf0 */, 316*5c1def83SBjoern A. Zeeb HAL_TX_MPDU_COUNT_TRANSFERND = 241 /* 0xf1 */, 317*5c1def83SBjoern A. Zeeb HAL_WHO_ANCHOR_OFFSET = 242 /* 0xf2 */, 318*5c1def83SBjoern A. Zeeb HAL_WHO_ANCHOR_VALUE = 243 /* 0xf3 */, 319*5c1def83SBjoern A. Zeeb HAL_WHO_CCE_INFO = 244 /* 0xf4 */, 320*5c1def83SBjoern A. Zeeb HAL_WHO_COMMIT = 245 /* 0xf5 */, 321*5c1def83SBjoern A. Zeeb HAL_WHO_COMMIT_DONE = 246 /* 0xf6 */, 322*5c1def83SBjoern A. Zeeb HAL_WHO_FLUSH = 247 /* 0xf7 */, 323*5c1def83SBjoern A. Zeeb HAL_WHO_L2_LLC = 248 /* 0xf8 */, 324*5c1def83SBjoern A. Zeeb HAL_WHO_L2_PAYLOAD = 249 /* 0xf9 */, 325*5c1def83SBjoern A. Zeeb HAL_WHO_L3_CHECKSUM = 250 /* 0xfa */, 326*5c1def83SBjoern A. Zeeb HAL_WHO_L3_INFO = 251 /* 0xfb */, 327*5c1def83SBjoern A. Zeeb HAL_WHO_L4_CHECKSUM = 252 /* 0xfc */, 328*5c1def83SBjoern A. Zeeb HAL_WHO_L4_INFO = 253 /* 0xfd */, 329*5c1def83SBjoern A. Zeeb HAL_WHO_MSDU = 254 /* 0xfe */, 330*5c1def83SBjoern A. Zeeb HAL_WHO_MSDU_MISC = 255 /* 0xff */, 331*5c1def83SBjoern A. Zeeb HAL_WHO_PACKET_DATA = 256 /* 0x100 */, 332*5c1def83SBjoern A. Zeeb HAL_WHO_PACKET_HDR = 257 /* 0x101 */, 333*5c1def83SBjoern A. Zeeb HAL_WHO_PPDU_END = 258 /* 0x102 */, 334*5c1def83SBjoern A. Zeeb HAL_WHO_PPDU_START = 259 /* 0x103 */, 335*5c1def83SBjoern A. Zeeb HAL_WHO_TSO = 260 /* 0x104 */, 336*5c1def83SBjoern A. Zeeb HAL_WHO_WMAC_HEADER_PV0 = 261 /* 0x105 */, 337*5c1def83SBjoern A. Zeeb HAL_WHO_WMAC_HEADER_PV1 = 262 /* 0x106 */, 338*5c1def83SBjoern A. Zeeb HAL_WHO_WMAC_IV = 263 /* 0x107 */, 339*5c1def83SBjoern A. Zeeb HAL_MPDU_INFO_END = 264 /* 0x108 */, 340*5c1def83SBjoern A. Zeeb HAL_MPDU_INFO_BITMAP = 265 /* 0x109 */, 341*5c1def83SBjoern A. Zeeb HAL_TX_QUEUE_EXTENSION = 266 /* 0x10a */, 342*5c1def83SBjoern A. Zeeb HAL_SCHEDULER_SELFGEN_RESPONSE_STATUS = 267 /* 0x10b */, 343*5c1def83SBjoern A. Zeeb HAL_TQM_UPDATE_TX_MPDU_COUNT_STATUS = 268 /* 0x10c */, 344*5c1def83SBjoern A. Zeeb HAL_TQM_ACKED_MPDU_STATUS = 269 /* 0x10d */, 345*5c1def83SBjoern A. Zeeb HAL_TQM_ADD_MSDU_STATUS = 270 /* 0x10e */, 346*5c1def83SBjoern A. Zeeb HAL_TQM_LIST_GEN_DONE = 271 /* 0x10f */, 347*5c1def83SBjoern A. Zeeb HAL_WHO_TERMINATE = 272 /* 0x110 */, 348*5c1def83SBjoern A. Zeeb HAL_TX_LAST_MPDU_END = 273 /* 0x111 */, 349*5c1def83SBjoern A. Zeeb HAL_TX_CV_DATA = 274 /* 0x112 */, 350*5c1def83SBjoern A. Zeeb HAL_PPDU_TX_END = 275 /* 0x113 */, 351*5c1def83SBjoern A. Zeeb HAL_PROT_TX_END = 276 /* 0x114 */, 352*5c1def83SBjoern A. Zeeb HAL_MPDU_INFO_GLOBAL_END = 277 /* 0x115 */, 353*5c1def83SBjoern A. Zeeb HAL_TQM_SCH_INSTR_GLOBAL_END = 278 /* 0x116 */, 354*5c1def83SBjoern A. Zeeb HAL_RX_PPDU_END_USER_STATS = 279 /* 0x117 */, 355*5c1def83SBjoern A. Zeeb HAL_RX_PPDU_END_USER_STATS_EXT = 280 /* 0x118 */, 356*5c1def83SBjoern A. Zeeb HAL_REO_GET_QUEUE_STATS = 281 /* 0x119 */, 357*5c1def83SBjoern A. Zeeb HAL_REO_FLUSH_QUEUE = 282 /* 0x11a */, 358*5c1def83SBjoern A. Zeeb HAL_REO_FLUSH_CACHE = 283 /* 0x11b */, 359*5c1def83SBjoern A. Zeeb HAL_REO_UNBLOCK_CACHE = 284 /* 0x11c */, 360*5c1def83SBjoern A. Zeeb HAL_REO_GET_QUEUE_STATS_STATUS = 285 /* 0x11d */, 361*5c1def83SBjoern A. Zeeb HAL_REO_FLUSH_QUEUE_STATUS = 286 /* 0x11e */, 362*5c1def83SBjoern A. Zeeb HAL_REO_FLUSH_CACHE_STATUS = 287 /* 0x11f */, 363*5c1def83SBjoern A. Zeeb HAL_REO_UNBLOCK_CACHE_STATUS = 288 /* 0x120 */, 364*5c1def83SBjoern A. Zeeb HAL_TQM_FLUSH_CACHE = 289 /* 0x121 */, 365*5c1def83SBjoern A. Zeeb HAL_TQM_UNBLOCK_CACHE = 290 /* 0x122 */, 366*5c1def83SBjoern A. Zeeb HAL_TQM_FLUSH_CACHE_STATUS = 291 /* 0x123 */, 367*5c1def83SBjoern A. Zeeb HAL_TQM_UNBLOCK_CACHE_STATUS = 292 /* 0x124 */, 368*5c1def83SBjoern A. Zeeb HAL_RX_PPDU_END_STATUS_DONE = 293 /* 0x125 */, 369*5c1def83SBjoern A. Zeeb HAL_RX_STATUS_BUFFER_DONE = 294 /* 0x126 */, 370*5c1def83SBjoern A. Zeeb HAL_TX_DATA_SYNC = 297 /* 0x129 */, 371*5c1def83SBjoern A. Zeeb HAL_PHYRX_CBF_READ_REQUEST_ACK = 298 /* 0x12a */, 372*5c1def83SBjoern A. Zeeb HAL_TQM_GET_MPDU_HEAD_INFO = 299 /* 0x12b */, 373*5c1def83SBjoern A. Zeeb HAL_TQM_SYNC_CMD = 300 /* 0x12c */, 374*5c1def83SBjoern A. Zeeb HAL_TQM_GET_MPDU_HEAD_INFO_STATUS = 301 /* 0x12d */, 375*5c1def83SBjoern A. Zeeb HAL_TQM_SYNC_CMD_STATUS = 302 /* 0x12e */, 376*5c1def83SBjoern A. Zeeb HAL_TQM_THRESHOLD_DROP_NOTIFICATION_STATUS = 303 /* 0x12f */, 377*5c1def83SBjoern A. Zeeb HAL_TQM_DESCRIPTOR_THRESHOLD_REACHED_STATUS = 304 /* 0x130 */, 378*5c1def83SBjoern A. Zeeb HAL_REO_FLUSH_TIMEOUT_LIST = 305 /* 0x131 */, 379*5c1def83SBjoern A. Zeeb HAL_REO_FLUSH_TIMEOUT_LIST_STATUS = 306 /* 0x132 */, 380*5c1def83SBjoern A. Zeeb HAL_REO_DESCRIPTOR_THRESHOLD_REACHED_STATUS = 307 /* 0x133 */, 381*5c1def83SBjoern A. Zeeb HAL_SCHEDULER_RX_SIFS_RESPONSE_TRIGGER_STATUS = 308 /* 0x134 */, 382*5c1def83SBjoern A. Zeeb HALXAMPLE_USER_TLV_32_NAME = 309 /* 0x135 */, 383*5c1def83SBjoern A. Zeeb HAL_RX_PPDU_START_USER_INFO = 310 /* 0x136 */, 384*5c1def83SBjoern A. Zeeb HAL_RX_RING_MASK = 311 /* 0x137 */, 385*5c1def83SBjoern A. Zeeb HAL_COEX_MAC_NAP = 312 /* 0x138 */, 386*5c1def83SBjoern A. Zeeb HAL_RXPCU_PPDU_END_INFO = 313 /* 0x139 */, 387*5c1def83SBjoern A. Zeeb HAL_WHO_MESH_CONTROL = 314 /* 0x13a */, 388*5c1def83SBjoern A. Zeeb HAL_PDG_SW_MODE_BW_START = 315 /* 0x13b */, 389*5c1def83SBjoern A. Zeeb HAL_PDG_SW_MODE_BW_END = 316 /* 0x13c */, 390*5c1def83SBjoern A. Zeeb HAL_PDG_WAIT_FOR_MAC_REQUEST = 317 /* 0x13d */, 391*5c1def83SBjoern A. Zeeb HAL_PDG_WAIT_FOR_PHY_REQUEST = 318 /* 0x13e */, 392*5c1def83SBjoern A. Zeeb HAL_SCHEDULER_END = 319 /* 0x13f */, 393*5c1def83SBjoern A. Zeeb HAL_RX_PPDU_START_DROPPED = 320 /* 0x140 */, 394*5c1def83SBjoern A. Zeeb HAL_RX_PPDU_END_DROPPED = 321 /* 0x141 */, 395*5c1def83SBjoern A. Zeeb HAL_RX_PPDU_END_STATUS_DONE_DROPPED = 322 /* 0x142 */, 396*5c1def83SBjoern A. Zeeb HAL_RX_MPDU_START_DROPPED = 323 /* 0x143 */, 397*5c1def83SBjoern A. Zeeb HAL_RX_MSDU_START_DROPPED = 324 /* 0x144 */, 398*5c1def83SBjoern A. Zeeb HAL_RX_MSDU_END_DROPPED = 325 /* 0x145 */, 399*5c1def83SBjoern A. Zeeb HAL_RX_MPDU_END_DROPPED = 326 /* 0x146 */, 400*5c1def83SBjoern A. Zeeb HAL_RX_ATTENTION_DROPPED = 327 /* 0x147 */, 401*5c1def83SBjoern A. Zeeb HAL_TXPCU_USER_SETUP = 328 /* 0x148 */, 402*5c1def83SBjoern A. Zeeb HAL_RXPCU_USER_SETUP_EXT = 329 /* 0x149 */, 403*5c1def83SBjoern A. Zeeb HAL_CMD_PART_0_END = 330 /* 0x14a */, 404*5c1def83SBjoern A. Zeeb HAL_MACTX_SYNTH_ON = 331 /* 0x14b */, 405*5c1def83SBjoern A. Zeeb HAL_SCH_CRITICAL_TLV_REFERENCE = 332 /* 0x14c */, 406*5c1def83SBjoern A. Zeeb HAL_TQM_MPDU_GLOBAL_START = 333 /* 0x14d */, 407*5c1def83SBjoern A. Zeeb HALXAMPLE_TLV_32 = 334 /* 0x14e */, 408*5c1def83SBjoern A. Zeeb HAL_TQM_UPDATE_TX_MSDU_FLOW = 335 /* 0x14f */, 409*5c1def83SBjoern A. Zeeb HAL_TQM_UPDATE_TX_MPDU_QUEUE_HEAD = 336 /* 0x150 */, 410*5c1def83SBjoern A. Zeeb HAL_TQM_UPDATE_TX_MSDU_FLOW_STATUS = 337 /* 0x151 */, 411*5c1def83SBjoern A. Zeeb HAL_TQM_UPDATE_TX_MPDU_QUEUE_HEAD_STATUS = 338 /* 0x152 */, 412*5c1def83SBjoern A. Zeeb HAL_REO_UPDATE_RX_REO_QUEUE = 339 /* 0x153 */, 413*5c1def83SBjoern A. Zeeb HAL_TQM_MPDU_QUEUEMPTY_STATUS = 340 /* 0x154 */, 414*5c1def83SBjoern A. Zeeb HAL_TQM_2_SCH_MPDU_AVAILABLE = 341 /* 0x155 */, 415*5c1def83SBjoern A. Zeeb HAL_PDG_TRIG_RESPONSE = 342 /* 0x156 */, 416*5c1def83SBjoern A. Zeeb HAL_TRIGGER_RESPONSE_TX_DONE = 343 /* 0x157 */, 417*5c1def83SBjoern A. Zeeb HAL_ABORT_FROM_PHYRX_DETAILS = 344 /* 0x158 */, 418*5c1def83SBjoern A. Zeeb HAL_SCH_TQM_CMD_WRAPPER = 345 /* 0x159 */, 419*5c1def83SBjoern A. Zeeb HAL_MPDUS_AVAILABLE = 346 /* 0x15a */, 420*5c1def83SBjoern A. Zeeb HAL_RECEIVED_RESPONSE_INFO_PART2 = 347 /* 0x15b */, 421*5c1def83SBjoern A. Zeeb HAL_PHYRX_TX_START_TIMING = 348 /* 0x15c */, 422*5c1def83SBjoern A. Zeeb HAL_TXPCU_PREAMBLE_DONE = 349 /* 0x15d */, 423*5c1def83SBjoern A. Zeeb HAL_NDP_PREAMBLE_DONE = 350 /* 0x15e */, 424*5c1def83SBjoern A. Zeeb HAL_SCH_TQM_CMD_WRAPPER_RBO_DROP = 351 /* 0x15f */, 425*5c1def83SBjoern A. Zeeb HAL_SCH_TQM_CMD_WRAPPER_CONT_DROP = 352 /* 0x160 */, 426*5c1def83SBjoern A. Zeeb HAL_MACTX_CLEAR_PREV_TX_INFO = 353 /* 0x161 */, 427*5c1def83SBjoern A. Zeeb HAL_TX_PUNCTURE_SETUP = 354 /* 0x162 */, 428*5c1def83SBjoern A. Zeeb HAL_R2R_STATUS_END = 355 /* 0x163 */, 429*5c1def83SBjoern A. Zeeb HAL_MACTX_PREFETCH_CV_COMMON = 356 /* 0x164 */, 430*5c1def83SBjoern A. Zeeb HAL_END_OF_FLUSH_MARKER = 357 /* 0x165 */, 431*5c1def83SBjoern A. Zeeb HAL_MACTX_MU_UPLINK_COMMON_PUNC = 358 /* 0x166 */, 432*5c1def83SBjoern A. Zeeb HAL_MACTX_MU_UPLINK_USER_SETUP_PUNC = 359 /* 0x167 */, 433*5c1def83SBjoern A. Zeeb HAL_RECEIVED_RESPONSE_USER_7_0 = 360 /* 0x168 */, 434*5c1def83SBjoern A. Zeeb HAL_RECEIVED_RESPONSE_USER_15_8 = 361 /* 0x169 */, 435*5c1def83SBjoern A. Zeeb HAL_RECEIVED_RESPONSE_USER_23_16 = 362 /* 0x16a */, 436*5c1def83SBjoern A. Zeeb HAL_RECEIVED_RESPONSE_USER_31_24 = 363 /* 0x16b */, 437*5c1def83SBjoern A. Zeeb HAL_RECEIVED_RESPONSE_USER_36_32 = 364 /* 0x16c */, 438*5c1def83SBjoern A. Zeeb HAL_TX_LOOPBACK_SETUP = 365 /* 0x16d */, 439*5c1def83SBjoern A. Zeeb HAL_PHYRX_OTHER_RECEIVE_INFO_RU_DETAILS = 366 /* 0x16e */, 440*5c1def83SBjoern A. Zeeb HAL_SCH_WAIT_INSTR_TX_PATH = 367 /* 0x16f */, 441*5c1def83SBjoern A. Zeeb HAL_MACTX_OTHER_TRANSMIT_INFO_TX2TX = 368 /* 0x170 */, 442*5c1def83SBjoern A. Zeeb HAL_MACTX_OTHER_TRANSMIT_INFOMUPHY_SETUP = 369 /* 0x171 */, 443*5c1def83SBjoern A. Zeeb HAL_PHYRX_OTHER_RECEIVE_INFOVM_DETAILS = 370 /* 0x172 */, 444*5c1def83SBjoern A. Zeeb HAL_TX_WUR_DATA = 371 /* 0x173 */, 445*5c1def83SBjoern A. Zeeb HAL_RX_PPDU_END_START = 372 /* 0x174 */, 446*5c1def83SBjoern A. Zeeb HAL_RX_PPDU_END_MIDDLE = 373 /* 0x175 */, 447*5c1def83SBjoern A. Zeeb HAL_RX_PPDU_END_LAST = 374 /* 0x176 */, 448*5c1def83SBjoern A. Zeeb HAL_MACTX_BACKOFF_BASED_TRANSMISSION = 375 /* 0x177 */, 449*5c1def83SBjoern A. Zeeb HAL_MACTX_OTHER_TRANSMIT_INFO_DL_OFDMA_TX = 376 /* 0x178 */, 450*5c1def83SBjoern A. Zeeb HAL_SRP_INFO = 377 /* 0x179 */, 451*5c1def83SBjoern A. Zeeb HAL_OBSS_SR_INFO = 378 /* 0x17a */, 452*5c1def83SBjoern A. Zeeb HAL_SCHEDULER_SW_MSG_STATUS = 379 /* 0x17b */, 453*5c1def83SBjoern A. Zeeb HAL_HWSCH_RXPCU_MAC_INFO_ANNOUNCEMENT = 380 /* 0x17c */, 454*5c1def83SBjoern A. Zeeb HAL_RXPCU_SETUP_COMPLETE = 381 /* 0x17d */, 455*5c1def83SBjoern A. Zeeb HAL_SNOOP_PPDU_START = 382 /* 0x17e */, 456*5c1def83SBjoern A. Zeeb HAL_SNOOP_MPDU_USR_DBG_INFO = 383 /* 0x17f */, 457*5c1def83SBjoern A. Zeeb HAL_SNOOP_MSDU_USR_DBG_INFO = 384 /* 0x180 */, 458*5c1def83SBjoern A. Zeeb HAL_SNOOP_MSDU_USR_DATA = 385 /* 0x181 */, 459*5c1def83SBjoern A. Zeeb HAL_SNOOP_MPDU_USR_STAT_INFO = 386 /* 0x182 */, 460*5c1def83SBjoern A. Zeeb HAL_SNOOP_PPDU_END = 387 /* 0x183 */, 461*5c1def83SBjoern A. Zeeb HAL_SNOOP_SPARE = 388 /* 0x184 */, 462*5c1def83SBjoern A. Zeeb HAL_PHYRX_OTHER_RECEIVE_INFO_MU_RSSI_COMMON = 390 /* 0x186 */, 463*5c1def83SBjoern A. Zeeb HAL_PHYRX_OTHER_RECEIVE_INFO_MU_RSSI_USER = 391 /* 0x187 */, 464*5c1def83SBjoern A. Zeeb HAL_MACTX_OTHER_TRANSMIT_INFO_SCH_DETAILS = 392 /* 0x188 */, 465*5c1def83SBjoern A. Zeeb HAL_PHYRX_OTHER_RECEIVE_INFO_108PVM_DETAILS = 393 /* 0x189 */, 466*5c1def83SBjoern A. Zeeb HAL_SCH_TLV_WRAPPER = 394 /* 0x18a */, 467*5c1def83SBjoern A. Zeeb HAL_SCHEDULER_STATUS_WRAPPER = 395 /* 0x18b */, 468*5c1def83SBjoern A. Zeeb HAL_MPDU_INFO_6X = 396 /* 0x18c */, 469*5c1def83SBjoern A. Zeeb HAL_MACTX_11AZ_USER_DESC_PER_USER = 397 /* 0x18d */, 470*5c1def83SBjoern A. Zeeb HAL_MACTX_U_SIGHT_SU_MU = 398 /* 0x18e */, 471*5c1def83SBjoern A. Zeeb HAL_MACTX_U_SIGHT_TB = 399 /* 0x18f */, 472*5c1def83SBjoern A. Zeeb HAL_PHYRX_U_SIGHT_SU_MU = 403 /* 0x193 */, 473*5c1def83SBjoern A. Zeeb HAL_PHYRX_U_SIGHT_TB = 404 /* 0x194 */, 474*5c1def83SBjoern A. Zeeb HAL_MACRX_LMR_READ_REQUEST = 408 /* 0x198 */, 475*5c1def83SBjoern A. Zeeb HAL_MACRX_LMR_DATA_REQUEST = 409 /* 0x199 */, 476*5c1def83SBjoern A. Zeeb HAL_PHYRX_LMR_TRANSFER_DONE = 410 /* 0x19a */, 477*5c1def83SBjoern A. Zeeb HAL_PHYRX_LMR_TRANSFER_ABORT = 411 /* 0x19b */, 478*5c1def83SBjoern A. Zeeb HAL_PHYRX_LMR_READ_REQUEST_ACK = 412 /* 0x19c */, 479*5c1def83SBjoern A. Zeeb HAL_MACRX_SECURE_LTF_SEQ_PTR = 413 /* 0x19d */, 480*5c1def83SBjoern A. Zeeb HAL_PHYRX_USER_INFO_MU_UL = 414 /* 0x19e */, 481*5c1def83SBjoern A. Zeeb HAL_MPDU_QUEUE_OVERVIEW = 415 /* 0x19f */, 482*5c1def83SBjoern A. Zeeb HAL_SCHEDULER_NAV_INFO = 416 /* 0x1a0 */, 483*5c1def83SBjoern A. Zeeb HAL_LMR_PEER_ENTRY = 418 /* 0x1a2 */, 484*5c1def83SBjoern A. Zeeb HAL_LMR_MPDU_START = 419 /* 0x1a3 */, 485*5c1def83SBjoern A. Zeeb HAL_LMR_DATA = 420 /* 0x1a4 */, 486*5c1def83SBjoern A. Zeeb HAL_LMR_MPDU_END = 421 /* 0x1a5 */, 487*5c1def83SBjoern A. Zeeb HAL_REO_GET_QUEUE_1K_STATS_STATUS = 422 /* 0x1a6 */, 488*5c1def83SBjoern A. Zeeb HAL_RX_FRAME_1K_BITMAP_ACK = 423 /* 0x1a7 */, 489*5c1def83SBjoern A. Zeeb HAL_TX_FES_STATUS_1K_BA = 424 /* 0x1a8 */, 490*5c1def83SBjoern A. Zeeb HAL_TQM_ACKED_1K_MPDU = 425 /* 0x1a9 */, 491*5c1def83SBjoern A. Zeeb HAL_MACRX_INBSS_OBSS_IND = 426 /* 0x1aa */, 492*5c1def83SBjoern A. Zeeb HAL_PHYRX_LOCATION = 427 /* 0x1ab */, 493*5c1def83SBjoern A. Zeeb HAL_MLO_TX_NOTIFICATION_SU = 428 /* 0x1ac */, 494*5c1def83SBjoern A. Zeeb HAL_MLO_TX_NOTIFICATION_MU = 429 /* 0x1ad */, 495*5c1def83SBjoern A. Zeeb HAL_MLO_TX_REQ_SU = 430 /* 0x1ae */, 496*5c1def83SBjoern A. Zeeb HAL_MLO_TX_REQ_MU = 431 /* 0x1af */, 497*5c1def83SBjoern A. Zeeb HAL_MLO_TX_RESP = 432 /* 0x1b0 */, 498*5c1def83SBjoern A. Zeeb HAL_MLO_RX_NOTIFICATION = 433 /* 0x1b1 */, 499*5c1def83SBjoern A. Zeeb HAL_MLO_BKOFF_TRUNC_REQ = 434 /* 0x1b2 */, 500*5c1def83SBjoern A. Zeeb HAL_MLO_TBTT_NOTIFICATION = 435 /* 0x1b3 */, 501*5c1def83SBjoern A. Zeeb HAL_MLO_MESSAGE = 436 /* 0x1b4 */, 502*5c1def83SBjoern A. Zeeb HAL_MLO_TS_SYNC_MSG = 437 /* 0x1b5 */, 503*5c1def83SBjoern A. Zeeb HAL_MLO_FES_SETUP = 438 /* 0x1b6 */, 504*5c1def83SBjoern A. Zeeb HAL_MLO_PDG_FES_SETUP_SU = 439 /* 0x1b7 */, 505*5c1def83SBjoern A. Zeeb HAL_MLO_PDG_FES_SETUP_MU = 440 /* 0x1b8 */, 506*5c1def83SBjoern A. Zeeb HAL_MPDU_INFO_1K_BITMAP = 441 /* 0x1b9 */, 507*5c1def83SBjoern A. Zeeb HAL_MON_BUF_ADDR = 442 /* 0x1ba */, 508*5c1def83SBjoern A. Zeeb HAL_TX_FRAG_STATE = 443 /* 0x1bb */, 509*5c1def83SBjoern A. Zeeb HAL_MACTXHT_SIG_USR_OFDMA = 446 /* 0x1be */, 510*5c1def83SBjoern A. Zeeb HAL_PHYRXHT_SIG_CMN_PUNC = 448 /* 0x1c0 */, 511*5c1def83SBjoern A. Zeeb HAL_PHYRXHT_SIG_CMN_OFDMA = 450 /* 0x1c2 */, 512*5c1def83SBjoern A. Zeeb HAL_PHYRXHT_SIG_USR_OFDMA = 454 /* 0x1c6 */, 513*5c1def83SBjoern A. Zeeb HAL_PHYRX_PKT_END_PART1 = 456 /* 0x1c8 */, 514*5c1def83SBjoern A. Zeeb HAL_MACTXXPECT_NDP_RECEPTION = 457 /* 0x1c9 */, 515*5c1def83SBjoern A. Zeeb HAL_MACTX_SECURE_LTF_SEQ_PTR = 458 /* 0x1ca */, 516*5c1def83SBjoern A. Zeeb HAL_MLO_PDG_BKOFF_TRUNC_NOTIFY = 460 /* 0x1cc */, 517*5c1def83SBjoern A. Zeeb HAL_PHYRX_11AZ_INTEGRITY_DATA = 461 /* 0x1cd */, 518*5c1def83SBjoern A. Zeeb HAL_PHYTX_LOCATION = 462 /* 0x1ce */, 519*5c1def83SBjoern A. Zeeb HAL_PHYTX_11AZ_INTEGRITY_DATA = 463 /* 0x1cf */, 520*5c1def83SBjoern A. Zeeb HAL_MACTXHT_SIG_USR_SU = 466 /* 0x1d2 */, 521*5c1def83SBjoern A. Zeeb HAL_MACTXHT_SIG_USR_MU_MIMO = 467 /* 0x1d3 */, 522*5c1def83SBjoern A. Zeeb HAL_PHYRXHT_SIG_USR_SU = 468 /* 0x1d4 */, 523*5c1def83SBjoern A. Zeeb HAL_PHYRXHT_SIG_USR_MU_MIMO = 469 /* 0x1d5 */, 524*5c1def83SBjoern A. Zeeb HAL_PHYRX_GENERIC_U_SIG = 470 /* 0x1d6 */, 525*5c1def83SBjoern A. Zeeb HAL_PHYRX_GENERICHT_SIG = 471 /* 0x1d7 */, 526*5c1def83SBjoern A. Zeeb HAL_OVERWRITE_RESP_START = 472 /* 0x1d8 */, 527*5c1def83SBjoern A. Zeeb HAL_OVERWRITE_RESP_PREAMBLE_INFO = 473 /* 0x1d9 */, 528*5c1def83SBjoern A. Zeeb HAL_OVERWRITE_RESP_FRAME_INFO = 474 /* 0x1da */, 529*5c1def83SBjoern A. Zeeb HAL_OVERWRITE_RESP_END = 475 /* 0x1db */, 530*5c1def83SBjoern A. Zeeb HAL_RXPCUARLY_RX_INDICATION = 476 /* 0x1dc */, 531*5c1def83SBjoern A. Zeeb HAL_MON_DROP = 477 /* 0x1dd */, 532*5c1def83SBjoern A. Zeeb HAL_MACRX_MU_UPLINK_COMMON_SNIFF = 478 /* 0x1de */, 533*5c1def83SBjoern A. Zeeb HAL_MACRX_MU_UPLINK_USER_SETUP_SNIFF = 479 /* 0x1df */, 534*5c1def83SBjoern A. Zeeb HAL_MACRX_MU_UPLINK_USER_SEL_SNIFF = 480 /* 0x1e0 */, 535*5c1def83SBjoern A. Zeeb HAL_MACRX_MU_UPLINK_FCS_STATUS_SNIFF = 481 /* 0x1e1 */, 536*5c1def83SBjoern A. Zeeb HAL_MACTX_PREFETCH_CV_DMA = 482 /* 0x1e2 */, 537*5c1def83SBjoern A. Zeeb HAL_MACTX_PREFETCH_CV_PER_USER = 483 /* 0x1e3 */, 538*5c1def83SBjoern A. Zeeb HAL_PHYRX_OTHER_RECEIVE_INFO_ALL_SIGB_DETAILS = 484 /* 0x1e4 */, 539*5c1def83SBjoern A. Zeeb HAL_MACTX_BF_PARAMS_UPDATE_COMMON = 485 /* 0x1e5 */, 540*5c1def83SBjoern A. Zeeb HAL_MACTX_BF_PARAMS_UPDATE_PER_USER = 486 /* 0x1e6 */, 541*5c1def83SBjoern A. Zeeb HAL_RANGING_USER_DETAILS = 487 /* 0x1e7 */, 542*5c1def83SBjoern A. Zeeb HAL_PHYTX_CV_CORR_STATUS = 488 /* 0x1e8 */, 543*5c1def83SBjoern A. Zeeb HAL_PHYTX_CV_CORR_COMMON = 489 /* 0x1e9 */, 544*5c1def83SBjoern A. Zeeb HAL_PHYTX_CV_CORR_USER = 490 /* 0x1ea */, 545*5c1def83SBjoern A. Zeeb HAL_MACTX_CV_CORR_COMMON = 491 /* 0x1eb */, 546*5c1def83SBjoern A. Zeeb HAL_MACTX_CV_CORR_MAC_INFO_GROUP = 492 /* 0x1ec */, 547*5c1def83SBjoern A. Zeeb HAL_BW_PUNCTUREVAL_WRAPPER = 493 /* 0x1ed */, 548*5c1def83SBjoern A. Zeeb HAL_MACTX_RX_NOTIFICATION_FOR_PHY = 494 /* 0x1ee */, 549*5c1def83SBjoern A. Zeeb HAL_MACTX_TX_NOTIFICATION_FOR_PHY = 495 /* 0x1ef */, 550*5c1def83SBjoern A. Zeeb HAL_MACTX_MU_UPLINK_COMMON_PER_BW = 496 /* 0x1f0 */, 551*5c1def83SBjoern A. Zeeb HAL_MACTX_MU_UPLINK_USER_SETUP_PER_BW = 497 /* 0x1f1 */, 552*5c1def83SBjoern A. Zeeb HAL_RX_PPDU_END_USER_STATS_EXT2 = 498 /* 0x1f2 */, 553*5c1def83SBjoern A. Zeeb HAL_FW2SW_MON = 499 /* 0x1f3 */, 554*5c1def83SBjoern A. Zeeb HAL_WSI_DIRECT_MESSAGE = 500 /* 0x1f4 */, 555*5c1def83SBjoern A. Zeeb HAL_MACTXMLSR_PRE_SWITCH = 501 /* 0x1f5 */, 556*5c1def83SBjoern A. Zeeb HAL_MACTXMLSR_SWITCH = 502 /* 0x1f6 */, 557*5c1def83SBjoern A. Zeeb HAL_MACTXMLSR_SWITCH_BACK = 503 /* 0x1f7 */, 558*5c1def83SBjoern A. Zeeb HAL_PHYTXMLSR_SWITCH_ACK = 504 /* 0x1f8 */, 559*5c1def83SBjoern A. Zeeb HAL_PHYTXMLSR_SWITCH_BACK_ACK = 505 /* 0x1f9 */, 560*5c1def83SBjoern A. Zeeb HAL_SPARE_REUSE_TAG_0 = 506 /* 0x1fa */, 561*5c1def83SBjoern A. Zeeb HAL_SPARE_REUSE_TAG_1 = 507 /* 0x1fb */, 562*5c1def83SBjoern A. Zeeb HAL_SPARE_REUSE_TAG_2 = 508 /* 0x1fc */, 563*5c1def83SBjoern A. Zeeb HAL_SPARE_REUSE_TAG_3 = 509 /* 0x1fd */, 564*5c1def83SBjoern A. Zeeb /* FIXME: Assign correct value for HAL_TCL_DATA_CMD */ 565*5c1def83SBjoern A. Zeeb HAL_TCL_DATA_CMD = 510, 566*5c1def83SBjoern A. Zeeb HAL_TLV_BASE = 511 /* 0x1ff */, 567*5c1def83SBjoern A. Zeeb }; 568*5c1def83SBjoern A. Zeeb 569*5c1def83SBjoern A. Zeeb #define HAL_TLV_HDR_TAG GENMASK(9, 1) 570*5c1def83SBjoern A. Zeeb #define HAL_TLV_HDR_LEN GENMASK(25, 10) 571*5c1def83SBjoern A. Zeeb #define HAL_TLV_USR_ID GENMASK(31, 26) 572*5c1def83SBjoern A. Zeeb 573*5c1def83SBjoern A. Zeeb #define HAL_TLV_ALIGN 4 574*5c1def83SBjoern A. Zeeb 575*5c1def83SBjoern A. Zeeb struct hal_tlv_hdr { 576*5c1def83SBjoern A. Zeeb __le32 tl; 577*5c1def83SBjoern A. Zeeb u8 value[]; 578*5c1def83SBjoern A. Zeeb } __packed; 579*5c1def83SBjoern A. Zeeb 580*5c1def83SBjoern A. Zeeb #define HAL_TLV_64_HDR_TAG GENMASK(9, 1) 581*5c1def83SBjoern A. Zeeb #define HAL_TLV_64_HDR_LEN GENMASK(21, 10) 582*5c1def83SBjoern A. Zeeb 583*5c1def83SBjoern A. Zeeb struct hal_tlv_64_hdr { 584*5c1def83SBjoern A. Zeeb u64 tl; 585*5c1def83SBjoern A. Zeeb u8 value[]; 586*5c1def83SBjoern A. Zeeb } __packed; 587*5c1def83SBjoern A. Zeeb 588*5c1def83SBjoern A. Zeeb #define RX_MPDU_DESC_INFO0_MSDU_COUNT GENMASK(7, 0) 589*5c1def83SBjoern A. Zeeb #define RX_MPDU_DESC_INFO0_FRAG_FLAG BIT(8) 590*5c1def83SBjoern A. Zeeb #define RX_MPDU_DESC_INFO0_MPDU_RETRY BIT(9) 591*5c1def83SBjoern A. Zeeb #define RX_MPDU_DESC_INFO0_AMPDU_FLAG BIT(10) 592*5c1def83SBjoern A. Zeeb #define RX_MPDU_DESC_INFO0_BAR_FRAME BIT(11) 593*5c1def83SBjoern A. Zeeb #define RX_MPDU_DESC_INFO0_VALID_PN BIT(12) 594*5c1def83SBjoern A. Zeeb #define RX_MPDU_DESC_INFO0_RAW_MPDU BIT(13) 595*5c1def83SBjoern A. Zeeb #define RX_MPDU_DESC_INFO0_MORE_FRAG_FLAG BIT(14) 596*5c1def83SBjoern A. Zeeb #define RX_MPDU_DESC_INFO0_SRC_INFO GENMASK(26, 15) 597*5c1def83SBjoern A. Zeeb #define RX_MPDU_DESC_INFO0_MPDU_QOS_CTRL_VALID BIT(27) 598*5c1def83SBjoern A. Zeeb #define RX_MPDU_DESC_INFO0_TID GENMASK(31, 28) 599*5c1def83SBjoern A. Zeeb 600*5c1def83SBjoern A. Zeeb /* TODO revisit after meta data is concluded */ 601*5c1def83SBjoern A. Zeeb #define RX_MPDU_DESC_META_DATA_PEER_ID GENMASK(15, 0) 602*5c1def83SBjoern A. Zeeb 603*5c1def83SBjoern A. Zeeb struct rx_mpdu_desc { 604*5c1def83SBjoern A. Zeeb __le32 info0; /* %RX_MPDU_DESC_INFO */ 605*5c1def83SBjoern A. Zeeb __le32 peer_meta_data; 606*5c1def83SBjoern A. Zeeb } __packed; 607*5c1def83SBjoern A. Zeeb 608*5c1def83SBjoern A. Zeeb /* rx_mpdu_desc 609*5c1def83SBjoern A. Zeeb * Producer: RXDMA 610*5c1def83SBjoern A. Zeeb * Consumer: REO/SW/FW 611*5c1def83SBjoern A. Zeeb * 612*5c1def83SBjoern A. Zeeb * msdu_count 613*5c1def83SBjoern A. Zeeb * The number of MSDUs within the MPDU 614*5c1def83SBjoern A. Zeeb * 615*5c1def83SBjoern A. Zeeb * fragment_flag 616*5c1def83SBjoern A. Zeeb * When set, this MPDU is a fragment and REO should forward this 617*5c1def83SBjoern A. Zeeb * fragment MPDU to the REO destination ring without any reorder 618*5c1def83SBjoern A. Zeeb * checks, pn checks or bitmap update. This implies that REO is 619*5c1def83SBjoern A. Zeeb * forwarding the pointer to the MSDU link descriptor. 620*5c1def83SBjoern A. Zeeb * 621*5c1def83SBjoern A. Zeeb * mpdu_retry_bit 622*5c1def83SBjoern A. Zeeb * The retry bit setting from the MPDU header of the received frame 623*5c1def83SBjoern A. Zeeb * 624*5c1def83SBjoern A. Zeeb * ampdu_flag 625*5c1def83SBjoern A. Zeeb * Indicates the MPDU was received as part of an A-MPDU. 626*5c1def83SBjoern A. Zeeb * 627*5c1def83SBjoern A. Zeeb * bar_frame 628*5c1def83SBjoern A. Zeeb * Indicates the received frame is a BAR frame. After processing, 629*5c1def83SBjoern A. Zeeb * this frame shall be pushed to SW or deleted. 630*5c1def83SBjoern A. Zeeb * 631*5c1def83SBjoern A. Zeeb * valid_pn 632*5c1def83SBjoern A. Zeeb * When not set, REO will not perform a PN sequence number check. 633*5c1def83SBjoern A. Zeeb * 634*5c1def83SBjoern A. Zeeb * raw_mpdu 635*5c1def83SBjoern A. Zeeb * Field only valid when first_msdu_in_mpdu_flag is set. Indicates 636*5c1def83SBjoern A. Zeeb * the contents in the MSDU buffer contains a 'RAW' MPDU. This 637*5c1def83SBjoern A. Zeeb * 'RAW' MPDU might be spread out over multiple MSDU buffers. 638*5c1def83SBjoern A. Zeeb * 639*5c1def83SBjoern A. Zeeb * more_fragment_flag 640*5c1def83SBjoern A. Zeeb * The More Fragment bit setting from the MPDU header of the 641*5c1def83SBjoern A. Zeeb * received frame 642*5c1def83SBjoern A. Zeeb * 643*5c1def83SBjoern A. Zeeb * src_info 644*5c1def83SBjoern A. Zeeb * Source (Virtual) device/interface info associated with this peer. 645*5c1def83SBjoern A. Zeeb * This field gets passed on by REO to PPE in the EDMA descriptor. 646*5c1def83SBjoern A. Zeeb * 647*5c1def83SBjoern A. Zeeb * mpdu_qos_control_valid 648*5c1def83SBjoern A. Zeeb * When set, the MPDU has a QoS control field 649*5c1def83SBjoern A. Zeeb * 650*5c1def83SBjoern A. Zeeb * tid 651*5c1def83SBjoern A. Zeeb * Field only valid when mpdu_qos_control_valid is set 652*5c1def83SBjoern A. Zeeb */ 653*5c1def83SBjoern A. Zeeb 654*5c1def83SBjoern A. Zeeb enum hal_rx_msdu_desc_reo_dest_ind { 655*5c1def83SBjoern A. Zeeb HAL_RX_MSDU_DESC_REO_DEST_IND_TCL, 656*5c1def83SBjoern A. Zeeb HAL_RX_MSDU_DESC_REO_DEST_IND_SW1, 657*5c1def83SBjoern A. Zeeb HAL_RX_MSDU_DESC_REO_DEST_IND_SW2, 658*5c1def83SBjoern A. Zeeb HAL_RX_MSDU_DESC_REO_DEST_IND_SW3, 659*5c1def83SBjoern A. Zeeb HAL_RX_MSDU_DESC_REO_DEST_IND_SW4, 660*5c1def83SBjoern A. Zeeb HAL_RX_MSDU_DESC_REO_DEST_IND_RELEASE, 661*5c1def83SBjoern A. Zeeb HAL_RX_MSDU_DESC_REO_DEST_IND_FW, 662*5c1def83SBjoern A. Zeeb HAL_RX_MSDU_DESC_REO_DEST_IND_SW5, 663*5c1def83SBjoern A. Zeeb HAL_RX_MSDU_DESC_REO_DEST_IND_SW6, 664*5c1def83SBjoern A. Zeeb HAL_RX_MSDU_DESC_REO_DEST_IND_SW7, 665*5c1def83SBjoern A. Zeeb HAL_RX_MSDU_DESC_REO_DEST_IND_SW8, 666*5c1def83SBjoern A. Zeeb }; 667*5c1def83SBjoern A. Zeeb 668*5c1def83SBjoern A. Zeeb #define RX_MSDU_DESC_INFO0_FIRST_MSDU_IN_MPDU BIT(0) 669*5c1def83SBjoern A. Zeeb #define RX_MSDU_DESC_INFO0_LAST_MSDU_IN_MPDU BIT(1) 670*5c1def83SBjoern A. Zeeb #define RX_MSDU_DESC_INFO0_MSDU_CONTINUATION BIT(2) 671*5c1def83SBjoern A. Zeeb #define RX_MSDU_DESC_INFO0_MSDU_LENGTH GENMASK(16, 3) 672*5c1def83SBjoern A. Zeeb #define RX_MSDU_DESC_INFO0_MSDU_DROP BIT(17) 673*5c1def83SBjoern A. Zeeb #define RX_MSDU_DESC_INFO0_VALID_SA BIT(18) 674*5c1def83SBjoern A. Zeeb #define RX_MSDU_DESC_INFO0_VALID_DA BIT(19) 675*5c1def83SBjoern A. Zeeb #define RX_MSDU_DESC_INFO0_DA_MCBC BIT(20) 676*5c1def83SBjoern A. Zeeb #define RX_MSDU_DESC_INFO0_L3_HDR_PAD_MSB BIT(21) 677*5c1def83SBjoern A. Zeeb #define RX_MSDU_DESC_INFO0_TCP_UDP_CHKSUM_FAIL BIT(22) 678*5c1def83SBjoern A. Zeeb #define RX_MSDU_DESC_INFO0_IP_CHKSUM_FAIL BIT(23) 679*5c1def83SBjoern A. Zeeb #define RX_MSDU_DESC_INFO0_FROM_DS BIT(24) 680*5c1def83SBjoern A. Zeeb #define RX_MSDU_DESC_INFO0_TO_DS BIT(25) 681*5c1def83SBjoern A. Zeeb #define RX_MSDU_DESC_INFO0_INTRA_BSS BIT(26) 682*5c1def83SBjoern A. Zeeb #define RX_MSDU_DESC_INFO0_DST_CHIP_ID GENMASK(28, 27) 683*5c1def83SBjoern A. Zeeb #define RX_MSDU_DESC_INFO0_DECAP_FORMAT GENMASK(30, 29) 684*5c1def83SBjoern A. Zeeb 685*5c1def83SBjoern A. Zeeb #define HAL_RX_MSDU_PKT_LENGTH_GET(val) \ 686*5c1def83SBjoern A. Zeeb (u32_get_bits((val), RX_MSDU_DESC_INFO0_MSDU_LENGTH)) 687*5c1def83SBjoern A. Zeeb 688*5c1def83SBjoern A. Zeeb struct rx_msdu_desc { 689*5c1def83SBjoern A. Zeeb __le32 info0; 690*5c1def83SBjoern A. Zeeb } __packed; 691*5c1def83SBjoern A. Zeeb 692*5c1def83SBjoern A. Zeeb /* rx_msdu_desc 693*5c1def83SBjoern A. Zeeb * 694*5c1def83SBjoern A. Zeeb * first_msdu_in_mpdu 695*5c1def83SBjoern A. Zeeb * Indicates first msdu in mpdu. 696*5c1def83SBjoern A. Zeeb * 697*5c1def83SBjoern A. Zeeb * last_msdu_in_mpdu 698*5c1def83SBjoern A. Zeeb * Indicates last msdu in mpdu. This flag can be true only when 699*5c1def83SBjoern A. Zeeb * 'Msdu_continuation' set to 0. This implies that when an msdu 700*5c1def83SBjoern A. Zeeb * is spread out over multiple buffers and thus msdu_continuation 701*5c1def83SBjoern A. Zeeb * is set, only for the very last buffer of the msdu, can the 702*5c1def83SBjoern A. Zeeb * 'last_msdu_in_mpdu' be set. 703*5c1def83SBjoern A. Zeeb * 704*5c1def83SBjoern A. Zeeb * When both first_msdu_in_mpdu and last_msdu_in_mpdu are set, 705*5c1def83SBjoern A. Zeeb * the MPDU that this MSDU belongs to only contains a single MSDU. 706*5c1def83SBjoern A. Zeeb * 707*5c1def83SBjoern A. Zeeb * msdu_continuation 708*5c1def83SBjoern A. Zeeb * When set, this MSDU buffer was not able to hold the entire MSDU. 709*5c1def83SBjoern A. Zeeb * The next buffer will therefore contain additional information 710*5c1def83SBjoern A. Zeeb * related to this MSDU. 711*5c1def83SBjoern A. Zeeb * 712*5c1def83SBjoern A. Zeeb * msdu_length 713*5c1def83SBjoern A. Zeeb * Field is only valid in combination with the 'first_msdu_in_mpdu' 714*5c1def83SBjoern A. Zeeb * being set. Full MSDU length in bytes after decapsulation. This 715*5c1def83SBjoern A. Zeeb * field is still valid for MPDU frames without A-MSDU. It still 716*5c1def83SBjoern A. Zeeb * represents MSDU length after decapsulation Or in case of RAW 717*5c1def83SBjoern A. Zeeb * MPDUs, it indicates the length of the entire MPDU (without FCS 718*5c1def83SBjoern A. Zeeb * field). 719*5c1def83SBjoern A. Zeeb * 720*5c1def83SBjoern A. Zeeb * msdu_drop 721*5c1def83SBjoern A. Zeeb * Indicates that REO shall drop this MSDU and not forward it to 722*5c1def83SBjoern A. Zeeb * any other ring. 723*5c1def83SBjoern A. Zeeb * 724*5c1def83SBjoern A. Zeeb * valid_sa 725*5c1def83SBjoern A. Zeeb * Indicates OLE found a valid SA entry for this MSDU. 726*5c1def83SBjoern A. Zeeb * 727*5c1def83SBjoern A. Zeeb * valid_da 728*5c1def83SBjoern A. Zeeb * When set, OLE found a valid DA entry for this MSDU. 729*5c1def83SBjoern A. Zeeb * 730*5c1def83SBjoern A. Zeeb * da_mcbc 731*5c1def83SBjoern A. Zeeb * Field Only valid if valid_da is set. Indicates the DA address 732*5c1def83SBjoern A. Zeeb * is a Multicast or Broadcast address for this MSDU. 733*5c1def83SBjoern A. Zeeb * 734*5c1def83SBjoern A. Zeeb * l3_header_padding_msb 735*5c1def83SBjoern A. Zeeb * Passed on from 'RX_MSDU_END' TLV (only the MSB is reported as 736*5c1def83SBjoern A. Zeeb * the LSB is always zero). Number of bytes padded to make sure 737*5c1def83SBjoern A. Zeeb * that the L3 header will always start of a Dword boundary 738*5c1def83SBjoern A. Zeeb * 739*5c1def83SBjoern A. Zeeb * tcp_udp_checksum_fail 740*5c1def83SBjoern A. Zeeb * Passed on from 'RX_ATTENTION' TLV 741*5c1def83SBjoern A. Zeeb * Indicates that the computed checksum did not match the checksum 742*5c1def83SBjoern A. Zeeb * in the TCP/UDP header. 743*5c1def83SBjoern A. Zeeb * 744*5c1def83SBjoern A. Zeeb * ip_checksum_fail 745*5c1def83SBjoern A. Zeeb * Passed on from 'RX_ATTENTION' TLV 746*5c1def83SBjoern A. Zeeb * Indicates that the computed checksum did not match the checksum 747*5c1def83SBjoern A. Zeeb * in the IP header. 748*5c1def83SBjoern A. Zeeb * 749*5c1def83SBjoern A. Zeeb * from_DS 750*5c1def83SBjoern A. Zeeb * Set if the 'from DS' bit is set in the frame control. 751*5c1def83SBjoern A. Zeeb * 752*5c1def83SBjoern A. Zeeb * to_DS 753*5c1def83SBjoern A. Zeeb * Set if the 'to DS' bit is set in the frame control. 754*5c1def83SBjoern A. Zeeb * 755*5c1def83SBjoern A. Zeeb * intra_bss 756*5c1def83SBjoern A. Zeeb * This packet needs intra-BSS routing by SW as the 'vdev_id' 757*5c1def83SBjoern A. Zeeb * for the destination is the same as the 'vdev_id' that this 758*5c1def83SBjoern A. Zeeb * MSDU was got in. 759*5c1def83SBjoern A. Zeeb * 760*5c1def83SBjoern A. Zeeb * dest_chip_id 761*5c1def83SBjoern A. Zeeb * If intra_bss is set, copied by RXOLE/RXDMA from 'ADDR_SEARCH_ENTRY' 762*5c1def83SBjoern A. Zeeb * to support intra-BSS routing with multi-chip multi-link operation. 763*5c1def83SBjoern A. Zeeb * This indicates into which chip's TCL the packet should be queued. 764*5c1def83SBjoern A. Zeeb * 765*5c1def83SBjoern A. Zeeb * decap_format 766*5c1def83SBjoern A. Zeeb * Indicates the format after decapsulation: 767*5c1def83SBjoern A. Zeeb */ 768*5c1def83SBjoern A. Zeeb 769*5c1def83SBjoern A. Zeeb #define RX_MSDU_EXT_DESC_INFO0_REO_DEST_IND GENMASK(4, 0) 770*5c1def83SBjoern A. Zeeb #define RX_MSDU_EXT_DESC_INFO0_SERVICE_CODE GENMASK(13, 5) 771*5c1def83SBjoern A. Zeeb #define RX_MSDU_EXT_DESC_INFO0_PRIORITY_VALID BIT(14) 772*5c1def83SBjoern A. Zeeb #define RX_MSDU_EXT_DESC_INFO0_DATA_OFFSET GENMASK(26, 15) 773*5c1def83SBjoern A. Zeeb #define RX_MSDU_EXT_DESC_INFO0_SRC_LINK_ID GENMASK(29, 27) 774*5c1def83SBjoern A. Zeeb 775*5c1def83SBjoern A. Zeeb struct rx_msdu_ext_desc { 776*5c1def83SBjoern A. Zeeb __le32 info0; 777*5c1def83SBjoern A. Zeeb } __packed; 778*5c1def83SBjoern A. Zeeb 779*5c1def83SBjoern A. Zeeb /* rx_msdu_ext_desc 780*5c1def83SBjoern A. Zeeb * 781*5c1def83SBjoern A. Zeeb * reo_destination_indication 782*5c1def83SBjoern A. Zeeb * The ID of the REO exit ring where the MSDU frame shall push 783*5c1def83SBjoern A. Zeeb * after (MPDU level) reordering has finished. 784*5c1def83SBjoern A. Zeeb * 785*5c1def83SBjoern A. Zeeb * service_code 786*5c1def83SBjoern A. Zeeb * Opaque service code between PPE and Wi-Fi 787*5c1def83SBjoern A. Zeeb * 788*5c1def83SBjoern A. Zeeb * priority_valid 789*5c1def83SBjoern A. Zeeb * 790*5c1def83SBjoern A. Zeeb * data_offset 791*5c1def83SBjoern A. Zeeb * The offset to Rx packet data within the buffer (including 792*5c1def83SBjoern A. Zeeb * Rx DMA offset programming and L3 header padding inserted 793*5c1def83SBjoern A. Zeeb * by Rx OLE). 794*5c1def83SBjoern A. Zeeb * 795*5c1def83SBjoern A. Zeeb * src_link_id 796*5c1def83SBjoern A. Zeeb * Set to the link ID of the PMAC that received the frame 797*5c1def83SBjoern A. Zeeb */ 798*5c1def83SBjoern A. Zeeb 799*5c1def83SBjoern A. Zeeb enum hal_reo_dest_ring_buffer_type { 800*5c1def83SBjoern A. Zeeb HAL_REO_DEST_RING_BUFFER_TYPE_MSDU, 801*5c1def83SBjoern A. Zeeb HAL_REO_DEST_RING_BUFFER_TYPE_LINK_DESC, 802*5c1def83SBjoern A. Zeeb }; 803*5c1def83SBjoern A. Zeeb 804*5c1def83SBjoern A. Zeeb enum hal_reo_dest_ring_push_reason { 805*5c1def83SBjoern A. Zeeb HAL_REO_DEST_RING_PUSH_REASON_ERR_DETECTED, 806*5c1def83SBjoern A. Zeeb HAL_REO_DEST_RING_PUSH_REASON_ROUTING_INSTRUCTION, 807*5c1def83SBjoern A. Zeeb }; 808*5c1def83SBjoern A. Zeeb 809*5c1def83SBjoern A. Zeeb enum hal_reo_dest_ring_error_code { 810*5c1def83SBjoern A. Zeeb HAL_REO_DEST_RING_ERROR_CODE_DESC_ADDR_ZERO, 811*5c1def83SBjoern A. Zeeb HAL_REO_DEST_RING_ERROR_CODE_DESC_INVALID, 812*5c1def83SBjoern A. Zeeb HAL_REO_DEST_RING_ERROR_CODE_AMPDU_IN_NON_BA, 813*5c1def83SBjoern A. Zeeb HAL_REO_DEST_RING_ERROR_CODE_NON_BA_DUPLICATE, 814*5c1def83SBjoern A. Zeeb HAL_REO_DEST_RING_ERROR_CODE_BA_DUPLICATE, 815*5c1def83SBjoern A. Zeeb HAL_REO_DEST_RING_ERROR_CODE_FRAME_2K_JUMP, 816*5c1def83SBjoern A. Zeeb HAL_REO_DEST_RING_ERROR_CODE_BAR_2K_JUMP, 817*5c1def83SBjoern A. Zeeb HAL_REO_DEST_RING_ERROR_CODE_FRAME_OOR, 818*5c1def83SBjoern A. Zeeb HAL_REO_DEST_RING_ERROR_CODE_BAR_OOR, 819*5c1def83SBjoern A. Zeeb HAL_REO_DEST_RING_ERROR_CODE_NO_BA_SESSION, 820*5c1def83SBjoern A. Zeeb HAL_REO_DEST_RING_ERROR_CODE_FRAME_SN_EQUALS_SSN, 821*5c1def83SBjoern A. Zeeb HAL_REO_DEST_RING_ERROR_CODE_PN_CHECK_FAILED, 822*5c1def83SBjoern A. Zeeb HAL_REO_DEST_RING_ERROR_CODE_2K_ERR_FLAG_SET, 823*5c1def83SBjoern A. Zeeb HAL_REO_DEST_RING_ERROR_CODE_PN_ERR_FLAG_SET, 824*5c1def83SBjoern A. Zeeb HAL_REO_DEST_RING_ERROR_CODE_DESC_BLOCKED, 825*5c1def83SBjoern A. Zeeb HAL_REO_DEST_RING_ERROR_CODE_MAX, 826*5c1def83SBjoern A. Zeeb }; 827*5c1def83SBjoern A. Zeeb 828*5c1def83SBjoern A. Zeeb #define HAL_REO_DEST_RING_INFO0_BUFFER_TYPE BIT(0) 829*5c1def83SBjoern A. Zeeb #define HAL_REO_DEST_RING_INFO0_PUSH_REASON GENMASK(2, 1) 830*5c1def83SBjoern A. Zeeb #define HAL_REO_DEST_RING_INFO0_ERROR_CODE GENMASK(7, 3) 831*5c1def83SBjoern A. Zeeb #define HAL_REO_DEST_RING_INFO0_MSDU_DATA_SIZE GENMASK(11, 8) 832*5c1def83SBjoern A. Zeeb #define HAL_REO_DEST_RING_INFO0_SW_EXCEPTION BIT(12) 833*5c1def83SBjoern A. Zeeb #define HAL_REO_DEST_RING_INFO0_SRC_LINK_ID GENMASK(15, 13) 834*5c1def83SBjoern A. Zeeb #define HAL_REO_DEST_RING_INFO0_SIGNATURE GENMASK(19, 16) 835*5c1def83SBjoern A. Zeeb #define HAL_REO_DEST_RING_INFO0_RING_ID GENMASK(27, 20) 836*5c1def83SBjoern A. Zeeb #define HAL_REO_DEST_RING_INFO0_LOOPING_COUNT GENMASK(31, 28) 837*5c1def83SBjoern A. Zeeb 838*5c1def83SBjoern A. Zeeb struct hal_reo_dest_ring { 839*5c1def83SBjoern A. Zeeb struct ath12k_buffer_addr buf_addr_info; 840*5c1def83SBjoern A. Zeeb struct rx_mpdu_desc rx_mpdu_info; 841*5c1def83SBjoern A. Zeeb struct rx_msdu_desc rx_msdu_info; 842*5c1def83SBjoern A. Zeeb __le32 buf_va_lo; 843*5c1def83SBjoern A. Zeeb __le32 buf_va_hi; 844*5c1def83SBjoern A. Zeeb __le32 info0; /* %HAL_REO_DEST_RING_INFO0_ */ 845*5c1def83SBjoern A. Zeeb } __packed; 846*5c1def83SBjoern A. Zeeb 847*5c1def83SBjoern A. Zeeb /* hal_reo_dest_ring 848*5c1def83SBjoern A. Zeeb * 849*5c1def83SBjoern A. Zeeb * Producer: RXDMA 850*5c1def83SBjoern A. Zeeb * Consumer: REO/SW/FW 851*5c1def83SBjoern A. Zeeb * 852*5c1def83SBjoern A. Zeeb * buf_addr_info 853*5c1def83SBjoern A. Zeeb * Details of the physical address of a buffer or MSDU 854*5c1def83SBjoern A. Zeeb * link descriptor. 855*5c1def83SBjoern A. Zeeb * 856*5c1def83SBjoern A. Zeeb * rx_mpdu_info 857*5c1def83SBjoern A. Zeeb * General information related to the MPDU that is passed 858*5c1def83SBjoern A. Zeeb * on from REO entrance ring to the REO destination ring. 859*5c1def83SBjoern A. Zeeb * 860*5c1def83SBjoern A. Zeeb * rx_msdu_info 861*5c1def83SBjoern A. Zeeb * General information related to the MSDU that is passed 862*5c1def83SBjoern A. Zeeb * on from RXDMA all the way to the REO destination ring. 863*5c1def83SBjoern A. Zeeb * 864*5c1def83SBjoern A. Zeeb * buf_va_lo 865*5c1def83SBjoern A. Zeeb * Field only valid if Reo_dest_buffer_type is set to MSDU_buf_address 866*5c1def83SBjoern A. Zeeb * Lower 32 bits of the 64-bit virtual address corresponding 867*5c1def83SBjoern A. Zeeb * to Buf_or_link_desc_addr_info 868*5c1def83SBjoern A. Zeeb * 869*5c1def83SBjoern A. Zeeb * buf_va_hi 870*5c1def83SBjoern A. Zeeb * Address (upper 32 bits) of the REO queue descriptor. 871*5c1def83SBjoern A. Zeeb * Upper 32 bits of the 64-bit virtual address corresponding 872*5c1def83SBjoern A. Zeeb * to Buf_or_link_desc_addr_info 873*5c1def83SBjoern A. Zeeb * 874*5c1def83SBjoern A. Zeeb * buffer_type 875*5c1def83SBjoern A. Zeeb * Indicates the type of address provided in the buf_addr_info. 876*5c1def83SBjoern A. Zeeb * Values are defined in enum %HAL_REO_DEST_RING_BUFFER_TYPE_. 877*5c1def83SBjoern A. Zeeb * 878*5c1def83SBjoern A. Zeeb * push_reason 879*5c1def83SBjoern A. Zeeb * Reason for pushing this frame to this exit ring. Values are 880*5c1def83SBjoern A. Zeeb * defined in enum %HAL_REO_DEST_RING_PUSH_REASON_. 881*5c1def83SBjoern A. Zeeb * 882*5c1def83SBjoern A. Zeeb * error_code 883*5c1def83SBjoern A. Zeeb * Valid only when 'push_reason' is set. All error codes are 884*5c1def83SBjoern A. Zeeb * defined in enum %HAL_REO_DEST_RING_ERROR_CODE_. 885*5c1def83SBjoern A. Zeeb * 886*5c1def83SBjoern A. Zeeb * captured_msdu_data_size 887*5c1def83SBjoern A. Zeeb * The number of following REO_DESTINATION STRUCTs that have 888*5c1def83SBjoern A. Zeeb * been replaced with msdu_data extracted from the msdu_buffer 889*5c1def83SBjoern A. Zeeb * and copied into the ring for easy FW/SW access. 890*5c1def83SBjoern A. Zeeb * 891*5c1def83SBjoern A. Zeeb * sw_exception 892*5c1def83SBjoern A. Zeeb * This field has the same setting as the SW_exception field 893*5c1def83SBjoern A. Zeeb * in the corresponding REO_entrance_ring descriptor. 894*5c1def83SBjoern A. Zeeb * When set, the REO entrance descriptor is generated by FW, 895*5c1def83SBjoern A. Zeeb * and the MPDU was processed in the following way: 896*5c1def83SBjoern A. Zeeb * - NO re-order function is needed. 897*5c1def83SBjoern A. Zeeb * - MPDU delinking is determined by the setting of Entrance 898*5c1def83SBjoern A. Zeeb * ring field: SW_excection_mpdu_delink 899*5c1def83SBjoern A. Zeeb * - Destination ring selection is based on the setting of 900*5c1def83SBjoern A. Zeeb * the Entrance ring field SW_exception_destination _ring_valid 901*5c1def83SBjoern A. Zeeb * 902*5c1def83SBjoern A. Zeeb * src_link_id 903*5c1def83SBjoern A. Zeeb * Set to the link ID of the PMAC that received the frame 904*5c1def83SBjoern A. Zeeb * 905*5c1def83SBjoern A. Zeeb * signature 906*5c1def83SBjoern A. Zeeb * Set to value 0x8 when msdu capture mode is enabled for this ring 907*5c1def83SBjoern A. Zeeb * 908*5c1def83SBjoern A. Zeeb * ring_id 909*5c1def83SBjoern A. Zeeb * The buffer pointer ring id. 910*5c1def83SBjoern A. Zeeb * 0 - Idle ring 911*5c1def83SBjoern A. Zeeb * 1 - N refers to other rings. 912*5c1def83SBjoern A. Zeeb * 913*5c1def83SBjoern A. Zeeb * looping_count 914*5c1def83SBjoern A. Zeeb * Indicates the number of times the producer of entries into 915*5c1def83SBjoern A. Zeeb * this ring has looped around the ring. 916*5c1def83SBjoern A. Zeeb */ 917*5c1def83SBjoern A. Zeeb 918*5c1def83SBjoern A. Zeeb #define HAL_REO_TO_PPE_RING_INFO0_DATA_LENGTH GENMASK(15, 0) 919*5c1def83SBjoern A. Zeeb #define HAL_REO_TO_PPE_RING_INFO0_DATA_OFFSET GENMASK(23, 16) 920*5c1def83SBjoern A. Zeeb #define HAL_REO_TO_PPE_RING_INFO0_POOL_ID GENMASK(28, 24) 921*5c1def83SBjoern A. Zeeb #define HAL_REO_TO_PPE_RING_INFO0_PREHEADER BIT(29) 922*5c1def83SBjoern A. Zeeb #define HAL_REO_TO_PPE_RING_INFO0_TSO_EN BIT(30) 923*5c1def83SBjoern A. Zeeb #define HAL_REO_TO_PPE_RING_INFO0_MORE BIT(31) 924*5c1def83SBjoern A. Zeeb 925*5c1def83SBjoern A. Zeeb struct hal_reo_to_ppe_ring { 926*5c1def83SBjoern A. Zeeb __le32 buffer_addr; 927*5c1def83SBjoern A. Zeeb __le32 info0; /* %HAL_REO_TO_PPE_RING_INFO0_ */ 928*5c1def83SBjoern A. Zeeb } __packed; 929*5c1def83SBjoern A. Zeeb 930*5c1def83SBjoern A. Zeeb /* hal_reo_to_ppe_ring 931*5c1def83SBjoern A. Zeeb * 932*5c1def83SBjoern A. Zeeb * Producer: REO 933*5c1def83SBjoern A. Zeeb * Consumer: PPE 934*5c1def83SBjoern A. Zeeb * 935*5c1def83SBjoern A. Zeeb * buf_addr_info 936*5c1def83SBjoern A. Zeeb * Details of the physical address of a buffer or MSDU 937*5c1def83SBjoern A. Zeeb * link descriptor. 938*5c1def83SBjoern A. Zeeb * 939*5c1def83SBjoern A. Zeeb * data_length 940*5c1def83SBjoern A. Zeeb * Length of valid data in bytes 941*5c1def83SBjoern A. Zeeb * 942*5c1def83SBjoern A. Zeeb * data_offset 943*5c1def83SBjoern A. Zeeb * Offset to the data from buffer pointer. Can be used to 944*5c1def83SBjoern A. Zeeb * strip header in the data for tunnel termination etc. 945*5c1def83SBjoern A. Zeeb * 946*5c1def83SBjoern A. Zeeb * pool_id 947*5c1def83SBjoern A. Zeeb * REO has global configuration register for this field. 948*5c1def83SBjoern A. Zeeb * It may have several free buffer pools, each 949*5c1def83SBjoern A. Zeeb * RX-Descriptor ring can fetch free buffer from specific 950*5c1def83SBjoern A. Zeeb * buffer pool; pool id will indicate which pool the buffer 951*5c1def83SBjoern A. Zeeb * will be released to; POOL_ID Zero returned to SW 952*5c1def83SBjoern A. Zeeb * 953*5c1def83SBjoern A. Zeeb * preheader 954*5c1def83SBjoern A. Zeeb * Disabled: 0 (Default) 955*5c1def83SBjoern A. Zeeb * Enabled: 1 956*5c1def83SBjoern A. Zeeb * 957*5c1def83SBjoern A. Zeeb * tso_en 958*5c1def83SBjoern A. Zeeb * Disabled: 0 (Default) 959*5c1def83SBjoern A. Zeeb * Enabled: 1 960*5c1def83SBjoern A. Zeeb * 961*5c1def83SBjoern A. Zeeb * more 962*5c1def83SBjoern A. Zeeb * More Segments followed 963*5c1def83SBjoern A. Zeeb */ 964*5c1def83SBjoern A. Zeeb 965*5c1def83SBjoern A. Zeeb enum hal_reo_entr_rxdma_push_reason { 966*5c1def83SBjoern A. Zeeb HAL_REO_ENTR_RING_RXDMA_PUSH_REASON_ERR_DETECTED, 967*5c1def83SBjoern A. Zeeb HAL_REO_ENTR_RING_RXDMA_PUSH_REASON_ROUTING_INSTRUCTION, 968*5c1def83SBjoern A. Zeeb HAL_REO_ENTR_RING_RXDMA_PUSH_REASON_RX_FLUSH, 969*5c1def83SBjoern A. Zeeb }; 970*5c1def83SBjoern A. Zeeb 971*5c1def83SBjoern A. Zeeb enum hal_reo_entr_rxdma_ecode { 972*5c1def83SBjoern A. Zeeb HAL_REO_ENTR_RING_RXDMA_ECODE_OVERFLOW_ERR, 973*5c1def83SBjoern A. Zeeb HAL_REO_ENTR_RING_RXDMA_ECODE_MPDU_LEN_ERR, 974*5c1def83SBjoern A. Zeeb HAL_REO_ENTR_RING_RXDMA_ECODE_FCS_ERR, 975*5c1def83SBjoern A. Zeeb HAL_REO_ENTR_RING_RXDMA_ECODE_DECRYPT_ERR, 976*5c1def83SBjoern A. Zeeb HAL_REO_ENTR_RING_RXDMA_ECODE_TKIP_MIC_ERR, 977*5c1def83SBjoern A. Zeeb HAL_REO_ENTR_RING_RXDMA_ECODE_UNECRYPTED_ERR, 978*5c1def83SBjoern A. Zeeb HAL_REO_ENTR_RING_RXDMA_ECODE_MSDU_LEN_ERR, 979*5c1def83SBjoern A. Zeeb HAL_REO_ENTR_RING_RXDMA_ECODE_MSDU_LIMIT_ERR, 980*5c1def83SBjoern A. Zeeb HAL_REO_ENTR_RING_RXDMA_ECODE_WIFI_PARSE_ERR, 981*5c1def83SBjoern A. Zeeb HAL_REO_ENTR_RING_RXDMA_ECODE_AMSDU_PARSE_ERR, 982*5c1def83SBjoern A. Zeeb HAL_REO_ENTR_RING_RXDMA_ECODE_SA_TIMEOUT_ERR, 983*5c1def83SBjoern A. Zeeb HAL_REO_ENTR_RING_RXDMA_ECODE_DA_TIMEOUT_ERR, 984*5c1def83SBjoern A. Zeeb HAL_REO_ENTR_RING_RXDMA_ECODE_FLOW_TIMEOUT_ERR, 985*5c1def83SBjoern A. Zeeb HAL_REO_ENTR_RING_RXDMA_ECODE_FLUSH_REQUEST_ERR, 986*5c1def83SBjoern A. Zeeb HAL_REO_ENTR_RING_RXDMA_ECODE_AMSDU_FRAG_ERR, 987*5c1def83SBjoern A. Zeeb HAL_REO_ENTR_RING_RXDMA_ECODE_MAX, 988*5c1def83SBjoern A. Zeeb }; 989*5c1def83SBjoern A. Zeeb 990*5c1def83SBjoern A. Zeeb enum hal_rx_reo_dest_ring { 991*5c1def83SBjoern A. Zeeb HAL_RX_REO_DEST_RING_TCL, 992*5c1def83SBjoern A. Zeeb HAL_RX_REO_DEST_RING_SW1, 993*5c1def83SBjoern A. Zeeb HAL_RX_REO_DEST_RING_SW2, 994*5c1def83SBjoern A. Zeeb HAL_RX_REO_DEST_RING_SW3, 995*5c1def83SBjoern A. Zeeb HAL_RX_REO_DEST_RING_SW4, 996*5c1def83SBjoern A. Zeeb HAL_RX_REO_DEST_RING_RELEASE, 997*5c1def83SBjoern A. Zeeb HAL_RX_REO_DEST_RING_FW, 998*5c1def83SBjoern A. Zeeb HAL_RX_REO_DEST_RING_SW5, 999*5c1def83SBjoern A. Zeeb HAL_RX_REO_DEST_RING_SW6, 1000*5c1def83SBjoern A. Zeeb HAL_RX_REO_DEST_RING_SW7, 1001*5c1def83SBjoern A. Zeeb HAL_RX_REO_DEST_RING_SW8, 1002*5c1def83SBjoern A. Zeeb }; 1003*5c1def83SBjoern A. Zeeb 1004*5c1def83SBjoern A. Zeeb #define HAL_REO_ENTR_RING_INFO0_QUEUE_ADDR_HI GENMASK(7, 0) 1005*5c1def83SBjoern A. Zeeb #define HAL_REO_ENTR_RING_INFO0_MPDU_BYTE_COUNT GENMASK(21, 8) 1006*5c1def83SBjoern A. Zeeb #define HAL_REO_ENTR_RING_INFO0_DEST_IND GENMASK(26, 22) 1007*5c1def83SBjoern A. Zeeb #define HAL_REO_ENTR_RING_INFO0_FRAMELESS_BAR BIT(27) 1008*5c1def83SBjoern A. Zeeb 1009*5c1def83SBjoern A. Zeeb #define HAL_REO_ENTR_RING_INFO1_RXDMA_PUSH_REASON GENMASK(1, 0) 1010*5c1def83SBjoern A. Zeeb #define HAL_REO_ENTR_RING_INFO1_RXDMA_ERROR_CODE GENMASK(6, 2) 1011*5c1def83SBjoern A. Zeeb #define HAL_REO_ENTR_RING_INFO1_MPDU_FRAG_NUM GENMASK(10, 7) 1012*5c1def83SBjoern A. Zeeb #define HAL_REO_ENTR_RING_INFO1_SW_EXCEPTION BIT(11) 1013*5c1def83SBjoern A. Zeeb #define HAL_REO_ENTR_RING_INFO1_SW_EXCEPT_MPDU_DELINK BIT(12) 1014*5c1def83SBjoern A. Zeeb #define HAL_REO_ENTR_RING_INFO1_SW_EXCEPTION_RING_VLD BIT(13) 1015*5c1def83SBjoern A. Zeeb #define HAL_REO_ENTR_RING_INFO1_SW_EXCEPTION_RING GENMASK(18, 14) 1016*5c1def83SBjoern A. Zeeb #define HAL_REO_ENTR_RING_INFO1_MPDU_SEQ_NUM GENMASK(30, 19) 1017*5c1def83SBjoern A. Zeeb 1018*5c1def83SBjoern A. Zeeb #define HAL_REO_ENTR_RING_INFO2_PHY_PPDU_ID GENMASK(15, 0) 1019*5c1def83SBjoern A. Zeeb #define HAL_REO_ENTR_RING_INFO2_SRC_LINK_ID GENMASK(18, 16) 1020*5c1def83SBjoern A. Zeeb #define HAL_REO_ENTR_RING_INFO2_RING_ID GENMASK(27, 20) 1021*5c1def83SBjoern A. Zeeb #define HAL_REO_ENTR_RING_INFO2_LOOPING_COUNT GENMASK(31, 28) 1022*5c1def83SBjoern A. Zeeb 1023*5c1def83SBjoern A. Zeeb struct hal_reo_entrance_ring { 1024*5c1def83SBjoern A. Zeeb struct ath12k_buffer_addr buf_addr_info; 1025*5c1def83SBjoern A. Zeeb struct rx_mpdu_desc rx_mpdu_info; 1026*5c1def83SBjoern A. Zeeb __le32 queue_addr_lo; 1027*5c1def83SBjoern A. Zeeb __le32 info0; /* %HAL_REO_ENTR_RING_INFO0_ */ 1028*5c1def83SBjoern A. Zeeb __le32 info1; /* %HAL_REO_ENTR_RING_INFO1_ */ 1029*5c1def83SBjoern A. Zeeb __le32 info2; /* %HAL_REO_DEST_RING_INFO2_ */ 1030*5c1def83SBjoern A. Zeeb 1031*5c1def83SBjoern A. Zeeb } __packed; 1032*5c1def83SBjoern A. Zeeb 1033*5c1def83SBjoern A. Zeeb /* hal_reo_entrance_ring 1034*5c1def83SBjoern A. Zeeb * 1035*5c1def83SBjoern A. Zeeb * Producer: RXDMA 1036*5c1def83SBjoern A. Zeeb * Consumer: REO 1037*5c1def83SBjoern A. Zeeb * 1038*5c1def83SBjoern A. Zeeb * buf_addr_info 1039*5c1def83SBjoern A. Zeeb * Details of the physical address of a buffer or MSDU 1040*5c1def83SBjoern A. Zeeb * link descriptor. 1041*5c1def83SBjoern A. Zeeb * 1042*5c1def83SBjoern A. Zeeb * rx_mpdu_info 1043*5c1def83SBjoern A. Zeeb * General information related to the MPDU that is passed 1044*5c1def83SBjoern A. Zeeb * on from REO entrance ring to the REO destination ring. 1045*5c1def83SBjoern A. Zeeb * 1046*5c1def83SBjoern A. Zeeb * queue_addr_lo 1047*5c1def83SBjoern A. Zeeb * Address (lower 32 bits) of the REO queue descriptor. 1048*5c1def83SBjoern A. Zeeb * 1049*5c1def83SBjoern A. Zeeb * queue_addr_hi 1050*5c1def83SBjoern A. Zeeb * Address (upper 8 bits) of the REO queue descriptor. 1051*5c1def83SBjoern A. Zeeb * 1052*5c1def83SBjoern A. Zeeb * mpdu_byte_count 1053*5c1def83SBjoern A. Zeeb * An approximation of the number of bytes received in this MPDU. 1054*5c1def83SBjoern A. Zeeb * Used to keeps stats on the amount of data flowing 1055*5c1def83SBjoern A. Zeeb * through a queue. 1056*5c1def83SBjoern A. Zeeb * 1057*5c1def83SBjoern A. Zeeb * reo_destination_indication 1058*5c1def83SBjoern A. Zeeb * The id of the reo exit ring where the msdu frame shall push 1059*5c1def83SBjoern A. Zeeb * after (MPDU level) reordering has finished. Values are defined 1060*5c1def83SBjoern A. Zeeb * in enum %HAL_RX_MSDU_DESC_REO_DEST_IND_. 1061*5c1def83SBjoern A. Zeeb * 1062*5c1def83SBjoern A. Zeeb * frameless_bar 1063*5c1def83SBjoern A. Zeeb * Indicates that this REO entrance ring struct contains BAR info 1064*5c1def83SBjoern A. Zeeb * from a multi TID BAR frame. The original multi TID BAR frame 1065*5c1def83SBjoern A. Zeeb * itself contained all the REO info for the first TID, but all 1066*5c1def83SBjoern A. Zeeb * the subsequent TID info and their linkage to the REO descriptors 1067*5c1def83SBjoern A. Zeeb * is passed down as 'frameless' BAR info. 1068*5c1def83SBjoern A. Zeeb * 1069*5c1def83SBjoern A. Zeeb * The only fields valid in this descriptor when this bit is set 1070*5c1def83SBjoern A. Zeeb * are queue_addr_lo, queue_addr_hi, mpdu_sequence_number, 1071*5c1def83SBjoern A. Zeeb * bar_frame and peer_meta_data. 1072*5c1def83SBjoern A. Zeeb * 1073*5c1def83SBjoern A. Zeeb * rxdma_push_reason 1074*5c1def83SBjoern A. Zeeb * Reason for pushing this frame to this exit ring. Values are 1075*5c1def83SBjoern A. Zeeb * defined in enum %HAL_REO_ENTR_RING_RXDMA_PUSH_REASON_. 1076*5c1def83SBjoern A. Zeeb * 1077*5c1def83SBjoern A. Zeeb * rxdma_error_code 1078*5c1def83SBjoern A. Zeeb * Valid only when 'push_reason' is set. All error codes are 1079*5c1def83SBjoern A. Zeeb * defined in enum %HAL_REO_ENTR_RING_RXDMA_ECODE_. 1080*5c1def83SBjoern A. Zeeb * 1081*5c1def83SBjoern A. Zeeb * mpdu_fragment_number 1082*5c1def83SBjoern A. Zeeb * Field only valid when Reo_level_mpdu_frame_info. 1083*5c1def83SBjoern A. Zeeb * Rx_mpdu_desc_info_details.Fragment_flag is set. 1084*5c1def83SBjoern A. Zeeb * 1085*5c1def83SBjoern A. Zeeb * sw_exception 1086*5c1def83SBjoern A. Zeeb * When not set, REO is performing all its default MPDU processing 1087*5c1def83SBjoern A. Zeeb * operations, 1088*5c1def83SBjoern A. Zeeb * When set, this REO entrance descriptor is generated by FW, and 1089*5c1def83SBjoern A. Zeeb * should be processed as an exception. This implies: 1090*5c1def83SBjoern A. Zeeb * NO re-order function is needed. 1091*5c1def83SBjoern A. Zeeb * MPDU delinking is determined by the setting of field 1092*5c1def83SBjoern A. Zeeb * SW_excection_mpdu_delink 1093*5c1def83SBjoern A. Zeeb * 1094*5c1def83SBjoern A. Zeeb * sw_exception_mpdu_delink 1095*5c1def83SBjoern A. Zeeb * Field only valid when SW_exception is set. 1096*5c1def83SBjoern A. Zeeb * 1'b0: REO should NOT delink the MPDU, and thus pass this 1097*5c1def83SBjoern A. Zeeb * MPDU on to the destination ring as is. This implies that 1098*5c1def83SBjoern A. Zeeb * in the REO_DESTINATION_RING struct field 1099*5c1def83SBjoern A. Zeeb * Buf_or_link_desc_addr_info should point to an MSDU link 1100*5c1def83SBjoern A. Zeeb * descriptor 1101*5c1def83SBjoern A. Zeeb * 1'b1: REO should perform the normal MPDU delink into MSDU operations. 1102*5c1def83SBjoern A. Zeeb * 1103*5c1def83SBjoern A. Zeeb * sw_exception_dest_ring 1104*5c1def83SBjoern A. Zeeb * Field only valid when fields SW_exception and SW 1105*5c1def83SBjoern A. Zeeb * exception_destination_ring_valid are set. values are defined 1106*5c1def83SBjoern A. Zeeb * in %HAL_RX_REO_DEST_RING_. 1107*5c1def83SBjoern A. Zeeb * 1108*5c1def83SBjoern A. Zeeb * mpdu_seq_number 1109*5c1def83SBjoern A. Zeeb * The field can have two different meanings based on the setting 1110*5c1def83SBjoern A. Zeeb * of sub-field Reo level mpdu frame info. 1111*5c1def83SBjoern A. Zeeb * Rx_mpdu_desc_info_details. BAR_frame 1112*5c1def83SBjoern A. Zeeb * 'BAR_frame' is NOT set: 1113*5c1def83SBjoern A. Zeeb * The MPDU sequence number of the received frame. 1114*5c1def83SBjoern A. Zeeb * 'BAR_frame' is set. 1115*5c1def83SBjoern A. Zeeb * The MPDU Start sequence number from the BAR frame 1116*5c1def83SBjoern A. Zeeb * 1117*5c1def83SBjoern A. Zeeb * phy_ppdu_id 1118*5c1def83SBjoern A. Zeeb * A PPDU counter value that PHY increments for every PPDU received 1119*5c1def83SBjoern A. Zeeb * 1120*5c1def83SBjoern A. Zeeb * src_link_id 1121*5c1def83SBjoern A. Zeeb * Set to the link ID of the PMAC that received the frame 1122*5c1def83SBjoern A. Zeeb * 1123*5c1def83SBjoern A. Zeeb * ring_id 1124*5c1def83SBjoern A. Zeeb * The buffer pointer ring id. 1125*5c1def83SBjoern A. Zeeb * 0 - Idle ring 1126*5c1def83SBjoern A. Zeeb * 1 - N refers to other rings. 1127*5c1def83SBjoern A. Zeeb * 1128*5c1def83SBjoern A. Zeeb * looping_count 1129*5c1def83SBjoern A. Zeeb * Indicates the number of times the producer of entries into 1130*5c1def83SBjoern A. Zeeb * this ring has looped around the ring. 1131*5c1def83SBjoern A. Zeeb */ 1132*5c1def83SBjoern A. Zeeb 1133*5c1def83SBjoern A. Zeeb #define HAL_REO_CMD_HDR_INFO0_CMD_NUMBER GENMASK(15, 0) 1134*5c1def83SBjoern A. Zeeb #define HAL_REO_CMD_HDR_INFO0_STATUS_REQUIRED BIT(16) 1135*5c1def83SBjoern A. Zeeb 1136*5c1def83SBjoern A. Zeeb struct hal_reo_cmd_hdr { 1137*5c1def83SBjoern A. Zeeb __le32 info0; 1138*5c1def83SBjoern A. Zeeb } __packed; 1139*5c1def83SBjoern A. Zeeb 1140*5c1def83SBjoern A. Zeeb #define HAL_REO_GET_QUEUE_STATS_INFO0_QUEUE_ADDR_HI GENMASK(7, 0) 1141*5c1def83SBjoern A. Zeeb #define HAL_REO_GET_QUEUE_STATS_INFO0_CLEAR_STATS BIT(8) 1142*5c1def83SBjoern A. Zeeb 1143*5c1def83SBjoern A. Zeeb struct hal_reo_get_queue_stats { 1144*5c1def83SBjoern A. Zeeb struct hal_reo_cmd_hdr cmd; 1145*5c1def83SBjoern A. Zeeb __le32 queue_addr_lo; 1146*5c1def83SBjoern A. Zeeb __le32 info0; 1147*5c1def83SBjoern A. Zeeb __le32 rsvd0[6]; 1148*5c1def83SBjoern A. Zeeb __le32 tlv64_pad; 1149*5c1def83SBjoern A. Zeeb } __packed; 1150*5c1def83SBjoern A. Zeeb 1151*5c1def83SBjoern A. Zeeb /* hal_reo_get_queue_stats 1152*5c1def83SBjoern A. Zeeb * Producer: SW 1153*5c1def83SBjoern A. Zeeb * Consumer: REO 1154*5c1def83SBjoern A. Zeeb * 1155*5c1def83SBjoern A. Zeeb * cmd 1156*5c1def83SBjoern A. Zeeb * Details for command execution tracking purposes. 1157*5c1def83SBjoern A. Zeeb * 1158*5c1def83SBjoern A. Zeeb * queue_addr_lo 1159*5c1def83SBjoern A. Zeeb * Address (lower 32 bits) of the REO queue descriptor. 1160*5c1def83SBjoern A. Zeeb * 1161*5c1def83SBjoern A. Zeeb * queue_addr_hi 1162*5c1def83SBjoern A. Zeeb * Address (upper 8 bits) of the REO queue descriptor. 1163*5c1def83SBjoern A. Zeeb * 1164*5c1def83SBjoern A. Zeeb * clear_stats 1165*5c1def83SBjoern A. Zeeb * Clear stats settings. When set, Clear the stats after 1166*5c1def83SBjoern A. Zeeb * generating the status. 1167*5c1def83SBjoern A. Zeeb * 1168*5c1def83SBjoern A. Zeeb * Following stats will be cleared. 1169*5c1def83SBjoern A. Zeeb * Timeout_count 1170*5c1def83SBjoern A. Zeeb * Forward_due_to_bar_count 1171*5c1def83SBjoern A. Zeeb * Duplicate_count 1172*5c1def83SBjoern A. Zeeb * Frames_in_order_count 1173*5c1def83SBjoern A. Zeeb * BAR_received_count 1174*5c1def83SBjoern A. Zeeb * MPDU_Frames_processed_count 1175*5c1def83SBjoern A. Zeeb * MSDU_Frames_processed_count 1176*5c1def83SBjoern A. Zeeb * Total_processed_byte_count 1177*5c1def83SBjoern A. Zeeb * Late_receive_MPDU_count 1178*5c1def83SBjoern A. Zeeb * window_jump_2k 1179*5c1def83SBjoern A. Zeeb * Hole_count 1180*5c1def83SBjoern A. Zeeb */ 1181*5c1def83SBjoern A. Zeeb 1182*5c1def83SBjoern A. Zeeb #define HAL_REO_FLUSH_QUEUE_INFO0_DESC_ADDR_HI GENMASK(7, 0) 1183*5c1def83SBjoern A. Zeeb #define HAL_REO_FLUSH_QUEUE_INFO0_BLOCK_DESC_ADDR BIT(8) 1184*5c1def83SBjoern A. Zeeb #define HAL_REO_FLUSH_QUEUE_INFO0_BLOCK_RESRC_IDX GENMASK(10, 9) 1185*5c1def83SBjoern A. Zeeb 1186*5c1def83SBjoern A. Zeeb struct hal_reo_flush_queue { 1187*5c1def83SBjoern A. Zeeb struct hal_reo_cmd_hdr cmd; 1188*5c1def83SBjoern A. Zeeb __le32 desc_addr_lo; 1189*5c1def83SBjoern A. Zeeb __le32 info0; 1190*5c1def83SBjoern A. Zeeb __le32 rsvd0[6]; 1191*5c1def83SBjoern A. Zeeb } __packed; 1192*5c1def83SBjoern A. Zeeb 1193*5c1def83SBjoern A. Zeeb #define HAL_REO_FLUSH_CACHE_INFO0_CACHE_ADDR_HI GENMASK(7, 0) 1194*5c1def83SBjoern A. Zeeb #define HAL_REO_FLUSH_CACHE_INFO0_FWD_ALL_MPDUS BIT(8) 1195*5c1def83SBjoern A. Zeeb #define HAL_REO_FLUSH_CACHE_INFO0_RELEASE_BLOCK_IDX BIT(9) 1196*5c1def83SBjoern A. Zeeb #define HAL_REO_FLUSH_CACHE_INFO0_BLOCK_RESRC_IDX GENMASK(11, 10) 1197*5c1def83SBjoern A. Zeeb #define HAL_REO_FLUSH_CACHE_INFO0_FLUSH_WO_INVALIDATE BIT(12) 1198*5c1def83SBjoern A. Zeeb #define HAL_REO_FLUSH_CACHE_INFO0_BLOCK_CACHE_USAGE BIT(13) 1199*5c1def83SBjoern A. Zeeb #define HAL_REO_FLUSH_CACHE_INFO0_FLUSH_ALL BIT(14) 1200*5c1def83SBjoern A. Zeeb 1201*5c1def83SBjoern A. Zeeb struct hal_reo_flush_cache { 1202*5c1def83SBjoern A. Zeeb struct hal_reo_cmd_hdr cmd; 1203*5c1def83SBjoern A. Zeeb __le32 cache_addr_lo; 1204*5c1def83SBjoern A. Zeeb __le32 info0; 1205*5c1def83SBjoern A. Zeeb __le32 rsvd0[6]; 1206*5c1def83SBjoern A. Zeeb } __packed; 1207*5c1def83SBjoern A. Zeeb 1208*5c1def83SBjoern A. Zeeb #define HAL_TCL_DATA_CMD_INFO0_CMD_TYPE BIT(0) 1209*5c1def83SBjoern A. Zeeb #define HAL_TCL_DATA_CMD_INFO0_DESC_TYPE BIT(1) 1210*5c1def83SBjoern A. Zeeb #define HAL_TCL_DATA_CMD_INFO0_BANK_ID GENMASK(7, 2) 1211*5c1def83SBjoern A. Zeeb #define HAL_TCL_DATA_CMD_INFO0_TX_NOTIFY_FRAME GENMASK(10, 8) 1212*5c1def83SBjoern A. Zeeb #define HAL_TCL_DATA_CMD_INFO0_HDR_LEN_READ_SEL BIT(11) 1213*5c1def83SBjoern A. Zeeb #define HAL_TCL_DATA_CMD_INFO0_BUF_TIMESTAMP GENMASK(30, 12) 1214*5c1def83SBjoern A. Zeeb #define HAL_TCL_DATA_CMD_INFO0_BUF_TIMESTAMP_VLD BIT(31) 1215*5c1def83SBjoern A. Zeeb 1216*5c1def83SBjoern A. Zeeb #define HAL_TCL_DATA_CMD_INFO1_CMD_NUM GENMASK(31, 16) 1217*5c1def83SBjoern A. Zeeb 1218*5c1def83SBjoern A. Zeeb #define HAL_TCL_DATA_CMD_INFO2_DATA_LEN GENMASK(15, 0) 1219*5c1def83SBjoern A. Zeeb #define HAL_TCL_DATA_CMD_INFO2_IP4_CKSUM_EN BIT(16) 1220*5c1def83SBjoern A. Zeeb #define HAL_TCL_DATA_CMD_INFO2_UDP4_CKSUM_EN BIT(17) 1221*5c1def83SBjoern A. Zeeb #define HAL_TCL_DATA_CMD_INFO2_UDP6_CKSUM_EN BIT(18) 1222*5c1def83SBjoern A. Zeeb #define HAL_TCL_DATA_CMD_INFO2_TCP4_CKSUM_EN BIT(19) 1223*5c1def83SBjoern A. Zeeb #define HAL_TCL_DATA_CMD_INFO2_TCP6_CKSUM_EN BIT(20) 1224*5c1def83SBjoern A. Zeeb #define HAL_TCL_DATA_CMD_INFO2_TO_FW BIT(21) 1225*5c1def83SBjoern A. Zeeb #define HAL_TCL_DATA_CMD_INFO2_PKT_OFFSET GENMASK(31, 23) 1226*5c1def83SBjoern A. Zeeb 1227*5c1def83SBjoern A. Zeeb #define HAL_TCL_DATA_CMD_INFO3_TID_OVERWRITE BIT(0) 1228*5c1def83SBjoern A. Zeeb #define HAL_TCL_DATA_CMD_INFO3_FLOW_OVERRIDE_EN BIT(1) 1229*5c1def83SBjoern A. Zeeb #define HAL_TCL_DATA_CMD_INFO3_CLASSIFY_INFO_SEL GENMASK(3, 2) 1230*5c1def83SBjoern A. Zeeb #define HAL_TCL_DATA_CMD_INFO3_TID GENMASK(7, 4) 1231*5c1def83SBjoern A. Zeeb #define HAL_TCL_DATA_CMD_INFO3_FLOW_OVERRIDE BIT(8) 1232*5c1def83SBjoern A. Zeeb #define HAL_TCL_DATA_CMD_INFO3_PMAC_ID GENMASK(10, 9) 1233*5c1def83SBjoern A. Zeeb #define HAL_TCL_DATA_CMD_INFO3_MSDU_COLOR GENMASK(12, 11) 1234*5c1def83SBjoern A. Zeeb #define HAL_TCL_DATA_CMD_INFO3_VDEV_ID GENMASK(31, 24) 1235*5c1def83SBjoern A. Zeeb 1236*5c1def83SBjoern A. Zeeb #define HAL_TCL_DATA_CMD_INFO4_SEARCH_INDEX GENMASK(19, 0) 1237*5c1def83SBjoern A. Zeeb #define HAL_TCL_DATA_CMD_INFO4_CACHE_SET_NUM GENMASK(23, 20) 1238*5c1def83SBjoern A. Zeeb #define HAL_TCL_DATA_CMD_INFO4_IDX_LOOKUP_OVERRIDE BIT(24) 1239*5c1def83SBjoern A. Zeeb 1240*5c1def83SBjoern A. Zeeb #define HAL_TCL_DATA_CMD_INFO5_RING_ID GENMASK(27, 20) 1241*5c1def83SBjoern A. Zeeb #define HAL_TCL_DATA_CMD_INFO5_LOOPING_COUNT GENMASK(31, 28) 1242*5c1def83SBjoern A. Zeeb 1243*5c1def83SBjoern A. Zeeb enum hal_encrypt_type { 1244*5c1def83SBjoern A. Zeeb HAL_ENCRYPT_TYPE_WEP_40, 1245*5c1def83SBjoern A. Zeeb HAL_ENCRYPT_TYPE_WEP_104, 1246*5c1def83SBjoern A. Zeeb HAL_ENCRYPT_TYPE_TKIP_NO_MIC, 1247*5c1def83SBjoern A. Zeeb HAL_ENCRYPT_TYPE_WEP_128, 1248*5c1def83SBjoern A. Zeeb HAL_ENCRYPT_TYPE_TKIP_MIC, 1249*5c1def83SBjoern A. Zeeb HAL_ENCRYPT_TYPE_WAPI, 1250*5c1def83SBjoern A. Zeeb HAL_ENCRYPT_TYPE_CCMP_128, 1251*5c1def83SBjoern A. Zeeb HAL_ENCRYPT_TYPE_OPEN, 1252*5c1def83SBjoern A. Zeeb HAL_ENCRYPT_TYPE_CCMP_256, 1253*5c1def83SBjoern A. Zeeb HAL_ENCRYPT_TYPE_GCMP_128, 1254*5c1def83SBjoern A. Zeeb HAL_ENCRYPT_TYPE_AES_GCMP_256, 1255*5c1def83SBjoern A. Zeeb HAL_ENCRYPT_TYPE_WAPI_GCM_SM4, 1256*5c1def83SBjoern A. Zeeb }; 1257*5c1def83SBjoern A. Zeeb 1258*5c1def83SBjoern A. Zeeb enum hal_tcl_encap_type { 1259*5c1def83SBjoern A. Zeeb HAL_TCL_ENCAP_TYPE_RAW, 1260*5c1def83SBjoern A. Zeeb HAL_TCL_ENCAP_TYPE_NATIVE_WIFI, 1261*5c1def83SBjoern A. Zeeb HAL_TCL_ENCAP_TYPE_ETHERNET, 1262*5c1def83SBjoern A. Zeeb HAL_TCL_ENCAP_TYPE_802_3 = 3, 1263*5c1def83SBjoern A. Zeeb }; 1264*5c1def83SBjoern A. Zeeb 1265*5c1def83SBjoern A. Zeeb enum hal_tcl_desc_type { 1266*5c1def83SBjoern A. Zeeb HAL_TCL_DESC_TYPE_BUFFER, 1267*5c1def83SBjoern A. Zeeb HAL_TCL_DESC_TYPE_EXT_DESC, 1268*5c1def83SBjoern A. Zeeb }; 1269*5c1def83SBjoern A. Zeeb 1270*5c1def83SBjoern A. Zeeb enum hal_wbm_htt_tx_comp_status { 1271*5c1def83SBjoern A. Zeeb HAL_WBM_REL_HTT_TX_COMP_STATUS_OK, 1272*5c1def83SBjoern A. Zeeb HAL_WBM_REL_HTT_TX_COMP_STATUS_DROP, 1273*5c1def83SBjoern A. Zeeb HAL_WBM_REL_HTT_TX_COMP_STATUS_TTL, 1274*5c1def83SBjoern A. Zeeb HAL_WBM_REL_HTT_TX_COMP_STATUS_REINJ, 1275*5c1def83SBjoern A. Zeeb HAL_WBM_REL_HTT_TX_COMP_STATUS_INSPECT, 1276*5c1def83SBjoern A. Zeeb HAL_WBM_REL_HTT_TX_COMP_STATUS_MEC_NOTIFY, 1277*5c1def83SBjoern A. Zeeb HAL_WBM_REL_HTT_TX_COMP_STATUS_MAX, 1278*5c1def83SBjoern A. Zeeb }; 1279*5c1def83SBjoern A. Zeeb 1280*5c1def83SBjoern A. Zeeb struct hal_tcl_data_cmd { 1281*5c1def83SBjoern A. Zeeb struct ath12k_buffer_addr buf_addr_info; 1282*5c1def83SBjoern A. Zeeb __le32 info0; 1283*5c1def83SBjoern A. Zeeb __le32 info1; 1284*5c1def83SBjoern A. Zeeb __le32 info2; 1285*5c1def83SBjoern A. Zeeb __le32 info3; 1286*5c1def83SBjoern A. Zeeb __le32 info4; 1287*5c1def83SBjoern A. Zeeb __le32 info5; 1288*5c1def83SBjoern A. Zeeb } __packed; 1289*5c1def83SBjoern A. Zeeb 1290*5c1def83SBjoern A. Zeeb /* hal_tcl_data_cmd 1291*5c1def83SBjoern A. Zeeb * 1292*5c1def83SBjoern A. Zeeb * buf_addr_info 1293*5c1def83SBjoern A. Zeeb * Details of the physical address of a buffer or MSDU 1294*5c1def83SBjoern A. Zeeb * link descriptor. 1295*5c1def83SBjoern A. Zeeb * 1296*5c1def83SBjoern A. Zeeb * tcl_cmd_type 1297*5c1def83SBjoern A. Zeeb * used to select the type of TCL Command descriptor 1298*5c1def83SBjoern A. Zeeb * 1299*5c1def83SBjoern A. Zeeb * desc_type 1300*5c1def83SBjoern A. Zeeb * Indicates the type of address provided in the buf_addr_info. 1301*5c1def83SBjoern A. Zeeb * Values are defined in enum %HAL_REO_DEST_RING_BUFFER_TYPE_. 1302*5c1def83SBjoern A. Zeeb * 1303*5c1def83SBjoern A. Zeeb * bank_id 1304*5c1def83SBjoern A. Zeeb * used to select one of the TCL register banks for fields removed 1305*5c1def83SBjoern A. Zeeb * from 'TCL_DATA_CMD' that do not change often within one virtual 1306*5c1def83SBjoern A. Zeeb * device or a set of virtual devices: 1307*5c1def83SBjoern A. Zeeb * 1308*5c1def83SBjoern A. Zeeb * tx_notify_frame 1309*5c1def83SBjoern A. Zeeb * TCL copies this value to 'TQM_ENTRANCE_RING' field FW_tx_notify_frame. 1310*5c1def83SBjoern A. Zeeb * 1311*5c1def83SBjoern A. Zeeb * hdr_length_read_sel 1312*5c1def83SBjoern A. Zeeb * used to select the per 'encap_type' register set for MSDU header 1313*5c1def83SBjoern A. Zeeb * read length 1314*5c1def83SBjoern A. Zeeb * 1315*5c1def83SBjoern A. Zeeb * buffer_timestamp 1316*5c1def83SBjoern A. Zeeb * buffer_timestamp_valid 1317*5c1def83SBjoern A. Zeeb * Frame system entrance timestamp. It shall be filled by first 1318*5c1def83SBjoern A. Zeeb * module (SW, TCL or TQM) that sees the frames first. 1319*5c1def83SBjoern A. Zeeb * 1320*5c1def83SBjoern A. Zeeb * cmd_num 1321*5c1def83SBjoern A. Zeeb * This number can be used to match against status. 1322*5c1def83SBjoern A. Zeeb * 1323*5c1def83SBjoern A. Zeeb * data_length 1324*5c1def83SBjoern A. Zeeb * MSDU length in case of direct descriptor. Length of link 1325*5c1def83SBjoern A. Zeeb * extension descriptor in case of Link extension descriptor. 1326*5c1def83SBjoern A. Zeeb * 1327*5c1def83SBjoern A. Zeeb * *_checksum_en 1328*5c1def83SBjoern A. Zeeb * Enable checksum replacement for ipv4, udp_over_ipv4, ipv6, 1329*5c1def83SBjoern A. Zeeb * udp_over_ipv6, tcp_over_ipv4 and tcp_over_ipv6. 1330*5c1def83SBjoern A. Zeeb * 1331*5c1def83SBjoern A. Zeeb * to_fw 1332*5c1def83SBjoern A. Zeeb * Forward packet to FW along with classification result. The 1333*5c1def83SBjoern A. Zeeb * packet will not be forward to TQM when this bit is set. 1334*5c1def83SBjoern A. Zeeb * 1'b0: Use classification result to forward the packet. 1335*5c1def83SBjoern A. Zeeb * 1'b1: Override classification result & forward packet only to fw 1336*5c1def83SBjoern A. Zeeb * 1337*5c1def83SBjoern A. Zeeb * packet_offset 1338*5c1def83SBjoern A. Zeeb * Packet offset from Metadata in case of direct buffer descriptor. 1339*5c1def83SBjoern A. Zeeb * 1340*5c1def83SBjoern A. Zeeb * hlos_tid_overwrite 1341*5c1def83SBjoern A. Zeeb * 1342*5c1def83SBjoern A. Zeeb * When set, TCL shall ignore the IP DSCP and VLAN PCP 1343*5c1def83SBjoern A. Zeeb * fields and use HLOS_TID as the final TID. Otherwise TCL 1344*5c1def83SBjoern A. Zeeb * shall consider the DSCP and PCP fields as well as HLOS_TID 1345*5c1def83SBjoern A. Zeeb * and choose a final TID based on the configured priority 1346*5c1def83SBjoern A. Zeeb * 1347*5c1def83SBjoern A. Zeeb * flow_override_enable 1348*5c1def83SBjoern A. Zeeb * TCL uses this to select the flow pointer from the peer table, 1349*5c1def83SBjoern A. Zeeb * which can be overridden by SW for pre-encrypted raw WiFi packets 1350*5c1def83SBjoern A. Zeeb * that cannot be parsed for UDP or for other MLO 1351*5c1def83SBjoern A. Zeeb * 0 - FP_PARSE_IP: Use the flow-pointer based on parsing the IPv4 1352*5c1def83SBjoern A. Zeeb * or IPv6 header. 1353*5c1def83SBjoern A. Zeeb * 1 - FP_USE_OVERRIDE: Use the who_classify_info_sel and 1354*5c1def83SBjoern A. Zeeb * flow_override fields to select the flow-pointer 1355*5c1def83SBjoern A. Zeeb * 1356*5c1def83SBjoern A. Zeeb * who_classify_info_sel 1357*5c1def83SBjoern A. Zeeb * Field only valid when flow_override_enable is set to FP_USE_OVERRIDE. 1358*5c1def83SBjoern A. Zeeb * This field is used to select one of the 'WHO_CLASSIFY_INFO's in the 1359*5c1def83SBjoern A. Zeeb * peer table in case more than 2 flows are mapped to a single TID. 1360*5c1def83SBjoern A. Zeeb * 0: To choose Flow 0 and 1 of any TID use this value. 1361*5c1def83SBjoern A. Zeeb * 1: To choose Flow 2 and 3 of any TID use this value. 1362*5c1def83SBjoern A. Zeeb * 2: To choose Flow 4 and 5 of any TID use this value. 1363*5c1def83SBjoern A. Zeeb * 3: To choose Flow 6 and 7 of any TID use this value. 1364*5c1def83SBjoern A. Zeeb * 1365*5c1def83SBjoern A. Zeeb * If who_classify_info sel is not in sync with the num_tx_classify_info 1366*5c1def83SBjoern A. Zeeb * field from address search, then TCL will set 'who_classify_info_sel' 1367*5c1def83SBjoern A. Zeeb * to 0 use flows 0 and 1. 1368*5c1def83SBjoern A. Zeeb * 1369*5c1def83SBjoern A. Zeeb * hlos_tid 1370*5c1def83SBjoern A. Zeeb * HLOS MSDU priority 1371*5c1def83SBjoern A. Zeeb * Field is used when HLOS_TID_overwrite is set. 1372*5c1def83SBjoern A. Zeeb * 1373*5c1def83SBjoern A. Zeeb * flow_override 1374*5c1def83SBjoern A. Zeeb * Field only valid when flow_override_enable is set to FP_USE_OVERRIDE 1375*5c1def83SBjoern A. Zeeb * TCL uses this to select the flow pointer from the peer table, 1376*5c1def83SBjoern A. Zeeb * which can be overridden by SW for pre-encrypted raw WiFi packets 1377*5c1def83SBjoern A. Zeeb * that cannot be parsed for UDP or for other MLO 1378*5c1def83SBjoern A. Zeeb * 0 - FP_USE_NON_UDP: Use the non-UDP flow pointer (flow 0) 1379*5c1def83SBjoern A. Zeeb * 1 - FP_USE_UDP: Use the UDP flow pointer (flow 1) 1380*5c1def83SBjoern A. Zeeb * 1381*5c1def83SBjoern A. Zeeb * pmac_id 1382*5c1def83SBjoern A. Zeeb * TCL uses this PMAC_ID in address search, i.e, while 1383*5c1def83SBjoern A. Zeeb * finding matching entry for the packet in AST corresponding 1384*5c1def83SBjoern A. Zeeb * to given PMAC_ID 1385*5c1def83SBjoern A. Zeeb * 1386*5c1def83SBjoern A. Zeeb * If PMAC ID is all 1s (=> value 3), it indicates wildcard 1387*5c1def83SBjoern A. Zeeb * match for any PMAC 1388*5c1def83SBjoern A. Zeeb * 1389*5c1def83SBjoern A. Zeeb * vdev_id 1390*5c1def83SBjoern A. Zeeb * Virtual device ID to check against the address search entry to 1391*5c1def83SBjoern A. Zeeb * avoid security issues from transmitting packets from an incorrect 1392*5c1def83SBjoern A. Zeeb * virtual device 1393*5c1def83SBjoern A. Zeeb * 1394*5c1def83SBjoern A. Zeeb * search_index 1395*5c1def83SBjoern A. Zeeb * The index that will be used for index based address or 1396*5c1def83SBjoern A. Zeeb * flow search. The field is valid when 'search_type' is 1 or 2. 1397*5c1def83SBjoern A. Zeeb * 1398*5c1def83SBjoern A. Zeeb * cache_set_num 1399*5c1def83SBjoern A. Zeeb * 1400*5c1def83SBjoern A. Zeeb * Cache set number that should be used to cache the index 1401*5c1def83SBjoern A. Zeeb * based search results, for address and flow search. This 1402*5c1def83SBjoern A. Zeeb * value should be equal to LSB four bits of the hash value of 1403*5c1def83SBjoern A. Zeeb * match data, in case of search index points to an entry which 1404*5c1def83SBjoern A. Zeeb * may be used in content based search also. The value can be 1405*5c1def83SBjoern A. Zeeb * anything when the entry pointed by search index will not be 1406*5c1def83SBjoern A. Zeeb * used for content based search. 1407*5c1def83SBjoern A. Zeeb * 1408*5c1def83SBjoern A. Zeeb * index_loop_override 1409*5c1def83SBjoern A. Zeeb * When set, address search and packet routing is forced to use 1410*5c1def83SBjoern A. Zeeb * 'search_index' instead of following the register configuration 1411*5c1def83SBjoern A. Zeeb * selected by Bank_id. 1412*5c1def83SBjoern A. Zeeb * 1413*5c1def83SBjoern A. Zeeb * ring_id 1414*5c1def83SBjoern A. Zeeb * The buffer pointer ring ID. 1415*5c1def83SBjoern A. Zeeb * 0 refers to the IDLE ring 1416*5c1def83SBjoern A. Zeeb * 1 - N refers to other rings 1417*5c1def83SBjoern A. Zeeb * 1418*5c1def83SBjoern A. Zeeb * looping_count 1419*5c1def83SBjoern A. Zeeb * 1420*5c1def83SBjoern A. Zeeb * A count value that indicates the number of times the 1421*5c1def83SBjoern A. Zeeb * producer of entries into the Ring has looped around the 1422*5c1def83SBjoern A. Zeeb * ring. 1423*5c1def83SBjoern A. Zeeb * 1424*5c1def83SBjoern A. Zeeb * At initialization time, this value is set to 0. On the 1425*5c1def83SBjoern A. Zeeb * first loop, this value is set to 1. After the max value is 1426*5c1def83SBjoern A. Zeeb * reached allowed by the number of bits for this field, the 1427*5c1def83SBjoern A. Zeeb * count value continues with 0 again. 1428*5c1def83SBjoern A. Zeeb * 1429*5c1def83SBjoern A. Zeeb * In case SW is the consumer of the ring entries, it can 1430*5c1def83SBjoern A. Zeeb * use this field to figure out up to where the producer of 1431*5c1def83SBjoern A. Zeeb * entries has created new entries. This eliminates the need to 1432*5c1def83SBjoern A. Zeeb * check where the head pointer' of the ring is located once 1433*5c1def83SBjoern A. Zeeb * the SW starts processing an interrupt indicating that new 1434*5c1def83SBjoern A. Zeeb * entries have been put into this ring... 1435*5c1def83SBjoern A. Zeeb * 1436*5c1def83SBjoern A. Zeeb * Also note that SW if it wants only needs to look at the 1437*5c1def83SBjoern A. Zeeb * LSB bit of this count value. 1438*5c1def83SBjoern A. Zeeb */ 1439*5c1def83SBjoern A. Zeeb 1440*5c1def83SBjoern A. Zeeb #define HAL_TCL_DESC_LEN sizeof(struct hal_tcl_data_cmd) 1441*5c1def83SBjoern A. Zeeb 1442*5c1def83SBjoern A. Zeeb #define HAL_TX_MSDU_EXT_INFO0_BUF_PTR_LO GENMASK(31, 0) 1443*5c1def83SBjoern A. Zeeb 1444*5c1def83SBjoern A. Zeeb #define HAL_TX_MSDU_EXT_INFO1_BUF_PTR_HI GENMASK(7, 0) 1445*5c1def83SBjoern A. Zeeb #define HAL_TX_MSDU_EXT_INFO1_EXTN_OVERRIDE BIT(8) 1446*5c1def83SBjoern A. Zeeb #define HAL_TX_MSDU_EXT_INFO1_ENCAP_TYPE GENMASK(10, 9) 1447*5c1def83SBjoern A. Zeeb #define HAL_TX_MSDU_EXT_INFO1_ENCRYPT_TYPE GENMASK(14, 11) 1448*5c1def83SBjoern A. Zeeb #define HAL_TX_MSDU_EXT_INFO1_BUF_LEN GENMASK(31, 16) 1449*5c1def83SBjoern A. Zeeb 1450*5c1def83SBjoern A. Zeeb struct hal_tx_msdu_ext_desc { 1451*5c1def83SBjoern A. Zeeb __le32 rsvd0[6]; 1452*5c1def83SBjoern A. Zeeb __le32 info0; 1453*5c1def83SBjoern A. Zeeb __le32 info1; 1454*5c1def83SBjoern A. Zeeb __le32 rsvd1[10]; 1455*5c1def83SBjoern A. Zeeb }; 1456*5c1def83SBjoern A. Zeeb 1457*5c1def83SBjoern A. Zeeb struct hal_tcl_gse_cmd { 1458*5c1def83SBjoern A. Zeeb __le32 ctrl_buf_addr_lo; 1459*5c1def83SBjoern A. Zeeb __le32 info0; 1460*5c1def83SBjoern A. Zeeb __le32 meta_data[2]; 1461*5c1def83SBjoern A. Zeeb __le32 rsvd0[2]; 1462*5c1def83SBjoern A. Zeeb __le32 info1; 1463*5c1def83SBjoern A. Zeeb } __packed; 1464*5c1def83SBjoern A. Zeeb 1465*5c1def83SBjoern A. Zeeb /* hal_tcl_gse_cmd 1466*5c1def83SBjoern A. Zeeb * 1467*5c1def83SBjoern A. Zeeb * ctrl_buf_addr_lo, ctrl_buf_addr_hi 1468*5c1def83SBjoern A. Zeeb * Address of a control buffer containing additional info needed 1469*5c1def83SBjoern A. Zeeb * for this command execution. 1470*5c1def83SBjoern A. Zeeb * 1471*5c1def83SBjoern A. Zeeb * meta_data 1472*5c1def83SBjoern A. Zeeb * Meta data to be returned in the status descriptor 1473*5c1def83SBjoern A. Zeeb */ 1474*5c1def83SBjoern A. Zeeb 1475*5c1def83SBjoern A. Zeeb enum hal_tcl_cache_op_res { 1476*5c1def83SBjoern A. Zeeb HAL_TCL_CACHE_OP_RES_DONE, 1477*5c1def83SBjoern A. Zeeb HAL_TCL_CACHE_OP_RES_NOT_FOUND, 1478*5c1def83SBjoern A. Zeeb HAL_TCL_CACHE_OP_RES_TIMEOUT, 1479*5c1def83SBjoern A. Zeeb }; 1480*5c1def83SBjoern A. Zeeb 1481*5c1def83SBjoern A. Zeeb struct hal_tcl_status_ring { 1482*5c1def83SBjoern A. Zeeb __le32 info0; 1483*5c1def83SBjoern A. Zeeb __le32 msdu_byte_count; 1484*5c1def83SBjoern A. Zeeb __le32 msdu_timestamp; 1485*5c1def83SBjoern A. Zeeb __le32 meta_data[2]; 1486*5c1def83SBjoern A. Zeeb __le32 info1; 1487*5c1def83SBjoern A. Zeeb __le32 rsvd0; 1488*5c1def83SBjoern A. Zeeb __le32 info2; 1489*5c1def83SBjoern A. Zeeb } __packed; 1490*5c1def83SBjoern A. Zeeb 1491*5c1def83SBjoern A. Zeeb /* hal_tcl_status_ring 1492*5c1def83SBjoern A. Zeeb * 1493*5c1def83SBjoern A. Zeeb * msdu_cnt 1494*5c1def83SBjoern A. Zeeb * msdu_byte_count 1495*5c1def83SBjoern A. Zeeb * MSDU count of Entry and MSDU byte count for entry 1. 1496*5c1def83SBjoern A. Zeeb * 1497*5c1def83SBjoern A. Zeeb */ 1498*5c1def83SBjoern A. Zeeb 1499*5c1def83SBjoern A. Zeeb #define HAL_CE_SRC_DESC_ADDR_INFO_ADDR_HI GENMASK(7, 0) 1500*5c1def83SBjoern A. Zeeb #define HAL_CE_SRC_DESC_ADDR_INFO_HASH_EN BIT(8) 1501*5c1def83SBjoern A. Zeeb #define HAL_CE_SRC_DESC_ADDR_INFO_BYTE_SWAP BIT(9) 1502*5c1def83SBjoern A. Zeeb #define HAL_CE_SRC_DESC_ADDR_INFO_DEST_SWAP BIT(10) 1503*5c1def83SBjoern A. Zeeb #define HAL_CE_SRC_DESC_ADDR_INFO_GATHER BIT(11) 1504*5c1def83SBjoern A. Zeeb #define HAL_CE_SRC_DESC_ADDR_INFO_LEN GENMASK(31, 16) 1505*5c1def83SBjoern A. Zeeb 1506*5c1def83SBjoern A. Zeeb #define HAL_CE_SRC_DESC_META_INFO_DATA GENMASK(15, 0) 1507*5c1def83SBjoern A. Zeeb 1508*5c1def83SBjoern A. Zeeb #define HAL_CE_SRC_DESC_FLAGS_RING_ID GENMASK(27, 20) 1509*5c1def83SBjoern A. Zeeb #define HAL_CE_SRC_DESC_FLAGS_LOOP_CNT HAL_SRNG_DESC_LOOP_CNT 1510*5c1def83SBjoern A. Zeeb 1511*5c1def83SBjoern A. Zeeb struct hal_ce_srng_src_desc { 1512*5c1def83SBjoern A. Zeeb __le32 buffer_addr_low; 1513*5c1def83SBjoern A. Zeeb __le32 buffer_addr_info; /* %HAL_CE_SRC_DESC_ADDR_INFO_ */ 1514*5c1def83SBjoern A. Zeeb __le32 meta_info; /* %HAL_CE_SRC_DESC_META_INFO_ */ 1515*5c1def83SBjoern A. Zeeb __le32 flags; /* %HAL_CE_SRC_DESC_FLAGS_ */ 1516*5c1def83SBjoern A. Zeeb } __packed; 1517*5c1def83SBjoern A. Zeeb 1518*5c1def83SBjoern A. Zeeb /* hal_ce_srng_src_desc 1519*5c1def83SBjoern A. Zeeb * 1520*5c1def83SBjoern A. Zeeb * buffer_addr_lo 1521*5c1def83SBjoern A. Zeeb * LSB 32 bits of the 40 Bit Pointer to the source buffer 1522*5c1def83SBjoern A. Zeeb * 1523*5c1def83SBjoern A. Zeeb * buffer_addr_hi 1524*5c1def83SBjoern A. Zeeb * MSB 8 bits of the 40 Bit Pointer to the source buffer 1525*5c1def83SBjoern A. Zeeb * 1526*5c1def83SBjoern A. Zeeb * toeplitz_en 1527*5c1def83SBjoern A. Zeeb * Enable generation of 32-bit Toeplitz-LFSR hash for 1528*5c1def83SBjoern A. Zeeb * data transfer. In case of gather field in first source 1529*5c1def83SBjoern A. Zeeb * ring entry of the gather copy cycle in taken into account. 1530*5c1def83SBjoern A. Zeeb * 1531*5c1def83SBjoern A. Zeeb * src_swap 1532*5c1def83SBjoern A. Zeeb * Treats source memory organization as big-endian. For 1533*5c1def83SBjoern A. Zeeb * each dword read (4 bytes), the byte 0 is swapped with byte 3 1534*5c1def83SBjoern A. Zeeb * and byte 1 is swapped with byte 2. 1535*5c1def83SBjoern A. Zeeb * In case of gather field in first source ring entry of 1536*5c1def83SBjoern A. Zeeb * the gather copy cycle in taken into account. 1537*5c1def83SBjoern A. Zeeb * 1538*5c1def83SBjoern A. Zeeb * dest_swap 1539*5c1def83SBjoern A. Zeeb * Treats destination memory organization as big-endian. 1540*5c1def83SBjoern A. Zeeb * For each dword write (4 bytes), the byte 0 is swapped with 1541*5c1def83SBjoern A. Zeeb * byte 3 and byte 1 is swapped with byte 2. 1542*5c1def83SBjoern A. Zeeb * In case of gather field in first source ring entry of 1543*5c1def83SBjoern A. Zeeb * the gather copy cycle in taken into account. 1544*5c1def83SBjoern A. Zeeb * 1545*5c1def83SBjoern A. Zeeb * gather 1546*5c1def83SBjoern A. Zeeb * Enables gather of multiple copy engine source 1547*5c1def83SBjoern A. Zeeb * descriptors to one destination. 1548*5c1def83SBjoern A. Zeeb * 1549*5c1def83SBjoern A. Zeeb * ce_res_0 1550*5c1def83SBjoern A. Zeeb * Reserved 1551*5c1def83SBjoern A. Zeeb * 1552*5c1def83SBjoern A. Zeeb * 1553*5c1def83SBjoern A. Zeeb * length 1554*5c1def83SBjoern A. Zeeb * Length of the buffer in units of octets of the current 1555*5c1def83SBjoern A. Zeeb * descriptor 1556*5c1def83SBjoern A. Zeeb * 1557*5c1def83SBjoern A. Zeeb * fw_metadata 1558*5c1def83SBjoern A. Zeeb * Meta data used by FW. 1559*5c1def83SBjoern A. Zeeb * In case of gather field in first source ring entry of 1560*5c1def83SBjoern A. Zeeb * the gather copy cycle in taken into account. 1561*5c1def83SBjoern A. Zeeb * 1562*5c1def83SBjoern A. Zeeb * ce_res_1 1563*5c1def83SBjoern A. Zeeb * Reserved 1564*5c1def83SBjoern A. Zeeb * 1565*5c1def83SBjoern A. Zeeb * ce_res_2 1566*5c1def83SBjoern A. Zeeb * Reserved 1567*5c1def83SBjoern A. Zeeb * 1568*5c1def83SBjoern A. Zeeb * ring_id 1569*5c1def83SBjoern A. Zeeb * The buffer pointer ring ID. 1570*5c1def83SBjoern A. Zeeb * 0 refers to the IDLE ring 1571*5c1def83SBjoern A. Zeeb * 1 - N refers to other rings 1572*5c1def83SBjoern A. Zeeb * Helps with debugging when dumping ring contents. 1573*5c1def83SBjoern A. Zeeb * 1574*5c1def83SBjoern A. Zeeb * looping_count 1575*5c1def83SBjoern A. Zeeb * A count value that indicates the number of times the 1576*5c1def83SBjoern A. Zeeb * producer of entries into the Ring has looped around the 1577*5c1def83SBjoern A. Zeeb * ring. 1578*5c1def83SBjoern A. Zeeb * 1579*5c1def83SBjoern A. Zeeb * At initialization time, this value is set to 0. On the 1580*5c1def83SBjoern A. Zeeb * first loop, this value is set to 1. After the max value is 1581*5c1def83SBjoern A. Zeeb * reached allowed by the number of bits for this field, the 1582*5c1def83SBjoern A. Zeeb * count value continues with 0 again. 1583*5c1def83SBjoern A. Zeeb * 1584*5c1def83SBjoern A. Zeeb * In case SW is the consumer of the ring entries, it can 1585*5c1def83SBjoern A. Zeeb * use this field to figure out up to where the producer of 1586*5c1def83SBjoern A. Zeeb * entries has created new entries. This eliminates the need to 1587*5c1def83SBjoern A. Zeeb * check where the head pointer' of the ring is located once 1588*5c1def83SBjoern A. Zeeb * the SW starts processing an interrupt indicating that new 1589*5c1def83SBjoern A. Zeeb * entries have been put into this ring... 1590*5c1def83SBjoern A. Zeeb * 1591*5c1def83SBjoern A. Zeeb * Also note that SW if it wants only needs to look at the 1592*5c1def83SBjoern A. Zeeb * LSB bit of this count value. 1593*5c1def83SBjoern A. Zeeb */ 1594*5c1def83SBjoern A. Zeeb 1595*5c1def83SBjoern A. Zeeb #define HAL_CE_DEST_DESC_ADDR_INFO_ADDR_HI GENMASK(7, 0) 1596*5c1def83SBjoern A. Zeeb #define HAL_CE_DEST_DESC_ADDR_INFO_RING_ID GENMASK(27, 20) 1597*5c1def83SBjoern A. Zeeb #define HAL_CE_DEST_DESC_ADDR_INFO_LOOP_CNT HAL_SRNG_DESC_LOOP_CNT 1598*5c1def83SBjoern A. Zeeb 1599*5c1def83SBjoern A. Zeeb struct hal_ce_srng_dest_desc { 1600*5c1def83SBjoern A. Zeeb __le32 buffer_addr_low; 1601*5c1def83SBjoern A. Zeeb __le32 buffer_addr_info; /* %HAL_CE_DEST_DESC_ADDR_INFO_ */ 1602*5c1def83SBjoern A. Zeeb } __packed; 1603*5c1def83SBjoern A. Zeeb 1604*5c1def83SBjoern A. Zeeb /* hal_ce_srng_dest_desc 1605*5c1def83SBjoern A. Zeeb * 1606*5c1def83SBjoern A. Zeeb * dst_buffer_low 1607*5c1def83SBjoern A. Zeeb * LSB 32 bits of the 40 Bit Pointer to the Destination 1608*5c1def83SBjoern A. Zeeb * buffer 1609*5c1def83SBjoern A. Zeeb * 1610*5c1def83SBjoern A. Zeeb * dst_buffer_high 1611*5c1def83SBjoern A. Zeeb * MSB 8 bits of the 40 Bit Pointer to the Destination 1612*5c1def83SBjoern A. Zeeb * buffer 1613*5c1def83SBjoern A. Zeeb * 1614*5c1def83SBjoern A. Zeeb * ce_res_4 1615*5c1def83SBjoern A. Zeeb * Reserved 1616*5c1def83SBjoern A. Zeeb * 1617*5c1def83SBjoern A. Zeeb * ring_id 1618*5c1def83SBjoern A. Zeeb * The buffer pointer ring ID. 1619*5c1def83SBjoern A. Zeeb * 0 refers to the IDLE ring 1620*5c1def83SBjoern A. Zeeb * 1 - N refers to other rings 1621*5c1def83SBjoern A. Zeeb * Helps with debugging when dumping ring contents. 1622*5c1def83SBjoern A. Zeeb * 1623*5c1def83SBjoern A. Zeeb * looping_count 1624*5c1def83SBjoern A. Zeeb * A count value that indicates the number of times the 1625*5c1def83SBjoern A. Zeeb * producer of entries into the Ring has looped around the 1626*5c1def83SBjoern A. Zeeb * ring. 1627*5c1def83SBjoern A. Zeeb * 1628*5c1def83SBjoern A. Zeeb * At initialization time, this value is set to 0. On the 1629*5c1def83SBjoern A. Zeeb * first loop, this value is set to 1. After the max value is 1630*5c1def83SBjoern A. Zeeb * reached allowed by the number of bits for this field, the 1631*5c1def83SBjoern A. Zeeb * count value continues with 0 again. 1632*5c1def83SBjoern A. Zeeb * 1633*5c1def83SBjoern A. Zeeb * In case SW is the consumer of the ring entries, it can 1634*5c1def83SBjoern A. Zeeb * use this field to figure out up to where the producer of 1635*5c1def83SBjoern A. Zeeb * entries has created new entries. This eliminates the need to 1636*5c1def83SBjoern A. Zeeb * check where the head pointer' of the ring is located once 1637*5c1def83SBjoern A. Zeeb * the SW starts processing an interrupt indicating that new 1638*5c1def83SBjoern A. Zeeb * entries have been put into this ring... 1639*5c1def83SBjoern A. Zeeb * 1640*5c1def83SBjoern A. Zeeb * Also note that SW if it wants only needs to look at the 1641*5c1def83SBjoern A. Zeeb * LSB bit of this count value. 1642*5c1def83SBjoern A. Zeeb */ 1643*5c1def83SBjoern A. Zeeb 1644*5c1def83SBjoern A. Zeeb #define HAL_CE_DST_STATUS_DESC_FLAGS_HASH_EN BIT(8) 1645*5c1def83SBjoern A. Zeeb #define HAL_CE_DST_STATUS_DESC_FLAGS_BYTE_SWAP BIT(9) 1646*5c1def83SBjoern A. Zeeb #define HAL_CE_DST_STATUS_DESC_FLAGS_DEST_SWAP BIT(10) 1647*5c1def83SBjoern A. Zeeb #define HAL_CE_DST_STATUS_DESC_FLAGS_GATHER BIT(11) 1648*5c1def83SBjoern A. Zeeb #define HAL_CE_DST_STATUS_DESC_FLAGS_LEN GENMASK(31, 16) 1649*5c1def83SBjoern A. Zeeb 1650*5c1def83SBjoern A. Zeeb #define HAL_CE_DST_STATUS_DESC_META_INFO_DATA GENMASK(15, 0) 1651*5c1def83SBjoern A. Zeeb #define HAL_CE_DST_STATUS_DESC_META_INFO_RING_ID GENMASK(27, 20) 1652*5c1def83SBjoern A. Zeeb #define HAL_CE_DST_STATUS_DESC_META_INFO_LOOP_CNT HAL_SRNG_DESC_LOOP_CNT 1653*5c1def83SBjoern A. Zeeb 1654*5c1def83SBjoern A. Zeeb struct hal_ce_srng_dst_status_desc { 1655*5c1def83SBjoern A. Zeeb __le32 flags; /* %HAL_CE_DST_STATUS_DESC_FLAGS_ */ 1656*5c1def83SBjoern A. Zeeb __le32 toeplitz_hash0; 1657*5c1def83SBjoern A. Zeeb __le32 toeplitz_hash1; 1658*5c1def83SBjoern A. Zeeb __le32 meta_info; /* HAL_CE_DST_STATUS_DESC_META_INFO_ */ 1659*5c1def83SBjoern A. Zeeb } __packed; 1660*5c1def83SBjoern A. Zeeb 1661*5c1def83SBjoern A. Zeeb /* hal_ce_srng_dst_status_desc 1662*5c1def83SBjoern A. Zeeb * 1663*5c1def83SBjoern A. Zeeb * ce_res_5 1664*5c1def83SBjoern A. Zeeb * Reserved 1665*5c1def83SBjoern A. Zeeb * 1666*5c1def83SBjoern A. Zeeb * toeplitz_en 1667*5c1def83SBjoern A. Zeeb * 1668*5c1def83SBjoern A. Zeeb * src_swap 1669*5c1def83SBjoern A. Zeeb * Source memory buffer swapped 1670*5c1def83SBjoern A. Zeeb * 1671*5c1def83SBjoern A. Zeeb * dest_swap 1672*5c1def83SBjoern A. Zeeb * Destination memory buffer swapped 1673*5c1def83SBjoern A. Zeeb * 1674*5c1def83SBjoern A. Zeeb * gather 1675*5c1def83SBjoern A. Zeeb * Gather of multiple copy engine source descriptors to one 1676*5c1def83SBjoern A. Zeeb * destination enabled 1677*5c1def83SBjoern A. Zeeb * 1678*5c1def83SBjoern A. Zeeb * ce_res_6 1679*5c1def83SBjoern A. Zeeb * Reserved 1680*5c1def83SBjoern A. Zeeb * 1681*5c1def83SBjoern A. Zeeb * length 1682*5c1def83SBjoern A. Zeeb * Sum of all the Lengths of the source descriptor in the 1683*5c1def83SBjoern A. Zeeb * gather chain 1684*5c1def83SBjoern A. Zeeb * 1685*5c1def83SBjoern A. Zeeb * toeplitz_hash_0 1686*5c1def83SBjoern A. Zeeb * 32 LS bits of 64 bit Toeplitz LFSR hash result 1687*5c1def83SBjoern A. Zeeb * 1688*5c1def83SBjoern A. Zeeb * toeplitz_hash_1 1689*5c1def83SBjoern A. Zeeb * 32 MS bits of 64 bit Toeplitz LFSR hash result 1690*5c1def83SBjoern A. Zeeb * 1691*5c1def83SBjoern A. Zeeb * fw_metadata 1692*5c1def83SBjoern A. Zeeb * Meta data used by FW 1693*5c1def83SBjoern A. Zeeb * In case of gather field in first source ring entry of 1694*5c1def83SBjoern A. Zeeb * the gather copy cycle in taken into account. 1695*5c1def83SBjoern A. Zeeb * 1696*5c1def83SBjoern A. Zeeb * ce_res_7 1697*5c1def83SBjoern A. Zeeb * Reserved 1698*5c1def83SBjoern A. Zeeb * 1699*5c1def83SBjoern A. Zeeb * ring_id 1700*5c1def83SBjoern A. Zeeb * The buffer pointer ring ID. 1701*5c1def83SBjoern A. Zeeb * 0 refers to the IDLE ring 1702*5c1def83SBjoern A. Zeeb * 1 - N refers to other rings 1703*5c1def83SBjoern A. Zeeb * Helps with debugging when dumping ring contents. 1704*5c1def83SBjoern A. Zeeb * 1705*5c1def83SBjoern A. Zeeb * looping_count 1706*5c1def83SBjoern A. Zeeb * A count value that indicates the number of times the 1707*5c1def83SBjoern A. Zeeb * producer of entries into the Ring has looped around the 1708*5c1def83SBjoern A. Zeeb * ring. 1709*5c1def83SBjoern A. Zeeb * 1710*5c1def83SBjoern A. Zeeb * At initialization time, this value is set to 0. On the 1711*5c1def83SBjoern A. Zeeb * first loop, this value is set to 1. After the max value is 1712*5c1def83SBjoern A. Zeeb * reached allowed by the number of bits for this field, the 1713*5c1def83SBjoern A. Zeeb * count value continues with 0 again. 1714*5c1def83SBjoern A. Zeeb * 1715*5c1def83SBjoern A. Zeeb * In case SW is the consumer of the ring entries, it can 1716*5c1def83SBjoern A. Zeeb * use this field to figure out up to where the producer of 1717*5c1def83SBjoern A. Zeeb * entries has created new entries. This eliminates the need to 1718*5c1def83SBjoern A. Zeeb * check where the head pointer' of the ring is located once 1719*5c1def83SBjoern A. Zeeb * the SW starts processing an interrupt indicating that new 1720*5c1def83SBjoern A. Zeeb * entries have been put into this ring... 1721*5c1def83SBjoern A. Zeeb * 1722*5c1def83SBjoern A. Zeeb * Also note that SW if it wants only needs to look at the 1723*5c1def83SBjoern A. Zeeb * LSB bit of this count value. 1724*5c1def83SBjoern A. Zeeb */ 1725*5c1def83SBjoern A. Zeeb 1726*5c1def83SBjoern A. Zeeb #define HAL_TX_RATE_STATS_INFO0_VALID BIT(0) 1727*5c1def83SBjoern A. Zeeb #define HAL_TX_RATE_STATS_INFO0_BW GENMASK(3, 1) 1728*5c1def83SBjoern A. Zeeb #define HAL_TX_RATE_STATS_INFO0_PKT_TYPE GENMASK(7, 4) 1729*5c1def83SBjoern A. Zeeb #define HAL_TX_RATE_STATS_INFO0_STBC BIT(8) 1730*5c1def83SBjoern A. Zeeb #define HAL_TX_RATE_STATS_INFO0_LDPC BIT(9) 1731*5c1def83SBjoern A. Zeeb #define HAL_TX_RATE_STATS_INFO0_SGI GENMASK(11, 10) 1732*5c1def83SBjoern A. Zeeb #define HAL_TX_RATE_STATS_INFO0_MCS GENMASK(15, 12) 1733*5c1def83SBjoern A. Zeeb #define HAL_TX_RATE_STATS_INFO0_OFDMA_TX BIT(16) 1734*5c1def83SBjoern A. Zeeb #define HAL_TX_RATE_STATS_INFO0_TONES_IN_RU GENMASK(28, 17) 1735*5c1def83SBjoern A. Zeeb 1736*5c1def83SBjoern A. Zeeb enum hal_tx_rate_stats_bw { 1737*5c1def83SBjoern A. Zeeb HAL_TX_RATE_STATS_BW_20, 1738*5c1def83SBjoern A. Zeeb HAL_TX_RATE_STATS_BW_40, 1739*5c1def83SBjoern A. Zeeb HAL_TX_RATE_STATS_BW_80, 1740*5c1def83SBjoern A. Zeeb HAL_TX_RATE_STATS_BW_160, 1741*5c1def83SBjoern A. Zeeb }; 1742*5c1def83SBjoern A. Zeeb 1743*5c1def83SBjoern A. Zeeb enum hal_tx_rate_stats_pkt_type { 1744*5c1def83SBjoern A. Zeeb HAL_TX_RATE_STATS_PKT_TYPE_11A, 1745*5c1def83SBjoern A. Zeeb HAL_TX_RATE_STATS_PKT_TYPE_11B, 1746*5c1def83SBjoern A. Zeeb HAL_TX_RATE_STATS_PKT_TYPE_11N, 1747*5c1def83SBjoern A. Zeeb HAL_TX_RATE_STATS_PKT_TYPE_11AC, 1748*5c1def83SBjoern A. Zeeb HAL_TX_RATE_STATS_PKT_TYPE_11AX, 1749*5c1def83SBjoern A. Zeeb HAL_TX_RATE_STATS_PKT_TYPE_11BA, 1750*5c1def83SBjoern A. Zeeb HAL_TX_RATE_STATS_PKT_TYPE_11BE, 1751*5c1def83SBjoern A. Zeeb }; 1752*5c1def83SBjoern A. Zeeb 1753*5c1def83SBjoern A. Zeeb enum hal_tx_rate_stats_sgi { 1754*5c1def83SBjoern A. Zeeb HAL_TX_RATE_STATS_SGI_08US, 1755*5c1def83SBjoern A. Zeeb HAL_TX_RATE_STATS_SGI_04US, 1756*5c1def83SBjoern A. Zeeb HAL_TX_RATE_STATS_SGI_16US, 1757*5c1def83SBjoern A. Zeeb HAL_TX_RATE_STATS_SGI_32US, 1758*5c1def83SBjoern A. Zeeb }; 1759*5c1def83SBjoern A. Zeeb 1760*5c1def83SBjoern A. Zeeb struct hal_tx_rate_stats { 1761*5c1def83SBjoern A. Zeeb __le32 info0; 1762*5c1def83SBjoern A. Zeeb __le32 tsf; 1763*5c1def83SBjoern A. Zeeb } __packed; 1764*5c1def83SBjoern A. Zeeb 1765*5c1def83SBjoern A. Zeeb struct hal_wbm_link_desc { 1766*5c1def83SBjoern A. Zeeb struct ath12k_buffer_addr buf_addr_info; 1767*5c1def83SBjoern A. Zeeb } __packed; 1768*5c1def83SBjoern A. Zeeb 1769*5c1def83SBjoern A. Zeeb /* hal_wbm_link_desc 1770*5c1def83SBjoern A. Zeeb * 1771*5c1def83SBjoern A. Zeeb * Producer: WBM 1772*5c1def83SBjoern A. Zeeb * Consumer: WBM 1773*5c1def83SBjoern A. Zeeb * 1774*5c1def83SBjoern A. Zeeb * buf_addr_info 1775*5c1def83SBjoern A. Zeeb * Details of the physical address of a buffer or MSDU 1776*5c1def83SBjoern A. Zeeb * link descriptor. 1777*5c1def83SBjoern A. Zeeb */ 1778*5c1def83SBjoern A. Zeeb 1779*5c1def83SBjoern A. Zeeb enum hal_wbm_rel_src_module { 1780*5c1def83SBjoern A. Zeeb HAL_WBM_REL_SRC_MODULE_TQM, 1781*5c1def83SBjoern A. Zeeb HAL_WBM_REL_SRC_MODULE_RXDMA, 1782*5c1def83SBjoern A. Zeeb HAL_WBM_REL_SRC_MODULE_REO, 1783*5c1def83SBjoern A. Zeeb HAL_WBM_REL_SRC_MODULE_FW, 1784*5c1def83SBjoern A. Zeeb HAL_WBM_REL_SRC_MODULE_SW, 1785*5c1def83SBjoern A. Zeeb }; 1786*5c1def83SBjoern A. Zeeb 1787*5c1def83SBjoern A. Zeeb enum hal_wbm_rel_desc_type { 1788*5c1def83SBjoern A. Zeeb HAL_WBM_REL_DESC_TYPE_REL_MSDU, 1789*5c1def83SBjoern A. Zeeb HAL_WBM_REL_DESC_TYPE_MSDU_LINK, 1790*5c1def83SBjoern A. Zeeb HAL_WBM_REL_DESC_TYPE_MPDU_LINK, 1791*5c1def83SBjoern A. Zeeb HAL_WBM_REL_DESC_TYPE_MSDU_EXT, 1792*5c1def83SBjoern A. Zeeb HAL_WBM_REL_DESC_TYPE_QUEUE_EXT, 1793*5c1def83SBjoern A. Zeeb }; 1794*5c1def83SBjoern A. Zeeb 1795*5c1def83SBjoern A. Zeeb /* hal_wbm_rel_desc_type 1796*5c1def83SBjoern A. Zeeb * 1797*5c1def83SBjoern A. Zeeb * msdu_buffer 1798*5c1def83SBjoern A. Zeeb * The address points to an MSDU buffer 1799*5c1def83SBjoern A. Zeeb * 1800*5c1def83SBjoern A. Zeeb * msdu_link_descriptor 1801*5c1def83SBjoern A. Zeeb * The address points to an Tx MSDU link descriptor 1802*5c1def83SBjoern A. Zeeb * 1803*5c1def83SBjoern A. Zeeb * mpdu_link_descriptor 1804*5c1def83SBjoern A. Zeeb * The address points to an MPDU link descriptor 1805*5c1def83SBjoern A. Zeeb * 1806*5c1def83SBjoern A. Zeeb * msdu_ext_descriptor 1807*5c1def83SBjoern A. Zeeb * The address points to an MSDU extension descriptor 1808*5c1def83SBjoern A. Zeeb * 1809*5c1def83SBjoern A. Zeeb * queue_ext_descriptor 1810*5c1def83SBjoern A. Zeeb * The address points to an TQM queue extension descriptor. WBM should 1811*5c1def83SBjoern A. Zeeb * treat this is the same way as a link descriptor. 1812*5c1def83SBjoern A. Zeeb */ 1813*5c1def83SBjoern A. Zeeb 1814*5c1def83SBjoern A. Zeeb enum hal_wbm_rel_bm_act { 1815*5c1def83SBjoern A. Zeeb HAL_WBM_REL_BM_ACT_PUT_IN_IDLE, 1816*5c1def83SBjoern A. Zeeb HAL_WBM_REL_BM_ACT_REL_MSDU, 1817*5c1def83SBjoern A. Zeeb }; 1818*5c1def83SBjoern A. Zeeb 1819*5c1def83SBjoern A. Zeeb /* hal_wbm_rel_bm_act 1820*5c1def83SBjoern A. Zeeb * 1821*5c1def83SBjoern A. Zeeb * put_in_idle_list 1822*5c1def83SBjoern A. Zeeb * Put the buffer or descriptor back in the idle list. In case of MSDU or 1823*5c1def83SBjoern A. Zeeb * MDPU link descriptor, BM does not need to check to release any 1824*5c1def83SBjoern A. Zeeb * individual MSDU buffers. 1825*5c1def83SBjoern A. Zeeb * 1826*5c1def83SBjoern A. Zeeb * release_msdu_list 1827*5c1def83SBjoern A. Zeeb * This BM action can only be used in combination with desc_type being 1828*5c1def83SBjoern A. Zeeb * msdu_link_descriptor. Field first_msdu_index points out which MSDU 1829*5c1def83SBjoern A. Zeeb * pointer in the MSDU link descriptor is the first of an MPDU that is 1830*5c1def83SBjoern A. Zeeb * released. BM shall release all the MSDU buffers linked to this first 1831*5c1def83SBjoern A. Zeeb * MSDU buffer pointer. All related MSDU buffer pointer entries shall be 1832*5c1def83SBjoern A. Zeeb * set to value 0, which represents the 'NULL' pointer. When all MSDU 1833*5c1def83SBjoern A. Zeeb * buffer pointers in the MSDU link descriptor are 'NULL', the MSDU link 1834*5c1def83SBjoern A. Zeeb * descriptor itself shall also be released. 1835*5c1def83SBjoern A. Zeeb */ 1836*5c1def83SBjoern A. Zeeb #define HAL_WBM_COMPL_RX_INFO0_REL_SRC_MODULE GENMASK(2, 0) 1837*5c1def83SBjoern A. Zeeb #define HAL_WBM_COMPL_RX_INFO0_BM_ACTION GENMASK(5, 3) 1838*5c1def83SBjoern A. Zeeb #define HAL_WBM_COMPL_RX_INFO0_DESC_TYPE GENMASK(8, 6) 1839*5c1def83SBjoern A. Zeeb #define HAL_WBM_COMPL_RX_INFO0_RBM GENMASK(12, 9) 1840*5c1def83SBjoern A. Zeeb #define HAL_WBM_COMPL_RX_INFO0_RXDMA_PUSH_REASON GENMASK(18, 17) 1841*5c1def83SBjoern A. Zeeb #define HAL_WBM_COMPL_RX_INFO0_RXDMA_ERROR_CODE GENMASK(23, 19) 1842*5c1def83SBjoern A. Zeeb #define HAL_WBM_COMPL_RX_INFO0_REO_PUSH_REASON GENMASK(25, 24) 1843*5c1def83SBjoern A. Zeeb #define HAL_WBM_COMPL_RX_INFO0_REO_ERROR_CODE GENMASK(30, 26) 1844*5c1def83SBjoern A. Zeeb #define HAL_WBM_COMPL_RX_INFO0_WBM_INTERNAL_ERROR BIT(31) 1845*5c1def83SBjoern A. Zeeb 1846*5c1def83SBjoern A. Zeeb #define HAL_WBM_COMPL_RX_INFO1_PHY_ADDR_HI GENMASK(7, 0) 1847*5c1def83SBjoern A. Zeeb #define HAL_WBM_COMPL_RX_INFO1_SW_COOKIE GENMASK(27, 8) 1848*5c1def83SBjoern A. Zeeb #define HAL_WBM_COMPL_RX_INFO1_LOOPING_COUNT GENMASK(31, 28) 1849*5c1def83SBjoern A. Zeeb 1850*5c1def83SBjoern A. Zeeb struct hal_wbm_completion_ring_rx { 1851*5c1def83SBjoern A. Zeeb __le32 addr_lo; 1852*5c1def83SBjoern A. Zeeb __le32 addr_hi; 1853*5c1def83SBjoern A. Zeeb __le32 info0; 1854*5c1def83SBjoern A. Zeeb struct rx_mpdu_desc rx_mpdu_info; 1855*5c1def83SBjoern A. Zeeb struct rx_msdu_desc rx_msdu_info; 1856*5c1def83SBjoern A. Zeeb __le32 phy_addr_lo; 1857*5c1def83SBjoern A. Zeeb __le32 info1; 1858*5c1def83SBjoern A. Zeeb } __packed; 1859*5c1def83SBjoern A. Zeeb 1860*5c1def83SBjoern A. Zeeb #define HAL_WBM_COMPL_TX_INFO0_REL_SRC_MODULE GENMASK(2, 0) 1861*5c1def83SBjoern A. Zeeb #define HAL_WBM_COMPL_TX_INFO0_DESC_TYPE GENMASK(8, 6) 1862*5c1def83SBjoern A. Zeeb #define HAL_WBM_COMPL_TX_INFO0_RBM GENMASK(12, 9) 1863*5c1def83SBjoern A. Zeeb #define HAL_WBM_COMPL_TX_INFO0_TQM_RELEASE_REASON GENMASK(16, 13) 1864*5c1def83SBjoern A. Zeeb #define HAL_WBM_COMPL_TX_INFO0_RBM_OVERRIDE_VLD BIT(17) 1865*5c1def83SBjoern A. Zeeb #define HAL_WBM_COMPL_TX_INFO0_SW_COOKIE_LO GENMASK(29, 18) 1866*5c1def83SBjoern A. Zeeb #define HAL_WBM_COMPL_TX_INFO0_CC_DONE BIT(30) 1867*5c1def83SBjoern A. Zeeb #define HAL_WBM_COMPL_TX_INFO0_WBM_INTERNAL_ERROR BIT(31) 1868*5c1def83SBjoern A. Zeeb 1869*5c1def83SBjoern A. Zeeb #define HAL_WBM_COMPL_TX_INFO1_TQM_STATUS_NUMBER GENMASK(23, 0) 1870*5c1def83SBjoern A. Zeeb #define HAL_WBM_COMPL_TX_INFO1_TRANSMIT_COUNT GENMASK(30, 24) 1871*5c1def83SBjoern A. Zeeb #define HAL_WBM_COMPL_TX_INFO1_SW_REL_DETAILS_VALID BIT(31) 1872*5c1def83SBjoern A. Zeeb 1873*5c1def83SBjoern A. Zeeb #define HAL_WBM_COMPL_TX_INFO2_ACK_FRAME_RSSI GENMASK(7, 0) 1874*5c1def83SBjoern A. Zeeb #define HAL_WBM_COMPL_TX_INFO2_FIRST_MSDU BIT(8) 1875*5c1def83SBjoern A. Zeeb #define HAL_WBM_COMPL_TX_INFO2_LAST_MSDU BIT(9) 1876*5c1def83SBjoern A. Zeeb #define HAL_WBM_COMPL_TX_INFO2_FW_TX_NOTIF_FRAME GENMASK(12, 10) 1877*5c1def83SBjoern A. Zeeb #define HAL_WBM_COMPL_TX_INFO2_BUFFER_TIMESTAMP GENMASK(31, 13) 1878*5c1def83SBjoern A. Zeeb 1879*5c1def83SBjoern A. Zeeb #define HAL_WBM_COMPL_TX_INFO3_PEER_ID GENMASK(15, 0) 1880*5c1def83SBjoern A. Zeeb #define HAL_WBM_COMPL_TX_INFO3_TID GENMASK(19, 16) 1881*5c1def83SBjoern A. Zeeb #define HAL_WBM_COMPL_TX_INFO3_SW_COOKIE_HI GENMASK(27, 20) 1882*5c1def83SBjoern A. Zeeb #define HAL_WBM_COMPL_TX_INFO3_LOOPING_COUNT GENMASK(31, 28) 1883*5c1def83SBjoern A. Zeeb 1884*5c1def83SBjoern A. Zeeb struct hal_wbm_completion_ring_tx { 1885*5c1def83SBjoern A. Zeeb __le32 buf_va_lo; 1886*5c1def83SBjoern A. Zeeb __le32 buf_va_hi; 1887*5c1def83SBjoern A. Zeeb __le32 info0; 1888*5c1def83SBjoern A. Zeeb __le32 info1; 1889*5c1def83SBjoern A. Zeeb __le32 info2; 1890*5c1def83SBjoern A. Zeeb struct hal_tx_rate_stats rate_stats; 1891*5c1def83SBjoern A. Zeeb __le32 info3; 1892*5c1def83SBjoern A. Zeeb } __packed; 1893*5c1def83SBjoern A. Zeeb 1894*5c1def83SBjoern A. Zeeb #define HAL_WBM_RELEASE_TX_INFO0_REL_SRC_MODULE GENMASK(2, 0) 1895*5c1def83SBjoern A. Zeeb #define HAL_WBM_RELEASE_TX_INFO0_BM_ACTION GENMASK(5, 3) 1896*5c1def83SBjoern A. Zeeb #define HAL_WBM_RELEASE_TX_INFO0_DESC_TYPE GENMASK(8, 6) 1897*5c1def83SBjoern A. Zeeb #define HAL_WBM_RELEASE_TX_INFO0_FIRST_MSDU_IDX GENMASK(12, 9) 1898*5c1def83SBjoern A. Zeeb #define HAL_WBM_RELEASE_TX_INFO0_TQM_RELEASE_REASON GENMASK(18, 13) 1899*5c1def83SBjoern A. Zeeb #define HAL_WBM_RELEASE_TX_INFO0_RBM_OVERRIDE_VLD BIT(17) 1900*5c1def83SBjoern A. Zeeb #define HAL_WBM_RELEASE_TX_INFO0_SW_BUFFER_COOKIE_11_0 GENMASK(29, 18) 1901*5c1def83SBjoern A. Zeeb #define HAL_WBM_RELEASE_TX_INFO0_WBM_INTERNAL_ERROR BIT(31) 1902*5c1def83SBjoern A. Zeeb 1903*5c1def83SBjoern A. Zeeb #define HAL_WBM_RELEASE_TX_INFO1_TQM_STATUS_NUMBER GENMASK(23, 0) 1904*5c1def83SBjoern A. Zeeb #define HAL_WBM_RELEASE_TX_INFO1_TRANSMIT_COUNT GENMASK(30, 24) 1905*5c1def83SBjoern A. Zeeb #define HAL_WBM_RELEASE_TX_INFO1_SW_REL_DETAILS_VALID BIT(31) 1906*5c1def83SBjoern A. Zeeb 1907*5c1def83SBjoern A. Zeeb #define HAL_WBM_RELEASE_TX_INFO2_ACK_FRAME_RSSI GENMASK(7, 0) 1908*5c1def83SBjoern A. Zeeb #define HAL_WBM_RELEASE_TX_INFO2_FIRST_MSDU BIT(8) 1909*5c1def83SBjoern A. Zeeb #define HAL_WBM_RELEASE_TX_INFO2_LAST_MSDU BIT(9) 1910*5c1def83SBjoern A. Zeeb #define HAL_WBM_RELEASE_TX_INFO2_FW_TX_NOTIF_FRAME GENMASK(12, 10) 1911*5c1def83SBjoern A. Zeeb #define HAL_WBM_RELEASE_TX_INFO2_BUFFER_TIMESTAMP GENMASK(31, 13) 1912*5c1def83SBjoern A. Zeeb 1913*5c1def83SBjoern A. Zeeb #define HAL_WBM_RELEASE_TX_INFO3_PEER_ID GENMASK(15, 0) 1914*5c1def83SBjoern A. Zeeb #define HAL_WBM_RELEASE_TX_INFO3_TID GENMASK(19, 16) 1915*5c1def83SBjoern A. Zeeb #define HAL_WBM_RELEASE_TX_INFO3_SW_BUFFER_COOKIE_19_12 GENMASK(27, 20) 1916*5c1def83SBjoern A. Zeeb #define HAL_WBM_RELEASE_TX_INFO3_LOOPING_COUNT GENMASK(31, 28) 1917*5c1def83SBjoern A. Zeeb 1918*5c1def83SBjoern A. Zeeb struct hal_wbm_release_ring_tx { 1919*5c1def83SBjoern A. Zeeb struct ath12k_buffer_addr buf_addr_info; 1920*5c1def83SBjoern A. Zeeb __le32 info0; 1921*5c1def83SBjoern A. Zeeb __le32 info1; 1922*5c1def83SBjoern A. Zeeb __le32 info2; 1923*5c1def83SBjoern A. Zeeb struct hal_tx_rate_stats rate_stats; 1924*5c1def83SBjoern A. Zeeb __le32 info3; 1925*5c1def83SBjoern A. Zeeb } __packed; 1926*5c1def83SBjoern A. Zeeb 1927*5c1def83SBjoern A. Zeeb #define HAL_WBM_RELEASE_RX_INFO0_REL_SRC_MODULE GENMASK(2, 0) 1928*5c1def83SBjoern A. Zeeb #define HAL_WBM_RELEASE_RX_INFO0_BM_ACTION GENMASK(5, 3) 1929*5c1def83SBjoern A. Zeeb #define HAL_WBM_RELEASE_RX_INFO0_DESC_TYPE GENMASK(8, 6) 1930*5c1def83SBjoern A. Zeeb #define HAL_WBM_RELEASE_RX_INFO0_FIRST_MSDU_IDX GENMASK(12, 9) 1931*5c1def83SBjoern A. Zeeb #define HAL_WBM_RELEASE_RX_INFO0_CC_STATUS BIT(16) 1932*5c1def83SBjoern A. Zeeb #define HAL_WBM_RELEASE_RX_INFO0_RXDMA_PUSH_REASON GENMASK(18, 17) 1933*5c1def83SBjoern A. Zeeb #define HAL_WBM_RELEASE_RX_INFO0_RXDMA_ERROR_CODE GENMASK(23, 19) 1934*5c1def83SBjoern A. Zeeb #define HAL_WBM_RELEASE_RX_INFO0_REO_PUSH_REASON GENMASK(25, 24) 1935*5c1def83SBjoern A. Zeeb #define HAL_WBM_RELEASE_RX_INFO0_REO_ERROR_CODE GENMASK(30, 26) 1936*5c1def83SBjoern A. Zeeb #define HAL_WBM_RELEASE_RX_INFO0_WBM_INTERNAL_ERROR BIT(31) 1937*5c1def83SBjoern A. Zeeb 1938*5c1def83SBjoern A. Zeeb #define HAL_WBM_RELEASE_RX_INFO2_RING_ID GENMASK(27, 20) 1939*5c1def83SBjoern A. Zeeb #define HAL_WBM_RELEASE_RX_INFO2_LOOPING_COUNT GENMASK(31, 28) 1940*5c1def83SBjoern A. Zeeb 1941*5c1def83SBjoern A. Zeeb struct hal_wbm_release_ring_rx { 1942*5c1def83SBjoern A. Zeeb struct ath12k_buffer_addr buf_addr_info; 1943*5c1def83SBjoern A. Zeeb __le32 info0; 1944*5c1def83SBjoern A. Zeeb struct rx_mpdu_desc rx_mpdu_info; 1945*5c1def83SBjoern A. Zeeb struct rx_msdu_desc rx_msdu_info; 1946*5c1def83SBjoern A. Zeeb __le32 info1; 1947*5c1def83SBjoern A. Zeeb __le32 info2; 1948*5c1def83SBjoern A. Zeeb } __packed; 1949*5c1def83SBjoern A. Zeeb 1950*5c1def83SBjoern A. Zeeb #define HAL_WBM_RELEASE_RX_CC_INFO0_RBM GENMASK(12, 9) 1951*5c1def83SBjoern A. Zeeb #define HAL_WBM_RELEASE_RX_CC_INFO1_COOKIE GENMASK(27, 8) 1952*5c1def83SBjoern A. Zeeb /* Used when hw cc is success */ 1953*5c1def83SBjoern A. Zeeb struct hal_wbm_release_ring_cc_rx { 1954*5c1def83SBjoern A. Zeeb __le32 buf_va_lo; 1955*5c1def83SBjoern A. Zeeb __le32 buf_va_hi; 1956*5c1def83SBjoern A. Zeeb __le32 info0; 1957*5c1def83SBjoern A. Zeeb struct rx_mpdu_desc rx_mpdu_info; 1958*5c1def83SBjoern A. Zeeb struct rx_msdu_desc rx_msdu_info; 1959*5c1def83SBjoern A. Zeeb __le32 buf_pa_lo; 1960*5c1def83SBjoern A. Zeeb __le32 info1; 1961*5c1def83SBjoern A. Zeeb } __packed; 1962*5c1def83SBjoern A. Zeeb 1963*5c1def83SBjoern A. Zeeb #define HAL_WBM_RELEASE_INFO0_REL_SRC_MODULE GENMASK(2, 0) 1964*5c1def83SBjoern A. Zeeb #define HAL_WBM_RELEASE_INFO0_BM_ACTION GENMASK(5, 3) 1965*5c1def83SBjoern A. Zeeb #define HAL_WBM_RELEASE_INFO0_DESC_TYPE GENMASK(8, 6) 1966*5c1def83SBjoern A. Zeeb #define HAL_WBM_RELEASE_INFO0_RXDMA_PUSH_REASON GENMASK(18, 17) 1967*5c1def83SBjoern A. Zeeb #define HAL_WBM_RELEASE_INFO0_RXDMA_ERROR_CODE GENMASK(23, 19) 1968*5c1def83SBjoern A. Zeeb #define HAL_WBM_RELEASE_INFO0_REO_PUSH_REASON GENMASK(25, 24) 1969*5c1def83SBjoern A. Zeeb #define HAL_WBM_RELEASE_INFO0_REO_ERROR_CODE GENMASK(30, 26) 1970*5c1def83SBjoern A. Zeeb #define HAL_WBM_RELEASE_INFO0_WBM_INTERNAL_ERROR BIT(31) 1971*5c1def83SBjoern A. Zeeb 1972*5c1def83SBjoern A. Zeeb #define HAL_WBM_RELEASE_INFO3_FIRST_MSDU BIT(0) 1973*5c1def83SBjoern A. Zeeb #define HAL_WBM_RELEASE_INFO3_LAST_MSDU BIT(1) 1974*5c1def83SBjoern A. Zeeb #define HAL_WBM_RELEASE_INFO3_CONTINUATION BIT(2) 1975*5c1def83SBjoern A. Zeeb 1976*5c1def83SBjoern A. Zeeb #define HAL_WBM_RELEASE_INFO5_LOOPING_COUNT GENMASK(31, 28) 1977*5c1def83SBjoern A. Zeeb 1978*5c1def83SBjoern A. Zeeb struct hal_wbm_release_ring { 1979*5c1def83SBjoern A. Zeeb struct ath12k_buffer_addr buf_addr_info; 1980*5c1def83SBjoern A. Zeeb __le32 info0; 1981*5c1def83SBjoern A. Zeeb __le32 info1; 1982*5c1def83SBjoern A. Zeeb __le32 info2; 1983*5c1def83SBjoern A. Zeeb __le32 info3; 1984*5c1def83SBjoern A. Zeeb __le32 info4; 1985*5c1def83SBjoern A. Zeeb __le32 info5; 1986*5c1def83SBjoern A. Zeeb } __packed; 1987*5c1def83SBjoern A. Zeeb 1988*5c1def83SBjoern A. Zeeb /* hal_wbm_release_ring 1989*5c1def83SBjoern A. Zeeb * 1990*5c1def83SBjoern A. Zeeb * Producer: SW/TQM/RXDMA/REO/SWITCH 1991*5c1def83SBjoern A. Zeeb * Consumer: WBM/SW/FW 1992*5c1def83SBjoern A. Zeeb * 1993*5c1def83SBjoern A. Zeeb * HTT tx status is overlaid on wbm_release ring on 4-byte words 2, 3, 4 and 5 1994*5c1def83SBjoern A. Zeeb * for software based completions. 1995*5c1def83SBjoern A. Zeeb * 1996*5c1def83SBjoern A. Zeeb * buf_addr_info 1997*5c1def83SBjoern A. Zeeb * Details of the physical address of the buffer or link descriptor. 1998*5c1def83SBjoern A. Zeeb * 1999*5c1def83SBjoern A. Zeeb * release_source_module 2000*5c1def83SBjoern A. Zeeb * Indicates which module initiated the release of this buffer/descriptor. 2001*5c1def83SBjoern A. Zeeb * Values are defined in enum %HAL_WBM_REL_SRC_MODULE_. 2002*5c1def83SBjoern A. Zeeb * 2003*5c1def83SBjoern A. Zeeb * buffer_or_desc_type 2004*5c1def83SBjoern A. Zeeb * Field only valid when WBM is marked as the return_buffer_manager in 2005*5c1def83SBjoern A. Zeeb * the Released_Buffer_address_info. Indicates that type of buffer or 2006*5c1def83SBjoern A. Zeeb * descriptor is being released. Values are in enum %HAL_WBM_REL_DESC_TYPE. 2007*5c1def83SBjoern A. Zeeb * 2008*5c1def83SBjoern A. Zeeb * wbm_internal_error 2009*5c1def83SBjoern A. Zeeb * Is set when WBM got a buffer pointer but the action was to push it to 2010*5c1def83SBjoern A. Zeeb * the idle link descriptor ring or do link related activity OR 2011*5c1def83SBjoern A. Zeeb * Is set when WBM got a link buffer pointer but the action was to push it 2012*5c1def83SBjoern A. Zeeb * to the buffer descriptor ring. 2013*5c1def83SBjoern A. Zeeb * 2014*5c1def83SBjoern A. Zeeb * looping_count 2015*5c1def83SBjoern A. Zeeb * A count value that indicates the number of times the 2016*5c1def83SBjoern A. Zeeb * producer of entries into the Buffer Manager Ring has looped 2017*5c1def83SBjoern A. Zeeb * around the ring. 2018*5c1def83SBjoern A. Zeeb * 2019*5c1def83SBjoern A. Zeeb * At initialization time, this value is set to 0. On the 2020*5c1def83SBjoern A. Zeeb * first loop, this value is set to 1. After the max value is 2021*5c1def83SBjoern A. Zeeb * reached allowed by the number of bits for this field, the 2022*5c1def83SBjoern A. Zeeb * count value continues with 0 again. 2023*5c1def83SBjoern A. Zeeb * 2024*5c1def83SBjoern A. Zeeb * In case SW is the consumer of the ring entries, it can 2025*5c1def83SBjoern A. Zeeb * use this field to figure out up to where the producer of 2026*5c1def83SBjoern A. Zeeb * entries has created new entries. This eliminates the need to 2027*5c1def83SBjoern A. Zeeb * check where the head pointer' of the ring is located once 2028*5c1def83SBjoern A. Zeeb * the SW starts processing an interrupt indicating that new 2029*5c1def83SBjoern A. Zeeb * entries have been put into this ring... 2030*5c1def83SBjoern A. Zeeb * 2031*5c1def83SBjoern A. Zeeb * Also note that SW if it wants only needs to look at the 2032*5c1def83SBjoern A. Zeeb * LSB bit of this count value. 2033*5c1def83SBjoern A. Zeeb */ 2034*5c1def83SBjoern A. Zeeb 2035*5c1def83SBjoern A. Zeeb /** 2036*5c1def83SBjoern A. Zeeb * enum hal_wbm_tqm_rel_reason - TQM release reason code 2037*5c1def83SBjoern A. Zeeb * @HAL_WBM_TQM_REL_REASON_FRAME_ACKED: ACK or BACK received for the frame 2038*5c1def83SBjoern A. Zeeb * @HAL_WBM_TQM_REL_REASON_CMD_REMOVE_MPDU: Command remove_mpdus initiated by SW 2039*5c1def83SBjoern A. Zeeb * @HAL_WBM_TQM_REL_REASON_CMD_REMOVE_TX: Command remove transmitted_mpdus 2040*5c1def83SBjoern A. Zeeb * initiated by sw. 2041*5c1def83SBjoern A. Zeeb * @HAL_WBM_TQM_REL_REASON_CMD_REMOVE_NOTX: Command remove untransmitted_mpdus 2042*5c1def83SBjoern A. Zeeb * initiated by sw. 2043*5c1def83SBjoern A. Zeeb * @HAL_WBM_TQM_REL_REASON_CMD_REMOVE_AGED_FRAMES: Command remove aged msdus or 2044*5c1def83SBjoern A. Zeeb * mpdus. 2045*5c1def83SBjoern A. Zeeb * @HAL_WBM_TQM_REL_REASON_CMD_REMOVE_RESEAON1: Remove command initiated by 2046*5c1def83SBjoern A. Zeeb * fw with fw_reason1. 2047*5c1def83SBjoern A. Zeeb * @HAL_WBM_TQM_REL_REASON_CMD_REMOVE_RESEAON2: Remove command initiated by 2048*5c1def83SBjoern A. Zeeb * fw with fw_reason2. 2049*5c1def83SBjoern A. Zeeb * @HAL_WBM_TQM_REL_REASON_CMD_REMOVE_RESEAON3: Remove command initiated by 2050*5c1def83SBjoern A. Zeeb * fw with fw_reason3. 2051*5c1def83SBjoern A. Zeeb */ 2052*5c1def83SBjoern A. Zeeb enum hal_wbm_tqm_rel_reason { 2053*5c1def83SBjoern A. Zeeb HAL_WBM_TQM_REL_REASON_FRAME_ACKED, 2054*5c1def83SBjoern A. Zeeb HAL_WBM_TQM_REL_REASON_CMD_REMOVE_MPDU, 2055*5c1def83SBjoern A. Zeeb HAL_WBM_TQM_REL_REASON_CMD_REMOVE_TX, 2056*5c1def83SBjoern A. Zeeb HAL_WBM_TQM_REL_REASON_CMD_REMOVE_NOTX, 2057*5c1def83SBjoern A. Zeeb HAL_WBM_TQM_REL_REASON_CMD_REMOVE_AGED_FRAMES, 2058*5c1def83SBjoern A. Zeeb HAL_WBM_TQM_REL_REASON_CMD_REMOVE_RESEAON1, 2059*5c1def83SBjoern A. Zeeb HAL_WBM_TQM_REL_REASON_CMD_REMOVE_RESEAON2, 2060*5c1def83SBjoern A. Zeeb HAL_WBM_TQM_REL_REASON_CMD_REMOVE_RESEAON3, 2061*5c1def83SBjoern A. Zeeb }; 2062*5c1def83SBjoern A. Zeeb 2063*5c1def83SBjoern A. Zeeb struct hal_wbm_buffer_ring { 2064*5c1def83SBjoern A. Zeeb struct ath12k_buffer_addr buf_addr_info; 2065*5c1def83SBjoern A. Zeeb }; 2066*5c1def83SBjoern A. Zeeb 2067*5c1def83SBjoern A. Zeeb enum hal_mon_end_reason { 2068*5c1def83SBjoern A. Zeeb HAL_MON_STATUS_BUFFER_FULL, 2069*5c1def83SBjoern A. Zeeb HAL_MON_FLUSH_DETECTED, 2070*5c1def83SBjoern A. Zeeb HAL_MON_END_OF_PPDU, 2071*5c1def83SBjoern A. Zeeb HAL_MON_PPDU_TRUNCATED, 2072*5c1def83SBjoern A. Zeeb }; 2073*5c1def83SBjoern A. Zeeb 2074*5c1def83SBjoern A. Zeeb #define HAL_SW_MONITOR_RING_INFO0_RXDMA_PUSH_REASON GENMASK(1, 0) 2075*5c1def83SBjoern A. Zeeb #define HAL_SW_MONITOR_RING_INFO0_RXDMA_ERROR_CODE GENMASK(6, 2) 2076*5c1def83SBjoern A. Zeeb #define HAL_SW_MONITOR_RING_INFO0_MPDU_FRAGMENT_NUMBER GENMASK(10, 7) 2077*5c1def83SBjoern A. Zeeb #define HAL_SW_MONITOR_RING_INFO0_FRAMELESS_BAR BIT(11) 2078*5c1def83SBjoern A. Zeeb #define HAL_SW_MONITOR_RING_INFO0_STATUS_BUF_COUNT GENMASK(15, 12) 2079*5c1def83SBjoern A. Zeeb #define HAL_SW_MONITOR_RING_INFO0_END_OF_PPDU BIT(16) 2080*5c1def83SBjoern A. Zeeb 2081*5c1def83SBjoern A. Zeeb #define HAL_SW_MONITOR_RING_INFO1_PHY_PPDU_ID GENMASK(15, 0) 2082*5c1def83SBjoern A. Zeeb #define HAL_SW_MONITOR_RING_INFO1_RING_ID GENMASK(27, 20) 2083*5c1def83SBjoern A. Zeeb #define HAL_SW_MONITOR_RING_INFO1_LOOPING_COUNT GENMASK(31, 28) 2084*5c1def83SBjoern A. Zeeb 2085*5c1def83SBjoern A. Zeeb struct hal_sw_monitor_ring { 2086*5c1def83SBjoern A. Zeeb struct ath12k_buffer_addr buf_addr_info; 2087*5c1def83SBjoern A. Zeeb struct rx_mpdu_desc rx_mpdu_info; 2088*5c1def83SBjoern A. Zeeb struct ath12k_buffer_addr status_buff_addr_info; 2089*5c1def83SBjoern A. Zeeb __le32 info0; /* %HAL_SW_MONITOR_RING_INFO0 */ 2090*5c1def83SBjoern A. Zeeb __le32 info1; /* %HAL_SW_MONITOR_RING_INFO1 */ 2091*5c1def83SBjoern A. Zeeb } __packed; 2092*5c1def83SBjoern A. Zeeb 2093*5c1def83SBjoern A. Zeeb /* hal_sw_monitor_ring 2094*5c1def83SBjoern A. Zeeb * 2095*5c1def83SBjoern A. Zeeb * Producer: RXDMA 2096*5c1def83SBjoern A. Zeeb * Consumer: REO/SW/FW 2097*5c1def83SBjoern A. Zeeb * buf_addr_info 2098*5c1def83SBjoern A. Zeeb * Details of the physical address of a buffer or MSDU 2099*5c1def83SBjoern A. Zeeb * link descriptor. 2100*5c1def83SBjoern A. Zeeb * 2101*5c1def83SBjoern A. Zeeb * rx_mpdu_info 2102*5c1def83SBjoern A. Zeeb * Details related to the MPDU being pushed to SW, valid 2103*5c1def83SBjoern A. Zeeb * only if end_of_ppdu is set to 0. 2104*5c1def83SBjoern A. Zeeb * 2105*5c1def83SBjoern A. Zeeb * status_buff_addr_info 2106*5c1def83SBjoern A. Zeeb * Details of the physical address of the first status 2107*5c1def83SBjoern A. Zeeb * buffer used for the PPDU (either the PPDU that included the 2108*5c1def83SBjoern A. Zeeb * MPDU being pushed to SW if end_of_ppdu = 0, or the PPDU 2109*5c1def83SBjoern A. Zeeb * whose end is indicated through end_of_ppdu = 1) 2110*5c1def83SBjoern A. Zeeb * 2111*5c1def83SBjoern A. Zeeb * rxdma_push_reason 2112*5c1def83SBjoern A. Zeeb * Indicates why RXDMA pushed the frame to this ring 2113*5c1def83SBjoern A. Zeeb * 2114*5c1def83SBjoern A. Zeeb * <enum 0 rxdma_error_detected> RXDMA detected an error an 2115*5c1def83SBjoern A. Zeeb * pushed this frame to this queue 2116*5c1def83SBjoern A. Zeeb * 2117*5c1def83SBjoern A. Zeeb * <enum 1 rxdma_routing_instruction> RXDMA pushed the 2118*5c1def83SBjoern A. Zeeb * frame to this queue per received routing instructions. No 2119*5c1def83SBjoern A. Zeeb * error within RXDMA was detected 2120*5c1def83SBjoern A. Zeeb * 2121*5c1def83SBjoern A. Zeeb * <enum 2 rxdma_rx_flush> RXDMA received an RX_FLUSH. As a 2122*5c1def83SBjoern A. Zeeb * result the MSDU link descriptor might not have the 2123*5c1def83SBjoern A. Zeeb * last_msdu_in_mpdu_flag set, but instead WBM might just see a 2124*5c1def83SBjoern A. Zeeb * NULL pointer in the MSDU link descriptor. This is to be 2125*5c1def83SBjoern A. Zeeb * considered a normal condition for this scenario. 2126*5c1def83SBjoern A. Zeeb * 2127*5c1def83SBjoern A. Zeeb * rxdma_error_code 2128*5c1def83SBjoern A. Zeeb * Field only valid when rxdma_push_reason is set to 2129*5c1def83SBjoern A. Zeeb * 'rxdma_error_detected.' 2130*5c1def83SBjoern A. Zeeb * 2131*5c1def83SBjoern A. Zeeb * <enum 0 rxdma_overflow_err>MPDU frame is not complete 2132*5c1def83SBjoern A. Zeeb * due to a FIFO overflow error in RXPCU. 2133*5c1def83SBjoern A. Zeeb * 2134*5c1def83SBjoern A. Zeeb * <enum 1 rxdma_mpdu_length_err>MPDU frame is not complete 2135*5c1def83SBjoern A. Zeeb * due to receiving incomplete MPDU from the PHY 2136*5c1def83SBjoern A. Zeeb * 2137*5c1def83SBjoern A. Zeeb * <enum 3 rxdma_decrypt_err>CRYPTO reported a decryption 2138*5c1def83SBjoern A. Zeeb * error or CRYPTO received an encrypted frame, but did not get 2139*5c1def83SBjoern A. Zeeb * a valid corresponding key id in the peer entry. 2140*5c1def83SBjoern A. Zeeb * 2141*5c1def83SBjoern A. Zeeb * <enum 4 rxdma_tkip_mic_err>CRYPTO reported a TKIP MIC 2142*5c1def83SBjoern A. Zeeb * error 2143*5c1def83SBjoern A. Zeeb * 2144*5c1def83SBjoern A. Zeeb * <enum 5 rxdma_unecrypted_err>CRYPTO reported an 2145*5c1def83SBjoern A. Zeeb * unencrypted frame error when encrypted was expected 2146*5c1def83SBjoern A. Zeeb * 2147*5c1def83SBjoern A. Zeeb * <enum 6 rxdma_msdu_len_err>RX OLE reported an MSDU 2148*5c1def83SBjoern A. Zeeb * length error 2149*5c1def83SBjoern A. Zeeb * 2150*5c1def83SBjoern A. Zeeb * <enum 7 rxdma_msdu_limit_err>RX OLE reported that max 2151*5c1def83SBjoern A. Zeeb * number of MSDUs allowed in an MPDU got exceeded 2152*5c1def83SBjoern A. Zeeb * 2153*5c1def83SBjoern A. Zeeb * <enum 8 rxdma_wifi_parse_err>RX OLE reported a parsing 2154*5c1def83SBjoern A. Zeeb * error 2155*5c1def83SBjoern A. Zeeb * 2156*5c1def83SBjoern A. Zeeb * <enum 9 rxdma_amsdu_parse_err>RX OLE reported an A-MSDU 2157*5c1def83SBjoern A. Zeeb * parsing error 2158*5c1def83SBjoern A. Zeeb * 2159*5c1def83SBjoern A. Zeeb * <enum 10 rxdma_sa_timeout_err>RX OLE reported a timeout 2160*5c1def83SBjoern A. Zeeb * during SA search 2161*5c1def83SBjoern A. Zeeb * 2162*5c1def83SBjoern A. Zeeb * <enum 11 rxdma_da_timeout_err>RX OLE reported a timeout 2163*5c1def83SBjoern A. Zeeb * during DA search 2164*5c1def83SBjoern A. Zeeb * 2165*5c1def83SBjoern A. Zeeb * <enum 12 rxdma_flow_timeout_err>RX OLE reported a 2166*5c1def83SBjoern A. Zeeb * timeout during flow search 2167*5c1def83SBjoern A. Zeeb * 2168*5c1def83SBjoern A. Zeeb * <enum 13 rxdma_flush_request>RXDMA received a flush 2169*5c1def83SBjoern A. Zeeb * request 2170*5c1def83SBjoern A. Zeeb * 2171*5c1def83SBjoern A. Zeeb * <enum 14 rxdma_amsdu_fragment_err>Rx PCU reported A-MSDU 2172*5c1def83SBjoern A. Zeeb * present as well as a fragmented MPDU. 2173*5c1def83SBjoern A. Zeeb * 2174*5c1def83SBjoern A. Zeeb * mpdu_fragment_number 2175*5c1def83SBjoern A. Zeeb * Field only valid when Reo_level_mpdu_frame_info. 2176*5c1def83SBjoern A. Zeeb * Rx_mpdu_desc_info_details.Fragment_flag is set and 2177*5c1def83SBjoern A. Zeeb * end_of_ppdu is set to 0. 2178*5c1def83SBjoern A. Zeeb * 2179*5c1def83SBjoern A. Zeeb * The fragment number from the 802.11 header. 2180*5c1def83SBjoern A. Zeeb * 2181*5c1def83SBjoern A. Zeeb * Note that the sequence number is embedded in the field: 2182*5c1def83SBjoern A. Zeeb * Reo_level_mpdu_frame_info. Rx_mpdu_desc_info_details. 2183*5c1def83SBjoern A. Zeeb * Mpdu_sequence_number 2184*5c1def83SBjoern A. Zeeb * 2185*5c1def83SBjoern A. Zeeb * frameless_bar 2186*5c1def83SBjoern A. Zeeb * When set, this SW monitor ring struct contains BAR info 2187*5c1def83SBjoern A. Zeeb * from a multi TID BAR frame. The original multi TID BAR frame 2188*5c1def83SBjoern A. Zeeb * itself contained all the REO info for the first TID, but all 2189*5c1def83SBjoern A. Zeeb * the subsequent TID info and their linkage to the REO 2190*5c1def83SBjoern A. Zeeb * descriptors is passed down as 'frameless' BAR info. 2191*5c1def83SBjoern A. Zeeb * 2192*5c1def83SBjoern A. Zeeb * The only fields valid in this descriptor when this bit 2193*5c1def83SBjoern A. Zeeb * is within the 2194*5c1def83SBjoern A. Zeeb * 2195*5c1def83SBjoern A. Zeeb * Reo_level_mpdu_frame_info: 2196*5c1def83SBjoern A. Zeeb * Within Rx_mpdu_desc_info_details: 2197*5c1def83SBjoern A. Zeeb * Mpdu_Sequence_number 2198*5c1def83SBjoern A. Zeeb * BAR_frame 2199*5c1def83SBjoern A. Zeeb * Peer_meta_data 2200*5c1def83SBjoern A. Zeeb * All other fields shall be set to 0. 2201*5c1def83SBjoern A. Zeeb * 2202*5c1def83SBjoern A. Zeeb * status_buf_count 2203*5c1def83SBjoern A. Zeeb * A count of status buffers used so far for the PPDU 2204*5c1def83SBjoern A. Zeeb * (either the PPDU that included the MPDU being pushed to SW 2205*5c1def83SBjoern A. Zeeb * if end_of_ppdu = 0, or the PPDU whose end is indicated 2206*5c1def83SBjoern A. Zeeb * through end_of_ppdu = 1) 2207*5c1def83SBjoern A. Zeeb * 2208*5c1def83SBjoern A. Zeeb * end_of_ppdu 2209*5c1def83SBjoern A. Zeeb * Some hw RXDMA can be configured to generate a separate 2210*5c1def83SBjoern A. Zeeb * 'SW_MONITOR_RING' descriptor at the end of a PPDU (either 2211*5c1def83SBjoern A. Zeeb * through an 'RX_PPDU_END' TLV or through an 'RX_FLUSH') to 2212*5c1def83SBjoern A. Zeeb * demarcate PPDUs. 2213*5c1def83SBjoern A. Zeeb * 2214*5c1def83SBjoern A. Zeeb * For such a descriptor, this bit is set to 1 and fields 2215*5c1def83SBjoern A. Zeeb * Reo_level_mpdu_frame_info, mpdu_fragment_number and 2216*5c1def83SBjoern A. Zeeb * Frameless_bar are all set to 0. 2217*5c1def83SBjoern A. Zeeb * 2218*5c1def83SBjoern A. Zeeb * Otherwise this bit is set to 0. 2219*5c1def83SBjoern A. Zeeb * 2220*5c1def83SBjoern A. Zeeb * phy_ppdu_id 2221*5c1def83SBjoern A. Zeeb * A PPDU counter value that PHY increments for every PPDU 2222*5c1def83SBjoern A. Zeeb * received 2223*5c1def83SBjoern A. Zeeb * 2224*5c1def83SBjoern A. Zeeb * The counter value wraps around. Some hw RXDMA can be 2225*5c1def83SBjoern A. Zeeb * configured to copy this from the RX_PPDU_START TLV for every 2226*5c1def83SBjoern A. Zeeb * output descriptor. 2227*5c1def83SBjoern A. Zeeb * 2228*5c1def83SBjoern A. Zeeb * ring_id 2229*5c1def83SBjoern A. Zeeb * For debugging. 2230*5c1def83SBjoern A. Zeeb * This field is filled in by the SRNG module. 2231*5c1def83SBjoern A. Zeeb * It help to identify the ring that is being looked 2232*5c1def83SBjoern A. Zeeb * 2233*5c1def83SBjoern A. Zeeb * looping_count 2234*5c1def83SBjoern A. Zeeb * For debugging. 2235*5c1def83SBjoern A. Zeeb * This field is filled in by the SRNG module. 2236*5c1def83SBjoern A. Zeeb * 2237*5c1def83SBjoern A. Zeeb * A count value that indicates the number of times the 2238*5c1def83SBjoern A. Zeeb * producer of entries into this Ring has looped around the 2239*5c1def83SBjoern A. Zeeb * ring. 2240*5c1def83SBjoern A. Zeeb * At initialization time, this value is set to 0. On the 2241*5c1def83SBjoern A. Zeeb * first loop, this value is set to 1. After the max value is 2242*5c1def83SBjoern A. Zeeb * reached allowed by the number of bits for this field, the 2243*5c1def83SBjoern A. Zeeb * count value continues with 0 again. 2244*5c1def83SBjoern A. Zeeb * 2245*5c1def83SBjoern A. Zeeb * In case SW is the consumer of the ring entries, it can 2246*5c1def83SBjoern A. Zeeb * use this field to figure out up to where the producer of 2247*5c1def83SBjoern A. Zeeb * entries has created new entries. This eliminates the need to 2248*5c1def83SBjoern A. Zeeb * check where the head pointer' of the ring is located once 2249*5c1def83SBjoern A. Zeeb * the SW starts processing an interrupt indicating that new 2250*5c1def83SBjoern A. Zeeb * entries have been put into this ring... 2251*5c1def83SBjoern A. Zeeb */ 2252*5c1def83SBjoern A. Zeeb 2253*5c1def83SBjoern A. Zeeb enum hal_desc_owner { 2254*5c1def83SBjoern A. Zeeb HAL_DESC_OWNER_WBM, 2255*5c1def83SBjoern A. Zeeb HAL_DESC_OWNER_SW, 2256*5c1def83SBjoern A. Zeeb HAL_DESC_OWNER_TQM, 2257*5c1def83SBjoern A. Zeeb HAL_DESC_OWNER_RXDMA, 2258*5c1def83SBjoern A. Zeeb HAL_DESC_OWNER_REO, 2259*5c1def83SBjoern A. Zeeb HAL_DESC_OWNER_SWITCH, 2260*5c1def83SBjoern A. Zeeb }; 2261*5c1def83SBjoern A. Zeeb 2262*5c1def83SBjoern A. Zeeb enum hal_desc_buf_type { 2263*5c1def83SBjoern A. Zeeb HAL_DESC_BUF_TYPE_TX_MSDU_LINK, 2264*5c1def83SBjoern A. Zeeb HAL_DESC_BUF_TYPE_TX_MPDU_LINK, 2265*5c1def83SBjoern A. Zeeb HAL_DESC_BUF_TYPE_TX_MPDU_QUEUE_HEAD, 2266*5c1def83SBjoern A. Zeeb HAL_DESC_BUF_TYPE_TX_MPDU_QUEUE_EXT, 2267*5c1def83SBjoern A. Zeeb HAL_DESC_BUF_TYPE_TX_FLOW, 2268*5c1def83SBjoern A. Zeeb HAL_DESC_BUF_TYPE_TX_BUFFER, 2269*5c1def83SBjoern A. Zeeb HAL_DESC_BUF_TYPE_RX_MSDU_LINK, 2270*5c1def83SBjoern A. Zeeb HAL_DESC_BUF_TYPE_RX_MPDU_LINK, 2271*5c1def83SBjoern A. Zeeb HAL_DESC_BUF_TYPE_RX_REO_QUEUE, 2272*5c1def83SBjoern A. Zeeb HAL_DESC_BUF_TYPE_RX_REO_QUEUE_EXT, 2273*5c1def83SBjoern A. Zeeb HAL_DESC_BUF_TYPE_RX_BUFFER, 2274*5c1def83SBjoern A. Zeeb HAL_DESC_BUF_TYPE_IDLE_LINK, 2275*5c1def83SBjoern A. Zeeb }; 2276*5c1def83SBjoern A. Zeeb 2277*5c1def83SBjoern A. Zeeb #define HAL_DESC_REO_OWNED 4 2278*5c1def83SBjoern A. Zeeb #define HAL_DESC_REO_QUEUE_DESC 8 2279*5c1def83SBjoern A. Zeeb #define HAL_DESC_REO_QUEUE_EXT_DESC 9 2280*5c1def83SBjoern A. Zeeb #define HAL_DESC_REO_NON_QOS_TID 16 2281*5c1def83SBjoern A. Zeeb 2282*5c1def83SBjoern A. Zeeb #define HAL_DESC_HDR_INFO0_OWNER GENMASK(3, 0) 2283*5c1def83SBjoern A. Zeeb #define HAL_DESC_HDR_INFO0_BUF_TYPE GENMASK(7, 4) 2284*5c1def83SBjoern A. Zeeb #define HAL_DESC_HDR_INFO0_DBG_RESERVED GENMASK(31, 8) 2285*5c1def83SBjoern A. Zeeb 2286*5c1def83SBjoern A. Zeeb struct hal_desc_header { 2287*5c1def83SBjoern A. Zeeb __le32 info0; 2288*5c1def83SBjoern A. Zeeb } __packed; 2289*5c1def83SBjoern A. Zeeb 2290*5c1def83SBjoern A. Zeeb struct hal_rx_mpdu_link_ptr { 2291*5c1def83SBjoern A. Zeeb struct ath12k_buffer_addr addr_info; 2292*5c1def83SBjoern A. Zeeb } __packed; 2293*5c1def83SBjoern A. Zeeb 2294*5c1def83SBjoern A. Zeeb struct hal_rx_msdu_details { 2295*5c1def83SBjoern A. Zeeb struct ath12k_buffer_addr buf_addr_info; 2296*5c1def83SBjoern A. Zeeb struct rx_msdu_desc rx_msdu_info; 2297*5c1def83SBjoern A. Zeeb struct rx_msdu_ext_desc rx_msdu_ext_info; 2298*5c1def83SBjoern A. Zeeb } __packed; 2299*5c1def83SBjoern A. Zeeb 2300*5c1def83SBjoern A. Zeeb #define HAL_RX_MSDU_LNK_INFO0_RX_QUEUE_NUMBER GENMASK(15, 0) 2301*5c1def83SBjoern A. Zeeb #define HAL_RX_MSDU_LNK_INFO0_FIRST_MSDU_LNK BIT(16) 2302*5c1def83SBjoern A. Zeeb 2303*5c1def83SBjoern A. Zeeb struct hal_rx_msdu_link { 2304*5c1def83SBjoern A. Zeeb struct hal_desc_header desc_hdr; 2305*5c1def83SBjoern A. Zeeb struct ath12k_buffer_addr buf_addr_info; 2306*5c1def83SBjoern A. Zeeb __le32 info0; 2307*5c1def83SBjoern A. Zeeb __le32 pn[4]; 2308*5c1def83SBjoern A. Zeeb struct hal_rx_msdu_details msdu_link[6]; 2309*5c1def83SBjoern A. Zeeb } __packed; 2310*5c1def83SBjoern A. Zeeb 2311*5c1def83SBjoern A. Zeeb struct hal_rx_reo_queue_ext { 2312*5c1def83SBjoern A. Zeeb struct hal_desc_header desc_hdr; 2313*5c1def83SBjoern A. Zeeb __le32 rsvd; 2314*5c1def83SBjoern A. Zeeb struct hal_rx_mpdu_link_ptr mpdu_link[15]; 2315*5c1def83SBjoern A. Zeeb } __packed; 2316*5c1def83SBjoern A. Zeeb 2317*5c1def83SBjoern A. Zeeb /* hal_rx_reo_queue_ext 2318*5c1def83SBjoern A. Zeeb * Consumer: REO 2319*5c1def83SBjoern A. Zeeb * Producer: REO 2320*5c1def83SBjoern A. Zeeb * 2321*5c1def83SBjoern A. Zeeb * descriptor_header 2322*5c1def83SBjoern A. Zeeb * Details about which module owns this struct. 2323*5c1def83SBjoern A. Zeeb * 2324*5c1def83SBjoern A. Zeeb * mpdu_link 2325*5c1def83SBjoern A. Zeeb * Pointer to the next MPDU_link descriptor in the MPDU queue. 2326*5c1def83SBjoern A. Zeeb */ 2327*5c1def83SBjoern A. Zeeb 2328*5c1def83SBjoern A. Zeeb enum hal_rx_reo_queue_pn_size { 2329*5c1def83SBjoern A. Zeeb HAL_RX_REO_QUEUE_PN_SIZE_24, 2330*5c1def83SBjoern A. Zeeb HAL_RX_REO_QUEUE_PN_SIZE_48, 2331*5c1def83SBjoern A. Zeeb HAL_RX_REO_QUEUE_PN_SIZE_128, 2332*5c1def83SBjoern A. Zeeb }; 2333*5c1def83SBjoern A. Zeeb 2334*5c1def83SBjoern A. Zeeb #define HAL_RX_REO_QUEUE_RX_QUEUE_NUMBER GENMASK(15, 0) 2335*5c1def83SBjoern A. Zeeb 2336*5c1def83SBjoern A. Zeeb #define HAL_RX_REO_QUEUE_INFO0_VLD BIT(0) 2337*5c1def83SBjoern A. Zeeb #define HAL_RX_REO_QUEUE_INFO0_ASSOC_LNK_DESC_COUNTER GENMASK(2, 1) 2338*5c1def83SBjoern A. Zeeb #define HAL_RX_REO_QUEUE_INFO0_DIS_DUP_DETECTION BIT(3) 2339*5c1def83SBjoern A. Zeeb #define HAL_RX_REO_QUEUE_INFO0_SOFT_REORDER_EN BIT(4) 2340*5c1def83SBjoern A. Zeeb #define HAL_RX_REO_QUEUE_INFO0_AC GENMASK(6, 5) 2341*5c1def83SBjoern A. Zeeb #define HAL_RX_REO_QUEUE_INFO0_BAR BIT(7) 2342*5c1def83SBjoern A. Zeeb #define HAL_RX_REO_QUEUE_INFO0_RETRY BIT(8) 2343*5c1def83SBjoern A. Zeeb #define HAL_RX_REO_QUEUE_INFO0_CHECK_2K_MODE BIT(9) 2344*5c1def83SBjoern A. Zeeb #define HAL_RX_REO_QUEUE_INFO0_OOR_MODE BIT(10) 2345*5c1def83SBjoern A. Zeeb #define HAL_RX_REO_QUEUE_INFO0_BA_WINDOW_SIZE GENMASK(20, 11) 2346*5c1def83SBjoern A. Zeeb #define HAL_RX_REO_QUEUE_INFO0_PN_CHECK BIT(21) 2347*5c1def83SBjoern A. Zeeb #define HAL_RX_REO_QUEUE_INFO0_EVEN_PN BIT(22) 2348*5c1def83SBjoern A. Zeeb #define HAL_RX_REO_QUEUE_INFO0_UNEVEN_PN BIT(23) 2349*5c1def83SBjoern A. Zeeb #define HAL_RX_REO_QUEUE_INFO0_PN_HANDLE_ENABLE BIT(24) 2350*5c1def83SBjoern A. Zeeb #define HAL_RX_REO_QUEUE_INFO0_PN_SIZE GENMASK(26, 25) 2351*5c1def83SBjoern A. Zeeb #define HAL_RX_REO_QUEUE_INFO0_IGNORE_AMPDU_FLG BIT(27) 2352*5c1def83SBjoern A. Zeeb 2353*5c1def83SBjoern A. Zeeb #define HAL_RX_REO_QUEUE_INFO1_SVLD BIT(0) 2354*5c1def83SBjoern A. Zeeb #define HAL_RX_REO_QUEUE_INFO1_SSN GENMASK(12, 1) 2355*5c1def83SBjoern A. Zeeb #define HAL_RX_REO_QUEUE_INFO1_CURRENT_IDX GENMASK(22, 13) 2356*5c1def83SBjoern A. Zeeb #define HAL_RX_REO_QUEUE_INFO1_SEQ_2K_ERR BIT(23) 2357*5c1def83SBjoern A. Zeeb #define HAL_RX_REO_QUEUE_INFO1_PN_ERR BIT(24) 2358*5c1def83SBjoern A. Zeeb #define HAL_RX_REO_QUEUE_INFO1_PN_VALID BIT(31) 2359*5c1def83SBjoern A. Zeeb 2360*5c1def83SBjoern A. Zeeb #define HAL_RX_REO_QUEUE_INFO2_MPDU_COUNT GENMASK(6, 0) 2361*5c1def83SBjoern A. Zeeb #define HAL_RX_REO_QUEUE_INFO2_MSDU_COUNT (31, 7) 2362*5c1def83SBjoern A. Zeeb 2363*5c1def83SBjoern A. Zeeb #define HAL_RX_REO_QUEUE_INFO3_TIMEOUT_COUNT GENMASK(9, 4) 2364*5c1def83SBjoern A. Zeeb #define HAL_RX_REO_QUEUE_INFO3_FWD_DUE_TO_BAR_CNT GENMASK(15, 10) 2365*5c1def83SBjoern A. Zeeb #define HAL_RX_REO_QUEUE_INFO3_DUPLICATE_COUNT GENMASK(31, 16) 2366*5c1def83SBjoern A. Zeeb 2367*5c1def83SBjoern A. Zeeb #define HAL_RX_REO_QUEUE_INFO4_FRAME_IN_ORD_COUNT GENMASK(23, 0) 2368*5c1def83SBjoern A. Zeeb #define HAL_RX_REO_QUEUE_INFO4_BAR_RECVD_COUNT GENMASK(31, 24) 2369*5c1def83SBjoern A. Zeeb 2370*5c1def83SBjoern A. Zeeb #define HAL_RX_REO_QUEUE_INFO5_LATE_RX_MPDU_COUNT GENMASK(11, 0) 2371*5c1def83SBjoern A. Zeeb #define HAL_RX_REO_QUEUE_INFO5_WINDOW_JUMP_2K GENMASK(15, 12) 2372*5c1def83SBjoern A. Zeeb #define HAL_RX_REO_QUEUE_INFO5_HOLE_COUNT GENMASK(31, 16) 2373*5c1def83SBjoern A. Zeeb 2374*5c1def83SBjoern A. Zeeb struct hal_rx_reo_queue { 2375*5c1def83SBjoern A. Zeeb struct hal_desc_header desc_hdr; 2376*5c1def83SBjoern A. Zeeb __le32 rx_queue_num; 2377*5c1def83SBjoern A. Zeeb __le32 info0; 2378*5c1def83SBjoern A. Zeeb __le32 info1; 2379*5c1def83SBjoern A. Zeeb __le32 pn[4]; 2380*5c1def83SBjoern A. Zeeb __le32 last_rx_enqueue_timestamp; 2381*5c1def83SBjoern A. Zeeb __le32 last_rx_dequeue_timestamp; 2382*5c1def83SBjoern A. Zeeb __le32 next_aging_queue[2]; 2383*5c1def83SBjoern A. Zeeb __le32 prev_aging_queue[2]; 2384*5c1def83SBjoern A. Zeeb __le32 rx_bitmap[9]; 2385*5c1def83SBjoern A. Zeeb __le32 info2; 2386*5c1def83SBjoern A. Zeeb __le32 info3; 2387*5c1def83SBjoern A. Zeeb __le32 info4; 2388*5c1def83SBjoern A. Zeeb __le32 processed_mpdus; 2389*5c1def83SBjoern A. Zeeb __le32 processed_msdus; 2390*5c1def83SBjoern A. Zeeb __le32 processed_total_bytes; 2391*5c1def83SBjoern A. Zeeb __le32 info5; 2392*5c1def83SBjoern A. Zeeb __le32 rsvd[2]; 2393*5c1def83SBjoern A. Zeeb struct hal_rx_reo_queue_ext ext_desc[]; 2394*5c1def83SBjoern A. Zeeb } __packed; 2395*5c1def83SBjoern A. Zeeb 2396*5c1def83SBjoern A. Zeeb /* hal_rx_reo_queue 2397*5c1def83SBjoern A. Zeeb * 2398*5c1def83SBjoern A. Zeeb * descriptor_header 2399*5c1def83SBjoern A. Zeeb * Details about which module owns this struct. Note that sub field 2400*5c1def83SBjoern A. Zeeb * Buffer_type shall be set to receive_reo_queue_descriptor. 2401*5c1def83SBjoern A. Zeeb * 2402*5c1def83SBjoern A. Zeeb * receive_queue_number 2403*5c1def83SBjoern A. Zeeb * Indicates the MPDU queue ID to which this MPDU link descriptor belongs. 2404*5c1def83SBjoern A. Zeeb * 2405*5c1def83SBjoern A. Zeeb * vld 2406*5c1def83SBjoern A. Zeeb * Valid bit indicating a session is established and the queue descriptor 2407*5c1def83SBjoern A. Zeeb * is valid. 2408*5c1def83SBjoern A. Zeeb * associated_link_descriptor_counter 2409*5c1def83SBjoern A. Zeeb * Indicates which of the 3 link descriptor counters shall be incremented 2410*5c1def83SBjoern A. Zeeb * or decremented when link descriptors are added or removed from this 2411*5c1def83SBjoern A. Zeeb * flow queue. 2412*5c1def83SBjoern A. Zeeb * disable_duplicate_detection 2413*5c1def83SBjoern A. Zeeb * When set, do not perform any duplicate detection. 2414*5c1def83SBjoern A. Zeeb * soft_reorder_enable 2415*5c1def83SBjoern A. Zeeb * When set, REO has been instructed to not perform the actual re-ordering 2416*5c1def83SBjoern A. Zeeb * of frames for this queue, but just to insert the reorder opcodes. 2417*5c1def83SBjoern A. Zeeb * ac 2418*5c1def83SBjoern A. Zeeb * Indicates the access category of the queue descriptor. 2419*5c1def83SBjoern A. Zeeb * bar 2420*5c1def83SBjoern A. Zeeb * Indicates if BAR has been received. 2421*5c1def83SBjoern A. Zeeb * retry 2422*5c1def83SBjoern A. Zeeb * Retry bit is checked if this bit is set. 2423*5c1def83SBjoern A. Zeeb * chk_2k_mode 2424*5c1def83SBjoern A. Zeeb * Indicates what type of operation is expected from Reo when the received 2425*5c1def83SBjoern A. Zeeb * frame SN falls within the 2K window. 2426*5c1def83SBjoern A. Zeeb * oor_mode 2427*5c1def83SBjoern A. Zeeb * Indicates what type of operation is expected when the received frame 2428*5c1def83SBjoern A. Zeeb * falls within the OOR window. 2429*5c1def83SBjoern A. Zeeb * ba_window_size 2430*5c1def83SBjoern A. Zeeb * Indicates the negotiated (window size + 1). Max of 256 bits. 2431*5c1def83SBjoern A. Zeeb * 2432*5c1def83SBjoern A. Zeeb * A value 255 means 256 bitmap, 63 means 64 bitmap, 0 (means non-BA 2433*5c1def83SBjoern A. Zeeb * session, with window size of 0). The 3 values here are the main values 2434*5c1def83SBjoern A. Zeeb * validated, but other values should work as well. 2435*5c1def83SBjoern A. Zeeb * 2436*5c1def83SBjoern A. Zeeb * A BA window size of 0 (=> one frame entry bitmat), means that there is 2437*5c1def83SBjoern A. Zeeb * no additional rx_reo_queue_ext desc. following rx_reo_queue in memory. 2438*5c1def83SBjoern A. Zeeb * A BA window size of 1 - 105, means that there is 1 rx_reo_queue_ext. 2439*5c1def83SBjoern A. Zeeb * A BA window size of 106 - 210, means that there are 2 rx_reo_queue_ext. 2440*5c1def83SBjoern A. Zeeb * A BA window size of 211 - 256, means that there are 3 rx_reo_queue_ext. 2441*5c1def83SBjoern A. Zeeb * pn_check_needed, pn_shall_be_even, pn_shall_be_uneven, pn_handling_enable, 2442*5c1def83SBjoern A. Zeeb * pn_size 2443*5c1def83SBjoern A. Zeeb * REO shall perform the PN increment check, even number check, uneven 2444*5c1def83SBjoern A. Zeeb * number check, PN error check and size of the PN field check. 2445*5c1def83SBjoern A. Zeeb * ignore_ampdu_flag 2446*5c1def83SBjoern A. Zeeb * REO shall ignore the ampdu_flag on entrance descriptor for this queue. 2447*5c1def83SBjoern A. Zeeb * 2448*5c1def83SBjoern A. Zeeb * svld 2449*5c1def83SBjoern A. Zeeb * Sequence number in next field is valid one. 2450*5c1def83SBjoern A. Zeeb * ssn 2451*5c1def83SBjoern A. Zeeb * Starting Sequence number of the session. 2452*5c1def83SBjoern A. Zeeb * current_index 2453*5c1def83SBjoern A. Zeeb * Points to last forwarded packet 2454*5c1def83SBjoern A. Zeeb * seq_2k_error_detected_flag 2455*5c1def83SBjoern A. Zeeb * REO has detected a 2k error jump in the sequence number and from that 2456*5c1def83SBjoern A. Zeeb * moment forward, all new frames are forwarded directly to FW, without 2457*5c1def83SBjoern A. Zeeb * duplicate detect, reordering, etc. 2458*5c1def83SBjoern A. Zeeb * pn_error_detected_flag 2459*5c1def83SBjoern A. Zeeb * REO has detected a PN error. 2460*5c1def83SBjoern A. Zeeb */ 2461*5c1def83SBjoern A. Zeeb 2462*5c1def83SBjoern A. Zeeb #define HAL_REO_UPD_RX_QUEUE_INFO0_QUEUE_ADDR_HI GENMASK(7, 0) 2463*5c1def83SBjoern A. Zeeb #define HAL_REO_UPD_RX_QUEUE_INFO0_UPD_RX_QUEUE_NUM BIT(8) 2464*5c1def83SBjoern A. Zeeb #define HAL_REO_UPD_RX_QUEUE_INFO0_UPD_VLD BIT(9) 2465*5c1def83SBjoern A. Zeeb #define HAL_REO_UPD_RX_QUEUE_INFO0_UPD_ASSOC_LNK_DESC_CNT BIT(10) 2466*5c1def83SBjoern A. Zeeb #define HAL_REO_UPD_RX_QUEUE_INFO0_UPD_DIS_DUP_DETECTION BIT(11) 2467*5c1def83SBjoern A. Zeeb #define HAL_REO_UPD_RX_QUEUE_INFO0_UPD_SOFT_REORDER_EN BIT(12) 2468*5c1def83SBjoern A. Zeeb #define HAL_REO_UPD_RX_QUEUE_INFO0_UPD_AC BIT(13) 2469*5c1def83SBjoern A. Zeeb #define HAL_REO_UPD_RX_QUEUE_INFO0_UPD_BAR BIT(14) 2470*5c1def83SBjoern A. Zeeb #define HAL_REO_UPD_RX_QUEUE_INFO0_UPD_RETRY BIT(15) 2471*5c1def83SBjoern A. Zeeb #define HAL_REO_UPD_RX_QUEUE_INFO0_UPD_CHECK_2K_MODE BIT(16) 2472*5c1def83SBjoern A. Zeeb #define HAL_REO_UPD_RX_QUEUE_INFO0_UPD_OOR_MODE BIT(17) 2473*5c1def83SBjoern A. Zeeb #define HAL_REO_UPD_RX_QUEUE_INFO0_UPD_BA_WINDOW_SIZE BIT(18) 2474*5c1def83SBjoern A. Zeeb #define HAL_REO_UPD_RX_QUEUE_INFO0_UPD_PN_CHECK BIT(19) 2475*5c1def83SBjoern A. Zeeb #define HAL_REO_UPD_RX_QUEUE_INFO0_UPD_EVEN_PN BIT(20) 2476*5c1def83SBjoern A. Zeeb #define HAL_REO_UPD_RX_QUEUE_INFO0_UPD_UNEVEN_PN BIT(21) 2477*5c1def83SBjoern A. Zeeb #define HAL_REO_UPD_RX_QUEUE_INFO0_UPD_PN_HANDLE_ENABLE BIT(22) 2478*5c1def83SBjoern A. Zeeb #define HAL_REO_UPD_RX_QUEUE_INFO0_UPD_PN_SIZE BIT(23) 2479*5c1def83SBjoern A. Zeeb #define HAL_REO_UPD_RX_QUEUE_INFO0_UPD_IGNORE_AMPDU_FLG BIT(24) 2480*5c1def83SBjoern A. Zeeb #define HAL_REO_UPD_RX_QUEUE_INFO0_UPD_SVLD BIT(25) 2481*5c1def83SBjoern A. Zeeb #define HAL_REO_UPD_RX_QUEUE_INFO0_UPD_SSN BIT(26) 2482*5c1def83SBjoern A. Zeeb #define HAL_REO_UPD_RX_QUEUE_INFO0_UPD_SEQ_2K_ERR BIT(27) 2483*5c1def83SBjoern A. Zeeb #define HAL_REO_UPD_RX_QUEUE_INFO0_UPD_PN_ERR BIT(28) 2484*5c1def83SBjoern A. Zeeb #define HAL_REO_UPD_RX_QUEUE_INFO0_UPD_PN_VALID BIT(29) 2485*5c1def83SBjoern A. Zeeb #define HAL_REO_UPD_RX_QUEUE_INFO0_UPD_PN BIT(30) 2486*5c1def83SBjoern A. Zeeb 2487*5c1def83SBjoern A. Zeeb #define HAL_REO_UPD_RX_QUEUE_INFO1_RX_QUEUE_NUMBER GENMASK(15, 0) 2488*5c1def83SBjoern A. Zeeb #define HAL_REO_UPD_RX_QUEUE_INFO1_VLD BIT(16) 2489*5c1def83SBjoern A. Zeeb #define HAL_REO_UPD_RX_QUEUE_INFO1_ASSOC_LNK_DESC_COUNTER GENMASK(18, 17) 2490*5c1def83SBjoern A. Zeeb #define HAL_REO_UPD_RX_QUEUE_INFO1_DIS_DUP_DETECTION BIT(19) 2491*5c1def83SBjoern A. Zeeb #define HAL_REO_UPD_RX_QUEUE_INFO1_SOFT_REORDER_EN BIT(20) 2492*5c1def83SBjoern A. Zeeb #define HAL_REO_UPD_RX_QUEUE_INFO1_AC GENMASK(22, 21) 2493*5c1def83SBjoern A. Zeeb #define HAL_REO_UPD_RX_QUEUE_INFO1_BAR BIT(23) 2494*5c1def83SBjoern A. Zeeb #define HAL_REO_UPD_RX_QUEUE_INFO1_RETRY BIT(24) 2495*5c1def83SBjoern A. Zeeb #define HAL_REO_UPD_RX_QUEUE_INFO1_CHECK_2K_MODE BIT(25) 2496*5c1def83SBjoern A. Zeeb #define HAL_REO_UPD_RX_QUEUE_INFO1_OOR_MODE BIT(26) 2497*5c1def83SBjoern A. Zeeb #define HAL_REO_UPD_RX_QUEUE_INFO1_PN_CHECK BIT(27) 2498*5c1def83SBjoern A. Zeeb #define HAL_REO_UPD_RX_QUEUE_INFO1_EVEN_PN BIT(28) 2499*5c1def83SBjoern A. Zeeb #define HAL_REO_UPD_RX_QUEUE_INFO1_UNEVEN_PN BIT(29) 2500*5c1def83SBjoern A. Zeeb #define HAL_REO_UPD_RX_QUEUE_INFO1_PN_HANDLE_ENABLE BIT(30) 2501*5c1def83SBjoern A. Zeeb #define HAL_REO_UPD_RX_QUEUE_INFO1_IGNORE_AMPDU_FLG BIT(31) 2502*5c1def83SBjoern A. Zeeb 2503*5c1def83SBjoern A. Zeeb #define HAL_REO_UPD_RX_QUEUE_INFO2_BA_WINDOW_SIZE GENMASK(7, 0) 2504*5c1def83SBjoern A. Zeeb #define HAL_REO_UPD_RX_QUEUE_INFO2_PN_SIZE GENMASK(9, 8) 2505*5c1def83SBjoern A. Zeeb #define HAL_REO_UPD_RX_QUEUE_INFO2_SVLD BIT(10) 2506*5c1def83SBjoern A. Zeeb #define HAL_REO_UPD_RX_QUEUE_INFO2_SSN GENMASK(22, 11) 2507*5c1def83SBjoern A. Zeeb #define HAL_REO_UPD_RX_QUEUE_INFO2_SEQ_2K_ERR BIT(23) 2508*5c1def83SBjoern A. Zeeb #define HAL_REO_UPD_RX_QUEUE_INFO2_PN_ERR BIT(24) 2509*5c1def83SBjoern A. Zeeb #define HAL_REO_UPD_RX_QUEUE_INFO2_PN_VALID BIT(25) 2510*5c1def83SBjoern A. Zeeb 2511*5c1def83SBjoern A. Zeeb struct hal_reo_update_rx_queue { 2512*5c1def83SBjoern A. Zeeb struct hal_reo_cmd_hdr cmd; 2513*5c1def83SBjoern A. Zeeb __le32 queue_addr_lo; 2514*5c1def83SBjoern A. Zeeb __le32 info0; 2515*5c1def83SBjoern A. Zeeb __le32 info1; 2516*5c1def83SBjoern A. Zeeb __le32 info2; 2517*5c1def83SBjoern A. Zeeb __le32 pn[4]; 2518*5c1def83SBjoern A. Zeeb } __packed; 2519*5c1def83SBjoern A. Zeeb 2520*5c1def83SBjoern A. Zeeb #define HAL_REO_UNBLOCK_CACHE_INFO0_UNBLK_CACHE BIT(0) 2521*5c1def83SBjoern A. Zeeb #define HAL_REO_UNBLOCK_CACHE_INFO0_RESOURCE_IDX GENMASK(2, 1) 2522*5c1def83SBjoern A. Zeeb 2523*5c1def83SBjoern A. Zeeb struct hal_reo_unblock_cache { 2524*5c1def83SBjoern A. Zeeb struct hal_reo_cmd_hdr cmd; 2525*5c1def83SBjoern A. Zeeb __le32 info0; 2526*5c1def83SBjoern A. Zeeb __le32 rsvd[7]; 2527*5c1def83SBjoern A. Zeeb } __packed; 2528*5c1def83SBjoern A. Zeeb 2529*5c1def83SBjoern A. Zeeb enum hal_reo_exec_status { 2530*5c1def83SBjoern A. Zeeb HAL_REO_EXEC_STATUS_SUCCESS, 2531*5c1def83SBjoern A. Zeeb HAL_REO_EXEC_STATUS_BLOCKED, 2532*5c1def83SBjoern A. Zeeb HAL_REO_EXEC_STATUS_FAILED, 2533*5c1def83SBjoern A. Zeeb HAL_REO_EXEC_STATUS_RESOURCE_BLOCKED, 2534*5c1def83SBjoern A. Zeeb }; 2535*5c1def83SBjoern A. Zeeb 2536*5c1def83SBjoern A. Zeeb #define HAL_REO_STATUS_HDR_INFO0_STATUS_NUM GENMASK(15, 0) 2537*5c1def83SBjoern A. Zeeb #define HAL_REO_STATUS_HDR_INFO0_EXEC_TIME GENMASK(25, 16) 2538*5c1def83SBjoern A. Zeeb #define HAL_REO_STATUS_HDR_INFO0_EXEC_STATUS GENMASK(27, 26) 2539*5c1def83SBjoern A. Zeeb 2540*5c1def83SBjoern A. Zeeb struct hal_reo_status_hdr { 2541*5c1def83SBjoern A. Zeeb __le32 info0; 2542*5c1def83SBjoern A. Zeeb __le32 timestamp; 2543*5c1def83SBjoern A. Zeeb } __packed; 2544*5c1def83SBjoern A. Zeeb 2545*5c1def83SBjoern A. Zeeb /* hal_reo_status_hdr 2546*5c1def83SBjoern A. Zeeb * Producer: REO 2547*5c1def83SBjoern A. Zeeb * Consumer: SW 2548*5c1def83SBjoern A. Zeeb * 2549*5c1def83SBjoern A. Zeeb * status_num 2550*5c1def83SBjoern A. Zeeb * The value in this field is equal to value of the reo command 2551*5c1def83SBjoern A. Zeeb * number. This field helps to correlate the statuses with the REO 2552*5c1def83SBjoern A. Zeeb * commands. 2553*5c1def83SBjoern A. Zeeb * 2554*5c1def83SBjoern A. Zeeb * execution_time (in us) 2555*5c1def83SBjoern A. Zeeb * The amount of time REO took to execute the command. Note that 2556*5c1def83SBjoern A. Zeeb * this time does not include the duration of the command waiting 2557*5c1def83SBjoern A. Zeeb * in the command ring, before the execution started. 2558*5c1def83SBjoern A. Zeeb * 2559*5c1def83SBjoern A. Zeeb * execution_status 2560*5c1def83SBjoern A. Zeeb * Execution status of the command. Values are defined in 2561*5c1def83SBjoern A. Zeeb * enum %HAL_REO_EXEC_STATUS_. 2562*5c1def83SBjoern A. Zeeb */ 2563*5c1def83SBjoern A. Zeeb #define HAL_REO_GET_QUEUE_STATS_STATUS_INFO0_SSN GENMASK(11, 0) 2564*5c1def83SBjoern A. Zeeb #define HAL_REO_GET_QUEUE_STATS_STATUS_INFO0_CUR_IDX GENMASK(21, 12) 2565*5c1def83SBjoern A. Zeeb 2566*5c1def83SBjoern A. Zeeb #define HAL_REO_GET_QUEUE_STATS_STATUS_INFO1_MPDU_COUNT GENMASK(6, 0) 2567*5c1def83SBjoern A. Zeeb #define HAL_REO_GET_QUEUE_STATS_STATUS_INFO1_MSDU_COUNT GENMASK(31, 7) 2568*5c1def83SBjoern A. Zeeb 2569*5c1def83SBjoern A. Zeeb #define HAL_REO_GET_QUEUE_STATS_STATUS_INFO2_WINDOW_JMP2K GENMASK(3, 0) 2570*5c1def83SBjoern A. Zeeb #define HAL_REO_GET_QUEUE_STATS_STATUS_INFO2_TIMEOUT_COUNT GENMASK(9, 4) 2571*5c1def83SBjoern A. Zeeb #define HAL_REO_GET_QUEUE_STATS_STATUS_INFO2_FDTB_COUNT GENMASK(15, 10) 2572*5c1def83SBjoern A. Zeeb #define HAL_REO_GET_QUEUE_STATS_STATUS_INFO2_DUPLICATE_COUNT GENMASK(31, 16) 2573*5c1def83SBjoern A. Zeeb 2574*5c1def83SBjoern A. Zeeb #define HAL_REO_GET_QUEUE_STATS_STATUS_INFO3_FIO_COUNT GENMASK(23, 0) 2575*5c1def83SBjoern A. Zeeb #define HAL_REO_GET_QUEUE_STATS_STATUS_INFO3_BAR_RCVD_CNT GENMASK(31, 24) 2576*5c1def83SBjoern A. Zeeb 2577*5c1def83SBjoern A. Zeeb #define HAL_REO_GET_QUEUE_STATS_STATUS_INFO4_LATE_RX_MPDU GENMASK(11, 0) 2578*5c1def83SBjoern A. Zeeb #define HAL_REO_GET_QUEUE_STATS_STATUS_INFO4_HOLE_COUNT GENMASK(27, 12) 2579*5c1def83SBjoern A. Zeeb 2580*5c1def83SBjoern A. Zeeb #define HAL_REO_GET_QUEUE_STATS_STATUS_INFO5_LOOPING_CNT GENMASK(31, 28) 2581*5c1def83SBjoern A. Zeeb 2582*5c1def83SBjoern A. Zeeb struct hal_reo_get_queue_stats_status { 2583*5c1def83SBjoern A. Zeeb struct hal_reo_status_hdr hdr; 2584*5c1def83SBjoern A. Zeeb __le32 info0; 2585*5c1def83SBjoern A. Zeeb __le32 pn[4]; 2586*5c1def83SBjoern A. Zeeb __le32 last_rx_enqueue_timestamp; 2587*5c1def83SBjoern A. Zeeb __le32 last_rx_dequeue_timestamp; 2588*5c1def83SBjoern A. Zeeb __le32 rx_bitmap[9]; 2589*5c1def83SBjoern A. Zeeb __le32 info1; 2590*5c1def83SBjoern A. Zeeb __le32 info2; 2591*5c1def83SBjoern A. Zeeb __le32 info3; 2592*5c1def83SBjoern A. Zeeb __le32 num_mpdu_frames; 2593*5c1def83SBjoern A. Zeeb __le32 num_msdu_frames; 2594*5c1def83SBjoern A. Zeeb __le32 total_bytes; 2595*5c1def83SBjoern A. Zeeb __le32 info4; 2596*5c1def83SBjoern A. Zeeb __le32 info5; 2597*5c1def83SBjoern A. Zeeb } __packed; 2598*5c1def83SBjoern A. Zeeb 2599*5c1def83SBjoern A. Zeeb /* hal_reo_get_queue_stats_status 2600*5c1def83SBjoern A. Zeeb * Producer: REO 2601*5c1def83SBjoern A. Zeeb * Consumer: SW 2602*5c1def83SBjoern A. Zeeb * 2603*5c1def83SBjoern A. Zeeb * status_hdr 2604*5c1def83SBjoern A. Zeeb * Details that can link this status with the original command. It 2605*5c1def83SBjoern A. Zeeb * also contains info on how long REO took to execute this command. 2606*5c1def83SBjoern A. Zeeb * 2607*5c1def83SBjoern A. Zeeb * ssn 2608*5c1def83SBjoern A. Zeeb * Starting Sequence number of the session, this changes whenever 2609*5c1def83SBjoern A. Zeeb * window moves (can be filled by SW then maintained by REO). 2610*5c1def83SBjoern A. Zeeb * 2611*5c1def83SBjoern A. Zeeb * current_index 2612*5c1def83SBjoern A. Zeeb * Points to last forwarded packet. 2613*5c1def83SBjoern A. Zeeb * 2614*5c1def83SBjoern A. Zeeb * pn 2615*5c1def83SBjoern A. Zeeb * Bits of the PN number. 2616*5c1def83SBjoern A. Zeeb * 2617*5c1def83SBjoern A. Zeeb * last_rx_enqueue_timestamp 2618*5c1def83SBjoern A. Zeeb * last_rx_dequeue_timestamp 2619*5c1def83SBjoern A. Zeeb * Timestamp of arrival of the last MPDU for this queue and 2620*5c1def83SBjoern A. Zeeb * Timestamp of forwarding an MPDU accordingly. 2621*5c1def83SBjoern A. Zeeb * 2622*5c1def83SBjoern A. Zeeb * rx_bitmap 2623*5c1def83SBjoern A. Zeeb * When a bit is set, the corresponding frame is currently held 2624*5c1def83SBjoern A. Zeeb * in the re-order queue. The bitmap is Fully managed by HW. 2625*5c1def83SBjoern A. Zeeb * 2626*5c1def83SBjoern A. Zeeb * current_mpdu_count 2627*5c1def83SBjoern A. Zeeb * current_msdu_count 2628*5c1def83SBjoern A. Zeeb * The number of MPDUs and MSDUs in the queue. 2629*5c1def83SBjoern A. Zeeb * 2630*5c1def83SBjoern A. Zeeb * timeout_count 2631*5c1def83SBjoern A. Zeeb * The number of times REO started forwarding frames even though 2632*5c1def83SBjoern A. Zeeb * there is a hole in the bitmap. Forwarding reason is timeout. 2633*5c1def83SBjoern A. Zeeb * 2634*5c1def83SBjoern A. Zeeb * forward_due_to_bar_count 2635*5c1def83SBjoern A. Zeeb * The number of times REO started forwarding frames even though 2636*5c1def83SBjoern A. Zeeb * there is a hole in the bitmap. Fwd reason is reception of BAR. 2637*5c1def83SBjoern A. Zeeb * 2638*5c1def83SBjoern A. Zeeb * duplicate_count 2639*5c1def83SBjoern A. Zeeb * The number of duplicate frames that have been detected. 2640*5c1def83SBjoern A. Zeeb * 2641*5c1def83SBjoern A. Zeeb * frames_in_order_count 2642*5c1def83SBjoern A. Zeeb * The number of frames that have been received in order (without 2643*5c1def83SBjoern A. Zeeb * a hole that prevented them from being forwarded immediately). 2644*5c1def83SBjoern A. Zeeb * 2645*5c1def83SBjoern A. Zeeb * bar_received_count 2646*5c1def83SBjoern A. Zeeb * The number of times a BAR frame is received. 2647*5c1def83SBjoern A. Zeeb * 2648*5c1def83SBjoern A. Zeeb * mpdu_frames_processed_count 2649*5c1def83SBjoern A. Zeeb * msdu_frames_processed_count 2650*5c1def83SBjoern A. Zeeb * The total number of MPDU/MSDU frames that have been processed. 2651*5c1def83SBjoern A. Zeeb * 2652*5c1def83SBjoern A. Zeeb * total_bytes 2653*5c1def83SBjoern A. Zeeb * An approximation of the number of bytes received for this queue. 2654*5c1def83SBjoern A. Zeeb * 2655*5c1def83SBjoern A. Zeeb * late_receive_mpdu_count 2656*5c1def83SBjoern A. Zeeb * The number of MPDUs received after the window had already moved 2657*5c1def83SBjoern A. Zeeb * on. The 'late' sequence window is defined as 2658*5c1def83SBjoern A. Zeeb * (Window SSN - 256) - (Window SSN - 1). 2659*5c1def83SBjoern A. Zeeb * 2660*5c1def83SBjoern A. Zeeb * window_jump_2k 2661*5c1def83SBjoern A. Zeeb * The number of times the window moved more than 2K 2662*5c1def83SBjoern A. Zeeb * 2663*5c1def83SBjoern A. Zeeb * hole_count 2664*5c1def83SBjoern A. Zeeb * The number of times a hole was created in the receive bitmap. 2665*5c1def83SBjoern A. Zeeb * 2666*5c1def83SBjoern A. Zeeb * looping_count 2667*5c1def83SBjoern A. Zeeb * A count value that indicates the number of times the producer of 2668*5c1def83SBjoern A. Zeeb * entries into this Ring has looped around the ring. 2669*5c1def83SBjoern A. Zeeb */ 2670*5c1def83SBjoern A. Zeeb 2671*5c1def83SBjoern A. Zeeb #define HAL_REO_STATUS_LOOP_CNT GENMASK(31, 28) 2672*5c1def83SBjoern A. Zeeb 2673*5c1def83SBjoern A. Zeeb #define HAL_REO_FLUSH_QUEUE_INFO0_ERR_DETECTED BIT(0) 2674*5c1def83SBjoern A. Zeeb #define HAL_REO_FLUSH_QUEUE_INFO0_RSVD GENMASK(31, 1) 2675*5c1def83SBjoern A. Zeeb #define HAL_REO_FLUSH_QUEUE_INFO1_RSVD GENMASK(27, 0) 2676*5c1def83SBjoern A. Zeeb 2677*5c1def83SBjoern A. Zeeb struct hal_reo_flush_queue_status { 2678*5c1def83SBjoern A. Zeeb struct hal_reo_status_hdr hdr; 2679*5c1def83SBjoern A. Zeeb __le32 info0; 2680*5c1def83SBjoern A. Zeeb __le32 rsvd0[21]; 2681*5c1def83SBjoern A. Zeeb __le32 info1; 2682*5c1def83SBjoern A. Zeeb } __packed; 2683*5c1def83SBjoern A. Zeeb 2684*5c1def83SBjoern A. Zeeb /* hal_reo_flush_queue_status 2685*5c1def83SBjoern A. Zeeb * Producer: REO 2686*5c1def83SBjoern A. Zeeb * Consumer: SW 2687*5c1def83SBjoern A. Zeeb * 2688*5c1def83SBjoern A. Zeeb * status_hdr 2689*5c1def83SBjoern A. Zeeb * Details that can link this status with the original command. It 2690*5c1def83SBjoern A. Zeeb * also contains info on how long REO took to execute this command. 2691*5c1def83SBjoern A. Zeeb * 2692*5c1def83SBjoern A. Zeeb * error_detected 2693*5c1def83SBjoern A. Zeeb * Status of blocking resource 2694*5c1def83SBjoern A. Zeeb * 2695*5c1def83SBjoern A. Zeeb * 0 - No error has been detected while executing this command 2696*5c1def83SBjoern A. Zeeb * 1 - Error detected. The resource to be used for blocking was 2697*5c1def83SBjoern A. Zeeb * already in use. 2698*5c1def83SBjoern A. Zeeb * 2699*5c1def83SBjoern A. Zeeb * looping_count 2700*5c1def83SBjoern A. Zeeb * A count value that indicates the number of times the producer of 2701*5c1def83SBjoern A. Zeeb * entries into this Ring has looped around the ring. 2702*5c1def83SBjoern A. Zeeb */ 2703*5c1def83SBjoern A. Zeeb 2704*5c1def83SBjoern A. Zeeb #define HAL_REO_FLUSH_CACHE_STATUS_INFO0_IS_ERR BIT(0) 2705*5c1def83SBjoern A. Zeeb #define HAL_REO_FLUSH_CACHE_STATUS_INFO0_BLOCK_ERR_CODE GENMASK(2, 1) 2706*5c1def83SBjoern A. Zeeb #define HAL_REO_FLUSH_CACHE_STATUS_INFO0_FLUSH_STATUS_HIT BIT(8) 2707*5c1def83SBjoern A. Zeeb #define HAL_REO_FLUSH_CACHE_STATUS_INFO0_FLUSH_DESC_TYPE GENMASK(11, 9) 2708*5c1def83SBjoern A. Zeeb #define HAL_REO_FLUSH_CACHE_STATUS_INFO0_FLUSH_CLIENT_ID GENMASK(15, 12) 2709*5c1def83SBjoern A. Zeeb #define HAL_REO_FLUSH_CACHE_STATUS_INFO0_FLUSH_ERR GENMASK(17, 16) 2710*5c1def83SBjoern A. Zeeb #define HAL_REO_FLUSH_CACHE_STATUS_INFO0_FLUSH_COUNT GENMASK(25, 18) 2711*5c1def83SBjoern A. Zeeb 2712*5c1def83SBjoern A. Zeeb struct hal_reo_flush_cache_status { 2713*5c1def83SBjoern A. Zeeb struct hal_reo_status_hdr hdr; 2714*5c1def83SBjoern A. Zeeb __le32 info0; 2715*5c1def83SBjoern A. Zeeb __le32 rsvd0[21]; 2716*5c1def83SBjoern A. Zeeb __le32 info1; 2717*5c1def83SBjoern A. Zeeb } __packed; 2718*5c1def83SBjoern A. Zeeb 2719*5c1def83SBjoern A. Zeeb /* hal_reo_flush_cache_status 2720*5c1def83SBjoern A. Zeeb * Producer: REO 2721*5c1def83SBjoern A. Zeeb * Consumer: SW 2722*5c1def83SBjoern A. Zeeb * 2723*5c1def83SBjoern A. Zeeb * status_hdr 2724*5c1def83SBjoern A. Zeeb * Details that can link this status with the original command. It 2725*5c1def83SBjoern A. Zeeb * also contains info on how long REO took to execute this command. 2726*5c1def83SBjoern A. Zeeb * 2727*5c1def83SBjoern A. Zeeb * error_detected 2728*5c1def83SBjoern A. Zeeb * Status for blocking resource handling 2729*5c1def83SBjoern A. Zeeb * 2730*5c1def83SBjoern A. Zeeb * 0 - No error has been detected while executing this command 2731*5c1def83SBjoern A. Zeeb * 1 - An error in the blocking resource management was detected 2732*5c1def83SBjoern A. Zeeb * 2733*5c1def83SBjoern A. Zeeb * block_error_details 2734*5c1def83SBjoern A. Zeeb * only valid when error_detected is set 2735*5c1def83SBjoern A. Zeeb * 2736*5c1def83SBjoern A. Zeeb * 0 - No blocking related errors found 2737*5c1def83SBjoern A. Zeeb * 1 - Blocking resource is already in use 2738*5c1def83SBjoern A. Zeeb * 2 - Resource requested to be unblocked, was not blocked 2739*5c1def83SBjoern A. Zeeb * 2740*5c1def83SBjoern A. Zeeb * cache_controller_flush_status_hit 2741*5c1def83SBjoern A. Zeeb * The status that the cache controller returned on executing the 2742*5c1def83SBjoern A. Zeeb * flush command. 2743*5c1def83SBjoern A. Zeeb * 2744*5c1def83SBjoern A. Zeeb * 0 - miss; 1 - hit 2745*5c1def83SBjoern A. Zeeb * 2746*5c1def83SBjoern A. Zeeb * cache_controller_flush_status_desc_type 2747*5c1def83SBjoern A. Zeeb * Flush descriptor type 2748*5c1def83SBjoern A. Zeeb * 2749*5c1def83SBjoern A. Zeeb * cache_controller_flush_status_client_id 2750*5c1def83SBjoern A. Zeeb * Module who made the flush request 2751*5c1def83SBjoern A. Zeeb * 2752*5c1def83SBjoern A. Zeeb * In REO, this is always 0 2753*5c1def83SBjoern A. Zeeb * 2754*5c1def83SBjoern A. Zeeb * cache_controller_flush_status_error 2755*5c1def83SBjoern A. Zeeb * Error condition 2756*5c1def83SBjoern A. Zeeb * 2757*5c1def83SBjoern A. Zeeb * 0 - No error found 2758*5c1def83SBjoern A. Zeeb * 1 - HW interface is still busy 2759*5c1def83SBjoern A. Zeeb * 2 - Line currently locked. Used for one line flush command 2760*5c1def83SBjoern A. Zeeb * 3 - At least one line is still locked. 2761*5c1def83SBjoern A. Zeeb * Used for cache flush command. 2762*5c1def83SBjoern A. Zeeb * 2763*5c1def83SBjoern A. Zeeb * cache_controller_flush_count 2764*5c1def83SBjoern A. Zeeb * The number of lines that were actually flushed out 2765*5c1def83SBjoern A. Zeeb * 2766*5c1def83SBjoern A. Zeeb * looping_count 2767*5c1def83SBjoern A. Zeeb * A count value that indicates the number of times the producer of 2768*5c1def83SBjoern A. Zeeb * entries into this Ring has looped around the ring. 2769*5c1def83SBjoern A. Zeeb */ 2770*5c1def83SBjoern A. Zeeb 2771*5c1def83SBjoern A. Zeeb #define HAL_REO_UNBLOCK_CACHE_STATUS_INFO0_IS_ERR BIT(0) 2772*5c1def83SBjoern A. Zeeb #define HAL_REO_UNBLOCK_CACHE_STATUS_INFO0_TYPE BIT(1) 2773*5c1def83SBjoern A. Zeeb 2774*5c1def83SBjoern A. Zeeb struct hal_reo_unblock_cache_status { 2775*5c1def83SBjoern A. Zeeb struct hal_reo_status_hdr hdr; 2776*5c1def83SBjoern A. Zeeb __le32 info0; 2777*5c1def83SBjoern A. Zeeb __le32 rsvd0[21]; 2778*5c1def83SBjoern A. Zeeb __le32 info1; 2779*5c1def83SBjoern A. Zeeb } __packed; 2780*5c1def83SBjoern A. Zeeb 2781*5c1def83SBjoern A. Zeeb /* hal_reo_unblock_cache_status 2782*5c1def83SBjoern A. Zeeb * Producer: REO 2783*5c1def83SBjoern A. Zeeb * Consumer: SW 2784*5c1def83SBjoern A. Zeeb * 2785*5c1def83SBjoern A. Zeeb * status_hdr 2786*5c1def83SBjoern A. Zeeb * Details that can link this status with the original command. It 2787*5c1def83SBjoern A. Zeeb * also contains info on how long REO took to execute this command. 2788*5c1def83SBjoern A. Zeeb * 2789*5c1def83SBjoern A. Zeeb * error_detected 2790*5c1def83SBjoern A. Zeeb * 0 - No error has been detected while executing this command 2791*5c1def83SBjoern A. Zeeb * 1 - The blocking resource was not in use, and therefore it could 2792*5c1def83SBjoern A. Zeeb * not be unblocked. 2793*5c1def83SBjoern A. Zeeb * 2794*5c1def83SBjoern A. Zeeb * unblock_type 2795*5c1def83SBjoern A. Zeeb * Reference to the type of unblock command 2796*5c1def83SBjoern A. Zeeb * 0 - Unblock a blocking resource 2797*5c1def83SBjoern A. Zeeb * 1 - The entire cache usage is unblock 2798*5c1def83SBjoern A. Zeeb * 2799*5c1def83SBjoern A. Zeeb * looping_count 2800*5c1def83SBjoern A. Zeeb * A count value that indicates the number of times the producer of 2801*5c1def83SBjoern A. Zeeb * entries into this Ring has looped around the ring. 2802*5c1def83SBjoern A. Zeeb */ 2803*5c1def83SBjoern A. Zeeb 2804*5c1def83SBjoern A. Zeeb #define HAL_REO_FLUSH_TIMEOUT_STATUS_INFO0_IS_ERR BIT(0) 2805*5c1def83SBjoern A. Zeeb #define HAL_REO_FLUSH_TIMEOUT_STATUS_INFO0_LIST_EMPTY BIT(1) 2806*5c1def83SBjoern A. Zeeb 2807*5c1def83SBjoern A. Zeeb #define HAL_REO_FLUSH_TIMEOUT_STATUS_INFO1_REL_DESC_COUNT GENMASK(15, 0) 2808*5c1def83SBjoern A. Zeeb #define HAL_REO_FLUSH_TIMEOUT_STATUS_INFO1_FWD_BUF_COUNT GENMASK(31, 16) 2809*5c1def83SBjoern A. Zeeb 2810*5c1def83SBjoern A. Zeeb struct hal_reo_flush_timeout_list_status { 2811*5c1def83SBjoern A. Zeeb struct hal_reo_status_hdr hdr; 2812*5c1def83SBjoern A. Zeeb __le32 info0; 2813*5c1def83SBjoern A. Zeeb __le32 info1; 2814*5c1def83SBjoern A. Zeeb __le32 rsvd0[20]; 2815*5c1def83SBjoern A. Zeeb __le32 info2; 2816*5c1def83SBjoern A. Zeeb } __packed; 2817*5c1def83SBjoern A. Zeeb 2818*5c1def83SBjoern A. Zeeb /* hal_reo_flush_timeout_list_status 2819*5c1def83SBjoern A. Zeeb * Producer: REO 2820*5c1def83SBjoern A. Zeeb * Consumer: SW 2821*5c1def83SBjoern A. Zeeb * 2822*5c1def83SBjoern A. Zeeb * status_hdr 2823*5c1def83SBjoern A. Zeeb * Details that can link this status with the original command. It 2824*5c1def83SBjoern A. Zeeb * also contains info on how long REO took to execute this command. 2825*5c1def83SBjoern A. Zeeb * 2826*5c1def83SBjoern A. Zeeb * error_detected 2827*5c1def83SBjoern A. Zeeb * 0 - No error has been detected while executing this command 2828*5c1def83SBjoern A. Zeeb * 1 - Command not properly executed and returned with error 2829*5c1def83SBjoern A. Zeeb * 2830*5c1def83SBjoern A. Zeeb * timeout_list_empty 2831*5c1def83SBjoern A. Zeeb * When set, REO has depleted the timeout list and all entries are 2832*5c1def83SBjoern A. Zeeb * gone. 2833*5c1def83SBjoern A. Zeeb * 2834*5c1def83SBjoern A. Zeeb * release_desc_count 2835*5c1def83SBjoern A. Zeeb * Producer: SW; Consumer: REO 2836*5c1def83SBjoern A. Zeeb * The number of link descriptor released 2837*5c1def83SBjoern A. Zeeb * 2838*5c1def83SBjoern A. Zeeb * forward_buf_count 2839*5c1def83SBjoern A. Zeeb * Producer: SW; Consumer: REO 2840*5c1def83SBjoern A. Zeeb * The number of buffers forwarded to the REO destination rings 2841*5c1def83SBjoern A. Zeeb * 2842*5c1def83SBjoern A. Zeeb * looping_count 2843*5c1def83SBjoern A. Zeeb * A count value that indicates the number of times the producer of 2844*5c1def83SBjoern A. Zeeb * entries into this Ring has looped around the ring. 2845*5c1def83SBjoern A. Zeeb */ 2846*5c1def83SBjoern A. Zeeb 2847*5c1def83SBjoern A. Zeeb #define HAL_REO_DESC_THRESH_STATUS_INFO0_THRESH_INDEX GENMASK(1, 0) 2848*5c1def83SBjoern A. Zeeb #define HAL_REO_DESC_THRESH_STATUS_INFO1_LINK_DESC_COUNTER0 GENMASK(23, 0) 2849*5c1def83SBjoern A. Zeeb #define HAL_REO_DESC_THRESH_STATUS_INFO2_LINK_DESC_COUNTER1 GENMASK(23, 0) 2850*5c1def83SBjoern A. Zeeb #define HAL_REO_DESC_THRESH_STATUS_INFO3_LINK_DESC_COUNTER2 GENMASK(23, 0) 2851*5c1def83SBjoern A. Zeeb #define HAL_REO_DESC_THRESH_STATUS_INFO4_LINK_DESC_COUNTER_SUM GENMASK(25, 0) 2852*5c1def83SBjoern A. Zeeb 2853*5c1def83SBjoern A. Zeeb struct hal_reo_desc_thresh_reached_status { 2854*5c1def83SBjoern A. Zeeb struct hal_reo_status_hdr hdr; 2855*5c1def83SBjoern A. Zeeb __le32 info0; 2856*5c1def83SBjoern A. Zeeb __le32 info1; 2857*5c1def83SBjoern A. Zeeb __le32 info2; 2858*5c1def83SBjoern A. Zeeb __le32 info3; 2859*5c1def83SBjoern A. Zeeb __le32 info4; 2860*5c1def83SBjoern A. Zeeb __le32 rsvd0[17]; 2861*5c1def83SBjoern A. Zeeb __le32 info5; 2862*5c1def83SBjoern A. Zeeb } __packed; 2863*5c1def83SBjoern A. Zeeb 2864*5c1def83SBjoern A. Zeeb /* hal_reo_desc_thresh_reached_status 2865*5c1def83SBjoern A. Zeeb * Producer: REO 2866*5c1def83SBjoern A. Zeeb * Consumer: SW 2867*5c1def83SBjoern A. Zeeb * 2868*5c1def83SBjoern A. Zeeb * status_hdr 2869*5c1def83SBjoern A. Zeeb * Details that can link this status with the original command. It 2870*5c1def83SBjoern A. Zeeb * also contains info on how long REO took to execute this command. 2871*5c1def83SBjoern A. Zeeb * 2872*5c1def83SBjoern A. Zeeb * threshold_index 2873*5c1def83SBjoern A. Zeeb * The index of the threshold register whose value got reached 2874*5c1def83SBjoern A. Zeeb * 2875*5c1def83SBjoern A. Zeeb * link_descriptor_counter0 2876*5c1def83SBjoern A. Zeeb * link_descriptor_counter1 2877*5c1def83SBjoern A. Zeeb * link_descriptor_counter2 2878*5c1def83SBjoern A. Zeeb * link_descriptor_counter_sum 2879*5c1def83SBjoern A. Zeeb * Value of the respective counters at generation of this message 2880*5c1def83SBjoern A. Zeeb * 2881*5c1def83SBjoern A. Zeeb * looping_count 2882*5c1def83SBjoern A. Zeeb * A count value that indicates the number of times the producer of 2883*5c1def83SBjoern A. Zeeb * entries into this Ring has looped around the ring. 2884*5c1def83SBjoern A. Zeeb */ 2885*5c1def83SBjoern A. Zeeb 2886*5c1def83SBjoern A. Zeeb #define HAL_TCL_ENTRANCE_FROM_PPE_RING_INFO0_DATA_LENGTH GENMASK(13, 0) 2887*5c1def83SBjoern A. Zeeb #define HAL_TCL_ENTRANCE_FROM_PPE_RING_INFO0_L4_CSUM_STATUS BIT(14) 2888*5c1def83SBjoern A. Zeeb #define HAL_TCL_ENTRANCE_FROM_PPE_RING_INFO0_L3_CSUM_STATUS BIT(15) 2889*5c1def83SBjoern A. Zeeb #define HAL_TCL_ENTRANCE_FROM_PPE_RING_INFO0_PID GENMASK(27, 24) 2890*5c1def83SBjoern A. Zeeb #define HAL_TCL_ENTRANCE_FROM_PPE_RING_INFO0_QDISC BIT(28) 2891*5c1def83SBjoern A. Zeeb #define HAL_TCL_ENTRANCE_FROM_PPE_RING_INFO0_MULTICAST BIT(29) 2892*5c1def83SBjoern A. Zeeb #define HAL_TCL_ENTRANCE_FROM_PPE_RING_INFO0_MORE BIT(30) 2893*5c1def83SBjoern A. Zeeb #define HAL_TCL_ENTRANCE_FROM_PPE_RING_INFO0_VALID_TOGGLE BIT(31) 2894*5c1def83SBjoern A. Zeeb 2895*5c1def83SBjoern A. Zeeb struct hal_tcl_entrance_from_ppe_ring { 2896*5c1def83SBjoern A. Zeeb __le32 buffer_addr; 2897*5c1def83SBjoern A. Zeeb __le32 info0; 2898*5c1def83SBjoern A. Zeeb } __packed; 2899*5c1def83SBjoern A. Zeeb 2900*5c1def83SBjoern A. Zeeb struct hal_mon_buf_ring { 2901*5c1def83SBjoern A. Zeeb __le32 paddr_lo; 2902*5c1def83SBjoern A. Zeeb __le32 paddr_hi; 2903*5c1def83SBjoern A. Zeeb __le64 cookie; 2904*5c1def83SBjoern A. Zeeb }; 2905*5c1def83SBjoern A. Zeeb 2906*5c1def83SBjoern A. Zeeb /* hal_mon_buf_ring 2907*5c1def83SBjoern A. Zeeb * Producer : SW 2908*5c1def83SBjoern A. Zeeb * Consumer : Monitor 2909*5c1def83SBjoern A. Zeeb * 2910*5c1def83SBjoern A. Zeeb * paddr_lo 2911*5c1def83SBjoern A. Zeeb * Lower 32-bit physical address of the buffer pointer from the source ring. 2912*5c1def83SBjoern A. Zeeb * paddr_hi 2913*5c1def83SBjoern A. Zeeb * bit range 7-0 : upper 8 bit of the physical address. 2914*5c1def83SBjoern A. Zeeb * bit range 31-8 : reserved. 2915*5c1def83SBjoern A. Zeeb * cookie 2916*5c1def83SBjoern A. Zeeb * Consumer: RxMon/TxMon 64 bit cookie of the buffers. 2917*5c1def83SBjoern A. Zeeb */ 2918*5c1def83SBjoern A. Zeeb 2919*5c1def83SBjoern A. Zeeb #define HAL_MON_DEST_COOKIE_BUF_ID GENMASK(17, 0) 2920*5c1def83SBjoern A. Zeeb 2921*5c1def83SBjoern A. Zeeb #define HAL_MON_DEST_INFO0_END_OFFSET GENMASK(15, 0) 2922*5c1def83SBjoern A. Zeeb #define HAL_MON_DEST_INFO0_FLUSH_DETECTED BIT(16) 2923*5c1def83SBjoern A. Zeeb #define HAL_MON_DEST_INFO0_END_OF_PPDU BIT(17) 2924*5c1def83SBjoern A. Zeeb #define HAL_MON_DEST_INFO0_INITIATOR BIT(18) 2925*5c1def83SBjoern A. Zeeb #define HAL_MON_DEST_INFO0_EMPTY_DESC BIT(19) 2926*5c1def83SBjoern A. Zeeb #define HAL_MON_DEST_INFO0_RING_ID GENMASK(27, 20) 2927*5c1def83SBjoern A. Zeeb #define HAL_MON_DEST_INFO0_LOOPING_COUNT GENMASK(31, 28) 2928*5c1def83SBjoern A. Zeeb 2929*5c1def83SBjoern A. Zeeb struct hal_mon_dest_desc { 2930*5c1def83SBjoern A. Zeeb __le32 cookie; 2931*5c1def83SBjoern A. Zeeb __le32 reserved; 2932*5c1def83SBjoern A. Zeeb __le32 ppdu_id; 2933*5c1def83SBjoern A. Zeeb __le32 info0; 2934*5c1def83SBjoern A. Zeeb }; 2935*5c1def83SBjoern A. Zeeb 2936*5c1def83SBjoern A. Zeeb /* hal_mon_dest_ring 2937*5c1def83SBjoern A. Zeeb * Producer : TxMon/RxMon 2938*5c1def83SBjoern A. Zeeb * Consumer : SW 2939*5c1def83SBjoern A. Zeeb * cookie 2940*5c1def83SBjoern A. Zeeb * bit 0 -17 buf_id to track the skb's vaddr. 2941*5c1def83SBjoern A. Zeeb * ppdu_id 2942*5c1def83SBjoern A. Zeeb * Phy ppdu_id 2943*5c1def83SBjoern A. Zeeb * end_offset 2944*5c1def83SBjoern A. Zeeb * The offset into status buffer where DMA ended, ie., offset to the last 2945*5c1def83SBjoern A. Zeeb * TLV + last TLV size. 2946*5c1def83SBjoern A. Zeeb * flush_detected 2947*5c1def83SBjoern A. Zeeb * Indicates whether 'tx_flush' or 'rx_flush' occurred. 2948*5c1def83SBjoern A. Zeeb * end_of_ppdu 2949*5c1def83SBjoern A. Zeeb * Indicates end of ppdu. 2950*5c1def83SBjoern A. Zeeb * pmac_id 2951*5c1def83SBjoern A. Zeeb * Indicates PMAC that received from frame. 2952*5c1def83SBjoern A. Zeeb * empty_descriptor 2953*5c1def83SBjoern A. Zeeb * This descriptor is written on flush or end of ppdu or end of status 2954*5c1def83SBjoern A. Zeeb * buffer. 2955*5c1def83SBjoern A. Zeeb * ring_id 2956*5c1def83SBjoern A. Zeeb * updated by SRNG. 2957*5c1def83SBjoern A. Zeeb * looping_count 2958*5c1def83SBjoern A. Zeeb * updated by SRNG. 2959*5c1def83SBjoern A. Zeeb */ 2960*5c1def83SBjoern A. Zeeb 2961*5c1def83SBjoern A. Zeeb #endif /* ATH12K_HAL_DESC_H */ 2962