1 // SPDX-License-Identifier: BSD-3-Clause-Clear 2 /* 3 * Copyright (c) 2018-2021 The Linux Foundation. All rights reserved. 4 * Copyright (c) 2021-2024 Qualcomm Innovation Center, Inc. All rights reserved. 5 */ 6 #include <linux/dma-mapping.h> 7 #include "hal_tx.h" 8 #include "hal_rx.h" 9 #include "debug.h" 10 #include "hal_desc.h" 11 #include "hif.h" 12 13 static const struct hal_srng_config hw_srng_config_template[] = { 14 /* TODO: max_rings can populated by querying HW capabilities */ 15 [HAL_REO_DST] = { 16 .start_ring_id = HAL_SRNG_RING_ID_REO2SW1, 17 .max_rings = 8, 18 .entry_size = sizeof(struct hal_reo_dest_ring) >> 2, 19 .mac_type = ATH12K_HAL_SRNG_UMAC, 20 .ring_dir = HAL_SRNG_DIR_DST, 21 .max_size = HAL_REO_REO2SW1_RING_BASE_MSB_RING_SIZE, 22 }, 23 [HAL_REO_EXCEPTION] = { 24 /* Designating REO2SW0 ring as exception ring. 25 * Any of theREO2SW rings can be used as exception ring. 26 */ 27 .start_ring_id = HAL_SRNG_RING_ID_REO2SW0, 28 .max_rings = 1, 29 .entry_size = sizeof(struct hal_reo_dest_ring) >> 2, 30 .mac_type = ATH12K_HAL_SRNG_UMAC, 31 .ring_dir = HAL_SRNG_DIR_DST, 32 .max_size = HAL_REO_REO2SW0_RING_BASE_MSB_RING_SIZE, 33 }, 34 [HAL_REO_REINJECT] = { 35 .start_ring_id = HAL_SRNG_RING_ID_SW2REO, 36 .max_rings = 4, 37 .entry_size = sizeof(struct hal_reo_entrance_ring) >> 2, 38 .mac_type = ATH12K_HAL_SRNG_UMAC, 39 .ring_dir = HAL_SRNG_DIR_SRC, 40 .max_size = HAL_REO_SW2REO_RING_BASE_MSB_RING_SIZE, 41 }, 42 [HAL_REO_CMD] = { 43 .start_ring_id = HAL_SRNG_RING_ID_REO_CMD, 44 .max_rings = 1, 45 .entry_size = (sizeof(struct hal_tlv_64_hdr) + 46 sizeof(struct hal_reo_get_queue_stats)) >> 2, 47 .mac_type = ATH12K_HAL_SRNG_UMAC, 48 .ring_dir = HAL_SRNG_DIR_SRC, 49 .max_size = HAL_REO_CMD_RING_BASE_MSB_RING_SIZE, 50 }, 51 [HAL_REO_STATUS] = { 52 .start_ring_id = HAL_SRNG_RING_ID_REO_STATUS, 53 .max_rings = 1, 54 .entry_size = (sizeof(struct hal_tlv_64_hdr) + 55 sizeof(struct hal_reo_get_queue_stats_status)) >> 2, 56 .mac_type = ATH12K_HAL_SRNG_UMAC, 57 .ring_dir = HAL_SRNG_DIR_DST, 58 .max_size = HAL_REO_STATUS_RING_BASE_MSB_RING_SIZE, 59 }, 60 [HAL_TCL_DATA] = { 61 .start_ring_id = HAL_SRNG_RING_ID_SW2TCL1, 62 .max_rings = 6, 63 .entry_size = sizeof(struct hal_tcl_data_cmd) >> 2, 64 .mac_type = ATH12K_HAL_SRNG_UMAC, 65 .ring_dir = HAL_SRNG_DIR_SRC, 66 .max_size = HAL_SW2TCL1_RING_BASE_MSB_RING_SIZE, 67 }, 68 [HAL_TCL_CMD] = { 69 .start_ring_id = HAL_SRNG_RING_ID_SW2TCL_CMD, 70 .max_rings = 1, 71 .entry_size = sizeof(struct hal_tcl_gse_cmd) >> 2, 72 .mac_type = ATH12K_HAL_SRNG_UMAC, 73 .ring_dir = HAL_SRNG_DIR_SRC, 74 .max_size = HAL_SW2TCL1_CMD_RING_BASE_MSB_RING_SIZE, 75 }, 76 [HAL_TCL_STATUS] = { 77 .start_ring_id = HAL_SRNG_RING_ID_TCL_STATUS, 78 .max_rings = 1, 79 .entry_size = (sizeof(struct hal_tlv_hdr) + 80 sizeof(struct hal_tcl_status_ring)) >> 2, 81 .mac_type = ATH12K_HAL_SRNG_UMAC, 82 .ring_dir = HAL_SRNG_DIR_DST, 83 .max_size = HAL_TCL_STATUS_RING_BASE_MSB_RING_SIZE, 84 }, 85 [HAL_CE_SRC] = { 86 .start_ring_id = HAL_SRNG_RING_ID_CE0_SRC, 87 .max_rings = 16, 88 .entry_size = sizeof(struct hal_ce_srng_src_desc) >> 2, 89 .mac_type = ATH12K_HAL_SRNG_UMAC, 90 .ring_dir = HAL_SRNG_DIR_SRC, 91 .max_size = HAL_CE_SRC_RING_BASE_MSB_RING_SIZE, 92 }, 93 [HAL_CE_DST] = { 94 .start_ring_id = HAL_SRNG_RING_ID_CE0_DST, 95 .max_rings = 16, 96 .entry_size = sizeof(struct hal_ce_srng_dest_desc) >> 2, 97 .mac_type = ATH12K_HAL_SRNG_UMAC, 98 .ring_dir = HAL_SRNG_DIR_SRC, 99 .max_size = HAL_CE_DST_RING_BASE_MSB_RING_SIZE, 100 }, 101 [HAL_CE_DST_STATUS] = { 102 .start_ring_id = HAL_SRNG_RING_ID_CE0_DST_STATUS, 103 .max_rings = 16, 104 .entry_size = sizeof(struct hal_ce_srng_dst_status_desc) >> 2, 105 .mac_type = ATH12K_HAL_SRNG_UMAC, 106 .ring_dir = HAL_SRNG_DIR_DST, 107 .max_size = HAL_CE_DST_STATUS_RING_BASE_MSB_RING_SIZE, 108 }, 109 [HAL_WBM_IDLE_LINK] = { 110 .start_ring_id = HAL_SRNG_RING_ID_WBM_IDLE_LINK, 111 .max_rings = 1, 112 .entry_size = sizeof(struct hal_wbm_link_desc) >> 2, 113 .mac_type = ATH12K_HAL_SRNG_UMAC, 114 .ring_dir = HAL_SRNG_DIR_SRC, 115 .max_size = HAL_WBM_IDLE_LINK_RING_BASE_MSB_RING_SIZE, 116 }, 117 [HAL_SW2WBM_RELEASE] = { 118 .start_ring_id = HAL_SRNG_RING_ID_WBM_SW0_RELEASE, 119 .max_rings = 2, 120 .entry_size = sizeof(struct hal_wbm_release_ring) >> 2, 121 .mac_type = ATH12K_HAL_SRNG_UMAC, 122 .ring_dir = HAL_SRNG_DIR_SRC, 123 .max_size = HAL_SW2WBM_RELEASE_RING_BASE_MSB_RING_SIZE, 124 }, 125 [HAL_WBM2SW_RELEASE] = { 126 .start_ring_id = HAL_SRNG_RING_ID_WBM2SW0_RELEASE, 127 .max_rings = 8, 128 .entry_size = sizeof(struct hal_wbm_release_ring) >> 2, 129 .mac_type = ATH12K_HAL_SRNG_UMAC, 130 .ring_dir = HAL_SRNG_DIR_DST, 131 .max_size = HAL_WBM2SW_RELEASE_RING_BASE_MSB_RING_SIZE, 132 }, 133 [HAL_RXDMA_BUF] = { 134 .start_ring_id = HAL_SRNG_SW2RXDMA_BUF0, 135 .max_rings = 1, 136 .entry_size = sizeof(struct hal_wbm_buffer_ring) >> 2, 137 .mac_type = ATH12K_HAL_SRNG_DMAC, 138 .ring_dir = HAL_SRNG_DIR_SRC, 139 .max_size = HAL_RXDMA_RING_MAX_SIZE_BE, 140 }, 141 [HAL_RXDMA_DST] = { 142 .start_ring_id = HAL_SRNG_RING_ID_WMAC1_RXDMA2SW0, 143 .max_rings = 0, 144 .entry_size = 0, 145 .mac_type = ATH12K_HAL_SRNG_PMAC, 146 .ring_dir = HAL_SRNG_DIR_DST, 147 .max_size = HAL_RXDMA_RING_MAX_SIZE_BE, 148 }, 149 [HAL_RXDMA_MONITOR_BUF] = { 150 .start_ring_id = HAL_SRNG_SW2RXMON_BUF0, 151 .max_rings = 1, 152 .entry_size = sizeof(struct hal_mon_buf_ring) >> 2, 153 .mac_type = ATH12K_HAL_SRNG_PMAC, 154 .ring_dir = HAL_SRNG_DIR_SRC, 155 .max_size = HAL_RXDMA_RING_MAX_SIZE_BE, 156 }, 157 [HAL_RXDMA_MONITOR_STATUS] = { 0, }, 158 [HAL_RXDMA_MONITOR_DESC] = { 0, }, 159 [HAL_RXDMA_DIR_BUF] = { 160 .start_ring_id = HAL_SRNG_RING_ID_RXDMA_DIR_BUF, 161 .max_rings = 2, 162 .entry_size = 8 >> 2, /* TODO: Define the struct */ 163 .mac_type = ATH12K_HAL_SRNG_PMAC, 164 .ring_dir = HAL_SRNG_DIR_SRC, 165 .max_size = HAL_RXDMA_RING_MAX_SIZE_BE, 166 }, 167 [HAL_PPE2TCL] = { 168 .start_ring_id = HAL_SRNG_RING_ID_PPE2TCL1, 169 .max_rings = 1, 170 .entry_size = sizeof(struct hal_tcl_entrance_from_ppe_ring) >> 2, 171 .mac_type = ATH12K_HAL_SRNG_PMAC, 172 .ring_dir = HAL_SRNG_DIR_SRC, 173 .max_size = HAL_SW2TCL1_RING_BASE_MSB_RING_SIZE, 174 }, 175 [HAL_PPE_RELEASE] = { 176 .start_ring_id = HAL_SRNG_RING_ID_WBM_PPE_RELEASE, 177 .max_rings = 1, 178 .entry_size = sizeof(struct hal_wbm_release_ring) >> 2, 179 .mac_type = ATH12K_HAL_SRNG_PMAC, 180 .ring_dir = HAL_SRNG_DIR_SRC, 181 .max_size = HAL_WBM2PPE_RELEASE_RING_BASE_MSB_RING_SIZE, 182 }, 183 [HAL_TX_MONITOR_BUF] = { 184 .start_ring_id = HAL_SRNG_SW2TXMON_BUF0, 185 .max_rings = 1, 186 .entry_size = sizeof(struct hal_mon_buf_ring) >> 2, 187 .mac_type = ATH12K_HAL_SRNG_PMAC, 188 .ring_dir = HAL_SRNG_DIR_SRC, 189 .max_size = HAL_RXDMA_RING_MAX_SIZE_BE, 190 }, 191 [HAL_RXDMA_MONITOR_DST] = { 192 .start_ring_id = HAL_SRNG_RING_ID_WMAC1_SW2RXMON_BUF0, 193 .max_rings = 1, 194 .entry_size = sizeof(struct hal_mon_dest_desc) >> 2, 195 .mac_type = ATH12K_HAL_SRNG_PMAC, 196 .ring_dir = HAL_SRNG_DIR_DST, 197 .max_size = HAL_RXDMA_RING_MAX_SIZE_BE, 198 }, 199 [HAL_TX_MONITOR_DST] = { 200 .start_ring_id = HAL_SRNG_RING_ID_WMAC1_TXMON2SW0_BUF0, 201 .max_rings = 1, 202 .entry_size = sizeof(struct hal_mon_dest_desc) >> 2, 203 .mac_type = ATH12K_HAL_SRNG_PMAC, 204 .ring_dir = HAL_SRNG_DIR_DST, 205 .max_size = HAL_RXDMA_RING_MAX_SIZE_BE, 206 } 207 }; 208 209 static const struct ath12k_hal_tcl_to_wbm_rbm_map 210 ath12k_hal_qcn9274_tcl_to_wbm_rbm_map[DP_TCL_NUM_RING_MAX] = { 211 { 212 .wbm_ring_num = 0, 213 .rbm_id = HAL_RX_BUF_RBM_SW0_BM, 214 }, 215 { 216 .wbm_ring_num = 1, 217 .rbm_id = HAL_RX_BUF_RBM_SW1_BM, 218 }, 219 { 220 .wbm_ring_num = 2, 221 .rbm_id = HAL_RX_BUF_RBM_SW2_BM, 222 }, 223 { 224 .wbm_ring_num = 4, 225 .rbm_id = HAL_RX_BUF_RBM_SW4_BM, 226 } 227 }; 228 229 static const struct ath12k_hal_tcl_to_wbm_rbm_map 230 ath12k_hal_wcn7850_tcl_to_wbm_rbm_map[DP_TCL_NUM_RING_MAX] = { 231 { 232 .wbm_ring_num = 0, 233 .rbm_id = HAL_RX_BUF_RBM_SW0_BM, 234 }, 235 { 236 .wbm_ring_num = 2, 237 .rbm_id = HAL_RX_BUF_RBM_SW2_BM, 238 }, 239 { 240 .wbm_ring_num = 4, 241 .rbm_id = HAL_RX_BUF_RBM_SW4_BM, 242 }, 243 }; 244 245 static unsigned int ath12k_hal_reo1_ring_id_offset(struct ath12k_base *ab) 246 { 247 return HAL_REO1_RING_ID(ab) - HAL_REO1_RING_BASE_LSB(ab); 248 } 249 250 static unsigned int ath12k_hal_reo1_ring_msi1_base_lsb_offset(struct ath12k_base *ab) 251 { 252 return HAL_REO1_RING_MSI1_BASE_LSB(ab) - HAL_REO1_RING_BASE_LSB(ab); 253 } 254 255 static unsigned int ath12k_hal_reo1_ring_msi1_base_msb_offset(struct ath12k_base *ab) 256 { 257 return HAL_REO1_RING_MSI1_BASE_MSB(ab) - HAL_REO1_RING_BASE_LSB(ab); 258 } 259 260 static unsigned int ath12k_hal_reo1_ring_msi1_data_offset(struct ath12k_base *ab) 261 { 262 return HAL_REO1_RING_MSI1_DATA(ab) - HAL_REO1_RING_BASE_LSB(ab); 263 } 264 265 static unsigned int ath12k_hal_reo1_ring_base_msb_offset(struct ath12k_base *ab) 266 { 267 return HAL_REO1_RING_BASE_MSB(ab) - HAL_REO1_RING_BASE_LSB(ab); 268 } 269 270 static unsigned int ath12k_hal_reo1_ring_producer_int_setup_offset(struct ath12k_base *ab) 271 { 272 return HAL_REO1_RING_PRODUCER_INT_SETUP(ab) - HAL_REO1_RING_BASE_LSB(ab); 273 } 274 275 static unsigned int ath12k_hal_reo1_ring_hp_addr_lsb_offset(struct ath12k_base *ab) 276 { 277 return HAL_REO1_RING_HP_ADDR_LSB(ab) - HAL_REO1_RING_BASE_LSB(ab); 278 } 279 280 static unsigned int ath12k_hal_reo1_ring_hp_addr_msb_offset(struct ath12k_base *ab) 281 { 282 return HAL_REO1_RING_HP_ADDR_MSB(ab) - HAL_REO1_RING_BASE_LSB(ab); 283 } 284 285 static unsigned int ath12k_hal_reo1_ring_misc_offset(struct ath12k_base *ab) 286 { 287 return HAL_REO1_RING_MISC(ab) - HAL_REO1_RING_BASE_LSB(ab); 288 } 289 290 static bool ath12k_hw_qcn9274_rx_desc_get_first_msdu(struct hal_rx_desc *desc) 291 { 292 return !!le16_get_bits(desc->u.qcn9274.msdu_end.info5, 293 RX_MSDU_END_INFO5_FIRST_MSDU); 294 } 295 296 static bool ath12k_hw_qcn9274_rx_desc_get_last_msdu(struct hal_rx_desc *desc) 297 { 298 return !!le16_get_bits(desc->u.qcn9274.msdu_end.info5, 299 RX_MSDU_END_INFO5_LAST_MSDU); 300 } 301 302 static u8 ath12k_hw_qcn9274_rx_desc_get_l3_pad_bytes(struct hal_rx_desc *desc) 303 { 304 return le16_get_bits(desc->u.qcn9274.msdu_end.info5, 305 RX_MSDU_END_INFO5_L3_HDR_PADDING); 306 } 307 308 static bool ath12k_hw_qcn9274_rx_desc_encrypt_valid(struct hal_rx_desc *desc) 309 { 310 return !!le32_get_bits(desc->u.qcn9274.mpdu_start.info4, 311 RX_MPDU_START_INFO4_ENCRYPT_INFO_VALID); 312 } 313 314 static u32 ath12k_hw_qcn9274_rx_desc_get_encrypt_type(struct hal_rx_desc *desc) 315 { 316 return le32_get_bits(desc->u.qcn9274.mpdu_start.info2, 317 RX_MPDU_START_INFO2_ENC_TYPE); 318 } 319 320 static u8 ath12k_hw_qcn9274_rx_desc_get_decap_type(struct hal_rx_desc *desc) 321 { 322 return le32_get_bits(desc->u.qcn9274.msdu_end.info11, 323 RX_MSDU_END_INFO11_DECAP_FORMAT); 324 } 325 326 static u8 ath12k_hw_qcn9274_rx_desc_get_mesh_ctl(struct hal_rx_desc *desc) 327 { 328 return le32_get_bits(desc->u.qcn9274.msdu_end.info11, 329 RX_MSDU_END_INFO11_MESH_CTRL_PRESENT); 330 } 331 332 static bool ath12k_hw_qcn9274_rx_desc_get_mpdu_seq_ctl_vld(struct hal_rx_desc *desc) 333 { 334 return !!le32_get_bits(desc->u.qcn9274.mpdu_start.info4, 335 RX_MPDU_START_INFO4_MPDU_SEQ_CTRL_VALID); 336 } 337 338 static bool ath12k_hw_qcn9274_rx_desc_get_mpdu_fc_valid(struct hal_rx_desc *desc) 339 { 340 return !!le32_get_bits(desc->u.qcn9274.mpdu_start.info4, 341 RX_MPDU_START_INFO4_MPDU_FCTRL_VALID); 342 } 343 344 static u16 ath12k_hw_qcn9274_rx_desc_get_mpdu_start_seq_no(struct hal_rx_desc *desc) 345 { 346 return le32_get_bits(desc->u.qcn9274.mpdu_start.info4, 347 RX_MPDU_START_INFO4_MPDU_SEQ_NUM); 348 } 349 350 static u16 ath12k_hw_qcn9274_rx_desc_get_msdu_len(struct hal_rx_desc *desc) 351 { 352 return le32_get_bits(desc->u.qcn9274.msdu_end.info10, 353 RX_MSDU_END_INFO10_MSDU_LENGTH); 354 } 355 356 static u8 ath12k_hw_qcn9274_rx_desc_get_msdu_sgi(struct hal_rx_desc *desc) 357 { 358 return le32_get_bits(desc->u.qcn9274.msdu_end.info12, 359 RX_MSDU_END_INFO12_SGI); 360 } 361 362 static u8 ath12k_hw_qcn9274_rx_desc_get_msdu_rate_mcs(struct hal_rx_desc *desc) 363 { 364 return le32_get_bits(desc->u.qcn9274.msdu_end.info12, 365 RX_MSDU_END_INFO12_RATE_MCS); 366 } 367 368 static u8 ath12k_hw_qcn9274_rx_desc_get_msdu_rx_bw(struct hal_rx_desc *desc) 369 { 370 return le32_get_bits(desc->u.qcn9274.msdu_end.info12, 371 RX_MSDU_END_INFO12_RECV_BW); 372 } 373 374 static u32 ath12k_hw_qcn9274_rx_desc_get_msdu_freq(struct hal_rx_desc *desc) 375 { 376 return __le32_to_cpu(desc->u.qcn9274.msdu_end.phy_meta_data); 377 } 378 379 static u8 ath12k_hw_qcn9274_rx_desc_get_msdu_pkt_type(struct hal_rx_desc *desc) 380 { 381 return le32_get_bits(desc->u.qcn9274.msdu_end.info12, 382 RX_MSDU_END_INFO12_PKT_TYPE); 383 } 384 385 static u8 ath12k_hw_qcn9274_rx_desc_get_msdu_nss(struct hal_rx_desc *desc) 386 { 387 return le32_get_bits(desc->u.qcn9274.msdu_end.info12, 388 RX_MSDU_END_INFO12_MIMO_SS_BITMAP); 389 } 390 391 static u8 ath12k_hw_qcn9274_rx_desc_get_mpdu_tid(struct hal_rx_desc *desc) 392 { 393 return le16_get_bits(desc->u.qcn9274.msdu_end.info5, 394 RX_MSDU_END_INFO5_TID); 395 } 396 397 static u16 ath12k_hw_qcn9274_rx_desc_get_mpdu_peer_id(struct hal_rx_desc *desc) 398 { 399 return __le16_to_cpu(desc->u.qcn9274.mpdu_start.sw_peer_id); 400 } 401 402 static void ath12k_hw_qcn9274_rx_desc_copy_end_tlv(struct hal_rx_desc *fdesc, 403 struct hal_rx_desc *ldesc) 404 { 405 memcpy(&fdesc->u.qcn9274.msdu_end, &ldesc->u.qcn9274.msdu_end, 406 sizeof(struct rx_msdu_end_qcn9274)); 407 } 408 409 static u32 ath12k_hw_qcn9274_rx_desc_get_mpdu_ppdu_id(struct hal_rx_desc *desc) 410 { 411 return __le16_to_cpu(desc->u.qcn9274.mpdu_start.phy_ppdu_id); 412 } 413 414 static void ath12k_hw_qcn9274_rx_desc_set_msdu_len(struct hal_rx_desc *desc, u16 len) 415 { 416 u32 info = __le32_to_cpu(desc->u.qcn9274.msdu_end.info10); 417 418 info &= ~RX_MSDU_END_INFO10_MSDU_LENGTH; 419 info |= u32_encode_bits(len, RX_MSDU_END_INFO10_MSDU_LENGTH); 420 421 desc->u.qcn9274.msdu_end.info10 = __cpu_to_le32(info); 422 } 423 424 static u8 *ath12k_hw_qcn9274_rx_desc_get_msdu_payload(struct hal_rx_desc *desc) 425 { 426 return &desc->u.qcn9274.msdu_payload[0]; 427 } 428 429 static u32 ath12k_hw_qcn9274_rx_desc_get_mpdu_start_offset(void) 430 { 431 return offsetof(struct hal_rx_desc_qcn9274, mpdu_start); 432 } 433 434 static u32 ath12k_hw_qcn9274_rx_desc_get_msdu_end_offset(void) 435 { 436 return offsetof(struct hal_rx_desc_qcn9274, msdu_end); 437 } 438 439 static bool ath12k_hw_qcn9274_rx_desc_mac_addr2_valid(struct hal_rx_desc *desc) 440 { 441 return __le32_to_cpu(desc->u.qcn9274.mpdu_start.info4) & 442 RX_MPDU_START_INFO4_MAC_ADDR2_VALID; 443 } 444 445 static u8 *ath12k_hw_qcn9274_rx_desc_mpdu_start_addr2(struct hal_rx_desc *desc) 446 { 447 return desc->u.qcn9274.mpdu_start.addr2; 448 } 449 450 static bool ath12k_hw_qcn9274_rx_desc_is_da_mcbc(struct hal_rx_desc *desc) 451 { 452 return __le32_to_cpu(desc->u.qcn9274.mpdu_start.info6) & 453 RX_MPDU_START_INFO6_MCAST_BCAST; 454 } 455 456 static void ath12k_hw_qcn9274_rx_desc_get_dot11_hdr(struct hal_rx_desc *desc, 457 struct ieee80211_hdr *hdr) 458 { 459 hdr->frame_control = desc->u.qcn9274.mpdu_start.frame_ctrl; 460 hdr->duration_id = desc->u.qcn9274.mpdu_start.duration; 461 ether_addr_copy(hdr->addr1, desc->u.qcn9274.mpdu_start.addr1); 462 ether_addr_copy(hdr->addr2, desc->u.qcn9274.mpdu_start.addr2); 463 ether_addr_copy(hdr->addr3, desc->u.qcn9274.mpdu_start.addr3); 464 if (__le32_to_cpu(desc->u.qcn9274.mpdu_start.info4) & 465 RX_MPDU_START_INFO4_MAC_ADDR4_VALID) { 466 ether_addr_copy(hdr->addr4, desc->u.qcn9274.mpdu_start.addr4); 467 } 468 hdr->seq_ctrl = desc->u.qcn9274.mpdu_start.seq_ctrl; 469 } 470 471 static void ath12k_hw_qcn9274_rx_desc_get_crypto_hdr(struct hal_rx_desc *desc, 472 u8 *crypto_hdr, 473 enum hal_encrypt_type enctype) 474 { 475 unsigned int key_id; 476 477 switch (enctype) { 478 case HAL_ENCRYPT_TYPE_OPEN: 479 return; 480 case HAL_ENCRYPT_TYPE_TKIP_NO_MIC: 481 case HAL_ENCRYPT_TYPE_TKIP_MIC: 482 crypto_hdr[0] = 483 HAL_RX_MPDU_INFO_PN_GET_BYTE2(desc->u.qcn9274.mpdu_start.pn[0]); 484 crypto_hdr[1] = 0; 485 crypto_hdr[2] = 486 HAL_RX_MPDU_INFO_PN_GET_BYTE1(desc->u.qcn9274.mpdu_start.pn[0]); 487 break; 488 case HAL_ENCRYPT_TYPE_CCMP_128: 489 case HAL_ENCRYPT_TYPE_CCMP_256: 490 case HAL_ENCRYPT_TYPE_GCMP_128: 491 case HAL_ENCRYPT_TYPE_AES_GCMP_256: 492 crypto_hdr[0] = 493 HAL_RX_MPDU_INFO_PN_GET_BYTE1(desc->u.qcn9274.mpdu_start.pn[0]); 494 crypto_hdr[1] = 495 HAL_RX_MPDU_INFO_PN_GET_BYTE2(desc->u.qcn9274.mpdu_start.pn[0]); 496 crypto_hdr[2] = 0; 497 break; 498 case HAL_ENCRYPT_TYPE_WEP_40: 499 case HAL_ENCRYPT_TYPE_WEP_104: 500 case HAL_ENCRYPT_TYPE_WEP_128: 501 case HAL_ENCRYPT_TYPE_WAPI_GCM_SM4: 502 case HAL_ENCRYPT_TYPE_WAPI: 503 return; 504 } 505 key_id = le32_get_bits(desc->u.qcn9274.mpdu_start.info5, 506 RX_MPDU_START_INFO5_KEY_ID); 507 crypto_hdr[3] = 0x20 | (key_id << 6); 508 crypto_hdr[4] = HAL_RX_MPDU_INFO_PN_GET_BYTE3(desc->u.qcn9274.mpdu_start.pn[0]); 509 crypto_hdr[5] = HAL_RX_MPDU_INFO_PN_GET_BYTE4(desc->u.qcn9274.mpdu_start.pn[0]); 510 crypto_hdr[6] = HAL_RX_MPDU_INFO_PN_GET_BYTE1(desc->u.qcn9274.mpdu_start.pn[1]); 511 crypto_hdr[7] = HAL_RX_MPDU_INFO_PN_GET_BYTE2(desc->u.qcn9274.mpdu_start.pn[1]); 512 } 513 514 static u16 ath12k_hw_qcn9274_rx_desc_get_mpdu_frame_ctl(struct hal_rx_desc *desc) 515 { 516 return __le16_to_cpu(desc->u.qcn9274.mpdu_start.frame_ctrl); 517 } 518 519 static int ath12k_hal_srng_create_config_qcn9274(struct ath12k_base *ab) 520 { 521 struct ath12k_hal *hal = &ab->hal; 522 struct hal_srng_config *s; 523 524 hal->srng_config = kmemdup(hw_srng_config_template, 525 sizeof(hw_srng_config_template), 526 GFP_KERNEL); 527 if (!hal->srng_config) 528 return -ENOMEM; 529 530 s = &hal->srng_config[HAL_REO_DST]; 531 s->reg_start[0] = HAL_SEQ_WCSS_UMAC_REO_REG + HAL_REO1_RING_BASE_LSB(ab); 532 s->reg_start[1] = HAL_SEQ_WCSS_UMAC_REO_REG + HAL_REO1_RING_HP; 533 s->reg_size[0] = HAL_REO2_RING_BASE_LSB(ab) - HAL_REO1_RING_BASE_LSB(ab); 534 s->reg_size[1] = HAL_REO2_RING_HP - HAL_REO1_RING_HP; 535 536 s = &hal->srng_config[HAL_REO_EXCEPTION]; 537 s->reg_start[0] = HAL_SEQ_WCSS_UMAC_REO_REG + HAL_REO_SW0_RING_BASE_LSB(ab); 538 s->reg_start[1] = HAL_SEQ_WCSS_UMAC_REO_REG + HAL_REO_SW0_RING_HP; 539 540 s = &hal->srng_config[HAL_REO_REINJECT]; 541 s->reg_start[0] = HAL_SEQ_WCSS_UMAC_REO_REG + HAL_SW2REO_RING_BASE_LSB(ab); 542 s->reg_start[1] = HAL_SEQ_WCSS_UMAC_REO_REG + HAL_SW2REO_RING_HP; 543 s->reg_size[0] = HAL_SW2REO1_RING_BASE_LSB(ab) - HAL_SW2REO_RING_BASE_LSB(ab); 544 s->reg_size[1] = HAL_SW2REO1_RING_HP - HAL_SW2REO_RING_HP; 545 546 s = &hal->srng_config[HAL_REO_CMD]; 547 s->reg_start[0] = HAL_SEQ_WCSS_UMAC_REO_REG + HAL_REO_CMD_RING_BASE_LSB(ab); 548 s->reg_start[1] = HAL_SEQ_WCSS_UMAC_REO_REG + HAL_REO_CMD_HP; 549 550 s = &hal->srng_config[HAL_REO_STATUS]; 551 s->reg_start[0] = HAL_SEQ_WCSS_UMAC_REO_REG + HAL_REO_STATUS_RING_BASE_LSB(ab); 552 s->reg_start[1] = HAL_SEQ_WCSS_UMAC_REO_REG + HAL_REO_STATUS_HP; 553 554 s = &hal->srng_config[HAL_TCL_DATA]; 555 s->reg_start[0] = HAL_SEQ_WCSS_UMAC_TCL_REG + HAL_TCL1_RING_BASE_LSB; 556 s->reg_start[1] = HAL_SEQ_WCSS_UMAC_TCL_REG + HAL_TCL1_RING_HP; 557 s->reg_size[0] = HAL_TCL2_RING_BASE_LSB - HAL_TCL1_RING_BASE_LSB; 558 s->reg_size[1] = HAL_TCL2_RING_HP - HAL_TCL1_RING_HP; 559 560 s = &hal->srng_config[HAL_TCL_CMD]; 561 s->reg_start[0] = HAL_SEQ_WCSS_UMAC_TCL_REG + HAL_TCL_RING_BASE_LSB(ab); 562 s->reg_start[1] = HAL_SEQ_WCSS_UMAC_TCL_REG + HAL_TCL_RING_HP; 563 564 s = &hal->srng_config[HAL_TCL_STATUS]; 565 s->reg_start[0] = HAL_SEQ_WCSS_UMAC_TCL_REG + HAL_TCL_STATUS_RING_BASE_LSB(ab); 566 s->reg_start[1] = HAL_SEQ_WCSS_UMAC_TCL_REG + HAL_TCL_STATUS_RING_HP; 567 568 s = &hal->srng_config[HAL_CE_SRC]; 569 s->reg_start[0] = HAL_SEQ_WCSS_UMAC_CE0_SRC_REG + HAL_CE_DST_RING_BASE_LSB; 570 s->reg_start[1] = HAL_SEQ_WCSS_UMAC_CE0_SRC_REG + HAL_CE_DST_RING_HP; 571 s->reg_size[0] = HAL_SEQ_WCSS_UMAC_CE1_SRC_REG - 572 HAL_SEQ_WCSS_UMAC_CE0_SRC_REG; 573 s->reg_size[1] = HAL_SEQ_WCSS_UMAC_CE1_SRC_REG - 574 HAL_SEQ_WCSS_UMAC_CE0_SRC_REG; 575 576 s = &hal->srng_config[HAL_CE_DST]; 577 s->reg_start[0] = HAL_SEQ_WCSS_UMAC_CE0_DST_REG + HAL_CE_DST_RING_BASE_LSB; 578 s->reg_start[1] = HAL_SEQ_WCSS_UMAC_CE0_DST_REG + HAL_CE_DST_RING_HP; 579 s->reg_size[0] = HAL_SEQ_WCSS_UMAC_CE1_DST_REG - 580 HAL_SEQ_WCSS_UMAC_CE0_DST_REG; 581 s->reg_size[1] = HAL_SEQ_WCSS_UMAC_CE1_DST_REG - 582 HAL_SEQ_WCSS_UMAC_CE0_DST_REG; 583 584 s = &hal->srng_config[HAL_CE_DST_STATUS]; 585 s->reg_start[0] = HAL_SEQ_WCSS_UMAC_CE0_DST_REG + 586 HAL_CE_DST_STATUS_RING_BASE_LSB; 587 s->reg_start[1] = HAL_SEQ_WCSS_UMAC_CE0_DST_REG + HAL_CE_DST_STATUS_RING_HP; 588 s->reg_size[0] = HAL_SEQ_WCSS_UMAC_CE1_DST_REG - 589 HAL_SEQ_WCSS_UMAC_CE0_DST_REG; 590 s->reg_size[1] = HAL_SEQ_WCSS_UMAC_CE1_DST_REG - 591 HAL_SEQ_WCSS_UMAC_CE0_DST_REG; 592 593 s = &hal->srng_config[HAL_WBM_IDLE_LINK]; 594 s->reg_start[0] = HAL_SEQ_WCSS_UMAC_WBM_REG + HAL_WBM_IDLE_LINK_RING_BASE_LSB(ab); 595 s->reg_start[1] = HAL_SEQ_WCSS_UMAC_WBM_REG + HAL_WBM_IDLE_LINK_RING_HP; 596 597 s = &hal->srng_config[HAL_SW2WBM_RELEASE]; 598 s->reg_start[0] = HAL_SEQ_WCSS_UMAC_WBM_REG + 599 HAL_WBM_SW_RELEASE_RING_BASE_LSB(ab); 600 s->reg_start[1] = HAL_SEQ_WCSS_UMAC_WBM_REG + HAL_WBM_SW_RELEASE_RING_HP; 601 s->reg_size[0] = HAL_WBM_SW1_RELEASE_RING_BASE_LSB(ab) - 602 HAL_WBM_SW_RELEASE_RING_BASE_LSB(ab); 603 s->reg_size[1] = HAL_WBM_SW1_RELEASE_RING_HP - HAL_WBM_SW_RELEASE_RING_HP; 604 605 s = &hal->srng_config[HAL_WBM2SW_RELEASE]; 606 s->reg_start[0] = HAL_SEQ_WCSS_UMAC_WBM_REG + HAL_WBM0_RELEASE_RING_BASE_LSB(ab); 607 s->reg_start[1] = HAL_SEQ_WCSS_UMAC_WBM_REG + HAL_WBM0_RELEASE_RING_HP; 608 s->reg_size[0] = HAL_WBM1_RELEASE_RING_BASE_LSB(ab) - 609 HAL_WBM0_RELEASE_RING_BASE_LSB(ab); 610 s->reg_size[1] = HAL_WBM1_RELEASE_RING_HP - HAL_WBM0_RELEASE_RING_HP; 611 612 /* Some LMAC rings are not accessed from the host: 613 * RXDMA_BUG, RXDMA_DST, RXDMA_MONITOR_BUF, RXDMA_MONITOR_STATUS, 614 * RXDMA_MONITOR_DST, RXDMA_MONITOR_DESC, RXDMA_DIR_BUF_SRC, 615 * RXDMA_RX_MONITOR_BUF, TX_MONITOR_BUF, TX_MONITOR_DST, SW2RXDMA 616 */ 617 s = &hal->srng_config[HAL_PPE2TCL]; 618 s->reg_start[0] = HAL_SEQ_WCSS_UMAC_TCL_REG + HAL_TCL_PPE2TCL1_RING_BASE_LSB; 619 s->reg_start[1] = HAL_SEQ_WCSS_UMAC_TCL_REG + HAL_TCL_PPE2TCL1_RING_HP; 620 621 s = &hal->srng_config[HAL_PPE_RELEASE]; 622 s->reg_start[0] = HAL_SEQ_WCSS_UMAC_WBM_REG + 623 HAL_WBM_PPE_RELEASE_RING_BASE_LSB(ab); 624 s->reg_start[1] = HAL_SEQ_WCSS_UMAC_WBM_REG + HAL_WBM_PPE_RELEASE_RING_HP; 625 626 return 0; 627 } 628 629 static u16 ath12k_hal_qcn9274_rx_mpdu_start_wmask_get(void) 630 { 631 return QCN9274_MPDU_START_WMASK; 632 } 633 634 static u32 ath12k_hal_qcn9274_rx_msdu_end_wmask_get(void) 635 { 636 return QCN9274_MSDU_END_WMASK; 637 } 638 639 static const struct hal_rx_ops *ath12k_hal_qcn9274_get_hal_rx_compact_ops(void) 640 { 641 return &hal_rx_qcn9274_compact_ops; 642 } 643 644 static bool ath12k_hw_qcn9274_dp_rx_h_msdu_done(struct hal_rx_desc *desc) 645 { 646 return !!le32_get_bits(desc->u.qcn9274.msdu_end.info14, 647 RX_MSDU_END_INFO14_MSDU_DONE); 648 } 649 650 static bool ath12k_hw_qcn9274_dp_rx_h_l4_cksum_fail(struct hal_rx_desc *desc) 651 { 652 return !!le32_get_bits(desc->u.qcn9274.msdu_end.info13, 653 RX_MSDU_END_INFO13_TCP_UDP_CKSUM_FAIL); 654 } 655 656 static bool ath12k_hw_qcn9274_dp_rx_h_ip_cksum_fail(struct hal_rx_desc *desc) 657 { 658 return !!le32_get_bits(desc->u.qcn9274.msdu_end.info13, 659 RX_MSDU_END_INFO13_IP_CKSUM_FAIL); 660 } 661 662 static bool ath12k_hw_qcn9274_dp_rx_h_is_decrypted(struct hal_rx_desc *desc) 663 { 664 return (le32_get_bits(desc->u.qcn9274.msdu_end.info14, 665 RX_MSDU_END_INFO14_DECRYPT_STATUS_CODE) == 666 RX_DESC_DECRYPT_STATUS_CODE_OK); 667 } 668 669 static u32 ath12k_hw_qcn9274_dp_rx_h_mpdu_err(struct hal_rx_desc *desc) 670 { 671 u32 info = __le32_to_cpu(desc->u.qcn9274.msdu_end.info13); 672 u32 errmap = 0; 673 674 if (info & RX_MSDU_END_INFO13_FCS_ERR) 675 errmap |= HAL_RX_MPDU_ERR_FCS; 676 677 if (info & RX_MSDU_END_INFO13_DECRYPT_ERR) 678 errmap |= HAL_RX_MPDU_ERR_DECRYPT; 679 680 if (info & RX_MSDU_END_INFO13_TKIP_MIC_ERR) 681 errmap |= HAL_RX_MPDU_ERR_TKIP_MIC; 682 683 if (info & RX_MSDU_END_INFO13_A_MSDU_ERROR) 684 errmap |= HAL_RX_MPDU_ERR_AMSDU_ERR; 685 686 if (info & RX_MSDU_END_INFO13_OVERFLOW_ERR) 687 errmap |= HAL_RX_MPDU_ERR_OVERFLOW; 688 689 if (info & RX_MSDU_END_INFO13_MSDU_LEN_ERR) 690 errmap |= HAL_RX_MPDU_ERR_MSDU_LEN; 691 692 if (info & RX_MSDU_END_INFO13_MPDU_LEN_ERR) 693 errmap |= HAL_RX_MPDU_ERR_MPDU_LEN; 694 695 return errmap; 696 } 697 698 static u32 ath12k_hw_qcn9274_get_rx_desc_size(void) 699 { 700 return sizeof(struct hal_rx_desc_qcn9274); 701 } 702 703 static u8 ath12k_hw_qcn9274_rx_desc_get_msdu_src_link(struct hal_rx_desc *desc) 704 { 705 return 0; 706 } 707 708 const struct hal_rx_ops hal_rx_qcn9274_ops = { 709 .rx_desc_get_first_msdu = ath12k_hw_qcn9274_rx_desc_get_first_msdu, 710 .rx_desc_get_last_msdu = ath12k_hw_qcn9274_rx_desc_get_last_msdu, 711 .rx_desc_get_l3_pad_bytes = ath12k_hw_qcn9274_rx_desc_get_l3_pad_bytes, 712 .rx_desc_encrypt_valid = ath12k_hw_qcn9274_rx_desc_encrypt_valid, 713 .rx_desc_get_encrypt_type = ath12k_hw_qcn9274_rx_desc_get_encrypt_type, 714 .rx_desc_get_decap_type = ath12k_hw_qcn9274_rx_desc_get_decap_type, 715 .rx_desc_get_mesh_ctl = ath12k_hw_qcn9274_rx_desc_get_mesh_ctl, 716 .rx_desc_get_mpdu_seq_ctl_vld = ath12k_hw_qcn9274_rx_desc_get_mpdu_seq_ctl_vld, 717 .rx_desc_get_mpdu_fc_valid = ath12k_hw_qcn9274_rx_desc_get_mpdu_fc_valid, 718 .rx_desc_get_mpdu_start_seq_no = ath12k_hw_qcn9274_rx_desc_get_mpdu_start_seq_no, 719 .rx_desc_get_msdu_len = ath12k_hw_qcn9274_rx_desc_get_msdu_len, 720 .rx_desc_get_msdu_sgi = ath12k_hw_qcn9274_rx_desc_get_msdu_sgi, 721 .rx_desc_get_msdu_rate_mcs = ath12k_hw_qcn9274_rx_desc_get_msdu_rate_mcs, 722 .rx_desc_get_msdu_rx_bw = ath12k_hw_qcn9274_rx_desc_get_msdu_rx_bw, 723 .rx_desc_get_msdu_freq = ath12k_hw_qcn9274_rx_desc_get_msdu_freq, 724 .rx_desc_get_msdu_pkt_type = ath12k_hw_qcn9274_rx_desc_get_msdu_pkt_type, 725 .rx_desc_get_msdu_nss = ath12k_hw_qcn9274_rx_desc_get_msdu_nss, 726 .rx_desc_get_mpdu_tid = ath12k_hw_qcn9274_rx_desc_get_mpdu_tid, 727 .rx_desc_get_mpdu_peer_id = ath12k_hw_qcn9274_rx_desc_get_mpdu_peer_id, 728 .rx_desc_copy_end_tlv = ath12k_hw_qcn9274_rx_desc_copy_end_tlv, 729 .rx_desc_get_mpdu_ppdu_id = ath12k_hw_qcn9274_rx_desc_get_mpdu_ppdu_id, 730 .rx_desc_set_msdu_len = ath12k_hw_qcn9274_rx_desc_set_msdu_len, 731 .rx_desc_get_msdu_payload = ath12k_hw_qcn9274_rx_desc_get_msdu_payload, 732 .rx_desc_get_mpdu_start_offset = ath12k_hw_qcn9274_rx_desc_get_mpdu_start_offset, 733 .rx_desc_get_msdu_end_offset = ath12k_hw_qcn9274_rx_desc_get_msdu_end_offset, 734 .rx_desc_mac_addr2_valid = ath12k_hw_qcn9274_rx_desc_mac_addr2_valid, 735 .rx_desc_mpdu_start_addr2 = ath12k_hw_qcn9274_rx_desc_mpdu_start_addr2, 736 .rx_desc_is_da_mcbc = ath12k_hw_qcn9274_rx_desc_is_da_mcbc, 737 .rx_desc_get_dot11_hdr = ath12k_hw_qcn9274_rx_desc_get_dot11_hdr, 738 .rx_desc_get_crypto_header = ath12k_hw_qcn9274_rx_desc_get_crypto_hdr, 739 .rx_desc_get_mpdu_frame_ctl = ath12k_hw_qcn9274_rx_desc_get_mpdu_frame_ctl, 740 .dp_rx_h_msdu_done = ath12k_hw_qcn9274_dp_rx_h_msdu_done, 741 .dp_rx_h_l4_cksum_fail = ath12k_hw_qcn9274_dp_rx_h_l4_cksum_fail, 742 .dp_rx_h_ip_cksum_fail = ath12k_hw_qcn9274_dp_rx_h_ip_cksum_fail, 743 .dp_rx_h_is_decrypted = ath12k_hw_qcn9274_dp_rx_h_is_decrypted, 744 .dp_rx_h_mpdu_err = ath12k_hw_qcn9274_dp_rx_h_mpdu_err, 745 .rx_desc_get_desc_size = ath12k_hw_qcn9274_get_rx_desc_size, 746 .rx_desc_get_msdu_src_link_id = ath12k_hw_qcn9274_rx_desc_get_msdu_src_link, 747 }; 748 749 static bool ath12k_hw_qcn9274_compact_rx_desc_get_first_msdu(struct hal_rx_desc *desc) 750 { 751 return !!le16_get_bits(desc->u.qcn9274_compact.msdu_end.info5, 752 RX_MSDU_END_INFO5_FIRST_MSDU); 753 } 754 755 static bool ath12k_hw_qcn9274_compact_rx_desc_get_last_msdu(struct hal_rx_desc *desc) 756 { 757 return !!le16_get_bits(desc->u.qcn9274_compact.msdu_end.info5, 758 RX_MSDU_END_INFO5_LAST_MSDU); 759 } 760 761 static u8 ath12k_hw_qcn9274_compact_rx_desc_get_l3_pad_bytes(struct hal_rx_desc *desc) 762 { 763 return le16_get_bits(desc->u.qcn9274_compact.msdu_end.info5, 764 RX_MSDU_END_INFO5_L3_HDR_PADDING); 765 } 766 767 static bool ath12k_hw_qcn9274_compact_rx_desc_encrypt_valid(struct hal_rx_desc *desc) 768 { 769 return !!le32_get_bits(desc->u.qcn9274_compact.mpdu_start.info4, 770 RX_MPDU_START_INFO4_ENCRYPT_INFO_VALID); 771 } 772 773 static u32 ath12k_hw_qcn9274_compact_rx_desc_get_encrypt_type(struct hal_rx_desc *desc) 774 { 775 return le32_get_bits(desc->u.qcn9274_compact.mpdu_start.info2, 776 RX_MPDU_START_INFO2_ENC_TYPE); 777 } 778 779 static u8 ath12k_hw_qcn9274_compact_rx_desc_get_decap_type(struct hal_rx_desc *desc) 780 { 781 return le32_get_bits(desc->u.qcn9274_compact.msdu_end.info11, 782 RX_MSDU_END_INFO11_DECAP_FORMAT); 783 } 784 785 static u8 ath12k_hw_qcn9274_compact_rx_desc_get_mesh_ctl(struct hal_rx_desc *desc) 786 { 787 return le32_get_bits(desc->u.qcn9274.msdu_end.info11, 788 RX_MSDU_END_INFO11_MESH_CTRL_PRESENT); 789 } 790 791 static bool 792 ath12k_hw_qcn9274_compact_rx_desc_get_mpdu_seq_ctl_vld(struct hal_rx_desc *desc) 793 { 794 return !!le32_get_bits(desc->u.qcn9274_compact.mpdu_start.info4, 795 RX_MPDU_START_INFO4_MPDU_SEQ_CTRL_VALID); 796 } 797 798 static bool ath12k_hw_qcn9274_compact_rx_desc_get_mpdu_fc_valid(struct hal_rx_desc *desc) 799 { 800 return !!le32_get_bits(desc->u.qcn9274_compact.mpdu_start.info4, 801 RX_MPDU_START_INFO4_MPDU_FCTRL_VALID); 802 } 803 804 static u16 805 ath12k_hw_qcn9274_compact_rx_desc_get_mpdu_start_seq_no(struct hal_rx_desc *desc) 806 { 807 return le32_get_bits(desc->u.qcn9274_compact.mpdu_start.info4, 808 RX_MPDU_START_INFO4_MPDU_SEQ_NUM); 809 } 810 811 static u16 ath12k_hw_qcn9274_compact_rx_desc_get_msdu_len(struct hal_rx_desc *desc) 812 { 813 return le32_get_bits(desc->u.qcn9274_compact.msdu_end.info10, 814 RX_MSDU_END_INFO10_MSDU_LENGTH); 815 } 816 817 static u8 ath12k_hw_qcn9274_compact_rx_desc_get_msdu_sgi(struct hal_rx_desc *desc) 818 { 819 return le32_get_bits(desc->u.qcn9274_compact.msdu_end.info12, 820 RX_MSDU_END_INFO12_SGI); 821 } 822 823 static u8 ath12k_hw_qcn9274_compact_rx_desc_get_msdu_rate_mcs(struct hal_rx_desc *desc) 824 { 825 return le32_get_bits(desc->u.qcn9274_compact.msdu_end.info12, 826 RX_MSDU_END_INFO12_RATE_MCS); 827 } 828 829 static u8 ath12k_hw_qcn9274_compact_rx_desc_get_msdu_rx_bw(struct hal_rx_desc *desc) 830 { 831 return le32_get_bits(desc->u.qcn9274_compact.msdu_end.info12, 832 RX_MSDU_END_INFO12_RECV_BW); 833 } 834 835 static u32 ath12k_hw_qcn9274_compact_rx_desc_get_msdu_freq(struct hal_rx_desc *desc) 836 { 837 return __le32_to_cpu(desc->u.qcn9274_compact.msdu_end.phy_meta_data); 838 } 839 840 static u8 ath12k_hw_qcn9274_compact_rx_desc_get_msdu_pkt_type(struct hal_rx_desc *desc) 841 { 842 return le32_get_bits(desc->u.qcn9274_compact.msdu_end.info12, 843 RX_MSDU_END_INFO12_PKT_TYPE); 844 } 845 846 static u8 ath12k_hw_qcn9274_compact_rx_desc_get_msdu_nss(struct hal_rx_desc *desc) 847 { 848 return le32_get_bits(desc->u.qcn9274_compact.msdu_end.info12, 849 RX_MSDU_END_INFO12_MIMO_SS_BITMAP); 850 } 851 852 static u8 ath12k_hw_qcn9274_compact_rx_desc_get_mpdu_tid(struct hal_rx_desc *desc) 853 { 854 return le16_get_bits(desc->u.qcn9274_compact.msdu_end.info5, 855 RX_MSDU_END_INFO5_TID); 856 } 857 858 static u16 ath12k_hw_qcn9274_compact_rx_desc_get_mpdu_peer_id(struct hal_rx_desc *desc) 859 { 860 return __le16_to_cpu(desc->u.qcn9274_compact.mpdu_start.sw_peer_id); 861 } 862 863 static void ath12k_hw_qcn9274_compact_rx_desc_copy_end_tlv(struct hal_rx_desc *fdesc, 864 struct hal_rx_desc *ldesc) 865 { 866 fdesc->u.qcn9274_compact.msdu_end = ldesc->u.qcn9274_compact.msdu_end; 867 } 868 869 static u32 ath12k_hw_qcn9274_compact_rx_desc_get_mpdu_ppdu_id(struct hal_rx_desc *desc) 870 { 871 return __le16_to_cpu(desc->u.qcn9274_compact.mpdu_start.phy_ppdu_id); 872 } 873 874 static void 875 ath12k_hw_qcn9274_compact_rx_desc_set_msdu_len(struct hal_rx_desc *desc, u16 len) 876 { 877 u32 info = __le32_to_cpu(desc->u.qcn9274_compact.msdu_end.info10); 878 879 info = u32_replace_bits(info, len, RX_MSDU_END_INFO10_MSDU_LENGTH); 880 desc->u.qcn9274_compact.msdu_end.info10 = __cpu_to_le32(info); 881 } 882 883 static u8 *ath12k_hw_qcn9274_compact_rx_desc_get_msdu_payload(struct hal_rx_desc *desc) 884 { 885 return &desc->u.qcn9274_compact.msdu_payload[0]; 886 } 887 888 static u32 ath12k_hw_qcn9274_compact_rx_desc_get_mpdu_start_offset(void) 889 { 890 return offsetof(struct hal_rx_desc_qcn9274_compact, mpdu_start); 891 } 892 893 static u32 ath12k_hw_qcn9274_compact_rx_desc_get_msdu_end_offset(void) 894 { 895 return offsetof(struct hal_rx_desc_qcn9274_compact, msdu_end); 896 } 897 898 static bool ath12k_hw_qcn9274_compact_rx_desc_mac_addr2_valid(struct hal_rx_desc *desc) 899 { 900 return __le32_to_cpu(desc->u.qcn9274_compact.mpdu_start.info4) & 901 RX_MPDU_START_INFO4_MAC_ADDR2_VALID; 902 } 903 904 static u8 *ath12k_hw_qcn9274_compact_rx_desc_mpdu_start_addr2(struct hal_rx_desc *desc) 905 { 906 return desc->u.qcn9274_compact.mpdu_start.addr2; 907 } 908 909 static bool ath12k_hw_qcn9274_compact_rx_desc_is_da_mcbc(struct hal_rx_desc *desc) 910 { 911 return __le32_to_cpu(desc->u.qcn9274_compact.mpdu_start.info6) & 912 RX_MPDU_START_INFO6_MCAST_BCAST; 913 } 914 915 static void ath12k_hw_qcn9274_compact_rx_desc_get_dot11_hdr(struct hal_rx_desc *desc, 916 struct ieee80211_hdr *hdr) 917 { 918 hdr->frame_control = desc->u.qcn9274_compact.mpdu_start.frame_ctrl; 919 hdr->duration_id = desc->u.qcn9274_compact.mpdu_start.duration; 920 ether_addr_copy(hdr->addr1, desc->u.qcn9274_compact.mpdu_start.addr1); 921 ether_addr_copy(hdr->addr2, desc->u.qcn9274_compact.mpdu_start.addr2); 922 ether_addr_copy(hdr->addr3, desc->u.qcn9274_compact.mpdu_start.addr3); 923 if (__le32_to_cpu(desc->u.qcn9274_compact.mpdu_start.info4) & 924 RX_MPDU_START_INFO4_MAC_ADDR4_VALID) { 925 ether_addr_copy(hdr->addr4, desc->u.qcn9274_compact.mpdu_start.addr4); 926 } 927 hdr->seq_ctrl = desc->u.qcn9274_compact.mpdu_start.seq_ctrl; 928 } 929 930 static void 931 ath12k_hw_qcn9274_compact_rx_desc_get_crypto_hdr(struct hal_rx_desc *desc, 932 u8 *crypto_hdr, 933 enum hal_encrypt_type enctype) 934 { 935 unsigned int key_id; 936 937 switch (enctype) { 938 case HAL_ENCRYPT_TYPE_OPEN: 939 return; 940 case HAL_ENCRYPT_TYPE_TKIP_NO_MIC: 941 case HAL_ENCRYPT_TYPE_TKIP_MIC: 942 crypto_hdr[0] = 943 HAL_RX_MPDU_INFO_PN_GET_BYTE2(desc->u.qcn9274_compact.mpdu_start.pn[0]); 944 crypto_hdr[1] = 0; 945 crypto_hdr[2] = 946 HAL_RX_MPDU_INFO_PN_GET_BYTE1(desc->u.qcn9274_compact.mpdu_start.pn[0]); 947 break; 948 case HAL_ENCRYPT_TYPE_CCMP_128: 949 case HAL_ENCRYPT_TYPE_CCMP_256: 950 case HAL_ENCRYPT_TYPE_GCMP_128: 951 case HAL_ENCRYPT_TYPE_AES_GCMP_256: 952 crypto_hdr[0] = 953 HAL_RX_MPDU_INFO_PN_GET_BYTE1(desc->u.qcn9274_compact.mpdu_start.pn[0]); 954 crypto_hdr[1] = 955 HAL_RX_MPDU_INFO_PN_GET_BYTE2(desc->u.qcn9274_compact.mpdu_start.pn[0]); 956 crypto_hdr[2] = 0; 957 break; 958 case HAL_ENCRYPT_TYPE_WEP_40: 959 case HAL_ENCRYPT_TYPE_WEP_104: 960 case HAL_ENCRYPT_TYPE_WEP_128: 961 case HAL_ENCRYPT_TYPE_WAPI_GCM_SM4: 962 case HAL_ENCRYPT_TYPE_WAPI: 963 return; 964 } 965 key_id = le32_get_bits(desc->u.qcn9274_compact.mpdu_start.info5, 966 RX_MPDU_START_INFO5_KEY_ID); 967 crypto_hdr[3] = 0x20 | (key_id << 6); 968 crypto_hdr[4] = 969 HAL_RX_MPDU_INFO_PN_GET_BYTE3(desc->u.qcn9274_compact.mpdu_start.pn[0]); 970 crypto_hdr[5] = 971 HAL_RX_MPDU_INFO_PN_GET_BYTE4(desc->u.qcn9274_compact.mpdu_start.pn[0]); 972 crypto_hdr[6] = 973 HAL_RX_MPDU_INFO_PN_GET_BYTE1(desc->u.qcn9274_compact.mpdu_start.pn[1]); 974 crypto_hdr[7] = 975 HAL_RX_MPDU_INFO_PN_GET_BYTE2(desc->u.qcn9274_compact.mpdu_start.pn[1]); 976 } 977 978 static u16 ath12k_hw_qcn9274_compact_rx_desc_get_mpdu_frame_ctl(struct hal_rx_desc *desc) 979 { 980 return __le16_to_cpu(desc->u.qcn9274_compact.mpdu_start.frame_ctrl); 981 } 982 983 static bool ath12k_hw_qcn9274_compact_dp_rx_h_msdu_done(struct hal_rx_desc *desc) 984 { 985 return !!le32_get_bits(desc->u.qcn9274_compact.msdu_end.info14, 986 RX_MSDU_END_INFO14_MSDU_DONE); 987 } 988 989 static bool ath12k_hw_qcn9274_compact_dp_rx_h_l4_cksum_fail(struct hal_rx_desc *desc) 990 { 991 return !!le32_get_bits(desc->u.qcn9274_compact.msdu_end.info13, 992 RX_MSDU_END_INFO13_TCP_UDP_CKSUM_FAIL); 993 } 994 995 static bool ath12k_hw_qcn9274_compact_dp_rx_h_ip_cksum_fail(struct hal_rx_desc *desc) 996 { 997 return !!le32_get_bits(desc->u.qcn9274_compact.msdu_end.info13, 998 RX_MSDU_END_INFO13_IP_CKSUM_FAIL); 999 } 1000 1001 static bool ath12k_hw_qcn9274_compact_dp_rx_h_is_decrypted(struct hal_rx_desc *desc) 1002 { 1003 return (le32_get_bits(desc->u.qcn9274_compact.msdu_end.info14, 1004 RX_MSDU_END_INFO14_DECRYPT_STATUS_CODE) == 1005 RX_DESC_DECRYPT_STATUS_CODE_OK); 1006 } 1007 1008 static u32 ath12k_hw_qcn9274_compact_dp_rx_h_mpdu_err(struct hal_rx_desc *desc) 1009 { 1010 u32 info = __le32_to_cpu(desc->u.qcn9274_compact.msdu_end.info13); 1011 u32 errmap = 0; 1012 1013 if (info & RX_MSDU_END_INFO13_FCS_ERR) 1014 errmap |= HAL_RX_MPDU_ERR_FCS; 1015 1016 if (info & RX_MSDU_END_INFO13_DECRYPT_ERR) 1017 errmap |= HAL_RX_MPDU_ERR_DECRYPT; 1018 1019 if (info & RX_MSDU_END_INFO13_TKIP_MIC_ERR) 1020 errmap |= HAL_RX_MPDU_ERR_TKIP_MIC; 1021 1022 if (info & RX_MSDU_END_INFO13_A_MSDU_ERROR) 1023 errmap |= HAL_RX_MPDU_ERR_AMSDU_ERR; 1024 1025 if (info & RX_MSDU_END_INFO13_OVERFLOW_ERR) 1026 errmap |= HAL_RX_MPDU_ERR_OVERFLOW; 1027 1028 if (info & RX_MSDU_END_INFO13_MSDU_LEN_ERR) 1029 errmap |= HAL_RX_MPDU_ERR_MSDU_LEN; 1030 1031 if (info & RX_MSDU_END_INFO13_MPDU_LEN_ERR) 1032 errmap |= HAL_RX_MPDU_ERR_MPDU_LEN; 1033 1034 return errmap; 1035 } 1036 1037 static u32 ath12k_hw_qcn9274_compact_get_rx_desc_size(void) 1038 { 1039 return sizeof(struct hal_rx_desc_qcn9274_compact); 1040 } 1041 1042 static u8 ath12k_hw_qcn9274_compact_rx_desc_get_msdu_src_link(struct hal_rx_desc *desc) 1043 { 1044 return le64_get_bits(desc->u.qcn9274_compact.msdu_end.msdu_end_tag, 1045 RX_MSDU_END_64_TLV_SRC_LINK_ID); 1046 } 1047 1048 const struct hal_rx_ops hal_rx_qcn9274_compact_ops = { 1049 .rx_desc_get_first_msdu = ath12k_hw_qcn9274_compact_rx_desc_get_first_msdu, 1050 .rx_desc_get_last_msdu = ath12k_hw_qcn9274_compact_rx_desc_get_last_msdu, 1051 .rx_desc_get_l3_pad_bytes = ath12k_hw_qcn9274_compact_rx_desc_get_l3_pad_bytes, 1052 .rx_desc_encrypt_valid = ath12k_hw_qcn9274_compact_rx_desc_encrypt_valid, 1053 .rx_desc_get_encrypt_type = ath12k_hw_qcn9274_compact_rx_desc_get_encrypt_type, 1054 .rx_desc_get_decap_type = ath12k_hw_qcn9274_compact_rx_desc_get_decap_type, 1055 .rx_desc_get_mesh_ctl = ath12k_hw_qcn9274_compact_rx_desc_get_mesh_ctl, 1056 .rx_desc_get_mpdu_seq_ctl_vld = 1057 ath12k_hw_qcn9274_compact_rx_desc_get_mpdu_seq_ctl_vld, 1058 .rx_desc_get_mpdu_fc_valid = ath12k_hw_qcn9274_compact_rx_desc_get_mpdu_fc_valid, 1059 .rx_desc_get_mpdu_start_seq_no = 1060 ath12k_hw_qcn9274_compact_rx_desc_get_mpdu_start_seq_no, 1061 .rx_desc_get_msdu_len = ath12k_hw_qcn9274_compact_rx_desc_get_msdu_len, 1062 .rx_desc_get_msdu_sgi = ath12k_hw_qcn9274_compact_rx_desc_get_msdu_sgi, 1063 .rx_desc_get_msdu_rate_mcs = ath12k_hw_qcn9274_compact_rx_desc_get_msdu_rate_mcs, 1064 .rx_desc_get_msdu_rx_bw = ath12k_hw_qcn9274_compact_rx_desc_get_msdu_rx_bw, 1065 .rx_desc_get_msdu_freq = ath12k_hw_qcn9274_compact_rx_desc_get_msdu_freq, 1066 .rx_desc_get_msdu_pkt_type = ath12k_hw_qcn9274_compact_rx_desc_get_msdu_pkt_type, 1067 .rx_desc_get_msdu_nss = ath12k_hw_qcn9274_compact_rx_desc_get_msdu_nss, 1068 .rx_desc_get_mpdu_tid = ath12k_hw_qcn9274_compact_rx_desc_get_mpdu_tid, 1069 .rx_desc_get_mpdu_peer_id = ath12k_hw_qcn9274_compact_rx_desc_get_mpdu_peer_id, 1070 .rx_desc_copy_end_tlv = ath12k_hw_qcn9274_compact_rx_desc_copy_end_tlv, 1071 .rx_desc_get_mpdu_ppdu_id = ath12k_hw_qcn9274_compact_rx_desc_get_mpdu_ppdu_id, 1072 .rx_desc_set_msdu_len = ath12k_hw_qcn9274_compact_rx_desc_set_msdu_len, 1073 .rx_desc_get_msdu_payload = ath12k_hw_qcn9274_compact_rx_desc_get_msdu_payload, 1074 .rx_desc_get_mpdu_start_offset = 1075 ath12k_hw_qcn9274_compact_rx_desc_get_mpdu_start_offset, 1076 .rx_desc_get_msdu_end_offset = 1077 ath12k_hw_qcn9274_compact_rx_desc_get_msdu_end_offset, 1078 .rx_desc_mac_addr2_valid = ath12k_hw_qcn9274_compact_rx_desc_mac_addr2_valid, 1079 .rx_desc_mpdu_start_addr2 = ath12k_hw_qcn9274_compact_rx_desc_mpdu_start_addr2, 1080 .rx_desc_is_da_mcbc = ath12k_hw_qcn9274_compact_rx_desc_is_da_mcbc, 1081 .rx_desc_get_dot11_hdr = ath12k_hw_qcn9274_compact_rx_desc_get_dot11_hdr, 1082 .rx_desc_get_crypto_header = ath12k_hw_qcn9274_compact_rx_desc_get_crypto_hdr, 1083 .rx_desc_get_mpdu_frame_ctl = 1084 ath12k_hw_qcn9274_compact_rx_desc_get_mpdu_frame_ctl, 1085 .dp_rx_h_msdu_done = ath12k_hw_qcn9274_compact_dp_rx_h_msdu_done, 1086 .dp_rx_h_l4_cksum_fail = ath12k_hw_qcn9274_compact_dp_rx_h_l4_cksum_fail, 1087 .dp_rx_h_ip_cksum_fail = ath12k_hw_qcn9274_compact_dp_rx_h_ip_cksum_fail, 1088 .dp_rx_h_is_decrypted = ath12k_hw_qcn9274_compact_dp_rx_h_is_decrypted, 1089 .dp_rx_h_mpdu_err = ath12k_hw_qcn9274_compact_dp_rx_h_mpdu_err, 1090 .rx_desc_get_desc_size = ath12k_hw_qcn9274_compact_get_rx_desc_size, 1091 .rx_desc_get_msdu_src_link_id = 1092 ath12k_hw_qcn9274_compact_rx_desc_get_msdu_src_link, 1093 }; 1094 1095 const struct hal_ops hal_qcn9274_ops = { 1096 .create_srng_config = ath12k_hal_srng_create_config_qcn9274, 1097 .tcl_to_wbm_rbm_map = ath12k_hal_qcn9274_tcl_to_wbm_rbm_map, 1098 .rxdma_ring_wmask_rx_mpdu_start = ath12k_hal_qcn9274_rx_mpdu_start_wmask_get, 1099 .rxdma_ring_wmask_rx_msdu_end = ath12k_hal_qcn9274_rx_msdu_end_wmask_get, 1100 .get_hal_rx_compact_ops = ath12k_hal_qcn9274_get_hal_rx_compact_ops, 1101 }; 1102 1103 static bool ath12k_hw_wcn7850_rx_desc_get_first_msdu(struct hal_rx_desc *desc) 1104 { 1105 return !!le16_get_bits(desc->u.wcn7850.msdu_end.info5, 1106 RX_MSDU_END_INFO5_FIRST_MSDU); 1107 } 1108 1109 static bool ath12k_hw_wcn7850_rx_desc_get_last_msdu(struct hal_rx_desc *desc) 1110 { 1111 return !!le16_get_bits(desc->u.wcn7850.msdu_end.info5, 1112 RX_MSDU_END_INFO5_LAST_MSDU); 1113 } 1114 1115 static u8 ath12k_hw_wcn7850_rx_desc_get_l3_pad_bytes(struct hal_rx_desc *desc) 1116 { 1117 return le16_get_bits(desc->u.wcn7850.msdu_end.info5, 1118 RX_MSDU_END_INFO5_L3_HDR_PADDING); 1119 } 1120 1121 static bool ath12k_hw_wcn7850_rx_desc_encrypt_valid(struct hal_rx_desc *desc) 1122 { 1123 return !!le32_get_bits(desc->u.wcn7850.mpdu_start.info4, 1124 RX_MPDU_START_INFO4_ENCRYPT_INFO_VALID); 1125 } 1126 1127 static u32 ath12k_hw_wcn7850_rx_desc_get_encrypt_type(struct hal_rx_desc *desc) 1128 { 1129 return le32_get_bits(desc->u.wcn7850.mpdu_start.info2, 1130 RX_MPDU_START_INFO2_ENC_TYPE); 1131 } 1132 1133 static u8 ath12k_hw_wcn7850_rx_desc_get_decap_type(struct hal_rx_desc *desc) 1134 { 1135 return le32_get_bits(desc->u.wcn7850.msdu_end.info11, 1136 RX_MSDU_END_INFO11_DECAP_FORMAT); 1137 } 1138 1139 static u8 ath12k_hw_wcn7850_rx_desc_get_mesh_ctl(struct hal_rx_desc *desc) 1140 { 1141 return le32_get_bits(desc->u.wcn7850.msdu_end.info11, 1142 RX_MSDU_END_INFO11_MESH_CTRL_PRESENT); 1143 } 1144 1145 static bool ath12k_hw_wcn7850_rx_desc_get_mpdu_seq_ctl_vld(struct hal_rx_desc *desc) 1146 { 1147 return !!le32_get_bits(desc->u.wcn7850.mpdu_start.info4, 1148 RX_MPDU_START_INFO4_MPDU_SEQ_CTRL_VALID); 1149 } 1150 1151 static bool ath12k_hw_wcn7850_rx_desc_get_mpdu_fc_valid(struct hal_rx_desc *desc) 1152 { 1153 return !!le32_get_bits(desc->u.wcn7850.mpdu_start.info4, 1154 RX_MPDU_START_INFO4_MPDU_FCTRL_VALID); 1155 } 1156 1157 static u16 ath12k_hw_wcn7850_rx_desc_get_mpdu_start_seq_no(struct hal_rx_desc *desc) 1158 { 1159 return le32_get_bits(desc->u.wcn7850.mpdu_start.info4, 1160 RX_MPDU_START_INFO4_MPDU_SEQ_NUM); 1161 } 1162 1163 static u16 ath12k_hw_wcn7850_rx_desc_get_msdu_len(struct hal_rx_desc *desc) 1164 { 1165 return le32_get_bits(desc->u.wcn7850.msdu_end.info10, 1166 RX_MSDU_END_INFO10_MSDU_LENGTH); 1167 } 1168 1169 static u8 ath12k_hw_wcn7850_rx_desc_get_msdu_sgi(struct hal_rx_desc *desc) 1170 { 1171 return le32_get_bits(desc->u.wcn7850.msdu_end.info12, 1172 RX_MSDU_END_INFO12_SGI); 1173 } 1174 1175 static u8 ath12k_hw_wcn7850_rx_desc_get_msdu_rate_mcs(struct hal_rx_desc *desc) 1176 { 1177 return le32_get_bits(desc->u.wcn7850.msdu_end.info12, 1178 RX_MSDU_END_INFO12_RATE_MCS); 1179 } 1180 1181 static u8 ath12k_hw_wcn7850_rx_desc_get_msdu_rx_bw(struct hal_rx_desc *desc) 1182 { 1183 return le32_get_bits(desc->u.wcn7850.msdu_end.info12, 1184 RX_MSDU_END_INFO12_RECV_BW); 1185 } 1186 1187 static u32 ath12k_hw_wcn7850_rx_desc_get_msdu_freq(struct hal_rx_desc *desc) 1188 { 1189 return __le32_to_cpu(desc->u.wcn7850.msdu_end.phy_meta_data); 1190 } 1191 1192 static u8 ath12k_hw_wcn7850_rx_desc_get_msdu_pkt_type(struct hal_rx_desc *desc) 1193 { 1194 return le32_get_bits(desc->u.wcn7850.msdu_end.info12, 1195 RX_MSDU_END_INFO12_PKT_TYPE); 1196 } 1197 1198 static u8 ath12k_hw_wcn7850_rx_desc_get_msdu_nss(struct hal_rx_desc *desc) 1199 { 1200 return le32_get_bits(desc->u.wcn7850.msdu_end.info12, 1201 RX_MSDU_END_INFO12_MIMO_SS_BITMAP); 1202 } 1203 1204 static u8 ath12k_hw_wcn7850_rx_desc_get_mpdu_tid(struct hal_rx_desc *desc) 1205 { 1206 return le32_get_bits(desc->u.wcn7850.mpdu_start.info2, 1207 RX_MPDU_START_INFO2_TID); 1208 } 1209 1210 static u16 ath12k_hw_wcn7850_rx_desc_get_mpdu_peer_id(struct hal_rx_desc *desc) 1211 { 1212 return __le16_to_cpu(desc->u.wcn7850.mpdu_start.sw_peer_id); 1213 } 1214 1215 static void ath12k_hw_wcn7850_rx_desc_copy_end_tlv(struct hal_rx_desc *fdesc, 1216 struct hal_rx_desc *ldesc) 1217 { 1218 memcpy(&fdesc->u.wcn7850.msdu_end, &ldesc->u.wcn7850.msdu_end, 1219 sizeof(struct rx_msdu_end_qcn9274)); 1220 } 1221 1222 static u32 ath12k_hw_wcn7850_rx_desc_get_mpdu_start_tag(struct hal_rx_desc *desc) 1223 { 1224 return le64_get_bits(desc->u.wcn7850.mpdu_start_tag, 1225 HAL_TLV_HDR_TAG); 1226 } 1227 1228 static u32 ath12k_hw_wcn7850_rx_desc_get_mpdu_ppdu_id(struct hal_rx_desc *desc) 1229 { 1230 return __le16_to_cpu(desc->u.wcn7850.mpdu_start.phy_ppdu_id); 1231 } 1232 1233 static void ath12k_hw_wcn7850_rx_desc_set_msdu_len(struct hal_rx_desc *desc, u16 len) 1234 { 1235 u32 info = __le32_to_cpu(desc->u.wcn7850.msdu_end.info10); 1236 1237 info &= ~RX_MSDU_END_INFO10_MSDU_LENGTH; 1238 info |= u32_encode_bits(len, RX_MSDU_END_INFO10_MSDU_LENGTH); 1239 1240 desc->u.wcn7850.msdu_end.info10 = __cpu_to_le32(info); 1241 } 1242 1243 static u8 *ath12k_hw_wcn7850_rx_desc_get_msdu_payload(struct hal_rx_desc *desc) 1244 { 1245 return &desc->u.wcn7850.msdu_payload[0]; 1246 } 1247 1248 static u32 ath12k_hw_wcn7850_rx_desc_get_mpdu_start_offset(void) 1249 { 1250 return offsetof(struct hal_rx_desc_wcn7850, mpdu_start_tag); 1251 } 1252 1253 static u32 ath12k_hw_wcn7850_rx_desc_get_msdu_end_offset(void) 1254 { 1255 return offsetof(struct hal_rx_desc_wcn7850, msdu_end_tag); 1256 } 1257 1258 static bool ath12k_hw_wcn7850_rx_desc_mac_addr2_valid(struct hal_rx_desc *desc) 1259 { 1260 return __le32_to_cpu(desc->u.wcn7850.mpdu_start.info4) & 1261 RX_MPDU_START_INFO4_MAC_ADDR2_VALID; 1262 } 1263 1264 static u8 *ath12k_hw_wcn7850_rx_desc_mpdu_start_addr2(struct hal_rx_desc *desc) 1265 { 1266 return desc->u.wcn7850.mpdu_start.addr2; 1267 } 1268 1269 static bool ath12k_hw_wcn7850_rx_desc_is_da_mcbc(struct hal_rx_desc *desc) 1270 { 1271 return __le32_to_cpu(desc->u.wcn7850.msdu_end.info13) & 1272 RX_MSDU_END_INFO13_MCAST_BCAST; 1273 } 1274 1275 static void ath12k_hw_wcn7850_rx_desc_get_dot11_hdr(struct hal_rx_desc *desc, 1276 struct ieee80211_hdr *hdr) 1277 { 1278 hdr->frame_control = desc->u.wcn7850.mpdu_start.frame_ctrl; 1279 hdr->duration_id = desc->u.wcn7850.mpdu_start.duration; 1280 ether_addr_copy(hdr->addr1, desc->u.wcn7850.mpdu_start.addr1); 1281 ether_addr_copy(hdr->addr2, desc->u.wcn7850.mpdu_start.addr2); 1282 ether_addr_copy(hdr->addr3, desc->u.wcn7850.mpdu_start.addr3); 1283 if (__le32_to_cpu(desc->u.wcn7850.mpdu_start.info4) & 1284 RX_MPDU_START_INFO4_MAC_ADDR4_VALID) { 1285 ether_addr_copy(hdr->addr4, desc->u.wcn7850.mpdu_start.addr4); 1286 } 1287 hdr->seq_ctrl = desc->u.wcn7850.mpdu_start.seq_ctrl; 1288 } 1289 1290 static void ath12k_hw_wcn7850_rx_desc_get_crypto_hdr(struct hal_rx_desc *desc, 1291 u8 *crypto_hdr, 1292 enum hal_encrypt_type enctype) 1293 { 1294 unsigned int key_id; 1295 1296 switch (enctype) { 1297 case HAL_ENCRYPT_TYPE_OPEN: 1298 return; 1299 case HAL_ENCRYPT_TYPE_TKIP_NO_MIC: 1300 case HAL_ENCRYPT_TYPE_TKIP_MIC: 1301 crypto_hdr[0] = 1302 HAL_RX_MPDU_INFO_PN_GET_BYTE2(desc->u.wcn7850.mpdu_start.pn[0]); 1303 crypto_hdr[1] = 0; 1304 crypto_hdr[2] = 1305 HAL_RX_MPDU_INFO_PN_GET_BYTE1(desc->u.wcn7850.mpdu_start.pn[0]); 1306 break; 1307 case HAL_ENCRYPT_TYPE_CCMP_128: 1308 case HAL_ENCRYPT_TYPE_CCMP_256: 1309 case HAL_ENCRYPT_TYPE_GCMP_128: 1310 case HAL_ENCRYPT_TYPE_AES_GCMP_256: 1311 crypto_hdr[0] = 1312 HAL_RX_MPDU_INFO_PN_GET_BYTE1(desc->u.wcn7850.mpdu_start.pn[0]); 1313 crypto_hdr[1] = 1314 HAL_RX_MPDU_INFO_PN_GET_BYTE2(desc->u.wcn7850.mpdu_start.pn[0]); 1315 crypto_hdr[2] = 0; 1316 break; 1317 case HAL_ENCRYPT_TYPE_WEP_40: 1318 case HAL_ENCRYPT_TYPE_WEP_104: 1319 case HAL_ENCRYPT_TYPE_WEP_128: 1320 case HAL_ENCRYPT_TYPE_WAPI_GCM_SM4: 1321 case HAL_ENCRYPT_TYPE_WAPI: 1322 return; 1323 } 1324 key_id = u32_get_bits(__le32_to_cpu(desc->u.wcn7850.mpdu_start.info5), 1325 RX_MPDU_START_INFO5_KEY_ID); 1326 crypto_hdr[3] = 0x20 | (key_id << 6); 1327 crypto_hdr[4] = HAL_RX_MPDU_INFO_PN_GET_BYTE3(desc->u.wcn7850.mpdu_start.pn[0]); 1328 crypto_hdr[5] = HAL_RX_MPDU_INFO_PN_GET_BYTE4(desc->u.wcn7850.mpdu_start.pn[0]); 1329 crypto_hdr[6] = HAL_RX_MPDU_INFO_PN_GET_BYTE1(desc->u.wcn7850.mpdu_start.pn[1]); 1330 crypto_hdr[7] = HAL_RX_MPDU_INFO_PN_GET_BYTE2(desc->u.wcn7850.mpdu_start.pn[1]); 1331 } 1332 1333 static u16 ath12k_hw_wcn7850_rx_desc_get_mpdu_frame_ctl(struct hal_rx_desc *desc) 1334 { 1335 return __le16_to_cpu(desc->u.wcn7850.mpdu_start.frame_ctrl); 1336 } 1337 1338 static int ath12k_hal_srng_create_config_wcn7850(struct ath12k_base *ab) 1339 { 1340 struct ath12k_hal *hal = &ab->hal; 1341 struct hal_srng_config *s; 1342 1343 hal->srng_config = kmemdup(hw_srng_config_template, 1344 sizeof(hw_srng_config_template), 1345 GFP_KERNEL); 1346 if (!hal->srng_config) 1347 return -ENOMEM; 1348 1349 s = &hal->srng_config[HAL_REO_DST]; 1350 s->reg_start[0] = HAL_SEQ_WCSS_UMAC_REO_REG + HAL_REO1_RING_BASE_LSB(ab); 1351 s->reg_start[1] = HAL_SEQ_WCSS_UMAC_REO_REG + HAL_REO1_RING_HP; 1352 s->reg_size[0] = HAL_REO2_RING_BASE_LSB(ab) - HAL_REO1_RING_BASE_LSB(ab); 1353 s->reg_size[1] = HAL_REO2_RING_HP - HAL_REO1_RING_HP; 1354 1355 s = &hal->srng_config[HAL_REO_EXCEPTION]; 1356 s->reg_start[0] = HAL_SEQ_WCSS_UMAC_REO_REG + HAL_REO_SW0_RING_BASE_LSB(ab); 1357 s->reg_start[1] = HAL_SEQ_WCSS_UMAC_REO_REG + HAL_REO_SW0_RING_HP; 1358 1359 s = &hal->srng_config[HAL_REO_REINJECT]; 1360 s->max_rings = 1; 1361 s->reg_start[0] = HAL_SEQ_WCSS_UMAC_REO_REG + HAL_SW2REO_RING_BASE_LSB(ab); 1362 s->reg_start[1] = HAL_SEQ_WCSS_UMAC_REO_REG + HAL_SW2REO_RING_HP; 1363 1364 s = &hal->srng_config[HAL_REO_CMD]; 1365 s->reg_start[0] = HAL_SEQ_WCSS_UMAC_REO_REG + HAL_REO_CMD_RING_BASE_LSB(ab); 1366 s->reg_start[1] = HAL_SEQ_WCSS_UMAC_REO_REG + HAL_REO_CMD_HP; 1367 1368 s = &hal->srng_config[HAL_REO_STATUS]; 1369 s->reg_start[0] = HAL_SEQ_WCSS_UMAC_REO_REG + HAL_REO_STATUS_RING_BASE_LSB(ab); 1370 s->reg_start[1] = HAL_SEQ_WCSS_UMAC_REO_REG + HAL_REO_STATUS_HP; 1371 1372 s = &hal->srng_config[HAL_TCL_DATA]; 1373 s->max_rings = 5; 1374 s->reg_start[0] = HAL_SEQ_WCSS_UMAC_TCL_REG + HAL_TCL1_RING_BASE_LSB; 1375 s->reg_start[1] = HAL_SEQ_WCSS_UMAC_TCL_REG + HAL_TCL1_RING_HP; 1376 s->reg_size[0] = HAL_TCL2_RING_BASE_LSB - HAL_TCL1_RING_BASE_LSB; 1377 s->reg_size[1] = HAL_TCL2_RING_HP - HAL_TCL1_RING_HP; 1378 1379 s = &hal->srng_config[HAL_TCL_CMD]; 1380 s->reg_start[0] = HAL_SEQ_WCSS_UMAC_TCL_REG + HAL_TCL_RING_BASE_LSB(ab); 1381 s->reg_start[1] = HAL_SEQ_WCSS_UMAC_TCL_REG + HAL_TCL_RING_HP; 1382 1383 s = &hal->srng_config[HAL_TCL_STATUS]; 1384 s->reg_start[0] = HAL_SEQ_WCSS_UMAC_TCL_REG + HAL_TCL_STATUS_RING_BASE_LSB(ab); 1385 s->reg_start[1] = HAL_SEQ_WCSS_UMAC_TCL_REG + HAL_TCL_STATUS_RING_HP; 1386 1387 s = &hal->srng_config[HAL_CE_SRC]; 1388 s->max_rings = 12; 1389 s->reg_start[0] = HAL_SEQ_WCSS_UMAC_CE0_SRC_REG + HAL_CE_DST_RING_BASE_LSB; 1390 s->reg_start[1] = HAL_SEQ_WCSS_UMAC_CE0_SRC_REG + HAL_CE_DST_RING_HP; 1391 s->reg_size[0] = HAL_SEQ_WCSS_UMAC_CE1_SRC_REG - 1392 HAL_SEQ_WCSS_UMAC_CE0_SRC_REG; 1393 s->reg_size[1] = HAL_SEQ_WCSS_UMAC_CE1_SRC_REG - 1394 HAL_SEQ_WCSS_UMAC_CE0_SRC_REG; 1395 1396 s = &hal->srng_config[HAL_CE_DST]; 1397 s->max_rings = 12; 1398 s->reg_start[0] = HAL_SEQ_WCSS_UMAC_CE0_DST_REG + HAL_CE_DST_RING_BASE_LSB; 1399 s->reg_start[1] = HAL_SEQ_WCSS_UMAC_CE0_DST_REG + HAL_CE_DST_RING_HP; 1400 s->reg_size[0] = HAL_SEQ_WCSS_UMAC_CE1_DST_REG - 1401 HAL_SEQ_WCSS_UMAC_CE0_DST_REG; 1402 s->reg_size[1] = HAL_SEQ_WCSS_UMAC_CE1_DST_REG - 1403 HAL_SEQ_WCSS_UMAC_CE0_DST_REG; 1404 1405 s = &hal->srng_config[HAL_CE_DST_STATUS]; 1406 s->max_rings = 12; 1407 s->reg_start[0] = HAL_SEQ_WCSS_UMAC_CE0_DST_REG + 1408 HAL_CE_DST_STATUS_RING_BASE_LSB; 1409 s->reg_start[1] = HAL_SEQ_WCSS_UMAC_CE0_DST_REG + HAL_CE_DST_STATUS_RING_HP; 1410 s->reg_size[0] = HAL_SEQ_WCSS_UMAC_CE1_DST_REG - 1411 HAL_SEQ_WCSS_UMAC_CE0_DST_REG; 1412 s->reg_size[1] = HAL_SEQ_WCSS_UMAC_CE1_DST_REG - 1413 HAL_SEQ_WCSS_UMAC_CE0_DST_REG; 1414 1415 s = &hal->srng_config[HAL_WBM_IDLE_LINK]; 1416 s->reg_start[0] = HAL_SEQ_WCSS_UMAC_WBM_REG + HAL_WBM_IDLE_LINK_RING_BASE_LSB(ab); 1417 s->reg_start[1] = HAL_SEQ_WCSS_UMAC_WBM_REG + HAL_WBM_IDLE_LINK_RING_HP; 1418 1419 s = &hal->srng_config[HAL_SW2WBM_RELEASE]; 1420 s->max_rings = 1; 1421 s->reg_start[0] = HAL_SEQ_WCSS_UMAC_WBM_REG + 1422 HAL_WBM_SW_RELEASE_RING_BASE_LSB(ab); 1423 s->reg_start[1] = HAL_SEQ_WCSS_UMAC_WBM_REG + HAL_WBM_SW_RELEASE_RING_HP; 1424 1425 s = &hal->srng_config[HAL_WBM2SW_RELEASE]; 1426 s->reg_start[0] = HAL_SEQ_WCSS_UMAC_WBM_REG + HAL_WBM0_RELEASE_RING_BASE_LSB(ab); 1427 s->reg_start[1] = HAL_SEQ_WCSS_UMAC_WBM_REG + HAL_WBM0_RELEASE_RING_HP; 1428 s->reg_size[0] = HAL_WBM1_RELEASE_RING_BASE_LSB(ab) - 1429 HAL_WBM0_RELEASE_RING_BASE_LSB(ab); 1430 s->reg_size[1] = HAL_WBM1_RELEASE_RING_HP - HAL_WBM0_RELEASE_RING_HP; 1431 1432 s = &hal->srng_config[HAL_RXDMA_BUF]; 1433 s->max_rings = 2; 1434 s->mac_type = ATH12K_HAL_SRNG_PMAC; 1435 1436 s = &hal->srng_config[HAL_RXDMA_DST]; 1437 s->max_rings = 1; 1438 s->entry_size = sizeof(struct hal_reo_entrance_ring) >> 2; 1439 1440 /* below rings are not used */ 1441 s = &hal->srng_config[HAL_RXDMA_DIR_BUF]; 1442 s->max_rings = 0; 1443 1444 s = &hal->srng_config[HAL_PPE2TCL]; 1445 s->max_rings = 0; 1446 1447 s = &hal->srng_config[HAL_PPE_RELEASE]; 1448 s->max_rings = 0; 1449 1450 s = &hal->srng_config[HAL_TX_MONITOR_BUF]; 1451 s->max_rings = 0; 1452 1453 s = &hal->srng_config[HAL_TX_MONITOR_DST]; 1454 s->max_rings = 0; 1455 1456 s = &hal->srng_config[HAL_PPE2TCL]; 1457 s->max_rings = 0; 1458 1459 return 0; 1460 } 1461 1462 static bool ath12k_hw_wcn7850_dp_rx_h_msdu_done(struct hal_rx_desc *desc) 1463 { 1464 return !!le32_get_bits(desc->u.wcn7850.msdu_end.info14, 1465 RX_MSDU_END_INFO14_MSDU_DONE); 1466 } 1467 1468 static bool ath12k_hw_wcn7850_dp_rx_h_l4_cksum_fail(struct hal_rx_desc *desc) 1469 { 1470 return !!le32_get_bits(desc->u.wcn7850.msdu_end.info13, 1471 RX_MSDU_END_INFO13_TCP_UDP_CKSUM_FAIL); 1472 } 1473 1474 static bool ath12k_hw_wcn7850_dp_rx_h_ip_cksum_fail(struct hal_rx_desc *desc) 1475 { 1476 return !!le32_get_bits(desc->u.wcn7850.msdu_end.info13, 1477 RX_MSDU_END_INFO13_IP_CKSUM_FAIL); 1478 } 1479 1480 static bool ath12k_hw_wcn7850_dp_rx_h_is_decrypted(struct hal_rx_desc *desc) 1481 { 1482 return (le32_get_bits(desc->u.wcn7850.msdu_end.info14, 1483 RX_MSDU_END_INFO14_DECRYPT_STATUS_CODE) == 1484 RX_DESC_DECRYPT_STATUS_CODE_OK); 1485 } 1486 1487 static u32 ath12k_hw_wcn7850_dp_rx_h_mpdu_err(struct hal_rx_desc *desc) 1488 { 1489 u32 info = __le32_to_cpu(desc->u.wcn7850.msdu_end.info13); 1490 u32 errmap = 0; 1491 1492 if (info & RX_MSDU_END_INFO13_FCS_ERR) 1493 errmap |= HAL_RX_MPDU_ERR_FCS; 1494 1495 if (info & RX_MSDU_END_INFO13_DECRYPT_ERR) 1496 errmap |= HAL_RX_MPDU_ERR_DECRYPT; 1497 1498 if (info & RX_MSDU_END_INFO13_TKIP_MIC_ERR) 1499 errmap |= HAL_RX_MPDU_ERR_TKIP_MIC; 1500 1501 if (info & RX_MSDU_END_INFO13_A_MSDU_ERROR) 1502 errmap |= HAL_RX_MPDU_ERR_AMSDU_ERR; 1503 1504 if (info & RX_MSDU_END_INFO13_OVERFLOW_ERR) 1505 errmap |= HAL_RX_MPDU_ERR_OVERFLOW; 1506 1507 if (info & RX_MSDU_END_INFO13_MSDU_LEN_ERR) 1508 errmap |= HAL_RX_MPDU_ERR_MSDU_LEN; 1509 1510 if (info & RX_MSDU_END_INFO13_MPDU_LEN_ERR) 1511 errmap |= HAL_RX_MPDU_ERR_MPDU_LEN; 1512 1513 return errmap; 1514 } 1515 1516 static u32 ath12k_hw_wcn7850_get_rx_desc_size(void) 1517 { 1518 return sizeof(struct hal_rx_desc_wcn7850); 1519 } 1520 1521 static u8 ath12k_hw_wcn7850_rx_desc_get_msdu_src_link(struct hal_rx_desc *desc) 1522 { 1523 return 0; 1524 } 1525 1526 const struct hal_rx_ops hal_rx_wcn7850_ops = { 1527 .rx_desc_get_first_msdu = ath12k_hw_wcn7850_rx_desc_get_first_msdu, 1528 .rx_desc_get_last_msdu = ath12k_hw_wcn7850_rx_desc_get_last_msdu, 1529 .rx_desc_get_l3_pad_bytes = ath12k_hw_wcn7850_rx_desc_get_l3_pad_bytes, 1530 .rx_desc_encrypt_valid = ath12k_hw_wcn7850_rx_desc_encrypt_valid, 1531 .rx_desc_get_encrypt_type = ath12k_hw_wcn7850_rx_desc_get_encrypt_type, 1532 .rx_desc_get_decap_type = ath12k_hw_wcn7850_rx_desc_get_decap_type, 1533 .rx_desc_get_mesh_ctl = ath12k_hw_wcn7850_rx_desc_get_mesh_ctl, 1534 .rx_desc_get_mpdu_seq_ctl_vld = ath12k_hw_wcn7850_rx_desc_get_mpdu_seq_ctl_vld, 1535 .rx_desc_get_mpdu_fc_valid = ath12k_hw_wcn7850_rx_desc_get_mpdu_fc_valid, 1536 .rx_desc_get_mpdu_start_seq_no = ath12k_hw_wcn7850_rx_desc_get_mpdu_start_seq_no, 1537 .rx_desc_get_msdu_len = ath12k_hw_wcn7850_rx_desc_get_msdu_len, 1538 .rx_desc_get_msdu_sgi = ath12k_hw_wcn7850_rx_desc_get_msdu_sgi, 1539 .rx_desc_get_msdu_rate_mcs = ath12k_hw_wcn7850_rx_desc_get_msdu_rate_mcs, 1540 .rx_desc_get_msdu_rx_bw = ath12k_hw_wcn7850_rx_desc_get_msdu_rx_bw, 1541 .rx_desc_get_msdu_freq = ath12k_hw_wcn7850_rx_desc_get_msdu_freq, 1542 .rx_desc_get_msdu_pkt_type = ath12k_hw_wcn7850_rx_desc_get_msdu_pkt_type, 1543 .rx_desc_get_msdu_nss = ath12k_hw_wcn7850_rx_desc_get_msdu_nss, 1544 .rx_desc_get_mpdu_tid = ath12k_hw_wcn7850_rx_desc_get_mpdu_tid, 1545 .rx_desc_get_mpdu_peer_id = ath12k_hw_wcn7850_rx_desc_get_mpdu_peer_id, 1546 .rx_desc_copy_end_tlv = ath12k_hw_wcn7850_rx_desc_copy_end_tlv, 1547 .rx_desc_get_mpdu_start_tag = ath12k_hw_wcn7850_rx_desc_get_mpdu_start_tag, 1548 .rx_desc_get_mpdu_ppdu_id = ath12k_hw_wcn7850_rx_desc_get_mpdu_ppdu_id, 1549 .rx_desc_set_msdu_len = ath12k_hw_wcn7850_rx_desc_set_msdu_len, 1550 .rx_desc_get_msdu_payload = ath12k_hw_wcn7850_rx_desc_get_msdu_payload, 1551 .rx_desc_get_mpdu_start_offset = ath12k_hw_wcn7850_rx_desc_get_mpdu_start_offset, 1552 .rx_desc_get_msdu_end_offset = ath12k_hw_wcn7850_rx_desc_get_msdu_end_offset, 1553 .rx_desc_mac_addr2_valid = ath12k_hw_wcn7850_rx_desc_mac_addr2_valid, 1554 .rx_desc_mpdu_start_addr2 = ath12k_hw_wcn7850_rx_desc_mpdu_start_addr2, 1555 .rx_desc_is_da_mcbc = ath12k_hw_wcn7850_rx_desc_is_da_mcbc, 1556 .rx_desc_get_dot11_hdr = ath12k_hw_wcn7850_rx_desc_get_dot11_hdr, 1557 .rx_desc_get_crypto_header = ath12k_hw_wcn7850_rx_desc_get_crypto_hdr, 1558 .rx_desc_get_mpdu_frame_ctl = ath12k_hw_wcn7850_rx_desc_get_mpdu_frame_ctl, 1559 .dp_rx_h_msdu_done = ath12k_hw_wcn7850_dp_rx_h_msdu_done, 1560 .dp_rx_h_l4_cksum_fail = ath12k_hw_wcn7850_dp_rx_h_l4_cksum_fail, 1561 .dp_rx_h_ip_cksum_fail = ath12k_hw_wcn7850_dp_rx_h_ip_cksum_fail, 1562 .dp_rx_h_is_decrypted = ath12k_hw_wcn7850_dp_rx_h_is_decrypted, 1563 .dp_rx_h_mpdu_err = ath12k_hw_wcn7850_dp_rx_h_mpdu_err, 1564 .rx_desc_get_desc_size = ath12k_hw_wcn7850_get_rx_desc_size, 1565 .rx_desc_get_msdu_src_link_id = ath12k_hw_wcn7850_rx_desc_get_msdu_src_link, 1566 }; 1567 1568 const struct hal_ops hal_wcn7850_ops = { 1569 .create_srng_config = ath12k_hal_srng_create_config_wcn7850, 1570 .tcl_to_wbm_rbm_map = ath12k_hal_wcn7850_tcl_to_wbm_rbm_map, 1571 .rxdma_ring_wmask_rx_mpdu_start = NULL, 1572 .rxdma_ring_wmask_rx_msdu_end = NULL, 1573 .get_hal_rx_compact_ops = NULL, 1574 }; 1575 1576 static int ath12k_hal_alloc_cont_rdp(struct ath12k_base *ab) 1577 { 1578 struct ath12k_hal *hal = &ab->hal; 1579 size_t size; 1580 1581 size = sizeof(u32) * HAL_SRNG_RING_ID_MAX; 1582 hal->rdp.vaddr = dma_alloc_coherent(ab->dev, size, &hal->rdp.paddr, 1583 GFP_KERNEL); 1584 if (!hal->rdp.vaddr) 1585 return -ENOMEM; 1586 1587 return 0; 1588 } 1589 1590 static void ath12k_hal_free_cont_rdp(struct ath12k_base *ab) 1591 { 1592 struct ath12k_hal *hal = &ab->hal; 1593 size_t size; 1594 1595 if (!hal->rdp.vaddr) 1596 return; 1597 1598 size = sizeof(u32) * HAL_SRNG_RING_ID_MAX; 1599 dma_free_coherent(ab->dev, size, 1600 hal->rdp.vaddr, hal->rdp.paddr); 1601 hal->rdp.vaddr = NULL; 1602 } 1603 1604 static int ath12k_hal_alloc_cont_wrp(struct ath12k_base *ab) 1605 { 1606 struct ath12k_hal *hal = &ab->hal; 1607 size_t size; 1608 1609 size = sizeof(u32) * (HAL_SRNG_NUM_PMAC_RINGS + HAL_SRNG_NUM_DMAC_RINGS); 1610 hal->wrp.vaddr = dma_alloc_coherent(ab->dev, size, &hal->wrp.paddr, 1611 GFP_KERNEL); 1612 if (!hal->wrp.vaddr) 1613 return -ENOMEM; 1614 1615 return 0; 1616 } 1617 1618 static void ath12k_hal_free_cont_wrp(struct ath12k_base *ab) 1619 { 1620 struct ath12k_hal *hal = &ab->hal; 1621 size_t size; 1622 1623 if (!hal->wrp.vaddr) 1624 return; 1625 1626 size = sizeof(u32) * (HAL_SRNG_NUM_PMAC_RINGS + HAL_SRNG_NUM_DMAC_RINGS); 1627 dma_free_coherent(ab->dev, size, 1628 hal->wrp.vaddr, hal->wrp.paddr); 1629 hal->wrp.vaddr = NULL; 1630 } 1631 1632 static void ath12k_hal_ce_dst_setup(struct ath12k_base *ab, 1633 struct hal_srng *srng, int ring_num) 1634 { 1635 struct hal_srng_config *srng_config = &ab->hal.srng_config[HAL_CE_DST]; 1636 u32 addr; 1637 u32 val; 1638 1639 addr = HAL_CE_DST_RING_CTRL + 1640 srng_config->reg_start[HAL_SRNG_REG_GRP_R0] + 1641 ring_num * srng_config->reg_size[HAL_SRNG_REG_GRP_R0]; 1642 1643 val = ath12k_hif_read32(ab, addr); 1644 val &= ~HAL_CE_DST_R0_DEST_CTRL_MAX_LEN; 1645 val |= u32_encode_bits(srng->u.dst_ring.max_buffer_length, 1646 HAL_CE_DST_R0_DEST_CTRL_MAX_LEN); 1647 ath12k_hif_write32(ab, addr, val); 1648 } 1649 1650 static void ath12k_hal_srng_dst_hw_init(struct ath12k_base *ab, 1651 struct hal_srng *srng) 1652 { 1653 struct ath12k_hal *hal = &ab->hal; 1654 u32 val; 1655 u64 hp_addr; 1656 u32 reg_base; 1657 1658 reg_base = srng->hwreg_base[HAL_SRNG_REG_GRP_R0]; 1659 1660 if (srng->flags & HAL_SRNG_FLAGS_MSI_INTR) { 1661 ath12k_hif_write32(ab, reg_base + 1662 ath12k_hal_reo1_ring_msi1_base_lsb_offset(ab), 1663 srng->msi_addr); 1664 1665 val = u32_encode_bits(((u64)srng->msi_addr >> HAL_ADDR_MSB_REG_SHIFT), 1666 HAL_REO1_RING_MSI1_BASE_MSB_ADDR) | 1667 HAL_REO1_RING_MSI1_BASE_MSB_MSI1_ENABLE; 1668 ath12k_hif_write32(ab, reg_base + 1669 ath12k_hal_reo1_ring_msi1_base_msb_offset(ab), val); 1670 1671 ath12k_hif_write32(ab, 1672 reg_base + ath12k_hal_reo1_ring_msi1_data_offset(ab), 1673 srng->msi_data); 1674 } 1675 1676 ath12k_hif_write32(ab, reg_base, srng->ring_base_paddr); 1677 1678 val = u32_encode_bits(((u64)srng->ring_base_paddr >> HAL_ADDR_MSB_REG_SHIFT), 1679 HAL_REO1_RING_BASE_MSB_RING_BASE_ADDR_MSB) | 1680 u32_encode_bits((srng->entry_size * srng->num_entries), 1681 HAL_REO1_RING_BASE_MSB_RING_SIZE); 1682 ath12k_hif_write32(ab, reg_base + ath12k_hal_reo1_ring_base_msb_offset(ab), val); 1683 1684 val = u32_encode_bits(srng->ring_id, HAL_REO1_RING_ID_RING_ID) | 1685 u32_encode_bits(srng->entry_size, HAL_REO1_RING_ID_ENTRY_SIZE); 1686 ath12k_hif_write32(ab, reg_base + ath12k_hal_reo1_ring_id_offset(ab), val); 1687 1688 /* interrupt setup */ 1689 val = u32_encode_bits((srng->intr_timer_thres_us >> 3), 1690 HAL_REO1_RING_PRDR_INT_SETUP_INTR_TMR_THOLD); 1691 1692 val |= u32_encode_bits((srng->intr_batch_cntr_thres_entries * srng->entry_size), 1693 HAL_REO1_RING_PRDR_INT_SETUP_BATCH_COUNTER_THOLD); 1694 1695 ath12k_hif_write32(ab, 1696 reg_base + ath12k_hal_reo1_ring_producer_int_setup_offset(ab), 1697 val); 1698 1699 hp_addr = hal->rdp.paddr + 1700 ((unsigned long)srng->u.dst_ring.hp_addr - 1701 (unsigned long)hal->rdp.vaddr); 1702 ath12k_hif_write32(ab, reg_base + ath12k_hal_reo1_ring_hp_addr_lsb_offset(ab), 1703 hp_addr & HAL_ADDR_LSB_REG_MASK); 1704 ath12k_hif_write32(ab, reg_base + ath12k_hal_reo1_ring_hp_addr_msb_offset(ab), 1705 hp_addr >> HAL_ADDR_MSB_REG_SHIFT); 1706 1707 /* Initialize head and tail pointers to indicate ring is empty */ 1708 reg_base = srng->hwreg_base[HAL_SRNG_REG_GRP_R2]; 1709 ath12k_hif_write32(ab, reg_base, 0); 1710 ath12k_hif_write32(ab, reg_base + HAL_REO1_RING_TP_OFFSET, 0); 1711 *srng->u.dst_ring.hp_addr = 0; 1712 1713 reg_base = srng->hwreg_base[HAL_SRNG_REG_GRP_R0]; 1714 val = 0; 1715 if (srng->flags & HAL_SRNG_FLAGS_DATA_TLV_SWAP) 1716 val |= HAL_REO1_RING_MISC_DATA_TLV_SWAP; 1717 if (srng->flags & HAL_SRNG_FLAGS_RING_PTR_SWAP) 1718 val |= HAL_REO1_RING_MISC_HOST_FW_SWAP; 1719 if (srng->flags & HAL_SRNG_FLAGS_MSI_SWAP) 1720 val |= HAL_REO1_RING_MISC_MSI_SWAP; 1721 val |= HAL_REO1_RING_MISC_SRNG_ENABLE; 1722 1723 ath12k_hif_write32(ab, reg_base + ath12k_hal_reo1_ring_misc_offset(ab), val); 1724 } 1725 1726 static void ath12k_hal_srng_src_hw_init(struct ath12k_base *ab, 1727 struct hal_srng *srng) 1728 { 1729 struct ath12k_hal *hal = &ab->hal; 1730 u32 val; 1731 u64 tp_addr; 1732 u32 reg_base; 1733 1734 reg_base = srng->hwreg_base[HAL_SRNG_REG_GRP_R0]; 1735 1736 if (srng->flags & HAL_SRNG_FLAGS_MSI_INTR) { 1737 ath12k_hif_write32(ab, reg_base + 1738 HAL_TCL1_RING_MSI1_BASE_LSB_OFFSET(ab), 1739 srng->msi_addr); 1740 1741 val = u32_encode_bits(((u64)srng->msi_addr >> HAL_ADDR_MSB_REG_SHIFT), 1742 HAL_TCL1_RING_MSI1_BASE_MSB_ADDR) | 1743 HAL_TCL1_RING_MSI1_BASE_MSB_MSI1_ENABLE; 1744 ath12k_hif_write32(ab, reg_base + 1745 HAL_TCL1_RING_MSI1_BASE_MSB_OFFSET(ab), 1746 val); 1747 1748 ath12k_hif_write32(ab, reg_base + 1749 HAL_TCL1_RING_MSI1_DATA_OFFSET(ab), 1750 srng->msi_data); 1751 } 1752 1753 ath12k_hif_write32(ab, reg_base, srng->ring_base_paddr); 1754 1755 val = u32_encode_bits(((u64)srng->ring_base_paddr >> HAL_ADDR_MSB_REG_SHIFT), 1756 HAL_TCL1_RING_BASE_MSB_RING_BASE_ADDR_MSB) | 1757 u32_encode_bits((srng->entry_size * srng->num_entries), 1758 HAL_TCL1_RING_BASE_MSB_RING_SIZE); 1759 ath12k_hif_write32(ab, reg_base + HAL_TCL1_RING_BASE_MSB_OFFSET, val); 1760 1761 val = u32_encode_bits(srng->entry_size, HAL_REO1_RING_ID_ENTRY_SIZE); 1762 ath12k_hif_write32(ab, reg_base + HAL_TCL1_RING_ID_OFFSET(ab), val); 1763 1764 val = u32_encode_bits(srng->intr_timer_thres_us, 1765 HAL_TCL1_RING_CONSR_INT_SETUP_IX0_INTR_TMR_THOLD); 1766 1767 val |= u32_encode_bits((srng->intr_batch_cntr_thres_entries * srng->entry_size), 1768 HAL_TCL1_RING_CONSR_INT_SETUP_IX0_BATCH_COUNTER_THOLD); 1769 1770 ath12k_hif_write32(ab, 1771 reg_base + HAL_TCL1_RING_CONSR_INT_SETUP_IX0_OFFSET(ab), 1772 val); 1773 1774 val = 0; 1775 if (srng->flags & HAL_SRNG_FLAGS_LOW_THRESH_INTR_EN) { 1776 val |= u32_encode_bits(srng->u.src_ring.low_threshold, 1777 HAL_TCL1_RING_CONSR_INT_SETUP_IX1_LOW_THOLD); 1778 } 1779 ath12k_hif_write32(ab, 1780 reg_base + HAL_TCL1_RING_CONSR_INT_SETUP_IX1_OFFSET(ab), 1781 val); 1782 1783 if (srng->ring_id != HAL_SRNG_RING_ID_WBM_IDLE_LINK) { 1784 tp_addr = hal->rdp.paddr + 1785 ((unsigned long)srng->u.src_ring.tp_addr - 1786 (unsigned long)hal->rdp.vaddr); 1787 ath12k_hif_write32(ab, 1788 reg_base + HAL_TCL1_RING_TP_ADDR_LSB_OFFSET(ab), 1789 tp_addr & HAL_ADDR_LSB_REG_MASK); 1790 ath12k_hif_write32(ab, 1791 reg_base + HAL_TCL1_RING_TP_ADDR_MSB_OFFSET(ab), 1792 tp_addr >> HAL_ADDR_MSB_REG_SHIFT); 1793 } 1794 1795 /* Initialize head and tail pointers to indicate ring is empty */ 1796 reg_base = srng->hwreg_base[HAL_SRNG_REG_GRP_R2]; 1797 ath12k_hif_write32(ab, reg_base, 0); 1798 ath12k_hif_write32(ab, reg_base + HAL_TCL1_RING_TP_OFFSET, 0); 1799 *srng->u.src_ring.tp_addr = 0; 1800 1801 reg_base = srng->hwreg_base[HAL_SRNG_REG_GRP_R0]; 1802 val = 0; 1803 if (srng->flags & HAL_SRNG_FLAGS_DATA_TLV_SWAP) 1804 val |= HAL_TCL1_RING_MISC_DATA_TLV_SWAP; 1805 if (srng->flags & HAL_SRNG_FLAGS_RING_PTR_SWAP) 1806 val |= HAL_TCL1_RING_MISC_HOST_FW_SWAP; 1807 if (srng->flags & HAL_SRNG_FLAGS_MSI_SWAP) 1808 val |= HAL_TCL1_RING_MISC_MSI_SWAP; 1809 1810 /* Loop count is not used for SRC rings */ 1811 val |= HAL_TCL1_RING_MISC_MSI_LOOPCNT_DISABLE; 1812 1813 val |= HAL_TCL1_RING_MISC_SRNG_ENABLE; 1814 1815 if (srng->ring_id == HAL_SRNG_RING_ID_WBM_IDLE_LINK) 1816 val |= HAL_TCL1_RING_MISC_MSI_RING_ID_DISABLE; 1817 1818 ath12k_hif_write32(ab, reg_base + HAL_TCL1_RING_MISC_OFFSET(ab), val); 1819 } 1820 1821 static void ath12k_hal_srng_hw_init(struct ath12k_base *ab, 1822 struct hal_srng *srng) 1823 { 1824 if (srng->ring_dir == HAL_SRNG_DIR_SRC) 1825 ath12k_hal_srng_src_hw_init(ab, srng); 1826 else 1827 ath12k_hal_srng_dst_hw_init(ab, srng); 1828 } 1829 1830 static int ath12k_hal_srng_get_ring_id(struct ath12k_base *ab, 1831 enum hal_ring_type type, 1832 int ring_num, int mac_id) 1833 { 1834 struct hal_srng_config *srng_config = &ab->hal.srng_config[type]; 1835 int ring_id; 1836 1837 if (ring_num >= srng_config->max_rings) { 1838 ath12k_warn(ab, "invalid ring number :%d\n", ring_num); 1839 return -EINVAL; 1840 } 1841 1842 ring_id = srng_config->start_ring_id + ring_num; 1843 if (srng_config->mac_type == ATH12K_HAL_SRNG_PMAC) 1844 ring_id += mac_id * HAL_SRNG_RINGS_PER_PMAC; 1845 1846 if (WARN_ON(ring_id >= HAL_SRNG_RING_ID_MAX)) 1847 return -EINVAL; 1848 1849 return ring_id; 1850 } 1851 1852 int ath12k_hal_srng_get_entrysize(struct ath12k_base *ab, u32 ring_type) 1853 { 1854 struct hal_srng_config *srng_config; 1855 1856 if (WARN_ON(ring_type >= HAL_MAX_RING_TYPES)) 1857 return -EINVAL; 1858 1859 srng_config = &ab->hal.srng_config[ring_type]; 1860 1861 return (srng_config->entry_size << 2); 1862 } 1863 1864 int ath12k_hal_srng_get_max_entries(struct ath12k_base *ab, u32 ring_type) 1865 { 1866 struct hal_srng_config *srng_config; 1867 1868 if (WARN_ON(ring_type >= HAL_MAX_RING_TYPES)) 1869 return -EINVAL; 1870 1871 srng_config = &ab->hal.srng_config[ring_type]; 1872 1873 return (srng_config->max_size / srng_config->entry_size); 1874 } 1875 1876 void ath12k_hal_srng_get_params(struct ath12k_base *ab, struct hal_srng *srng, 1877 struct hal_srng_params *params) 1878 { 1879 params->ring_base_paddr = srng->ring_base_paddr; 1880 params->ring_base_vaddr = srng->ring_base_vaddr; 1881 params->num_entries = srng->num_entries; 1882 params->intr_timer_thres_us = srng->intr_timer_thres_us; 1883 params->intr_batch_cntr_thres_entries = 1884 srng->intr_batch_cntr_thres_entries; 1885 params->low_threshold = srng->u.src_ring.low_threshold; 1886 params->msi_addr = srng->msi_addr; 1887 params->msi2_addr = srng->msi2_addr; 1888 params->msi_data = srng->msi_data; 1889 params->msi2_data = srng->msi2_data; 1890 params->flags = srng->flags; 1891 } 1892 1893 dma_addr_t ath12k_hal_srng_get_hp_addr(struct ath12k_base *ab, 1894 struct hal_srng *srng) 1895 { 1896 if (!(srng->flags & HAL_SRNG_FLAGS_LMAC_RING)) 1897 return 0; 1898 1899 if (srng->ring_dir == HAL_SRNG_DIR_SRC) 1900 return ab->hal.wrp.paddr + 1901 ((unsigned long)srng->u.src_ring.hp_addr - 1902 (unsigned long)ab->hal.wrp.vaddr); 1903 else 1904 return ab->hal.rdp.paddr + 1905 ((unsigned long)srng->u.dst_ring.hp_addr - 1906 (unsigned long)ab->hal.rdp.vaddr); 1907 } 1908 1909 dma_addr_t ath12k_hal_srng_get_tp_addr(struct ath12k_base *ab, 1910 struct hal_srng *srng) 1911 { 1912 if (!(srng->flags & HAL_SRNG_FLAGS_LMAC_RING)) 1913 return 0; 1914 1915 if (srng->ring_dir == HAL_SRNG_DIR_SRC) 1916 return ab->hal.rdp.paddr + 1917 ((unsigned long)srng->u.src_ring.tp_addr - 1918 (unsigned long)ab->hal.rdp.vaddr); 1919 else 1920 return ab->hal.wrp.paddr + 1921 ((unsigned long)srng->u.dst_ring.tp_addr - 1922 (unsigned long)ab->hal.wrp.vaddr); 1923 } 1924 1925 u32 ath12k_hal_ce_get_desc_size(enum hal_ce_desc type) 1926 { 1927 switch (type) { 1928 case HAL_CE_DESC_SRC: 1929 return sizeof(struct hal_ce_srng_src_desc); 1930 case HAL_CE_DESC_DST: 1931 return sizeof(struct hal_ce_srng_dest_desc); 1932 case HAL_CE_DESC_DST_STATUS: 1933 return sizeof(struct hal_ce_srng_dst_status_desc); 1934 } 1935 1936 return 0; 1937 } 1938 1939 void ath12k_hal_ce_src_set_desc(struct hal_ce_srng_src_desc *desc, dma_addr_t paddr, 1940 u32 len, u32 id, u8 byte_swap_data) 1941 { 1942 desc->buffer_addr_low = cpu_to_le32(paddr & HAL_ADDR_LSB_REG_MASK); 1943 desc->buffer_addr_info = 1944 le32_encode_bits(((u64)paddr >> HAL_ADDR_MSB_REG_SHIFT), 1945 HAL_CE_SRC_DESC_ADDR_INFO_ADDR_HI) | 1946 le32_encode_bits(byte_swap_data, 1947 HAL_CE_SRC_DESC_ADDR_INFO_BYTE_SWAP) | 1948 le32_encode_bits(0, HAL_CE_SRC_DESC_ADDR_INFO_GATHER) | 1949 le32_encode_bits(len, HAL_CE_SRC_DESC_ADDR_INFO_LEN); 1950 desc->meta_info = le32_encode_bits(id, HAL_CE_SRC_DESC_META_INFO_DATA); 1951 } 1952 1953 void ath12k_hal_ce_dst_set_desc(struct hal_ce_srng_dest_desc *desc, dma_addr_t paddr) 1954 { 1955 desc->buffer_addr_low = cpu_to_le32(paddr & HAL_ADDR_LSB_REG_MASK); 1956 desc->buffer_addr_info = 1957 le32_encode_bits(((u64)paddr >> HAL_ADDR_MSB_REG_SHIFT), 1958 HAL_CE_DEST_DESC_ADDR_INFO_ADDR_HI); 1959 } 1960 1961 u32 ath12k_hal_ce_dst_status_get_length(struct hal_ce_srng_dst_status_desc *desc) 1962 { 1963 u32 len; 1964 1965 len = le32_get_bits(desc->flags, HAL_CE_DST_STATUS_DESC_FLAGS_LEN); 1966 desc->flags &= ~cpu_to_le32(HAL_CE_DST_STATUS_DESC_FLAGS_LEN); 1967 1968 return len; 1969 } 1970 1971 void ath12k_hal_set_link_desc_addr(struct hal_wbm_link_desc *desc, u32 cookie, 1972 dma_addr_t paddr, 1973 enum hal_rx_buf_return_buf_manager rbm) 1974 { 1975 desc->buf_addr_info.info0 = le32_encode_bits((paddr & HAL_ADDR_LSB_REG_MASK), 1976 BUFFER_ADDR_INFO0_ADDR); 1977 desc->buf_addr_info.info1 = 1978 le32_encode_bits(((u64)paddr >> HAL_ADDR_MSB_REG_SHIFT), 1979 BUFFER_ADDR_INFO1_ADDR) | 1980 le32_encode_bits(rbm, BUFFER_ADDR_INFO1_RET_BUF_MGR) | 1981 le32_encode_bits(cookie, BUFFER_ADDR_INFO1_SW_COOKIE); 1982 } 1983 1984 void *ath12k_hal_srng_dst_peek(struct ath12k_base *ab, struct hal_srng *srng) 1985 { 1986 lockdep_assert_held(&srng->lock); 1987 1988 if (srng->u.dst_ring.tp != srng->u.dst_ring.cached_hp) 1989 return (srng->ring_base_vaddr + srng->u.dst_ring.tp); 1990 1991 return NULL; 1992 } 1993 1994 void *ath12k_hal_srng_dst_get_next_entry(struct ath12k_base *ab, 1995 struct hal_srng *srng) 1996 { 1997 void *desc; 1998 1999 lockdep_assert_held(&srng->lock); 2000 2001 if (srng->u.dst_ring.tp == srng->u.dst_ring.cached_hp) 2002 return NULL; 2003 2004 desc = srng->ring_base_vaddr + srng->u.dst_ring.tp; 2005 2006 srng->u.dst_ring.tp = (srng->u.dst_ring.tp + srng->entry_size) % 2007 srng->ring_size; 2008 2009 return desc; 2010 } 2011 2012 int ath12k_hal_srng_dst_num_free(struct ath12k_base *ab, struct hal_srng *srng, 2013 bool sync_hw_ptr) 2014 { 2015 u32 tp, hp; 2016 2017 lockdep_assert_held(&srng->lock); 2018 2019 tp = srng->u.dst_ring.tp; 2020 2021 if (sync_hw_ptr) { 2022 hp = *srng->u.dst_ring.hp_addr; 2023 srng->u.dst_ring.cached_hp = hp; 2024 } else { 2025 hp = srng->u.dst_ring.cached_hp; 2026 } 2027 2028 if (hp >= tp) 2029 return (hp - tp) / srng->entry_size; 2030 else 2031 return (srng->ring_size - tp + hp) / srng->entry_size; 2032 } 2033 2034 /* Returns number of available entries in src ring */ 2035 int ath12k_hal_srng_src_num_free(struct ath12k_base *ab, struct hal_srng *srng, 2036 bool sync_hw_ptr) 2037 { 2038 u32 tp, hp; 2039 2040 lockdep_assert_held(&srng->lock); 2041 2042 hp = srng->u.src_ring.hp; 2043 2044 if (sync_hw_ptr) { 2045 tp = *srng->u.src_ring.tp_addr; 2046 srng->u.src_ring.cached_tp = tp; 2047 } else { 2048 tp = srng->u.src_ring.cached_tp; 2049 } 2050 2051 if (tp > hp) 2052 return ((tp - hp) / srng->entry_size) - 1; 2053 else 2054 return ((srng->ring_size - hp + tp) / srng->entry_size) - 1; 2055 } 2056 2057 void *ath12k_hal_srng_src_get_next_entry(struct ath12k_base *ab, 2058 struct hal_srng *srng) 2059 { 2060 void *desc; 2061 u32 next_hp; 2062 2063 lockdep_assert_held(&srng->lock); 2064 2065 /* TODO: Using % is expensive, but we have to do this since size of some 2066 * SRNG rings is not power of 2 (due to descriptor sizes). Need to see 2067 * if separate function is defined for rings having power of 2 ring size 2068 * (TCL2SW, REO2SW, SW2RXDMA and CE rings) so that we can avoid the 2069 * overhead of % by using mask (with &). 2070 */ 2071 next_hp = (srng->u.src_ring.hp + srng->entry_size) % srng->ring_size; 2072 2073 if (next_hp == srng->u.src_ring.cached_tp) 2074 return NULL; 2075 2076 desc = srng->ring_base_vaddr + srng->u.src_ring.hp; 2077 srng->u.src_ring.hp = next_hp; 2078 2079 /* TODO: Reap functionality is not used by all rings. If particular 2080 * ring does not use reap functionality, we need not update reap_hp 2081 * with next_hp pointer. Need to make sure a separate function is used 2082 * before doing any optimization by removing below code updating 2083 * reap_hp. 2084 */ 2085 srng->u.src_ring.reap_hp = next_hp; 2086 2087 return desc; 2088 } 2089 2090 void *ath12k_hal_srng_src_reap_next(struct ath12k_base *ab, 2091 struct hal_srng *srng) 2092 { 2093 void *desc; 2094 u32 next_reap_hp; 2095 2096 lockdep_assert_held(&srng->lock); 2097 2098 next_reap_hp = (srng->u.src_ring.reap_hp + srng->entry_size) % 2099 srng->ring_size; 2100 2101 if (next_reap_hp == srng->u.src_ring.cached_tp) 2102 return NULL; 2103 2104 desc = srng->ring_base_vaddr + next_reap_hp; 2105 srng->u.src_ring.reap_hp = next_reap_hp; 2106 2107 return desc; 2108 } 2109 2110 void *ath12k_hal_srng_src_get_next_reaped(struct ath12k_base *ab, 2111 struct hal_srng *srng) 2112 { 2113 void *desc; 2114 2115 lockdep_assert_held(&srng->lock); 2116 2117 if (srng->u.src_ring.hp == srng->u.src_ring.reap_hp) 2118 return NULL; 2119 2120 desc = srng->ring_base_vaddr + srng->u.src_ring.hp; 2121 srng->u.src_ring.hp = (srng->u.src_ring.hp + srng->entry_size) % 2122 srng->ring_size; 2123 2124 return desc; 2125 } 2126 2127 void ath12k_hal_srng_access_begin(struct ath12k_base *ab, struct hal_srng *srng) 2128 { 2129 lockdep_assert_held(&srng->lock); 2130 2131 if (srng->ring_dir == HAL_SRNG_DIR_SRC) 2132 srng->u.src_ring.cached_tp = 2133 *(volatile u32 *)srng->u.src_ring.tp_addr; 2134 else 2135 srng->u.dst_ring.cached_hp = *srng->u.dst_ring.hp_addr; 2136 } 2137 2138 /* Update cached ring head/tail pointers to HW. ath12k_hal_srng_access_begin() 2139 * should have been called before this. 2140 */ 2141 void ath12k_hal_srng_access_end(struct ath12k_base *ab, struct hal_srng *srng) 2142 { 2143 lockdep_assert_held(&srng->lock); 2144 2145 /* TODO: See if we need a write memory barrier here */ 2146 if (srng->flags & HAL_SRNG_FLAGS_LMAC_RING) { 2147 /* For LMAC rings, ring pointer updates are done through FW and 2148 * hence written to a shared memory location that is read by FW 2149 */ 2150 if (srng->ring_dir == HAL_SRNG_DIR_SRC) { 2151 srng->u.src_ring.last_tp = 2152 *(volatile u32 *)srng->u.src_ring.tp_addr; 2153 *srng->u.src_ring.hp_addr = srng->u.src_ring.hp; 2154 } else { 2155 srng->u.dst_ring.last_hp = *srng->u.dst_ring.hp_addr; 2156 *srng->u.dst_ring.tp_addr = srng->u.dst_ring.tp; 2157 } 2158 } else { 2159 if (srng->ring_dir == HAL_SRNG_DIR_SRC) { 2160 srng->u.src_ring.last_tp = 2161 *(volatile u32 *)srng->u.src_ring.tp_addr; 2162 ath12k_hif_write32(ab, 2163 (unsigned long)srng->u.src_ring.hp_addr - 2164 (unsigned long)ab->mem, 2165 srng->u.src_ring.hp); 2166 } else { 2167 srng->u.dst_ring.last_hp = *srng->u.dst_ring.hp_addr; 2168 ath12k_hif_write32(ab, 2169 (unsigned long)srng->u.dst_ring.tp_addr - 2170 (unsigned long)ab->mem, 2171 srng->u.dst_ring.tp); 2172 } 2173 } 2174 2175 srng->timestamp = jiffies; 2176 } 2177 2178 void ath12k_hal_setup_link_idle_list(struct ath12k_base *ab, 2179 struct hal_wbm_idle_scatter_list *sbuf, 2180 u32 nsbufs, u32 tot_link_desc, 2181 u32 end_offset) 2182 { 2183 struct ath12k_buffer_addr *link_addr; 2184 int i; 2185 u32 reg_scatter_buf_sz = HAL_WBM_IDLE_SCATTER_BUF_SIZE / 64; 2186 u32 val; 2187 2188 link_addr = (void *)sbuf[0].vaddr + HAL_WBM_IDLE_SCATTER_BUF_SIZE; 2189 2190 for (i = 1; i < nsbufs; i++) { 2191 link_addr->info0 = cpu_to_le32(sbuf[i].paddr & HAL_ADDR_LSB_REG_MASK); 2192 2193 link_addr->info1 = 2194 le32_encode_bits((u64)sbuf[i].paddr >> HAL_ADDR_MSB_REG_SHIFT, 2195 HAL_WBM_SCATTERED_DESC_MSB_BASE_ADDR_39_32) | 2196 le32_encode_bits(BASE_ADDR_MATCH_TAG_VAL, 2197 HAL_WBM_SCATTERED_DESC_MSB_BASE_ADDR_MATCH_TAG); 2198 2199 link_addr = (void *)sbuf[i].vaddr + 2200 HAL_WBM_IDLE_SCATTER_BUF_SIZE; 2201 } 2202 2203 val = u32_encode_bits(reg_scatter_buf_sz, HAL_WBM_SCATTER_BUFFER_SIZE) | 2204 u32_encode_bits(0x1, HAL_WBM_LINK_DESC_IDLE_LIST_MODE); 2205 2206 ath12k_hif_write32(ab, 2207 HAL_SEQ_WCSS_UMAC_WBM_REG + 2208 HAL_WBM_R0_IDLE_LIST_CONTROL_ADDR(ab), 2209 val); 2210 2211 val = u32_encode_bits(reg_scatter_buf_sz * nsbufs, 2212 HAL_WBM_SCATTER_RING_SIZE_OF_IDLE_LINK_DESC_LIST); 2213 ath12k_hif_write32(ab, 2214 HAL_SEQ_WCSS_UMAC_WBM_REG + HAL_WBM_R0_IDLE_LIST_SIZE_ADDR(ab), 2215 val); 2216 2217 val = u32_encode_bits(sbuf[0].paddr & HAL_ADDR_LSB_REG_MASK, 2218 BUFFER_ADDR_INFO0_ADDR); 2219 ath12k_hif_write32(ab, 2220 HAL_SEQ_WCSS_UMAC_WBM_REG + 2221 HAL_WBM_SCATTERED_RING_BASE_LSB(ab), 2222 val); 2223 2224 val = u32_encode_bits(BASE_ADDR_MATCH_TAG_VAL, 2225 HAL_WBM_SCATTERED_DESC_MSB_BASE_ADDR_MATCH_TAG) | 2226 u32_encode_bits((u64)sbuf[0].paddr >> HAL_ADDR_MSB_REG_SHIFT, 2227 HAL_WBM_SCATTERED_DESC_MSB_BASE_ADDR_39_32); 2228 ath12k_hif_write32(ab, 2229 HAL_SEQ_WCSS_UMAC_WBM_REG + 2230 HAL_WBM_SCATTERED_RING_BASE_MSB(ab), 2231 val); 2232 2233 /* Setup head and tail pointers for the idle list */ 2234 val = u32_encode_bits(sbuf[nsbufs - 1].paddr, BUFFER_ADDR_INFO0_ADDR); 2235 ath12k_hif_write32(ab, 2236 HAL_SEQ_WCSS_UMAC_WBM_REG + 2237 HAL_WBM_SCATTERED_DESC_PTR_HEAD_INFO_IX0(ab), 2238 val); 2239 2240 val = u32_encode_bits(((u64)sbuf[nsbufs - 1].paddr >> HAL_ADDR_MSB_REG_SHIFT), 2241 HAL_WBM_SCATTERED_DESC_MSB_BASE_ADDR_39_32) | 2242 u32_encode_bits((end_offset >> 2), 2243 HAL_WBM_SCATTERED_DESC_HEAD_P_OFFSET_IX1); 2244 ath12k_hif_write32(ab, 2245 HAL_SEQ_WCSS_UMAC_WBM_REG + 2246 HAL_WBM_SCATTERED_DESC_PTR_HEAD_INFO_IX1(ab), 2247 val); 2248 2249 val = u32_encode_bits(sbuf[0].paddr, BUFFER_ADDR_INFO0_ADDR); 2250 ath12k_hif_write32(ab, 2251 HAL_SEQ_WCSS_UMAC_WBM_REG + 2252 HAL_WBM_SCATTERED_DESC_PTR_HEAD_INFO_IX0(ab), 2253 val); 2254 2255 val = u32_encode_bits(sbuf[0].paddr, BUFFER_ADDR_INFO0_ADDR); 2256 ath12k_hif_write32(ab, 2257 HAL_SEQ_WCSS_UMAC_WBM_REG + 2258 HAL_WBM_SCATTERED_DESC_PTR_TAIL_INFO_IX0(ab), 2259 val); 2260 2261 val = u32_encode_bits(((u64)sbuf[0].paddr >> HAL_ADDR_MSB_REG_SHIFT), 2262 HAL_WBM_SCATTERED_DESC_MSB_BASE_ADDR_39_32) | 2263 u32_encode_bits(0, HAL_WBM_SCATTERED_DESC_TAIL_P_OFFSET_IX1); 2264 ath12k_hif_write32(ab, 2265 HAL_SEQ_WCSS_UMAC_WBM_REG + 2266 HAL_WBM_SCATTERED_DESC_PTR_TAIL_INFO_IX1(ab), 2267 val); 2268 2269 val = 2 * tot_link_desc; 2270 ath12k_hif_write32(ab, 2271 HAL_SEQ_WCSS_UMAC_WBM_REG + 2272 HAL_WBM_SCATTERED_DESC_PTR_HP_ADDR(ab), 2273 val); 2274 2275 /* Enable the SRNG */ 2276 val = u32_encode_bits(1, HAL_WBM_IDLE_LINK_RING_MISC_SRNG_ENABLE) | 2277 u32_encode_bits(1, HAL_WBM_IDLE_LINK_RING_MISC_RIND_ID_DISABLE); 2278 ath12k_hif_write32(ab, 2279 HAL_SEQ_WCSS_UMAC_WBM_REG + 2280 HAL_WBM_IDLE_LINK_RING_MISC_ADDR(ab), 2281 val); 2282 } 2283 2284 int ath12k_hal_srng_setup(struct ath12k_base *ab, enum hal_ring_type type, 2285 int ring_num, int mac_id, 2286 struct hal_srng_params *params) 2287 { 2288 struct ath12k_hal *hal = &ab->hal; 2289 struct hal_srng_config *srng_config = &ab->hal.srng_config[type]; 2290 struct hal_srng *srng; 2291 int ring_id; 2292 u32 idx; 2293 int i; 2294 u32 reg_base; 2295 2296 ring_id = ath12k_hal_srng_get_ring_id(ab, type, ring_num, mac_id); 2297 if (ring_id < 0) 2298 return ring_id; 2299 2300 srng = &hal->srng_list[ring_id]; 2301 2302 srng->ring_id = ring_id; 2303 srng->ring_dir = srng_config->ring_dir; 2304 srng->ring_base_paddr = params->ring_base_paddr; 2305 srng->ring_base_vaddr = params->ring_base_vaddr; 2306 srng->entry_size = srng_config->entry_size; 2307 srng->num_entries = params->num_entries; 2308 srng->ring_size = srng->entry_size * srng->num_entries; 2309 srng->intr_batch_cntr_thres_entries = 2310 params->intr_batch_cntr_thres_entries; 2311 srng->intr_timer_thres_us = params->intr_timer_thres_us; 2312 srng->flags = params->flags; 2313 srng->msi_addr = params->msi_addr; 2314 srng->msi2_addr = params->msi2_addr; 2315 srng->msi_data = params->msi_data; 2316 srng->msi2_data = params->msi2_data; 2317 srng->initialized = 1; 2318 spin_lock_init(&srng->lock); 2319 lockdep_set_class(&srng->lock, &srng->lock_key); 2320 2321 for (i = 0; i < HAL_SRNG_NUM_REG_GRP; i++) { 2322 srng->hwreg_base[i] = srng_config->reg_start[i] + 2323 (ring_num * srng_config->reg_size[i]); 2324 } 2325 2326 memset(srng->ring_base_vaddr, 0, 2327 (srng->entry_size * srng->num_entries) << 2); 2328 2329 reg_base = srng->hwreg_base[HAL_SRNG_REG_GRP_R2]; 2330 2331 if (srng->ring_dir == HAL_SRNG_DIR_SRC) { 2332 srng->u.src_ring.hp = 0; 2333 srng->u.src_ring.cached_tp = 0; 2334 srng->u.src_ring.reap_hp = srng->ring_size - srng->entry_size; 2335 srng->u.src_ring.tp_addr = (void *)(hal->rdp.vaddr + ring_id); 2336 srng->u.src_ring.low_threshold = params->low_threshold * 2337 srng->entry_size; 2338 if (srng_config->mac_type == ATH12K_HAL_SRNG_UMAC) { 2339 if (!ab->hw_params->supports_shadow_regs) 2340 srng->u.src_ring.hp_addr = 2341 (u32 *)((unsigned long)ab->mem + reg_base); 2342 else 2343 ath12k_dbg(ab, ATH12K_DBG_HAL, 2344 "hal type %d ring_num %d reg_base 0x%x shadow 0x%lx\n", 2345 type, ring_num, 2346 reg_base, 2347 (unsigned long)srng->u.src_ring.hp_addr - 2348 (unsigned long)ab->mem); 2349 } else { 2350 idx = ring_id - HAL_SRNG_RING_ID_DMAC_CMN_ID_START; 2351 srng->u.src_ring.hp_addr = (void *)(hal->wrp.vaddr + 2352 idx); 2353 srng->flags |= HAL_SRNG_FLAGS_LMAC_RING; 2354 } 2355 } else { 2356 /* During initialization loop count in all the descriptors 2357 * will be set to zero, and HW will set it to 1 on completing 2358 * descriptor update in first loop, and increments it by 1 on 2359 * subsequent loops (loop count wraps around after reaching 2360 * 0xffff). The 'loop_cnt' in SW ring state is the expected 2361 * loop count in descriptors updated by HW (to be processed 2362 * by SW). 2363 */ 2364 srng->u.dst_ring.loop_cnt = 1; 2365 srng->u.dst_ring.tp = 0; 2366 srng->u.dst_ring.cached_hp = 0; 2367 srng->u.dst_ring.hp_addr = (void *)(hal->rdp.vaddr + ring_id); 2368 if (srng_config->mac_type == ATH12K_HAL_SRNG_UMAC) { 2369 if (!ab->hw_params->supports_shadow_regs) 2370 srng->u.dst_ring.tp_addr = 2371 (u32 *)((unsigned long)ab->mem + reg_base + 2372 (HAL_REO1_RING_TP - HAL_REO1_RING_HP)); 2373 else 2374 ath12k_dbg(ab, ATH12K_DBG_HAL, 2375 "type %d ring_num %d target_reg 0x%x shadow 0x%lx\n", 2376 type, ring_num, 2377 reg_base + HAL_REO1_RING_TP - HAL_REO1_RING_HP, 2378 (unsigned long)srng->u.dst_ring.tp_addr - 2379 (unsigned long)ab->mem); 2380 } else { 2381 /* For PMAC & DMAC rings, tail pointer updates will be done 2382 * through FW by writing to a shared memory location 2383 */ 2384 idx = ring_id - HAL_SRNG_RING_ID_DMAC_CMN_ID_START; 2385 srng->u.dst_ring.tp_addr = (void *)(hal->wrp.vaddr + 2386 idx); 2387 srng->flags |= HAL_SRNG_FLAGS_LMAC_RING; 2388 } 2389 } 2390 2391 if (srng_config->mac_type != ATH12K_HAL_SRNG_UMAC) 2392 return ring_id; 2393 2394 ath12k_hal_srng_hw_init(ab, srng); 2395 2396 if (type == HAL_CE_DST) { 2397 srng->u.dst_ring.max_buffer_length = params->max_buffer_len; 2398 ath12k_hal_ce_dst_setup(ab, srng, ring_num); 2399 } 2400 2401 return ring_id; 2402 } 2403 2404 static void ath12k_hal_srng_update_hp_tp_addr(struct ath12k_base *ab, 2405 int shadow_cfg_idx, 2406 enum hal_ring_type ring_type, 2407 int ring_num) 2408 { 2409 struct hal_srng *srng; 2410 struct ath12k_hal *hal = &ab->hal; 2411 int ring_id; 2412 struct hal_srng_config *srng_config = &hal->srng_config[ring_type]; 2413 2414 ring_id = ath12k_hal_srng_get_ring_id(ab, ring_type, ring_num, 0); 2415 if (ring_id < 0) 2416 return; 2417 2418 srng = &hal->srng_list[ring_id]; 2419 2420 if (srng_config->ring_dir == HAL_SRNG_DIR_DST) 2421 srng->u.dst_ring.tp_addr = (u32 *)(HAL_SHADOW_REG(shadow_cfg_idx) + 2422 (unsigned long)ab->mem); 2423 else 2424 srng->u.src_ring.hp_addr = (u32 *)(HAL_SHADOW_REG(shadow_cfg_idx) + 2425 (unsigned long)ab->mem); 2426 } 2427 2428 int ath12k_hal_srng_update_shadow_config(struct ath12k_base *ab, 2429 enum hal_ring_type ring_type, 2430 int ring_num) 2431 { 2432 struct ath12k_hal *hal = &ab->hal; 2433 struct hal_srng_config *srng_config = &hal->srng_config[ring_type]; 2434 int shadow_cfg_idx = hal->num_shadow_reg_configured; 2435 u32 target_reg; 2436 2437 if (shadow_cfg_idx >= HAL_SHADOW_NUM_REGS) 2438 return -EINVAL; 2439 2440 hal->num_shadow_reg_configured++; 2441 2442 target_reg = srng_config->reg_start[HAL_HP_OFFSET_IN_REG_START]; 2443 target_reg += srng_config->reg_size[HAL_HP_OFFSET_IN_REG_START] * 2444 ring_num; 2445 2446 /* For destination ring, shadow the TP */ 2447 if (srng_config->ring_dir == HAL_SRNG_DIR_DST) 2448 target_reg += HAL_OFFSET_FROM_HP_TO_TP; 2449 2450 hal->shadow_reg_addr[shadow_cfg_idx] = target_reg; 2451 2452 /* update hp/tp addr to hal structure*/ 2453 ath12k_hal_srng_update_hp_tp_addr(ab, shadow_cfg_idx, ring_type, 2454 ring_num); 2455 2456 ath12k_dbg(ab, ATH12K_DBG_HAL, 2457 "target_reg %x, shadow reg 0x%x shadow_idx 0x%x, ring_type %d, ring num %d", 2458 target_reg, 2459 HAL_SHADOW_REG(shadow_cfg_idx), 2460 shadow_cfg_idx, 2461 ring_type, ring_num); 2462 2463 return 0; 2464 } 2465 2466 void ath12k_hal_srng_shadow_config(struct ath12k_base *ab) 2467 { 2468 struct ath12k_hal *hal = &ab->hal; 2469 int ring_type, ring_num; 2470 2471 /* update all the non-CE srngs. */ 2472 for (ring_type = 0; ring_type < HAL_MAX_RING_TYPES; ring_type++) { 2473 struct hal_srng_config *srng_config = &hal->srng_config[ring_type]; 2474 2475 if (ring_type == HAL_CE_SRC || 2476 ring_type == HAL_CE_DST || 2477 ring_type == HAL_CE_DST_STATUS) 2478 continue; 2479 2480 if (srng_config->mac_type == ATH12K_HAL_SRNG_DMAC || 2481 srng_config->mac_type == ATH12K_HAL_SRNG_PMAC) 2482 continue; 2483 2484 for (ring_num = 0; ring_num < srng_config->max_rings; ring_num++) 2485 ath12k_hal_srng_update_shadow_config(ab, ring_type, ring_num); 2486 } 2487 } 2488 2489 void ath12k_hal_srng_get_shadow_config(struct ath12k_base *ab, 2490 u32 **cfg, u32 *len) 2491 { 2492 struct ath12k_hal *hal = &ab->hal; 2493 2494 *len = hal->num_shadow_reg_configured; 2495 *cfg = hal->shadow_reg_addr; 2496 } 2497 2498 void ath12k_hal_srng_shadow_update_hp_tp(struct ath12k_base *ab, 2499 struct hal_srng *srng) 2500 { 2501 lockdep_assert_held(&srng->lock); 2502 2503 /* check whether the ring is empty. Update the shadow 2504 * HP only when then ring isn't' empty. 2505 */ 2506 if (srng->ring_dir == HAL_SRNG_DIR_SRC && 2507 *srng->u.src_ring.tp_addr != srng->u.src_ring.hp) 2508 ath12k_hal_srng_access_end(ab, srng); 2509 } 2510 2511 static void ath12k_hal_register_srng_lock_keys(struct ath12k_base *ab) 2512 { 2513 struct ath12k_hal *hal = &ab->hal; 2514 u32 ring_id; 2515 2516 for (ring_id = 0; ring_id < HAL_SRNG_RING_ID_MAX; ring_id++) 2517 lockdep_register_key(&hal->srng_list[ring_id].lock_key); 2518 } 2519 2520 static void ath12k_hal_unregister_srng_lock_keys(struct ath12k_base *ab) 2521 { 2522 struct ath12k_hal *hal = &ab->hal; 2523 u32 ring_id; 2524 2525 for (ring_id = 0; ring_id < HAL_SRNG_RING_ID_MAX; ring_id++) 2526 lockdep_unregister_key(&hal->srng_list[ring_id].lock_key); 2527 } 2528 2529 int ath12k_hal_srng_init(struct ath12k_base *ab) 2530 { 2531 struct ath12k_hal *hal = &ab->hal; 2532 int ret; 2533 2534 memset(hal, 0, sizeof(*hal)); 2535 2536 ret = ab->hw_params->hal_ops->create_srng_config(ab); 2537 if (ret) 2538 goto err_hal; 2539 2540 ret = ath12k_hal_alloc_cont_rdp(ab); 2541 if (ret) 2542 goto err_hal; 2543 2544 ret = ath12k_hal_alloc_cont_wrp(ab); 2545 if (ret) 2546 goto err_free_cont_rdp; 2547 2548 ath12k_hal_register_srng_lock_keys(ab); 2549 2550 return 0; 2551 2552 err_free_cont_rdp: 2553 ath12k_hal_free_cont_rdp(ab); 2554 2555 err_hal: 2556 return ret; 2557 } 2558 2559 void ath12k_hal_srng_deinit(struct ath12k_base *ab) 2560 { 2561 struct ath12k_hal *hal = &ab->hal; 2562 2563 ath12k_hal_unregister_srng_lock_keys(ab); 2564 ath12k_hal_free_cont_rdp(ab); 2565 ath12k_hal_free_cont_wrp(ab); 2566 kfree(hal->srng_config); 2567 hal->srng_config = NULL; 2568 } 2569 2570 void ath12k_hal_dump_srng_stats(struct ath12k_base *ab) 2571 { 2572 struct hal_srng *srng; 2573 struct ath12k_ext_irq_grp *irq_grp; 2574 struct ath12k_ce_pipe *ce_pipe; 2575 int i; 2576 2577 ath12k_err(ab, "Last interrupt received for each CE:\n"); 2578 for (i = 0; i < ab->hw_params->ce_count; i++) { 2579 ce_pipe = &ab->ce.ce_pipe[i]; 2580 2581 if (ath12k_ce_get_attr_flags(ab, i) & CE_ATTR_DIS_INTR) 2582 continue; 2583 2584 ath12k_err(ab, "CE_id %d pipe_num %d %ums before\n", 2585 i, ce_pipe->pipe_num, 2586 jiffies_to_msecs(jiffies - ce_pipe->timestamp)); 2587 } 2588 2589 ath12k_err(ab, "\nLast interrupt received for each group:\n"); 2590 for (i = 0; i < ATH12K_EXT_IRQ_GRP_NUM_MAX; i++) { 2591 irq_grp = &ab->ext_irq_grp[i]; 2592 ath12k_err(ab, "group_id %d %ums before\n", 2593 irq_grp->grp_id, 2594 jiffies_to_msecs(jiffies - irq_grp->timestamp)); 2595 } 2596 2597 for (i = 0; i < HAL_SRNG_RING_ID_MAX; i++) { 2598 srng = &ab->hal.srng_list[i]; 2599 2600 if (!srng->initialized) 2601 continue; 2602 2603 if (srng->ring_dir == HAL_SRNG_DIR_SRC) 2604 ath12k_err(ab, 2605 "src srng id %u hp %u, reap_hp %u, cur tp %u, cached tp %u last tp %u napi processed before %ums\n", 2606 srng->ring_id, srng->u.src_ring.hp, 2607 srng->u.src_ring.reap_hp, 2608 *srng->u.src_ring.tp_addr, srng->u.src_ring.cached_tp, 2609 srng->u.src_ring.last_tp, 2610 jiffies_to_msecs(jiffies - srng->timestamp)); 2611 else if (srng->ring_dir == HAL_SRNG_DIR_DST) 2612 ath12k_err(ab, 2613 "dst srng id %u tp %u, cur hp %u, cached hp %u last hp %u napi processed before %ums\n", 2614 srng->ring_id, srng->u.dst_ring.tp, 2615 *srng->u.dst_ring.hp_addr, 2616 srng->u.dst_ring.cached_hp, 2617 srng->u.dst_ring.last_hp, 2618 jiffies_to_msecs(jiffies - srng->timestamp)); 2619 } 2620 } 2621