162306a36Sopenharmony_ci/* SPDX-License-Identifier: BSD-3-Clause-Clear */ 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * Copyright (c) 2018-2021 The Linux Foundation. All rights reserved. 462306a36Sopenharmony_ci * Copyright (c) 2021-2022 Qualcomm Innovation Center, Inc. All rights reserved. 562306a36Sopenharmony_ci */ 662306a36Sopenharmony_ci 762306a36Sopenharmony_ci#ifndef ATH12K_DP_H 862306a36Sopenharmony_ci#define ATH12K_DP_H 962306a36Sopenharmony_ci 1062306a36Sopenharmony_ci#include "hal_rx.h" 1162306a36Sopenharmony_ci#include "hw.h" 1262306a36Sopenharmony_ci 1362306a36Sopenharmony_ci#define MAX_RXDMA_PER_PDEV 2 1462306a36Sopenharmony_ci 1562306a36Sopenharmony_cistruct ath12k_base; 1662306a36Sopenharmony_cistruct ath12k_peer; 1762306a36Sopenharmony_cistruct ath12k_dp; 1862306a36Sopenharmony_cistruct ath12k_vif; 1962306a36Sopenharmony_cistruct hal_tcl_status_ring; 2062306a36Sopenharmony_cistruct ath12k_ext_irq_grp; 2162306a36Sopenharmony_ci 2262306a36Sopenharmony_ci#define DP_MON_PURGE_TIMEOUT_MS 100 2362306a36Sopenharmony_ci#define DP_MON_SERVICE_BUDGET 128 2462306a36Sopenharmony_ci 2562306a36Sopenharmony_cistruct dp_srng { 2662306a36Sopenharmony_ci u32 *vaddr_unaligned; 2762306a36Sopenharmony_ci u32 *vaddr; 2862306a36Sopenharmony_ci dma_addr_t paddr_unaligned; 2962306a36Sopenharmony_ci dma_addr_t paddr; 3062306a36Sopenharmony_ci int size; 3162306a36Sopenharmony_ci u32 ring_id; 3262306a36Sopenharmony_ci}; 3362306a36Sopenharmony_ci 3462306a36Sopenharmony_cistruct dp_rxdma_ring { 3562306a36Sopenharmony_ci struct dp_srng refill_buf_ring; 3662306a36Sopenharmony_ci struct idr bufs_idr; 3762306a36Sopenharmony_ci /* Protects bufs_idr */ 3862306a36Sopenharmony_ci spinlock_t idr_lock; 3962306a36Sopenharmony_ci int bufs_max; 4062306a36Sopenharmony_ci}; 4162306a36Sopenharmony_ci 4262306a36Sopenharmony_ci#define ATH12K_TX_COMPL_NEXT(x) (((x) + 1) % DP_TX_COMP_RING_SIZE) 4362306a36Sopenharmony_ci 4462306a36Sopenharmony_cistruct dp_tx_ring { 4562306a36Sopenharmony_ci u8 tcl_data_ring_id; 4662306a36Sopenharmony_ci struct dp_srng tcl_data_ring; 4762306a36Sopenharmony_ci struct dp_srng tcl_comp_ring; 4862306a36Sopenharmony_ci struct hal_wbm_completion_ring_tx *tx_status; 4962306a36Sopenharmony_ci int tx_status_head; 5062306a36Sopenharmony_ci int tx_status_tail; 5162306a36Sopenharmony_ci}; 5262306a36Sopenharmony_ci 5362306a36Sopenharmony_cistruct ath12k_pdev_mon_stats { 5462306a36Sopenharmony_ci u32 status_ppdu_state; 5562306a36Sopenharmony_ci u32 status_ppdu_start; 5662306a36Sopenharmony_ci u32 status_ppdu_end; 5762306a36Sopenharmony_ci u32 status_ppdu_compl; 5862306a36Sopenharmony_ci u32 status_ppdu_start_mis; 5962306a36Sopenharmony_ci u32 status_ppdu_end_mis; 6062306a36Sopenharmony_ci u32 status_ppdu_done; 6162306a36Sopenharmony_ci u32 dest_ppdu_done; 6262306a36Sopenharmony_ci u32 dest_mpdu_done; 6362306a36Sopenharmony_ci u32 dest_mpdu_drop; 6462306a36Sopenharmony_ci u32 dup_mon_linkdesc_cnt; 6562306a36Sopenharmony_ci u32 dup_mon_buf_cnt; 6662306a36Sopenharmony_ci}; 6762306a36Sopenharmony_ci 6862306a36Sopenharmony_cistruct dp_link_desc_bank { 6962306a36Sopenharmony_ci void *vaddr_unaligned; 7062306a36Sopenharmony_ci void *vaddr; 7162306a36Sopenharmony_ci dma_addr_t paddr_unaligned; 7262306a36Sopenharmony_ci dma_addr_t paddr; 7362306a36Sopenharmony_ci u32 size; 7462306a36Sopenharmony_ci}; 7562306a36Sopenharmony_ci 7662306a36Sopenharmony_ci/* Size to enforce scatter idle list mode */ 7762306a36Sopenharmony_ci#define DP_LINK_DESC_ALLOC_SIZE_THRESH 0x200000 7862306a36Sopenharmony_ci#define DP_LINK_DESC_BANKS_MAX 8 7962306a36Sopenharmony_ci 8062306a36Sopenharmony_ci#define DP_LINK_DESC_START 0x4000 8162306a36Sopenharmony_ci#define DP_LINK_DESC_SHIFT 3 8262306a36Sopenharmony_ci 8362306a36Sopenharmony_ci#define DP_LINK_DESC_COOKIE_SET(id, page) \ 8462306a36Sopenharmony_ci ((((id) + DP_LINK_DESC_START) << DP_LINK_DESC_SHIFT) | (page)) 8562306a36Sopenharmony_ci 8662306a36Sopenharmony_ci#define DP_LINK_DESC_BANK_MASK GENMASK(2, 0) 8762306a36Sopenharmony_ci 8862306a36Sopenharmony_ci#define DP_RX_DESC_COOKIE_INDEX_MAX 0x3ffff 8962306a36Sopenharmony_ci#define DP_RX_DESC_COOKIE_POOL_ID_MAX 0x1c0000 9062306a36Sopenharmony_ci#define DP_RX_DESC_COOKIE_MAX \ 9162306a36Sopenharmony_ci (DP_RX_DESC_COOKIE_INDEX_MAX | DP_RX_DESC_COOKIE_POOL_ID_MAX) 9262306a36Sopenharmony_ci#define DP_NOT_PPDU_ID_WRAP_AROUND 20000 9362306a36Sopenharmony_ci 9462306a36Sopenharmony_cienum ath12k_dp_ppdu_state { 9562306a36Sopenharmony_ci DP_PPDU_STATUS_START, 9662306a36Sopenharmony_ci DP_PPDU_STATUS_DONE, 9762306a36Sopenharmony_ci}; 9862306a36Sopenharmony_ci 9962306a36Sopenharmony_cistruct dp_mon_mpdu { 10062306a36Sopenharmony_ci struct list_head list; 10162306a36Sopenharmony_ci struct sk_buff *head; 10262306a36Sopenharmony_ci struct sk_buff *tail; 10362306a36Sopenharmony_ci}; 10462306a36Sopenharmony_ci 10562306a36Sopenharmony_ci#define DP_MON_MAX_STATUS_BUF 32 10662306a36Sopenharmony_ci 10762306a36Sopenharmony_cistruct ath12k_mon_data { 10862306a36Sopenharmony_ci struct dp_link_desc_bank link_desc_banks[DP_LINK_DESC_BANKS_MAX]; 10962306a36Sopenharmony_ci struct hal_rx_mon_ppdu_info mon_ppdu_info; 11062306a36Sopenharmony_ci 11162306a36Sopenharmony_ci u32 mon_ppdu_status; 11262306a36Sopenharmony_ci u32 mon_last_buf_cookie; 11362306a36Sopenharmony_ci u64 mon_last_linkdesc_paddr; 11462306a36Sopenharmony_ci u16 chan_noise_floor; 11562306a36Sopenharmony_ci 11662306a36Sopenharmony_ci struct ath12k_pdev_mon_stats rx_mon_stats; 11762306a36Sopenharmony_ci /* lock for monitor data */ 11862306a36Sopenharmony_ci spinlock_t mon_lock; 11962306a36Sopenharmony_ci struct sk_buff_head rx_status_q; 12062306a36Sopenharmony_ci struct dp_mon_mpdu *mon_mpdu; 12162306a36Sopenharmony_ci struct list_head dp_rx_mon_mpdu_list; 12262306a36Sopenharmony_ci struct sk_buff *dest_skb_q[DP_MON_MAX_STATUS_BUF]; 12362306a36Sopenharmony_ci struct dp_mon_tx_ppdu_info *tx_prot_ppdu_info; 12462306a36Sopenharmony_ci struct dp_mon_tx_ppdu_info *tx_data_ppdu_info; 12562306a36Sopenharmony_ci}; 12662306a36Sopenharmony_ci 12762306a36Sopenharmony_cistruct ath12k_pdev_dp { 12862306a36Sopenharmony_ci u32 mac_id; 12962306a36Sopenharmony_ci atomic_t num_tx_pending; 13062306a36Sopenharmony_ci wait_queue_head_t tx_empty_waitq; 13162306a36Sopenharmony_ci struct dp_srng rxdma_mon_dst_ring[MAX_RXDMA_PER_PDEV]; 13262306a36Sopenharmony_ci struct dp_srng tx_mon_dst_ring[MAX_RXDMA_PER_PDEV]; 13362306a36Sopenharmony_ci 13462306a36Sopenharmony_ci struct ieee80211_rx_status rx_status; 13562306a36Sopenharmony_ci struct ath12k_mon_data mon_data; 13662306a36Sopenharmony_ci}; 13762306a36Sopenharmony_ci 13862306a36Sopenharmony_ci#define DP_NUM_CLIENTS_MAX 64 13962306a36Sopenharmony_ci#define DP_AVG_TIDS_PER_CLIENT 2 14062306a36Sopenharmony_ci#define DP_NUM_TIDS_MAX (DP_NUM_CLIENTS_MAX * DP_AVG_TIDS_PER_CLIENT) 14162306a36Sopenharmony_ci#define DP_AVG_MSDUS_PER_FLOW 128 14262306a36Sopenharmony_ci#define DP_AVG_FLOWS_PER_TID 2 14362306a36Sopenharmony_ci#define DP_AVG_MPDUS_PER_TID_MAX 128 14462306a36Sopenharmony_ci#define DP_AVG_MSDUS_PER_MPDU 4 14562306a36Sopenharmony_ci 14662306a36Sopenharmony_ci#define DP_RX_HASH_ENABLE 1 /* Enable hash based Rx steering */ 14762306a36Sopenharmony_ci 14862306a36Sopenharmony_ci#define DP_BA_WIN_SZ_MAX 256 14962306a36Sopenharmony_ci 15062306a36Sopenharmony_ci#define DP_TCL_NUM_RING_MAX 4 15162306a36Sopenharmony_ci 15262306a36Sopenharmony_ci#define DP_IDLE_SCATTER_BUFS_MAX 16 15362306a36Sopenharmony_ci 15462306a36Sopenharmony_ci#define DP_WBM_RELEASE_RING_SIZE 64 15562306a36Sopenharmony_ci#define DP_TCL_DATA_RING_SIZE 512 15662306a36Sopenharmony_ci#define DP_TX_COMP_RING_SIZE 32768 15762306a36Sopenharmony_ci#define DP_TX_IDR_SIZE DP_TX_COMP_RING_SIZE 15862306a36Sopenharmony_ci#define DP_TCL_CMD_RING_SIZE 32 15962306a36Sopenharmony_ci#define DP_TCL_STATUS_RING_SIZE 32 16062306a36Sopenharmony_ci#define DP_REO_DST_RING_MAX 8 16162306a36Sopenharmony_ci#define DP_REO_DST_RING_SIZE 2048 16262306a36Sopenharmony_ci#define DP_REO_REINJECT_RING_SIZE 32 16362306a36Sopenharmony_ci#define DP_RX_RELEASE_RING_SIZE 1024 16462306a36Sopenharmony_ci#define DP_REO_EXCEPTION_RING_SIZE 128 16562306a36Sopenharmony_ci#define DP_REO_CMD_RING_SIZE 128 16662306a36Sopenharmony_ci#define DP_REO_STATUS_RING_SIZE 2048 16762306a36Sopenharmony_ci#define DP_RXDMA_BUF_RING_SIZE 4096 16862306a36Sopenharmony_ci#define DP_RXDMA_REFILL_RING_SIZE 2048 16962306a36Sopenharmony_ci#define DP_RXDMA_ERR_DST_RING_SIZE 1024 17062306a36Sopenharmony_ci#define DP_RXDMA_MON_STATUS_RING_SIZE 1024 17162306a36Sopenharmony_ci#define DP_RXDMA_MONITOR_BUF_RING_SIZE 4096 17262306a36Sopenharmony_ci#define DP_RXDMA_MONITOR_DST_RING_SIZE 2048 17362306a36Sopenharmony_ci#define DP_RXDMA_MONITOR_DESC_RING_SIZE 4096 17462306a36Sopenharmony_ci#define DP_TX_MONITOR_BUF_RING_SIZE 4096 17562306a36Sopenharmony_ci#define DP_TX_MONITOR_DEST_RING_SIZE 2048 17662306a36Sopenharmony_ci 17762306a36Sopenharmony_ci#define DP_TX_MONITOR_BUF_SIZE 2048 17862306a36Sopenharmony_ci#define DP_TX_MONITOR_BUF_SIZE_MIN 48 17962306a36Sopenharmony_ci#define DP_TX_MONITOR_BUF_SIZE_MAX 8192 18062306a36Sopenharmony_ci 18162306a36Sopenharmony_ci#define DP_RX_BUFFER_SIZE 2048 18262306a36Sopenharmony_ci#define DP_RX_BUFFER_SIZE_LITE 1024 18362306a36Sopenharmony_ci#define DP_RX_BUFFER_ALIGN_SIZE 128 18462306a36Sopenharmony_ci 18562306a36Sopenharmony_ci#define DP_RXDMA_BUF_COOKIE_BUF_ID GENMASK(17, 0) 18662306a36Sopenharmony_ci#define DP_RXDMA_BUF_COOKIE_PDEV_ID GENMASK(19, 18) 18762306a36Sopenharmony_ci 18862306a36Sopenharmony_ci#define DP_HW2SW_MACID(mac_id) ({ typeof(mac_id) x = (mac_id); x ? x - 1 : 0; }) 18962306a36Sopenharmony_ci#define DP_SW2HW_MACID(mac_id) ((mac_id) + 1) 19062306a36Sopenharmony_ci 19162306a36Sopenharmony_ci#define DP_TX_DESC_ID_MAC_ID GENMASK(1, 0) 19262306a36Sopenharmony_ci#define DP_TX_DESC_ID_MSDU_ID GENMASK(18, 2) 19362306a36Sopenharmony_ci#define DP_TX_DESC_ID_POOL_ID GENMASK(20, 19) 19462306a36Sopenharmony_ci 19562306a36Sopenharmony_ci#define ATH12K_SHADOW_DP_TIMER_INTERVAL 20 19662306a36Sopenharmony_ci#define ATH12K_SHADOW_CTRL_TIMER_INTERVAL 10 19762306a36Sopenharmony_ci 19862306a36Sopenharmony_ci#define ATH12K_NUM_POOL_TX_DESC 32768 19962306a36Sopenharmony_ci 20062306a36Sopenharmony_ci/* TODO: revisit this count during testing */ 20162306a36Sopenharmony_ci#define ATH12K_RX_DESC_COUNT (12288) 20262306a36Sopenharmony_ci 20362306a36Sopenharmony_ci#define ATH12K_PAGE_SIZE PAGE_SIZE 20462306a36Sopenharmony_ci 20562306a36Sopenharmony_ci/* Total 1024 entries in PPT, i.e 4K/4 considering 4K aligned 20662306a36Sopenharmony_ci * SPT pages which makes lower 12bits 0 20762306a36Sopenharmony_ci */ 20862306a36Sopenharmony_ci#define ATH12K_MAX_PPT_ENTRIES 1024 20962306a36Sopenharmony_ci 21062306a36Sopenharmony_ci/* Total 512 entries in a SPT, i.e 4K Page/8 */ 21162306a36Sopenharmony_ci#define ATH12K_MAX_SPT_ENTRIES 512 21262306a36Sopenharmony_ci 21362306a36Sopenharmony_ci#define ATH12K_NUM_RX_SPT_PAGES ((ATH12K_RX_DESC_COUNT) / ATH12K_MAX_SPT_ENTRIES) 21462306a36Sopenharmony_ci 21562306a36Sopenharmony_ci#define ATH12K_TX_SPT_PAGES_PER_POOL (ATH12K_NUM_POOL_TX_DESC / \ 21662306a36Sopenharmony_ci ATH12K_MAX_SPT_ENTRIES) 21762306a36Sopenharmony_ci#define ATH12K_NUM_TX_SPT_PAGES (ATH12K_TX_SPT_PAGES_PER_POOL * ATH12K_HW_MAX_QUEUES) 21862306a36Sopenharmony_ci#define ATH12K_NUM_SPT_PAGES (ATH12K_NUM_RX_SPT_PAGES + ATH12K_NUM_TX_SPT_PAGES) 21962306a36Sopenharmony_ci 22062306a36Sopenharmony_ci/* The SPT pages are divided for RX and TX, first block for RX 22162306a36Sopenharmony_ci * and remaining for TX 22262306a36Sopenharmony_ci */ 22362306a36Sopenharmony_ci#define ATH12K_NUM_TX_SPT_PAGE_START ATH12K_NUM_RX_SPT_PAGES 22462306a36Sopenharmony_ci 22562306a36Sopenharmony_ci#define ATH12K_DP_RX_DESC_MAGIC 0xBABABABA 22662306a36Sopenharmony_ci 22762306a36Sopenharmony_ci/* 4K aligned address have last 12 bits set to 0, this check is done 22862306a36Sopenharmony_ci * so that two spt pages address can be stored per 8bytes 22962306a36Sopenharmony_ci * of CMEM (PPT) 23062306a36Sopenharmony_ci */ 23162306a36Sopenharmony_ci#define ATH12K_SPT_4K_ALIGN_CHECK 0xFFF 23262306a36Sopenharmony_ci#define ATH12K_SPT_4K_ALIGN_OFFSET 12 23362306a36Sopenharmony_ci#define ATH12K_PPT_ADDR_OFFSET(ppt_index) (4 * (ppt_index)) 23462306a36Sopenharmony_ci 23562306a36Sopenharmony_ci/* To indicate HW of CMEM address, b0-31 are cmem base received via QMI */ 23662306a36Sopenharmony_ci#define ATH12K_CMEM_ADDR_MSB 0x10 23762306a36Sopenharmony_ci 23862306a36Sopenharmony_ci/* Of 20 bits cookie, b0-b8 is to indicate SPT offset and b9-19 for PPT */ 23962306a36Sopenharmony_ci#define ATH12K_CC_SPT_MSB 8 24062306a36Sopenharmony_ci#define ATH12K_CC_PPT_MSB 19 24162306a36Sopenharmony_ci#define ATH12K_CC_PPT_SHIFT 9 24262306a36Sopenharmony_ci#define ATH12k_DP_CC_COOKIE_SPT GENMASK(8, 0) 24362306a36Sopenharmony_ci#define ATH12K_DP_CC_COOKIE_PPT GENMASK(19, 9) 24462306a36Sopenharmony_ci 24562306a36Sopenharmony_ci#define DP_REO_QREF_NUM GENMASK(31, 16) 24662306a36Sopenharmony_ci#define DP_MAX_PEER_ID 2047 24762306a36Sopenharmony_ci 24862306a36Sopenharmony_ci/* Total size of the LUT is based on 2K peers, each having reference 24962306a36Sopenharmony_ci * for 17tids, note each entry is of type ath12k_reo_queue_ref 25062306a36Sopenharmony_ci * hence total size is 2048 * 17 * 8 = 278528 25162306a36Sopenharmony_ci */ 25262306a36Sopenharmony_ci#define DP_REOQ_LUT_SIZE 278528 25362306a36Sopenharmony_ci 25462306a36Sopenharmony_ci/* Invalid TX Bank ID value */ 25562306a36Sopenharmony_ci#define DP_INVALID_BANK_ID -1 25662306a36Sopenharmony_ci 25762306a36Sopenharmony_cistruct ath12k_dp_tx_bank_profile { 25862306a36Sopenharmony_ci u8 is_configured; 25962306a36Sopenharmony_ci u32 num_users; 26062306a36Sopenharmony_ci u32 bank_config; 26162306a36Sopenharmony_ci}; 26262306a36Sopenharmony_ci 26362306a36Sopenharmony_cistruct ath12k_hp_update_timer { 26462306a36Sopenharmony_ci struct timer_list timer; 26562306a36Sopenharmony_ci bool started; 26662306a36Sopenharmony_ci bool init; 26762306a36Sopenharmony_ci u32 tx_num; 26862306a36Sopenharmony_ci u32 timer_tx_num; 26962306a36Sopenharmony_ci u32 ring_id; 27062306a36Sopenharmony_ci u32 interval; 27162306a36Sopenharmony_ci struct ath12k_base *ab; 27262306a36Sopenharmony_ci}; 27362306a36Sopenharmony_ci 27462306a36Sopenharmony_cistruct ath12k_rx_desc_info { 27562306a36Sopenharmony_ci struct list_head list; 27662306a36Sopenharmony_ci struct sk_buff *skb; 27762306a36Sopenharmony_ci u32 cookie; 27862306a36Sopenharmony_ci u32 magic; 27962306a36Sopenharmony_ci}; 28062306a36Sopenharmony_ci 28162306a36Sopenharmony_cistruct ath12k_tx_desc_info { 28262306a36Sopenharmony_ci struct list_head list; 28362306a36Sopenharmony_ci struct sk_buff *skb; 28462306a36Sopenharmony_ci u32 desc_id; /* Cookie */ 28562306a36Sopenharmony_ci u8 mac_id; 28662306a36Sopenharmony_ci u8 pool_id; 28762306a36Sopenharmony_ci}; 28862306a36Sopenharmony_ci 28962306a36Sopenharmony_cistruct ath12k_spt_info { 29062306a36Sopenharmony_ci dma_addr_t paddr; 29162306a36Sopenharmony_ci u64 *vaddr; 29262306a36Sopenharmony_ci struct ath12k_rx_desc_info *rxbaddr[ATH12K_NUM_RX_SPT_PAGES]; 29362306a36Sopenharmony_ci struct ath12k_tx_desc_info *txbaddr[ATH12K_NUM_TX_SPT_PAGES]; 29462306a36Sopenharmony_ci}; 29562306a36Sopenharmony_ci 29662306a36Sopenharmony_cistruct ath12k_reo_queue_ref { 29762306a36Sopenharmony_ci u32 info0; 29862306a36Sopenharmony_ci u32 info1; 29962306a36Sopenharmony_ci} __packed; 30062306a36Sopenharmony_ci 30162306a36Sopenharmony_cistruct ath12k_reo_q_addr_lut { 30262306a36Sopenharmony_ci dma_addr_t paddr; 30362306a36Sopenharmony_ci u32 *vaddr; 30462306a36Sopenharmony_ci}; 30562306a36Sopenharmony_ci 30662306a36Sopenharmony_cistruct ath12k_dp { 30762306a36Sopenharmony_ci struct ath12k_base *ab; 30862306a36Sopenharmony_ci u8 num_bank_profiles; 30962306a36Sopenharmony_ci /* protects the access and update of bank_profiles */ 31062306a36Sopenharmony_ci spinlock_t tx_bank_lock; 31162306a36Sopenharmony_ci struct ath12k_dp_tx_bank_profile *bank_profiles; 31262306a36Sopenharmony_ci enum ath12k_htc_ep_id eid; 31362306a36Sopenharmony_ci struct completion htt_tgt_version_received; 31462306a36Sopenharmony_ci u8 htt_tgt_ver_major; 31562306a36Sopenharmony_ci u8 htt_tgt_ver_minor; 31662306a36Sopenharmony_ci struct dp_link_desc_bank link_desc_banks[DP_LINK_DESC_BANKS_MAX]; 31762306a36Sopenharmony_ci struct dp_srng wbm_idle_ring; 31862306a36Sopenharmony_ci struct dp_srng wbm_desc_rel_ring; 31962306a36Sopenharmony_ci struct dp_srng tcl_cmd_ring; 32062306a36Sopenharmony_ci struct dp_srng tcl_status_ring; 32162306a36Sopenharmony_ci struct dp_srng reo_reinject_ring; 32262306a36Sopenharmony_ci struct dp_srng rx_rel_ring; 32362306a36Sopenharmony_ci struct dp_srng reo_except_ring; 32462306a36Sopenharmony_ci struct dp_srng reo_cmd_ring; 32562306a36Sopenharmony_ci struct dp_srng reo_status_ring; 32662306a36Sopenharmony_ci struct dp_srng reo_dst_ring[DP_REO_DST_RING_MAX]; 32762306a36Sopenharmony_ci struct dp_tx_ring tx_ring[DP_TCL_NUM_RING_MAX]; 32862306a36Sopenharmony_ci struct hal_wbm_idle_scatter_list scatter_list[DP_IDLE_SCATTER_BUFS_MAX]; 32962306a36Sopenharmony_ci struct list_head reo_cmd_list; 33062306a36Sopenharmony_ci struct list_head reo_cmd_cache_flush_list; 33162306a36Sopenharmony_ci u32 reo_cmd_cache_flush_count; 33262306a36Sopenharmony_ci 33362306a36Sopenharmony_ci /* protects access to below fields, 33462306a36Sopenharmony_ci * - reo_cmd_list 33562306a36Sopenharmony_ci * - reo_cmd_cache_flush_list 33662306a36Sopenharmony_ci * - reo_cmd_cache_flush_count 33762306a36Sopenharmony_ci */ 33862306a36Sopenharmony_ci spinlock_t reo_cmd_lock; 33962306a36Sopenharmony_ci struct ath12k_hp_update_timer reo_cmd_timer; 34062306a36Sopenharmony_ci struct ath12k_hp_update_timer tx_ring_timer[DP_TCL_NUM_RING_MAX]; 34162306a36Sopenharmony_ci struct ath12k_spt_info *spt_info; 34262306a36Sopenharmony_ci u32 num_spt_pages; 34362306a36Sopenharmony_ci struct list_head rx_desc_free_list; 34462306a36Sopenharmony_ci struct list_head rx_desc_used_list; 34562306a36Sopenharmony_ci /* protects the free and used desc list */ 34662306a36Sopenharmony_ci spinlock_t rx_desc_lock; 34762306a36Sopenharmony_ci 34862306a36Sopenharmony_ci struct list_head tx_desc_free_list[ATH12K_HW_MAX_QUEUES]; 34962306a36Sopenharmony_ci struct list_head tx_desc_used_list[ATH12K_HW_MAX_QUEUES]; 35062306a36Sopenharmony_ci /* protects the free and used desc lists */ 35162306a36Sopenharmony_ci spinlock_t tx_desc_lock[ATH12K_HW_MAX_QUEUES]; 35262306a36Sopenharmony_ci 35362306a36Sopenharmony_ci struct dp_rxdma_ring rx_refill_buf_ring; 35462306a36Sopenharmony_ci struct dp_srng rx_mac_buf_ring[MAX_RXDMA_PER_PDEV]; 35562306a36Sopenharmony_ci struct dp_srng rxdma_err_dst_ring[MAX_RXDMA_PER_PDEV]; 35662306a36Sopenharmony_ci struct dp_rxdma_ring rxdma_mon_buf_ring; 35762306a36Sopenharmony_ci struct dp_rxdma_ring tx_mon_buf_ring; 35862306a36Sopenharmony_ci struct ath12k_reo_q_addr_lut reoq_lut; 35962306a36Sopenharmony_ci}; 36062306a36Sopenharmony_ci 36162306a36Sopenharmony_ci/* HTT definitions */ 36262306a36Sopenharmony_ci 36362306a36Sopenharmony_ci#define HTT_TCL_META_DATA_TYPE BIT(0) 36462306a36Sopenharmony_ci#define HTT_TCL_META_DATA_VALID_HTT BIT(1) 36562306a36Sopenharmony_ci 36662306a36Sopenharmony_ci/* vdev meta data */ 36762306a36Sopenharmony_ci#define HTT_TCL_META_DATA_VDEV_ID GENMASK(9, 2) 36862306a36Sopenharmony_ci#define HTT_TCL_META_DATA_PDEV_ID GENMASK(11, 10) 36962306a36Sopenharmony_ci#define HTT_TCL_META_DATA_HOST_INSPECTED BIT(12) 37062306a36Sopenharmony_ci 37162306a36Sopenharmony_ci/* peer meta data */ 37262306a36Sopenharmony_ci#define HTT_TCL_META_DATA_PEER_ID GENMASK(15, 2) 37362306a36Sopenharmony_ci 37462306a36Sopenharmony_ci#define HTT_TX_WBM_COMP_STATUS_OFFSET 8 37562306a36Sopenharmony_ci 37662306a36Sopenharmony_ci/* HTT tx completion is overlaid in wbm_release_ring */ 37762306a36Sopenharmony_ci#define HTT_TX_WBM_COMP_INFO0_STATUS GENMASK(16, 13) 37862306a36Sopenharmony_ci#define HTT_TX_WBM_COMP_INFO1_REINJECT_REASON GENMASK(3, 0) 37962306a36Sopenharmony_ci#define HTT_TX_WBM_COMP_INFO1_EXCEPTION_FRAME BIT(4) 38062306a36Sopenharmony_ci 38162306a36Sopenharmony_ci#define HTT_TX_WBM_COMP_INFO2_ACK_RSSI GENMASK(31, 24) 38262306a36Sopenharmony_ci 38362306a36Sopenharmony_cistruct htt_tx_wbm_completion { 38462306a36Sopenharmony_ci __le32 rsvd0[2]; 38562306a36Sopenharmony_ci __le32 info0; 38662306a36Sopenharmony_ci __le32 info1; 38762306a36Sopenharmony_ci __le32 info2; 38862306a36Sopenharmony_ci __le32 info3; 38962306a36Sopenharmony_ci __le32 info4; 39062306a36Sopenharmony_ci __le32 rsvd1; 39162306a36Sopenharmony_ci 39262306a36Sopenharmony_ci} __packed; 39362306a36Sopenharmony_ci 39462306a36Sopenharmony_cienum htt_h2t_msg_type { 39562306a36Sopenharmony_ci HTT_H2T_MSG_TYPE_VERSION_REQ = 0, 39662306a36Sopenharmony_ci HTT_H2T_MSG_TYPE_SRING_SETUP = 0xb, 39762306a36Sopenharmony_ci HTT_H2T_MSG_TYPE_RX_RING_SELECTION_CFG = 0xc, 39862306a36Sopenharmony_ci HTT_H2T_MSG_TYPE_EXT_STATS_CFG = 0x10, 39962306a36Sopenharmony_ci HTT_H2T_MSG_TYPE_PPDU_STATS_CFG = 0x11, 40062306a36Sopenharmony_ci HTT_H2T_MSG_TYPE_VDEV_TXRX_STATS_CFG = 0x1a, 40162306a36Sopenharmony_ci HTT_H2T_MSG_TYPE_TX_MONITOR_CFG = 0x1b, 40262306a36Sopenharmony_ci}; 40362306a36Sopenharmony_ci 40462306a36Sopenharmony_ci#define HTT_VER_REQ_INFO_MSG_ID GENMASK(7, 0) 40562306a36Sopenharmony_ci 40662306a36Sopenharmony_cistruct htt_ver_req_cmd { 40762306a36Sopenharmony_ci __le32 ver_reg_info; 40862306a36Sopenharmony_ci} __packed; 40962306a36Sopenharmony_ci 41062306a36Sopenharmony_cienum htt_srng_ring_type { 41162306a36Sopenharmony_ci HTT_HW_TO_SW_RING, 41262306a36Sopenharmony_ci HTT_SW_TO_HW_RING, 41362306a36Sopenharmony_ci HTT_SW_TO_SW_RING, 41462306a36Sopenharmony_ci}; 41562306a36Sopenharmony_ci 41662306a36Sopenharmony_cienum htt_srng_ring_id { 41762306a36Sopenharmony_ci HTT_RXDMA_HOST_BUF_RING, 41862306a36Sopenharmony_ci HTT_RXDMA_MONITOR_STATUS_RING, 41962306a36Sopenharmony_ci HTT_RXDMA_MONITOR_BUF_RING, 42062306a36Sopenharmony_ci HTT_RXDMA_MONITOR_DESC_RING, 42162306a36Sopenharmony_ci HTT_RXDMA_MONITOR_DEST_RING, 42262306a36Sopenharmony_ci HTT_HOST1_TO_FW_RXBUF_RING, 42362306a36Sopenharmony_ci HTT_HOST2_TO_FW_RXBUF_RING, 42462306a36Sopenharmony_ci HTT_RXDMA_NON_MONITOR_DEST_RING, 42562306a36Sopenharmony_ci HTT_TX_MON_HOST2MON_BUF_RING, 42662306a36Sopenharmony_ci HTT_TX_MON_MON2HOST_DEST_RING, 42762306a36Sopenharmony_ci}; 42862306a36Sopenharmony_ci 42962306a36Sopenharmony_ci/* host -> target HTT_SRING_SETUP message 43062306a36Sopenharmony_ci * 43162306a36Sopenharmony_ci * After target is booted up, Host can send SRING setup message for 43262306a36Sopenharmony_ci * each host facing LMAC SRING. Target setups up HW registers based 43362306a36Sopenharmony_ci * on setup message and confirms back to Host if response_required is set. 43462306a36Sopenharmony_ci * Host should wait for confirmation message before sending new SRING 43562306a36Sopenharmony_ci * setup message 43662306a36Sopenharmony_ci * 43762306a36Sopenharmony_ci * The message would appear as follows: 43862306a36Sopenharmony_ci * 43962306a36Sopenharmony_ci * |31 24|23 20|19|18 16|15|14 8|7 0| 44062306a36Sopenharmony_ci * |--------------- +-----------------+----------------+------------------| 44162306a36Sopenharmony_ci * | ring_type | ring_id | pdev_id | msg_type | 44262306a36Sopenharmony_ci * |----------------------------------------------------------------------| 44362306a36Sopenharmony_ci * | ring_base_addr_lo | 44462306a36Sopenharmony_ci * |----------------------------------------------------------------------| 44562306a36Sopenharmony_ci * | ring_base_addr_hi | 44662306a36Sopenharmony_ci * |----------------------------------------------------------------------| 44762306a36Sopenharmony_ci * |ring_misc_cfg_flag|ring_entry_size| ring_size | 44862306a36Sopenharmony_ci * |----------------------------------------------------------------------| 44962306a36Sopenharmony_ci * | ring_head_offset32_remote_addr_lo | 45062306a36Sopenharmony_ci * |----------------------------------------------------------------------| 45162306a36Sopenharmony_ci * | ring_head_offset32_remote_addr_hi | 45262306a36Sopenharmony_ci * |----------------------------------------------------------------------| 45362306a36Sopenharmony_ci * | ring_tail_offset32_remote_addr_lo | 45462306a36Sopenharmony_ci * |----------------------------------------------------------------------| 45562306a36Sopenharmony_ci * | ring_tail_offset32_remote_addr_hi | 45662306a36Sopenharmony_ci * |----------------------------------------------------------------------| 45762306a36Sopenharmony_ci * | ring_msi_addr_lo | 45862306a36Sopenharmony_ci * |----------------------------------------------------------------------| 45962306a36Sopenharmony_ci * | ring_msi_addr_hi | 46062306a36Sopenharmony_ci * |----------------------------------------------------------------------| 46162306a36Sopenharmony_ci * | ring_msi_data | 46262306a36Sopenharmony_ci * |----------------------------------------------------------------------| 46362306a36Sopenharmony_ci * | intr_timer_th |IM| intr_batch_counter_th | 46462306a36Sopenharmony_ci * |----------------------------------------------------------------------| 46562306a36Sopenharmony_ci * | reserved |RR|PTCF| intr_low_threshold | 46662306a36Sopenharmony_ci * |----------------------------------------------------------------------| 46762306a36Sopenharmony_ci * Where 46862306a36Sopenharmony_ci * IM = sw_intr_mode 46962306a36Sopenharmony_ci * RR = response_required 47062306a36Sopenharmony_ci * PTCF = prefetch_timer_cfg 47162306a36Sopenharmony_ci * 47262306a36Sopenharmony_ci * The message is interpreted as follows: 47362306a36Sopenharmony_ci * dword0 - b'0:7 - msg_type: This will be set to 47462306a36Sopenharmony_ci * HTT_H2T_MSG_TYPE_SRING_SETUP 47562306a36Sopenharmony_ci * b'8:15 - pdev_id: 47662306a36Sopenharmony_ci * 0 (for rings at SOC/UMAC level), 47762306a36Sopenharmony_ci * 1/2/3 mac id (for rings at LMAC level) 47862306a36Sopenharmony_ci * b'16:23 - ring_id: identify which ring is to setup, 47962306a36Sopenharmony_ci * more details can be got from enum htt_srng_ring_id 48062306a36Sopenharmony_ci * b'24:31 - ring_type: identify type of host rings, 48162306a36Sopenharmony_ci * more details can be got from enum htt_srng_ring_type 48262306a36Sopenharmony_ci * dword1 - b'0:31 - ring_base_addr_lo: Lower 32bits of ring base address 48362306a36Sopenharmony_ci * dword2 - b'0:31 - ring_base_addr_hi: Upper 32bits of ring base address 48462306a36Sopenharmony_ci * dword3 - b'0:15 - ring_size: size of the ring in unit of 4-bytes words 48562306a36Sopenharmony_ci * b'16:23 - ring_entry_size: Size of each entry in 4-byte word units 48662306a36Sopenharmony_ci * b'24:31 - ring_misc_cfg_flag: Valid only for HW_TO_SW_RING and 48762306a36Sopenharmony_ci * SW_TO_HW_RING. 48862306a36Sopenharmony_ci * Refer to HTT_SRING_SETUP_RING_MISC_CFG_RING defs. 48962306a36Sopenharmony_ci * dword4 - b'0:31 - ring_head_off32_remote_addr_lo: 49062306a36Sopenharmony_ci * Lower 32 bits of memory address of the remote variable 49162306a36Sopenharmony_ci * storing the 4-byte word offset that identifies the head 49262306a36Sopenharmony_ci * element within the ring. 49362306a36Sopenharmony_ci * (The head offset variable has type u32.) 49462306a36Sopenharmony_ci * Valid for HW_TO_SW and SW_TO_SW rings. 49562306a36Sopenharmony_ci * dword5 - b'0:31 - ring_head_off32_remote_addr_hi: 49662306a36Sopenharmony_ci * Upper 32 bits of memory address of the remote variable 49762306a36Sopenharmony_ci * storing the 4-byte word offset that identifies the head 49862306a36Sopenharmony_ci * element within the ring. 49962306a36Sopenharmony_ci * (The head offset variable has type u32.) 50062306a36Sopenharmony_ci * Valid for HW_TO_SW and SW_TO_SW rings. 50162306a36Sopenharmony_ci * dword6 - b'0:31 - ring_tail_off32_remote_addr_lo: 50262306a36Sopenharmony_ci * Lower 32 bits of memory address of the remote variable 50362306a36Sopenharmony_ci * storing the 4-byte word offset that identifies the tail 50462306a36Sopenharmony_ci * element within the ring. 50562306a36Sopenharmony_ci * (The tail offset variable has type u32.) 50662306a36Sopenharmony_ci * Valid for HW_TO_SW and SW_TO_SW rings. 50762306a36Sopenharmony_ci * dword7 - b'0:31 - ring_tail_off32_remote_addr_hi: 50862306a36Sopenharmony_ci * Upper 32 bits of memory address of the remote variable 50962306a36Sopenharmony_ci * storing the 4-byte word offset that identifies the tail 51062306a36Sopenharmony_ci * element within the ring. 51162306a36Sopenharmony_ci * (The tail offset variable has type u32.) 51262306a36Sopenharmony_ci * Valid for HW_TO_SW and SW_TO_SW rings. 51362306a36Sopenharmony_ci * dword8 - b'0:31 - ring_msi_addr_lo: Lower 32bits of MSI cfg address 51462306a36Sopenharmony_ci * valid only for HW_TO_SW_RING and SW_TO_HW_RING 51562306a36Sopenharmony_ci * dword9 - b'0:31 - ring_msi_addr_hi: Upper 32bits of MSI cfg address 51662306a36Sopenharmony_ci * valid only for HW_TO_SW_RING and SW_TO_HW_RING 51762306a36Sopenharmony_ci * dword10 - b'0:31 - ring_msi_data: MSI data 51862306a36Sopenharmony_ci * Refer to HTT_SRING_SETUP_RING_MSC_CFG_xxx defs 51962306a36Sopenharmony_ci * valid only for HW_TO_SW_RING and SW_TO_HW_RING 52062306a36Sopenharmony_ci * dword11 - b'0:14 - intr_batch_counter_th: 52162306a36Sopenharmony_ci * batch counter threshold is in units of 4-byte words. 52262306a36Sopenharmony_ci * HW internally maintains and increments batch count. 52362306a36Sopenharmony_ci * (see SRING spec for detail description). 52462306a36Sopenharmony_ci * When batch count reaches threshold value, an interrupt 52562306a36Sopenharmony_ci * is generated by HW. 52662306a36Sopenharmony_ci * b'15 - sw_intr_mode: 52762306a36Sopenharmony_ci * This configuration shall be static. 52862306a36Sopenharmony_ci * Only programmed at power up. 52962306a36Sopenharmony_ci * 0: generate pulse style sw interrupts 53062306a36Sopenharmony_ci * 1: generate level style sw interrupts 53162306a36Sopenharmony_ci * b'16:31 - intr_timer_th: 53262306a36Sopenharmony_ci * The timer init value when timer is idle or is 53362306a36Sopenharmony_ci * initialized to start downcounting. 53462306a36Sopenharmony_ci * In 8us units (to cover a range of 0 to 524 ms) 53562306a36Sopenharmony_ci * dword12 - b'0:15 - intr_low_threshold: 53662306a36Sopenharmony_ci * Used only by Consumer ring to generate ring_sw_int_p. 53762306a36Sopenharmony_ci * Ring entries low threshold water mark, that is used 53862306a36Sopenharmony_ci * in combination with the interrupt timer as well as 53962306a36Sopenharmony_ci * the clearing of the level interrupt. 54062306a36Sopenharmony_ci * b'16:18 - prefetch_timer_cfg: 54162306a36Sopenharmony_ci * Used only by Consumer ring to set timer mode to 54262306a36Sopenharmony_ci * support Application prefetch handling. 54362306a36Sopenharmony_ci * The external tail offset/pointer will be updated 54462306a36Sopenharmony_ci * at following intervals: 54562306a36Sopenharmony_ci * 3'b000: (Prefetch feature disabled; used only for debug) 54662306a36Sopenharmony_ci * 3'b001: 1 usec 54762306a36Sopenharmony_ci * 3'b010: 4 usec 54862306a36Sopenharmony_ci * 3'b011: 8 usec (default) 54962306a36Sopenharmony_ci * 3'b100: 16 usec 55062306a36Sopenharmony_ci * Others: Reserved 55162306a36Sopenharmony_ci * b'19 - response_required: 55262306a36Sopenharmony_ci * Host needs HTT_T2H_MSG_TYPE_SRING_SETUP_DONE as response 55362306a36Sopenharmony_ci * b'20:31 - reserved: reserved for future use 55462306a36Sopenharmony_ci */ 55562306a36Sopenharmony_ci 55662306a36Sopenharmony_ci#define HTT_SRNG_SETUP_CMD_INFO0_MSG_TYPE GENMASK(7, 0) 55762306a36Sopenharmony_ci#define HTT_SRNG_SETUP_CMD_INFO0_PDEV_ID GENMASK(15, 8) 55862306a36Sopenharmony_ci#define HTT_SRNG_SETUP_CMD_INFO0_RING_ID GENMASK(23, 16) 55962306a36Sopenharmony_ci#define HTT_SRNG_SETUP_CMD_INFO0_RING_TYPE GENMASK(31, 24) 56062306a36Sopenharmony_ci 56162306a36Sopenharmony_ci#define HTT_SRNG_SETUP_CMD_INFO1_RING_SIZE GENMASK(15, 0) 56262306a36Sopenharmony_ci#define HTT_SRNG_SETUP_CMD_INFO1_RING_ENTRY_SIZE GENMASK(23, 16) 56362306a36Sopenharmony_ci#define HTT_SRNG_SETUP_CMD_INFO1_RING_LOOP_CNT_DIS BIT(25) 56462306a36Sopenharmony_ci#define HTT_SRNG_SETUP_CMD_INFO1_RING_FLAGS_MSI_SWAP BIT(27) 56562306a36Sopenharmony_ci#define HTT_SRNG_SETUP_CMD_INFO1_RING_FLAGS_HOST_FW_SWAP BIT(28) 56662306a36Sopenharmony_ci#define HTT_SRNG_SETUP_CMD_INFO1_RING_FLAGS_TLV_SWAP BIT(29) 56762306a36Sopenharmony_ci 56862306a36Sopenharmony_ci#define HTT_SRNG_SETUP_CMD_INTR_INFO_BATCH_COUNTER_THRESH GENMASK(14, 0) 56962306a36Sopenharmony_ci#define HTT_SRNG_SETUP_CMD_INTR_INFO_SW_INTR_MODE BIT(15) 57062306a36Sopenharmony_ci#define HTT_SRNG_SETUP_CMD_INTR_INFO_INTR_TIMER_THRESH GENMASK(31, 16) 57162306a36Sopenharmony_ci 57262306a36Sopenharmony_ci#define HTT_SRNG_SETUP_CMD_INFO2_INTR_LOW_THRESH GENMASK(15, 0) 57362306a36Sopenharmony_ci#define HTT_SRNG_SETUP_CMD_INFO2_PRE_FETCH_TIMER_CFG GENMASK(18, 16) 57462306a36Sopenharmony_ci#define HTT_SRNG_SETUP_CMD_INFO2_RESPONSE_REQUIRED BIT(19) 57562306a36Sopenharmony_ci 57662306a36Sopenharmony_cistruct htt_srng_setup_cmd { 57762306a36Sopenharmony_ci __le32 info0; 57862306a36Sopenharmony_ci __le32 ring_base_addr_lo; 57962306a36Sopenharmony_ci __le32 ring_base_addr_hi; 58062306a36Sopenharmony_ci __le32 info1; 58162306a36Sopenharmony_ci __le32 ring_head_off32_remote_addr_lo; 58262306a36Sopenharmony_ci __le32 ring_head_off32_remote_addr_hi; 58362306a36Sopenharmony_ci __le32 ring_tail_off32_remote_addr_lo; 58462306a36Sopenharmony_ci __le32 ring_tail_off32_remote_addr_hi; 58562306a36Sopenharmony_ci __le32 ring_msi_addr_lo; 58662306a36Sopenharmony_ci __le32 ring_msi_addr_hi; 58762306a36Sopenharmony_ci __le32 msi_data; 58862306a36Sopenharmony_ci __le32 intr_info; 58962306a36Sopenharmony_ci __le32 info2; 59062306a36Sopenharmony_ci} __packed; 59162306a36Sopenharmony_ci 59262306a36Sopenharmony_ci/* host -> target FW PPDU_STATS config message 59362306a36Sopenharmony_ci * 59462306a36Sopenharmony_ci * @details 59562306a36Sopenharmony_ci * The following field definitions describe the format of the HTT host 59662306a36Sopenharmony_ci * to target FW for PPDU_STATS_CFG msg. 59762306a36Sopenharmony_ci * The message allows the host to configure the PPDU_STATS_IND messages 59862306a36Sopenharmony_ci * produced by the target. 59962306a36Sopenharmony_ci * 60062306a36Sopenharmony_ci * |31 24|23 16|15 8|7 0| 60162306a36Sopenharmony_ci * |-----------------------------------------------------------| 60262306a36Sopenharmony_ci * | REQ bit mask | pdev_mask | msg type | 60362306a36Sopenharmony_ci * |-----------------------------------------------------------| 60462306a36Sopenharmony_ci * Header fields: 60562306a36Sopenharmony_ci * - MSG_TYPE 60662306a36Sopenharmony_ci * Bits 7:0 60762306a36Sopenharmony_ci * Purpose: identifies this is a req to configure ppdu_stats_ind from target 60862306a36Sopenharmony_ci * Value: 0x11 60962306a36Sopenharmony_ci * - PDEV_MASK 61062306a36Sopenharmony_ci * Bits 8:15 61162306a36Sopenharmony_ci * Purpose: identifies which pdevs this PPDU stats configuration applies to 61262306a36Sopenharmony_ci * Value: This is a overloaded field, refer to usage and interpretation of 61362306a36Sopenharmony_ci * PDEV in interface document. 61462306a36Sopenharmony_ci * Bit 8 : Reserved for SOC stats 61562306a36Sopenharmony_ci * Bit 9 - 15 : Indicates PDEV_MASK in DBDC 61662306a36Sopenharmony_ci * Indicates MACID_MASK in DBS 61762306a36Sopenharmony_ci * - REQ_TLV_BIT_MASK 61862306a36Sopenharmony_ci * Bits 16:31 61962306a36Sopenharmony_ci * Purpose: each set bit indicates the corresponding PPDU stats TLV type 62062306a36Sopenharmony_ci * needs to be included in the target's PPDU_STATS_IND messages. 62162306a36Sopenharmony_ci * Value: refer htt_ppdu_stats_tlv_tag_t <<<??? 62262306a36Sopenharmony_ci * 62362306a36Sopenharmony_ci */ 62462306a36Sopenharmony_ci 62562306a36Sopenharmony_cistruct htt_ppdu_stats_cfg_cmd { 62662306a36Sopenharmony_ci __le32 msg; 62762306a36Sopenharmony_ci} __packed; 62862306a36Sopenharmony_ci 62962306a36Sopenharmony_ci#define HTT_PPDU_STATS_CFG_MSG_TYPE GENMASK(7, 0) 63062306a36Sopenharmony_ci#define HTT_PPDU_STATS_CFG_PDEV_ID GENMASK(15, 8) 63162306a36Sopenharmony_ci#define HTT_PPDU_STATS_CFG_TLV_TYPE_BITMASK GENMASK(31, 16) 63262306a36Sopenharmony_ci 63362306a36Sopenharmony_cienum htt_ppdu_stats_tag_type { 63462306a36Sopenharmony_ci HTT_PPDU_STATS_TAG_COMMON, 63562306a36Sopenharmony_ci HTT_PPDU_STATS_TAG_USR_COMMON, 63662306a36Sopenharmony_ci HTT_PPDU_STATS_TAG_USR_RATE, 63762306a36Sopenharmony_ci HTT_PPDU_STATS_TAG_USR_MPDU_ENQ_BITMAP_64, 63862306a36Sopenharmony_ci HTT_PPDU_STATS_TAG_USR_MPDU_ENQ_BITMAP_256, 63962306a36Sopenharmony_ci HTT_PPDU_STATS_TAG_SCH_CMD_STATUS, 64062306a36Sopenharmony_ci HTT_PPDU_STATS_TAG_USR_COMPLTN_COMMON, 64162306a36Sopenharmony_ci HTT_PPDU_STATS_TAG_USR_COMPLTN_BA_BITMAP_64, 64262306a36Sopenharmony_ci HTT_PPDU_STATS_TAG_USR_COMPLTN_BA_BITMAP_256, 64362306a36Sopenharmony_ci HTT_PPDU_STATS_TAG_USR_COMPLTN_ACK_BA_STATUS, 64462306a36Sopenharmony_ci HTT_PPDU_STATS_TAG_USR_COMPLTN_FLUSH, 64562306a36Sopenharmony_ci HTT_PPDU_STATS_TAG_USR_COMMON_ARRAY, 64662306a36Sopenharmony_ci HTT_PPDU_STATS_TAG_INFO, 64762306a36Sopenharmony_ci HTT_PPDU_STATS_TAG_TX_MGMTCTRL_PAYLOAD, 64862306a36Sopenharmony_ci 64962306a36Sopenharmony_ci /* New TLV's are added above to this line */ 65062306a36Sopenharmony_ci HTT_PPDU_STATS_TAG_MAX, 65162306a36Sopenharmony_ci}; 65262306a36Sopenharmony_ci 65362306a36Sopenharmony_ci#define HTT_PPDU_STATS_TAG_DEFAULT (BIT(HTT_PPDU_STATS_TAG_COMMON) \ 65462306a36Sopenharmony_ci | BIT(HTT_PPDU_STATS_TAG_USR_COMMON) \ 65562306a36Sopenharmony_ci | BIT(HTT_PPDU_STATS_TAG_USR_RATE) \ 65662306a36Sopenharmony_ci | BIT(HTT_PPDU_STATS_TAG_SCH_CMD_STATUS) \ 65762306a36Sopenharmony_ci | BIT(HTT_PPDU_STATS_TAG_USR_COMPLTN_COMMON) \ 65862306a36Sopenharmony_ci | BIT(HTT_PPDU_STATS_TAG_USR_COMPLTN_ACK_BA_STATUS) \ 65962306a36Sopenharmony_ci | BIT(HTT_PPDU_STATS_TAG_USR_COMPLTN_FLUSH) \ 66062306a36Sopenharmony_ci | BIT(HTT_PPDU_STATS_TAG_USR_COMMON_ARRAY)) 66162306a36Sopenharmony_ci 66262306a36Sopenharmony_ci#define HTT_PPDU_STATS_TAG_PKTLOG (BIT(HTT_PPDU_STATS_TAG_USR_MPDU_ENQ_BITMAP_64) | \ 66362306a36Sopenharmony_ci BIT(HTT_PPDU_STATS_TAG_USR_MPDU_ENQ_BITMAP_256) | \ 66462306a36Sopenharmony_ci BIT(HTT_PPDU_STATS_TAG_USR_COMPLTN_BA_BITMAP_64) | \ 66562306a36Sopenharmony_ci BIT(HTT_PPDU_STATS_TAG_USR_COMPLTN_BA_BITMAP_256) | \ 66662306a36Sopenharmony_ci BIT(HTT_PPDU_STATS_TAG_INFO) | \ 66762306a36Sopenharmony_ci BIT(HTT_PPDU_STATS_TAG_TX_MGMTCTRL_PAYLOAD) | \ 66862306a36Sopenharmony_ci HTT_PPDU_STATS_TAG_DEFAULT) 66962306a36Sopenharmony_ci 67062306a36Sopenharmony_cienum htt_stats_internal_ppdu_frametype { 67162306a36Sopenharmony_ci HTT_STATS_PPDU_FTYPE_CTRL, 67262306a36Sopenharmony_ci HTT_STATS_PPDU_FTYPE_DATA, 67362306a36Sopenharmony_ci HTT_STATS_PPDU_FTYPE_BAR, 67462306a36Sopenharmony_ci HTT_STATS_PPDU_FTYPE_MAX 67562306a36Sopenharmony_ci}; 67662306a36Sopenharmony_ci 67762306a36Sopenharmony_ci/* HTT_H2T_MSG_TYPE_RX_RING_SELECTION_CFG Message 67862306a36Sopenharmony_ci * 67962306a36Sopenharmony_ci * details: 68062306a36Sopenharmony_ci * HTT_H2T_MSG_TYPE_RX_RING_SELECTION_CFG message is sent by host to 68162306a36Sopenharmony_ci * configure RXDMA rings. 68262306a36Sopenharmony_ci * The configuration is per ring based and includes both packet subtypes 68362306a36Sopenharmony_ci * and PPDU/MPDU TLVs. 68462306a36Sopenharmony_ci * 68562306a36Sopenharmony_ci * The message would appear as follows: 68662306a36Sopenharmony_ci * 68762306a36Sopenharmony_ci * |31 26|25|24|23 16|15 8|7 0| 68862306a36Sopenharmony_ci * |-----------------+----------------+----------------+---------------| 68962306a36Sopenharmony_ci * | rsvd1 |PS|SS| ring_id | pdev_id | msg_type | 69062306a36Sopenharmony_ci * |-------------------------------------------------------------------| 69162306a36Sopenharmony_ci * | rsvd2 | ring_buffer_size | 69262306a36Sopenharmony_ci * |-------------------------------------------------------------------| 69362306a36Sopenharmony_ci * | packet_type_enable_flags_0 | 69462306a36Sopenharmony_ci * |-------------------------------------------------------------------| 69562306a36Sopenharmony_ci * | packet_type_enable_flags_1 | 69662306a36Sopenharmony_ci * |-------------------------------------------------------------------| 69762306a36Sopenharmony_ci * | packet_type_enable_flags_2 | 69862306a36Sopenharmony_ci * |-------------------------------------------------------------------| 69962306a36Sopenharmony_ci * | packet_type_enable_flags_3 | 70062306a36Sopenharmony_ci * |-------------------------------------------------------------------| 70162306a36Sopenharmony_ci * | tlv_filter_in_flags | 70262306a36Sopenharmony_ci * |-------------------------------------------------------------------| 70362306a36Sopenharmony_ci * Where: 70462306a36Sopenharmony_ci * PS = pkt_swap 70562306a36Sopenharmony_ci * SS = status_swap 70662306a36Sopenharmony_ci * The message is interpreted as follows: 70762306a36Sopenharmony_ci * dword0 - b'0:7 - msg_type: This will be set to 70862306a36Sopenharmony_ci * HTT_H2T_MSG_TYPE_RX_RING_SELECTION_CFG 70962306a36Sopenharmony_ci * b'8:15 - pdev_id: 71062306a36Sopenharmony_ci * 0 (for rings at SOC/UMAC level), 71162306a36Sopenharmony_ci * 1/2/3 mac id (for rings at LMAC level) 71262306a36Sopenharmony_ci * b'16:23 - ring_id : Identify the ring to configure. 71362306a36Sopenharmony_ci * More details can be got from enum htt_srng_ring_id 71462306a36Sopenharmony_ci * b'24 - status_swap: 1 is to swap status TLV 71562306a36Sopenharmony_ci * b'25 - pkt_swap: 1 is to swap packet TLV 71662306a36Sopenharmony_ci * b'26:31 - rsvd1: reserved for future use 71762306a36Sopenharmony_ci * dword1 - b'0:16 - ring_buffer_size: size of buffers referenced by rx ring, 71862306a36Sopenharmony_ci * in byte units. 71962306a36Sopenharmony_ci * Valid only for HW_TO_SW_RING and SW_TO_HW_RING 72062306a36Sopenharmony_ci * - b'16:31 - rsvd2: Reserved for future use 72162306a36Sopenharmony_ci * dword2 - b'0:31 - packet_type_enable_flags_0: 72262306a36Sopenharmony_ci * Enable MGMT packet from 0b0000 to 0b1001 72362306a36Sopenharmony_ci * bits from low to high: FP, MD, MO - 3 bits 72462306a36Sopenharmony_ci * FP: Filter_Pass 72562306a36Sopenharmony_ci * MD: Monitor_Direct 72662306a36Sopenharmony_ci * MO: Monitor_Other 72762306a36Sopenharmony_ci * 10 mgmt subtypes * 3 bits -> 30 bits 72862306a36Sopenharmony_ci * Refer to PKT_TYPE_ENABLE_FLAG0_xxx_MGMT_xxx defs 72962306a36Sopenharmony_ci * dword3 - b'0:31 - packet_type_enable_flags_1: 73062306a36Sopenharmony_ci * Enable MGMT packet from 0b1010 to 0b1111 73162306a36Sopenharmony_ci * bits from low to high: FP, MD, MO - 3 bits 73262306a36Sopenharmony_ci * Refer to PKT_TYPE_ENABLE_FLAG1_xxx_MGMT_xxx defs 73362306a36Sopenharmony_ci * dword4 - b'0:31 - packet_type_enable_flags_2: 73462306a36Sopenharmony_ci * Enable CTRL packet from 0b0000 to 0b1001 73562306a36Sopenharmony_ci * bits from low to high: FP, MD, MO - 3 bits 73662306a36Sopenharmony_ci * Refer to PKT_TYPE_ENABLE_FLAG2_xxx_CTRL_xxx defs 73762306a36Sopenharmony_ci * dword5 - b'0:31 - packet_type_enable_flags_3: 73862306a36Sopenharmony_ci * Enable CTRL packet from 0b1010 to 0b1111, 73962306a36Sopenharmony_ci * MCAST_DATA, UCAST_DATA, NULL_DATA 74062306a36Sopenharmony_ci * bits from low to high: FP, MD, MO - 3 bits 74162306a36Sopenharmony_ci * Refer to PKT_TYPE_ENABLE_FLAG3_xxx_CTRL_xxx defs 74262306a36Sopenharmony_ci * dword6 - b'0:31 - tlv_filter_in_flags: 74362306a36Sopenharmony_ci * Filter in Attention/MPDU/PPDU/Header/User tlvs 74462306a36Sopenharmony_ci * Refer to CFG_TLV_FILTER_IN_FLAG defs 74562306a36Sopenharmony_ci */ 74662306a36Sopenharmony_ci 74762306a36Sopenharmony_ci#define HTT_RX_RING_SELECTION_CFG_CMD_INFO0_MSG_TYPE GENMASK(7, 0) 74862306a36Sopenharmony_ci#define HTT_RX_RING_SELECTION_CFG_CMD_INFO0_PDEV_ID GENMASK(15, 8) 74962306a36Sopenharmony_ci#define HTT_RX_RING_SELECTION_CFG_CMD_INFO0_RING_ID GENMASK(23, 16) 75062306a36Sopenharmony_ci#define HTT_RX_RING_SELECTION_CFG_CMD_INFO0_SS BIT(24) 75162306a36Sopenharmony_ci#define HTT_RX_RING_SELECTION_CFG_CMD_INFO0_PS BIT(25) 75262306a36Sopenharmony_ci#define HTT_RX_RING_SELECTION_CFG_CMD_INFO1_BUF_SIZE GENMASK(15, 0) 75362306a36Sopenharmony_ci#define HTT_RX_RING_SELECTION_CFG_CMD_OFFSET_VALID BIT(26) 75462306a36Sopenharmony_ci 75562306a36Sopenharmony_ci#define HTT_RX_RING_SELECTION_CFG_RX_PACKET_OFFSET GENMASK(15, 0) 75662306a36Sopenharmony_ci#define HTT_RX_RING_SELECTION_CFG_RX_HEADER_OFFSET GENMASK(31, 16) 75762306a36Sopenharmony_ci#define HTT_RX_RING_SELECTION_CFG_RX_MPDU_END_OFFSET GENMASK(15, 0) 75862306a36Sopenharmony_ci#define HTT_RX_RING_SELECTION_CFG_RX_MPDU_START_OFFSET GENMASK(31, 16) 75962306a36Sopenharmony_ci#define HTT_RX_RING_SELECTION_CFG_RX_MSDU_END_OFFSET GENMASK(15, 0) 76062306a36Sopenharmony_ci#define HTT_RX_RING_SELECTION_CFG_RX_MSDU_START_OFFSET GENMASK(31, 16) 76162306a36Sopenharmony_ci#define HTT_RX_RING_SELECTION_CFG_RX_ATTENTION_OFFSET GENMASK(15, 0) 76262306a36Sopenharmony_ci 76362306a36Sopenharmony_cienum htt_rx_filter_tlv_flags { 76462306a36Sopenharmony_ci HTT_RX_FILTER_TLV_FLAGS_MPDU_START = BIT(0), 76562306a36Sopenharmony_ci HTT_RX_FILTER_TLV_FLAGS_MSDU_START = BIT(1), 76662306a36Sopenharmony_ci HTT_RX_FILTER_TLV_FLAGS_RX_PACKET = BIT(2), 76762306a36Sopenharmony_ci HTT_RX_FILTER_TLV_FLAGS_MSDU_END = BIT(3), 76862306a36Sopenharmony_ci HTT_RX_FILTER_TLV_FLAGS_MPDU_END = BIT(4), 76962306a36Sopenharmony_ci HTT_RX_FILTER_TLV_FLAGS_PACKET_HEADER = BIT(5), 77062306a36Sopenharmony_ci HTT_RX_FILTER_TLV_FLAGS_PER_MSDU_HEADER = BIT(6), 77162306a36Sopenharmony_ci HTT_RX_FILTER_TLV_FLAGS_ATTENTION = BIT(7), 77262306a36Sopenharmony_ci HTT_RX_FILTER_TLV_FLAGS_PPDU_START = BIT(8), 77362306a36Sopenharmony_ci HTT_RX_FILTER_TLV_FLAGS_PPDU_END = BIT(9), 77462306a36Sopenharmony_ci HTT_RX_FILTER_TLV_FLAGS_PPDU_END_USER_STATS = BIT(10), 77562306a36Sopenharmony_ci HTT_RX_FILTER_TLV_FLAGS_PPDU_END_USER_STATS_EXT = BIT(11), 77662306a36Sopenharmony_ci HTT_RX_FILTER_TLV_FLAGS_PPDU_END_STATUS_DONE = BIT(12), 77762306a36Sopenharmony_ci}; 77862306a36Sopenharmony_ci 77962306a36Sopenharmony_cienum htt_rx_mgmt_pkt_filter_tlv_flags0 { 78062306a36Sopenharmony_ci HTT_RX_FP_MGMT_PKT_FILTER_TLV_FLAGS0_ASSOC_REQ = BIT(0), 78162306a36Sopenharmony_ci HTT_RX_MD_MGMT_PKT_FILTER_TLV_FLAGS0_ASSOC_REQ = BIT(1), 78262306a36Sopenharmony_ci HTT_RX_MO_MGMT_PKT_FILTER_TLV_FLAGS0_ASSOC_REQ = BIT(2), 78362306a36Sopenharmony_ci HTT_RX_FP_MGMT_PKT_FILTER_TLV_FLAGS0_ASSOC_RESP = BIT(3), 78462306a36Sopenharmony_ci HTT_RX_MD_MGMT_PKT_FILTER_TLV_FLAGS0_ASSOC_RESP = BIT(4), 78562306a36Sopenharmony_ci HTT_RX_MO_MGMT_PKT_FILTER_TLV_FLAGS0_ASSOC_RESP = BIT(5), 78662306a36Sopenharmony_ci HTT_RX_FP_MGMT_PKT_FILTER_TLV_FLAGS0_REASSOC_REQ = BIT(6), 78762306a36Sopenharmony_ci HTT_RX_MD_MGMT_PKT_FILTER_TLV_FLAGS0_REASSOC_REQ = BIT(7), 78862306a36Sopenharmony_ci HTT_RX_MO_MGMT_PKT_FILTER_TLV_FLAGS0_REASSOC_REQ = BIT(8), 78962306a36Sopenharmony_ci HTT_RX_FP_MGMT_PKT_FILTER_TLV_FLAGS0_REASSOC_RESP = BIT(9), 79062306a36Sopenharmony_ci HTT_RX_MD_MGMT_PKT_FILTER_TLV_FLAGS0_REASSOC_RESP = BIT(10), 79162306a36Sopenharmony_ci HTT_RX_MO_MGMT_PKT_FILTER_TLV_FLAGS0_REASSOC_RESP = BIT(11), 79262306a36Sopenharmony_ci HTT_RX_FP_MGMT_PKT_FILTER_TLV_FLAGS0_PROBE_REQ = BIT(12), 79362306a36Sopenharmony_ci HTT_RX_MD_MGMT_PKT_FILTER_TLV_FLAGS0_PROBE_REQ = BIT(13), 79462306a36Sopenharmony_ci HTT_RX_MO_MGMT_PKT_FILTER_TLV_FLAGS0_PROBE_REQ = BIT(14), 79562306a36Sopenharmony_ci HTT_RX_FP_MGMT_PKT_FILTER_TLV_FLAGS0_PROBE_RESP = BIT(15), 79662306a36Sopenharmony_ci HTT_RX_MD_MGMT_PKT_FILTER_TLV_FLAGS0_PROBE_RESP = BIT(16), 79762306a36Sopenharmony_ci HTT_RX_MO_MGMT_PKT_FILTER_TLV_FLAGS0_PROBE_RESP = BIT(17), 79862306a36Sopenharmony_ci HTT_RX_FP_MGMT_PKT_FILTER_TLV_FLAGS0_PROBE_TIMING_ADV = BIT(18), 79962306a36Sopenharmony_ci HTT_RX_MD_MGMT_PKT_FILTER_TLV_FLAGS0_PROBE_TIMING_ADV = BIT(19), 80062306a36Sopenharmony_ci HTT_RX_MO_MGMT_PKT_FILTER_TLV_FLAGS0_PROBE_TIMING_ADV = BIT(20), 80162306a36Sopenharmony_ci HTT_RX_FP_MGMT_PKT_FILTER_TLV_FLAGS0_RESERVED_7 = BIT(21), 80262306a36Sopenharmony_ci HTT_RX_MD_MGMT_PKT_FILTER_TLV_FLAGS0_RESERVED_7 = BIT(22), 80362306a36Sopenharmony_ci HTT_RX_MO_MGMT_PKT_FILTER_TLV_FLAGS0_RESERVED_7 = BIT(23), 80462306a36Sopenharmony_ci HTT_RX_FP_MGMT_PKT_FILTER_TLV_FLAGS0_BEACON = BIT(24), 80562306a36Sopenharmony_ci HTT_RX_MD_MGMT_PKT_FILTER_TLV_FLAGS0_BEACON = BIT(25), 80662306a36Sopenharmony_ci HTT_RX_MO_MGMT_PKT_FILTER_TLV_FLAGS0_BEACON = BIT(26), 80762306a36Sopenharmony_ci HTT_RX_FP_MGMT_PKT_FILTER_TLV_FLAGS0_ATIM = BIT(27), 80862306a36Sopenharmony_ci HTT_RX_MD_MGMT_PKT_FILTER_TLV_FLAGS0_ATIM = BIT(28), 80962306a36Sopenharmony_ci HTT_RX_MO_MGMT_PKT_FILTER_TLV_FLAGS0_ATIM = BIT(29), 81062306a36Sopenharmony_ci}; 81162306a36Sopenharmony_ci 81262306a36Sopenharmony_cienum htt_rx_mgmt_pkt_filter_tlv_flags1 { 81362306a36Sopenharmony_ci HTT_RX_FP_MGMT_PKT_FILTER_TLV_FLAGS1_DISASSOC = BIT(0), 81462306a36Sopenharmony_ci HTT_RX_MD_MGMT_PKT_FILTER_TLV_FLAGS1_DISASSOC = BIT(1), 81562306a36Sopenharmony_ci HTT_RX_MO_MGMT_PKT_FILTER_TLV_FLAGS1_DISASSOC = BIT(2), 81662306a36Sopenharmony_ci HTT_RX_FP_MGMT_PKT_FILTER_TLV_FLAGS1_AUTH = BIT(3), 81762306a36Sopenharmony_ci HTT_RX_MD_MGMT_PKT_FILTER_TLV_FLAGS1_AUTH = BIT(4), 81862306a36Sopenharmony_ci HTT_RX_MO_MGMT_PKT_FILTER_TLV_FLAGS1_AUTH = BIT(5), 81962306a36Sopenharmony_ci HTT_RX_FP_MGMT_PKT_FILTER_TLV_FLAGS1_DEAUTH = BIT(6), 82062306a36Sopenharmony_ci HTT_RX_MD_MGMT_PKT_FILTER_TLV_FLAGS1_DEAUTH = BIT(7), 82162306a36Sopenharmony_ci HTT_RX_MO_MGMT_PKT_FILTER_TLV_FLAGS1_DEAUTH = BIT(8), 82262306a36Sopenharmony_ci HTT_RX_FP_MGMT_PKT_FILTER_TLV_FLAGS1_ACTION = BIT(9), 82362306a36Sopenharmony_ci HTT_RX_MD_MGMT_PKT_FILTER_TLV_FLAGS1_ACTION = BIT(10), 82462306a36Sopenharmony_ci HTT_RX_MO_MGMT_PKT_FILTER_TLV_FLAGS1_ACTION = BIT(11), 82562306a36Sopenharmony_ci HTT_RX_FP_MGMT_PKT_FILTER_TLV_FLAGS1_ACTION_NOACK = BIT(12), 82662306a36Sopenharmony_ci HTT_RX_MD_MGMT_PKT_FILTER_TLV_FLAGS1_ACTION_NOACK = BIT(13), 82762306a36Sopenharmony_ci HTT_RX_MO_MGMT_PKT_FILTER_TLV_FLAGS1_ACTION_NOACK = BIT(14), 82862306a36Sopenharmony_ci HTT_RX_FP_MGMT_PKT_FILTER_TLV_FLAGS1_RESERVED_15 = BIT(15), 82962306a36Sopenharmony_ci HTT_RX_MD_MGMT_PKT_FILTER_TLV_FLAGS1_RESERVED_15 = BIT(16), 83062306a36Sopenharmony_ci HTT_RX_MO_MGMT_PKT_FILTER_TLV_FLAGS1_RESERVED_15 = BIT(17), 83162306a36Sopenharmony_ci}; 83262306a36Sopenharmony_ci 83362306a36Sopenharmony_cienum htt_rx_ctrl_pkt_filter_tlv_flags2 { 83462306a36Sopenharmony_ci HTT_RX_FP_CTRL_PKT_FILTER_TLV_FLAGS2_CTRL_RESERVED_1 = BIT(0), 83562306a36Sopenharmony_ci HTT_RX_MD_CTRL_PKT_FILTER_TLV_FLAGS2_CTRL_RESERVED_1 = BIT(1), 83662306a36Sopenharmony_ci HTT_RX_MO_CTRL_PKT_FILTER_TLV_FLAGS2_CTRL_RESERVED_1 = BIT(2), 83762306a36Sopenharmony_ci HTT_RX_FP_CTRL_PKT_FILTER_TLV_FLAGS2_CTRL_RESERVED_2 = BIT(3), 83862306a36Sopenharmony_ci HTT_RX_MD_CTRL_PKT_FILTER_TLV_FLAGS2_CTRL_RESERVED_2 = BIT(4), 83962306a36Sopenharmony_ci HTT_RX_MO_CTRL_PKT_FILTER_TLV_FLAGS2_CTRL_RESERVED_2 = BIT(5), 84062306a36Sopenharmony_ci HTT_RX_FP_CTRL_PKT_FILTER_TLV_FLAGS2_CTRL_TRIGGER = BIT(6), 84162306a36Sopenharmony_ci HTT_RX_MD_CTRL_PKT_FILTER_TLV_FLAGS2_CTRL_TRIGGER = BIT(7), 84262306a36Sopenharmony_ci HTT_RX_MO_CTRL_PKT_FILTER_TLV_FLAGS2_CTRL_TRIGGER = BIT(8), 84362306a36Sopenharmony_ci HTT_RX_FP_CTRL_PKT_FILTER_TLV_FLAGS2_CTRL_RESERVED_4 = BIT(9), 84462306a36Sopenharmony_ci HTT_RX_MD_CTRL_PKT_FILTER_TLV_FLAGS2_CTRL_RESERVED_4 = BIT(10), 84562306a36Sopenharmony_ci HTT_RX_MO_CTRL_PKT_FILTER_TLV_FLAGS2_CTRL_RESERVED_4 = BIT(11), 84662306a36Sopenharmony_ci HTT_RX_FP_CTRL_PKT_FILTER_TLV_FLAGS2_CTRL_BF_REP_POLL = BIT(12), 84762306a36Sopenharmony_ci HTT_RX_MD_CTRL_PKT_FILTER_TLV_FLAGS2_CTRL_BF_REP_POLL = BIT(13), 84862306a36Sopenharmony_ci HTT_RX_MO_CTRL_PKT_FILTER_TLV_FLAGS2_CTRL_BF_REP_POLL = BIT(14), 84962306a36Sopenharmony_ci HTT_RX_FP_CTRL_PKT_FILTER_TLV_FLAGS2_CTRL_VHT_NDP = BIT(15), 85062306a36Sopenharmony_ci HTT_RX_MD_CTRL_PKT_FILTER_TLV_FLAGS2_CTRL_VHT_NDP = BIT(16), 85162306a36Sopenharmony_ci HTT_RX_MO_CTRL_PKT_FILTER_TLV_FLAGS2_CTRL_VHT_NDP = BIT(17), 85262306a36Sopenharmony_ci HTT_RX_FP_CTRL_PKT_FILTER_TLV_FLAGS2_CTRL_FRAME_EXT = BIT(18), 85362306a36Sopenharmony_ci HTT_RX_MD_CTRL_PKT_FILTER_TLV_FLAGS2_CTRL_FRAME_EXT = BIT(19), 85462306a36Sopenharmony_ci HTT_RX_MO_CTRL_PKT_FILTER_TLV_FLAGS2_CTRL_FRAME_EXT = BIT(20), 85562306a36Sopenharmony_ci HTT_RX_FP_CTRL_PKT_FILTER_TLV_FLAGS2_CTRL_WRAPPER = BIT(21), 85662306a36Sopenharmony_ci HTT_RX_MD_CTRL_PKT_FILTER_TLV_FLAGS2_CTRL_WRAPPER = BIT(22), 85762306a36Sopenharmony_ci HTT_RX_MO_CTRL_PKT_FILTER_TLV_FLAGS2_CTRL_WRAPPER = BIT(23), 85862306a36Sopenharmony_ci HTT_RX_FP_CTRL_PKT_FILTER_TLV_FLAGS2_BAR = BIT(24), 85962306a36Sopenharmony_ci HTT_RX_MD_CTRL_PKT_FILTER_TLV_FLAGS2_BAR = BIT(25), 86062306a36Sopenharmony_ci HTT_RX_MO_CTRL_PKT_FILTER_TLV_FLAGS2_BAR = BIT(26), 86162306a36Sopenharmony_ci HTT_RX_FP_CTRL_PKT_FILTER_TLV_FLAGS2_BA = BIT(27), 86262306a36Sopenharmony_ci HTT_RX_MD_CTRL_PKT_FILTER_TLV_FLAGS2_BA = BIT(28), 86362306a36Sopenharmony_ci HTT_RX_MO_CTRL_PKT_FILTER_TLV_FLAGS2_BA = BIT(29), 86462306a36Sopenharmony_ci}; 86562306a36Sopenharmony_ci 86662306a36Sopenharmony_cienum htt_rx_ctrl_pkt_filter_tlv_flags3 { 86762306a36Sopenharmony_ci HTT_RX_FP_CTRL_PKT_FILTER_TLV_FLAGS3_PSPOLL = BIT(0), 86862306a36Sopenharmony_ci HTT_RX_MD_CTRL_PKT_FILTER_TLV_FLAGS3_PSPOLL = BIT(1), 86962306a36Sopenharmony_ci HTT_RX_MO_CTRL_PKT_FILTER_TLV_FLAGS3_PSPOLL = BIT(2), 87062306a36Sopenharmony_ci HTT_RX_FP_CTRL_PKT_FILTER_TLV_FLAGS3_RTS = BIT(3), 87162306a36Sopenharmony_ci HTT_RX_MD_CTRL_PKT_FILTER_TLV_FLAGS3_RTS = BIT(4), 87262306a36Sopenharmony_ci HTT_RX_MO_CTRL_PKT_FILTER_TLV_FLAGS3_RTS = BIT(5), 87362306a36Sopenharmony_ci HTT_RX_FP_CTRL_PKT_FILTER_TLV_FLAGS3_CTS = BIT(6), 87462306a36Sopenharmony_ci HTT_RX_MD_CTRL_PKT_FILTER_TLV_FLAGS3_CTS = BIT(7), 87562306a36Sopenharmony_ci HTT_RX_MO_CTRL_PKT_FILTER_TLV_FLAGS3_CTS = BIT(8), 87662306a36Sopenharmony_ci HTT_RX_FP_CTRL_PKT_FILTER_TLV_FLAGS3_ACK = BIT(9), 87762306a36Sopenharmony_ci HTT_RX_MD_CTRL_PKT_FILTER_TLV_FLAGS3_ACK = BIT(10), 87862306a36Sopenharmony_ci HTT_RX_MO_CTRL_PKT_FILTER_TLV_FLAGS3_ACK = BIT(11), 87962306a36Sopenharmony_ci HTT_RX_FP_CTRL_PKT_FILTER_TLV_FLAGS3_CFEND = BIT(12), 88062306a36Sopenharmony_ci HTT_RX_MD_CTRL_PKT_FILTER_TLV_FLAGS3_CFEND = BIT(13), 88162306a36Sopenharmony_ci HTT_RX_MO_CTRL_PKT_FILTER_TLV_FLAGS3_CFEND = BIT(14), 88262306a36Sopenharmony_ci HTT_RX_FP_CTRL_PKT_FILTER_TLV_FLAGS3_CFEND_ACK = BIT(15), 88362306a36Sopenharmony_ci HTT_RX_MD_CTRL_PKT_FILTER_TLV_FLAGS3_CFEND_ACK = BIT(16), 88462306a36Sopenharmony_ci HTT_RX_MO_CTRL_PKT_FILTER_TLV_FLAGS3_CFEND_ACK = BIT(17), 88562306a36Sopenharmony_ci}; 88662306a36Sopenharmony_ci 88762306a36Sopenharmony_cienum htt_rx_data_pkt_filter_tlv_flasg3 { 88862306a36Sopenharmony_ci HTT_RX_FP_DATA_PKT_FILTER_TLV_FLASG3_MCAST = BIT(18), 88962306a36Sopenharmony_ci HTT_RX_MD_DATA_PKT_FILTER_TLV_FLASG3_MCAST = BIT(19), 89062306a36Sopenharmony_ci HTT_RX_MO_DATA_PKT_FILTER_TLV_FLASG3_MCAST = BIT(20), 89162306a36Sopenharmony_ci HTT_RX_FP_DATA_PKT_FILTER_TLV_FLASG3_UCAST = BIT(21), 89262306a36Sopenharmony_ci HTT_RX_MD_DATA_PKT_FILTER_TLV_FLASG3_UCAST = BIT(22), 89362306a36Sopenharmony_ci HTT_RX_MO_DATA_PKT_FILTER_TLV_FLASG3_UCAST = BIT(23), 89462306a36Sopenharmony_ci HTT_RX_FP_DATA_PKT_FILTER_TLV_FLASG3_NULL_DATA = BIT(24), 89562306a36Sopenharmony_ci HTT_RX_MD_DATA_PKT_FILTER_TLV_FLASG3_NULL_DATA = BIT(25), 89662306a36Sopenharmony_ci HTT_RX_MO_DATA_PKT_FILTER_TLV_FLASG3_NULL_DATA = BIT(26), 89762306a36Sopenharmony_ci}; 89862306a36Sopenharmony_ci 89962306a36Sopenharmony_ci#define HTT_RX_FP_MGMT_FILTER_FLAGS0 \ 90062306a36Sopenharmony_ci (HTT_RX_FP_MGMT_PKT_FILTER_TLV_FLAGS0_ASSOC_REQ \ 90162306a36Sopenharmony_ci | HTT_RX_FP_MGMT_PKT_FILTER_TLV_FLAGS0_ASSOC_RESP \ 90262306a36Sopenharmony_ci | HTT_RX_FP_MGMT_PKT_FILTER_TLV_FLAGS0_REASSOC_REQ \ 90362306a36Sopenharmony_ci | HTT_RX_FP_MGMT_PKT_FILTER_TLV_FLAGS0_REASSOC_RESP \ 90462306a36Sopenharmony_ci | HTT_RX_FP_MGMT_PKT_FILTER_TLV_FLAGS0_PROBE_REQ \ 90562306a36Sopenharmony_ci | HTT_RX_FP_MGMT_PKT_FILTER_TLV_FLAGS0_PROBE_RESP \ 90662306a36Sopenharmony_ci | HTT_RX_FP_MGMT_PKT_FILTER_TLV_FLAGS0_PROBE_TIMING_ADV \ 90762306a36Sopenharmony_ci | HTT_RX_FP_MGMT_PKT_FILTER_TLV_FLAGS0_BEACON \ 90862306a36Sopenharmony_ci | HTT_RX_FP_MGMT_PKT_FILTER_TLV_FLAGS0_ATIM) 90962306a36Sopenharmony_ci 91062306a36Sopenharmony_ci#define HTT_RX_MD_MGMT_FILTER_FLAGS0 \ 91162306a36Sopenharmony_ci (HTT_RX_MD_MGMT_PKT_FILTER_TLV_FLAGS0_ASSOC_REQ \ 91262306a36Sopenharmony_ci | HTT_RX_MD_MGMT_PKT_FILTER_TLV_FLAGS0_ASSOC_RESP \ 91362306a36Sopenharmony_ci | HTT_RX_MD_MGMT_PKT_FILTER_TLV_FLAGS0_REASSOC_REQ \ 91462306a36Sopenharmony_ci | HTT_RX_MD_MGMT_PKT_FILTER_TLV_FLAGS0_REASSOC_RESP \ 91562306a36Sopenharmony_ci | HTT_RX_MD_MGMT_PKT_FILTER_TLV_FLAGS0_PROBE_REQ \ 91662306a36Sopenharmony_ci | HTT_RX_MD_MGMT_PKT_FILTER_TLV_FLAGS0_PROBE_RESP \ 91762306a36Sopenharmony_ci | HTT_RX_MD_MGMT_PKT_FILTER_TLV_FLAGS0_PROBE_TIMING_ADV \ 91862306a36Sopenharmony_ci | HTT_RX_MD_MGMT_PKT_FILTER_TLV_FLAGS0_BEACON \ 91962306a36Sopenharmony_ci | HTT_RX_MD_MGMT_PKT_FILTER_TLV_FLAGS0_ATIM) 92062306a36Sopenharmony_ci 92162306a36Sopenharmony_ci#define HTT_RX_MO_MGMT_FILTER_FLAGS0 \ 92262306a36Sopenharmony_ci (HTT_RX_MO_MGMT_PKT_FILTER_TLV_FLAGS0_ASSOC_REQ \ 92362306a36Sopenharmony_ci | HTT_RX_MO_MGMT_PKT_FILTER_TLV_FLAGS0_ASSOC_RESP \ 92462306a36Sopenharmony_ci | HTT_RX_MO_MGMT_PKT_FILTER_TLV_FLAGS0_REASSOC_REQ \ 92562306a36Sopenharmony_ci | HTT_RX_MO_MGMT_PKT_FILTER_TLV_FLAGS0_REASSOC_RESP \ 92662306a36Sopenharmony_ci | HTT_RX_MO_MGMT_PKT_FILTER_TLV_FLAGS0_PROBE_REQ \ 92762306a36Sopenharmony_ci | HTT_RX_MO_MGMT_PKT_FILTER_TLV_FLAGS0_PROBE_RESP \ 92862306a36Sopenharmony_ci | HTT_RX_MO_MGMT_PKT_FILTER_TLV_FLAGS0_PROBE_TIMING_ADV \ 92962306a36Sopenharmony_ci | HTT_RX_MO_MGMT_PKT_FILTER_TLV_FLAGS0_BEACON \ 93062306a36Sopenharmony_ci | HTT_RX_MO_MGMT_PKT_FILTER_TLV_FLAGS0_ATIM) 93162306a36Sopenharmony_ci 93262306a36Sopenharmony_ci#define HTT_RX_FP_MGMT_FILTER_FLAGS1 (HTT_RX_FP_MGMT_PKT_FILTER_TLV_FLAGS1_DISASSOC \ 93362306a36Sopenharmony_ci | HTT_RX_FP_MGMT_PKT_FILTER_TLV_FLAGS1_AUTH \ 93462306a36Sopenharmony_ci | HTT_RX_FP_MGMT_PKT_FILTER_TLV_FLAGS1_DEAUTH \ 93562306a36Sopenharmony_ci | HTT_RX_FP_MGMT_PKT_FILTER_TLV_FLAGS1_ACTION \ 93662306a36Sopenharmony_ci | HTT_RX_FP_MGMT_PKT_FILTER_TLV_FLAGS1_ACTION_NOACK) 93762306a36Sopenharmony_ci 93862306a36Sopenharmony_ci#define HTT_RX_MD_MGMT_FILTER_FLAGS1 (HTT_RX_MD_MGMT_PKT_FILTER_TLV_FLAGS1_DISASSOC \ 93962306a36Sopenharmony_ci | HTT_RX_MD_MGMT_PKT_FILTER_TLV_FLAGS1_AUTH \ 94062306a36Sopenharmony_ci | HTT_RX_MD_MGMT_PKT_FILTER_TLV_FLAGS1_DEAUTH \ 94162306a36Sopenharmony_ci | HTT_RX_MD_MGMT_PKT_FILTER_TLV_FLAGS1_ACTION \ 94262306a36Sopenharmony_ci | HTT_RX_MD_MGMT_PKT_FILTER_TLV_FLAGS1_ACTION_NOACK) 94362306a36Sopenharmony_ci 94462306a36Sopenharmony_ci#define HTT_RX_MO_MGMT_FILTER_FLAGS1 (HTT_RX_MO_MGMT_PKT_FILTER_TLV_FLAGS1_DISASSOC \ 94562306a36Sopenharmony_ci | HTT_RX_MO_MGMT_PKT_FILTER_TLV_FLAGS1_AUTH \ 94662306a36Sopenharmony_ci | HTT_RX_MO_MGMT_PKT_FILTER_TLV_FLAGS1_DEAUTH \ 94762306a36Sopenharmony_ci | HTT_RX_MO_MGMT_PKT_FILTER_TLV_FLAGS1_ACTION \ 94862306a36Sopenharmony_ci | HTT_RX_MO_MGMT_PKT_FILTER_TLV_FLAGS1_ACTION_NOACK) 94962306a36Sopenharmony_ci 95062306a36Sopenharmony_ci#define HTT_RX_FP_CTRL_FILTER_FLASG2 (HTT_RX_FP_CTRL_PKT_FILTER_TLV_FLAGS2_CTRL_WRAPPER \ 95162306a36Sopenharmony_ci | HTT_RX_FP_CTRL_PKT_FILTER_TLV_FLAGS2_BAR \ 95262306a36Sopenharmony_ci | HTT_RX_FP_CTRL_PKT_FILTER_TLV_FLAGS2_BA) 95362306a36Sopenharmony_ci 95462306a36Sopenharmony_ci#define HTT_RX_MD_CTRL_FILTER_FLASG2 (HTT_RX_MD_CTRL_PKT_FILTER_TLV_FLAGS2_CTRL_WRAPPER \ 95562306a36Sopenharmony_ci | HTT_RX_MD_CTRL_PKT_FILTER_TLV_FLAGS2_BAR \ 95662306a36Sopenharmony_ci | HTT_RX_MD_CTRL_PKT_FILTER_TLV_FLAGS2_BA) 95762306a36Sopenharmony_ci 95862306a36Sopenharmony_ci#define HTT_RX_MO_CTRL_FILTER_FLASG2 (HTT_RX_MO_CTRL_PKT_FILTER_TLV_FLAGS2_CTRL_WRAPPER \ 95962306a36Sopenharmony_ci | HTT_RX_MO_CTRL_PKT_FILTER_TLV_FLAGS2_BAR \ 96062306a36Sopenharmony_ci | HTT_RX_MO_CTRL_PKT_FILTER_TLV_FLAGS2_BA) 96162306a36Sopenharmony_ci 96262306a36Sopenharmony_ci#define HTT_RX_FP_CTRL_FILTER_FLASG3 (HTT_RX_FP_CTRL_PKT_FILTER_TLV_FLAGS3_PSPOLL \ 96362306a36Sopenharmony_ci | HTT_RX_FP_CTRL_PKT_FILTER_TLV_FLAGS3_RTS \ 96462306a36Sopenharmony_ci | HTT_RX_FP_CTRL_PKT_FILTER_TLV_FLAGS3_CTS \ 96562306a36Sopenharmony_ci | HTT_RX_FP_CTRL_PKT_FILTER_TLV_FLAGS3_ACK \ 96662306a36Sopenharmony_ci | HTT_RX_FP_CTRL_PKT_FILTER_TLV_FLAGS3_CFEND \ 96762306a36Sopenharmony_ci | HTT_RX_FP_CTRL_PKT_FILTER_TLV_FLAGS3_CFEND_ACK) 96862306a36Sopenharmony_ci 96962306a36Sopenharmony_ci#define HTT_RX_MD_CTRL_FILTER_FLASG3 (HTT_RX_MD_CTRL_PKT_FILTER_TLV_FLAGS3_PSPOLL \ 97062306a36Sopenharmony_ci | HTT_RX_MD_CTRL_PKT_FILTER_TLV_FLAGS3_RTS \ 97162306a36Sopenharmony_ci | HTT_RX_MD_CTRL_PKT_FILTER_TLV_FLAGS3_CTS \ 97262306a36Sopenharmony_ci | HTT_RX_MD_CTRL_PKT_FILTER_TLV_FLAGS3_ACK \ 97362306a36Sopenharmony_ci | HTT_RX_MD_CTRL_PKT_FILTER_TLV_FLAGS3_CFEND \ 97462306a36Sopenharmony_ci | HTT_RX_MD_CTRL_PKT_FILTER_TLV_FLAGS3_CFEND_ACK) 97562306a36Sopenharmony_ci 97662306a36Sopenharmony_ci#define HTT_RX_MO_CTRL_FILTER_FLASG3 (HTT_RX_MO_CTRL_PKT_FILTER_TLV_FLAGS3_PSPOLL \ 97762306a36Sopenharmony_ci | HTT_RX_MO_CTRL_PKT_FILTER_TLV_FLAGS3_RTS \ 97862306a36Sopenharmony_ci | HTT_RX_MO_CTRL_PKT_FILTER_TLV_FLAGS3_CTS \ 97962306a36Sopenharmony_ci | HTT_RX_MO_CTRL_PKT_FILTER_TLV_FLAGS3_ACK \ 98062306a36Sopenharmony_ci | HTT_RX_MO_CTRL_PKT_FILTER_TLV_FLAGS3_CFEND \ 98162306a36Sopenharmony_ci | HTT_RX_MO_CTRL_PKT_FILTER_TLV_FLAGS3_CFEND_ACK) 98262306a36Sopenharmony_ci 98362306a36Sopenharmony_ci#define HTT_RX_FP_DATA_FILTER_FLASG3 (HTT_RX_FP_DATA_PKT_FILTER_TLV_FLASG3_MCAST \ 98462306a36Sopenharmony_ci | HTT_RX_FP_DATA_PKT_FILTER_TLV_FLASG3_UCAST \ 98562306a36Sopenharmony_ci | HTT_RX_FP_DATA_PKT_FILTER_TLV_FLASG3_NULL_DATA) 98662306a36Sopenharmony_ci 98762306a36Sopenharmony_ci#define HTT_RX_MD_DATA_FILTER_FLASG3 (HTT_RX_MD_DATA_PKT_FILTER_TLV_FLASG3_MCAST \ 98862306a36Sopenharmony_ci | HTT_RX_MD_DATA_PKT_FILTER_TLV_FLASG3_UCAST \ 98962306a36Sopenharmony_ci | HTT_RX_MD_DATA_PKT_FILTER_TLV_FLASG3_NULL_DATA) 99062306a36Sopenharmony_ci 99162306a36Sopenharmony_ci#define HTT_RX_MO_DATA_FILTER_FLASG3 (HTT_RX_MO_DATA_PKT_FILTER_TLV_FLASG3_MCAST \ 99262306a36Sopenharmony_ci | HTT_RX_MO_DATA_PKT_FILTER_TLV_FLASG3_UCAST \ 99362306a36Sopenharmony_ci | HTT_RX_MO_DATA_PKT_FILTER_TLV_FLASG3_NULL_DATA) 99462306a36Sopenharmony_ci 99562306a36Sopenharmony_ci#define HTT_RX_MON_FP_MGMT_FILTER_FLAGS0 \ 99662306a36Sopenharmony_ci (HTT_RX_FP_MGMT_FILTER_FLAGS0 | \ 99762306a36Sopenharmony_ci HTT_RX_FP_MGMT_PKT_FILTER_TLV_FLAGS0_RESERVED_7) 99862306a36Sopenharmony_ci 99962306a36Sopenharmony_ci#define HTT_RX_MON_MO_MGMT_FILTER_FLAGS0 \ 100062306a36Sopenharmony_ci (HTT_RX_MO_MGMT_FILTER_FLAGS0 | \ 100162306a36Sopenharmony_ci HTT_RX_MO_MGMT_PKT_FILTER_TLV_FLAGS0_RESERVED_7) 100262306a36Sopenharmony_ci 100362306a36Sopenharmony_ci#define HTT_RX_MON_FP_MGMT_FILTER_FLAGS1 \ 100462306a36Sopenharmony_ci (HTT_RX_FP_MGMT_FILTER_FLAGS1 | \ 100562306a36Sopenharmony_ci HTT_RX_FP_MGMT_PKT_FILTER_TLV_FLAGS1_RESERVED_15) 100662306a36Sopenharmony_ci 100762306a36Sopenharmony_ci#define HTT_RX_MON_MO_MGMT_FILTER_FLAGS1 \ 100862306a36Sopenharmony_ci (HTT_RX_MO_MGMT_FILTER_FLAGS1 | \ 100962306a36Sopenharmony_ci HTT_RX_MO_MGMT_PKT_FILTER_TLV_FLAGS1_RESERVED_15) 101062306a36Sopenharmony_ci 101162306a36Sopenharmony_ci#define HTT_RX_MON_FP_CTRL_FILTER_FLASG2 \ 101262306a36Sopenharmony_ci (HTT_RX_FP_CTRL_FILTER_FLASG2 | \ 101362306a36Sopenharmony_ci HTT_RX_FP_CTRL_PKT_FILTER_TLV_FLAGS2_CTRL_RESERVED_1 | \ 101462306a36Sopenharmony_ci HTT_RX_FP_CTRL_PKT_FILTER_TLV_FLAGS2_CTRL_RESERVED_2 | \ 101562306a36Sopenharmony_ci HTT_RX_FP_CTRL_PKT_FILTER_TLV_FLAGS2_CTRL_TRIGGER | \ 101662306a36Sopenharmony_ci HTT_RX_FP_CTRL_PKT_FILTER_TLV_FLAGS2_CTRL_RESERVED_4 | \ 101762306a36Sopenharmony_ci HTT_RX_FP_CTRL_PKT_FILTER_TLV_FLAGS2_CTRL_BF_REP_POLL | \ 101862306a36Sopenharmony_ci HTT_RX_FP_CTRL_PKT_FILTER_TLV_FLAGS2_CTRL_VHT_NDP | \ 101962306a36Sopenharmony_ci HTT_RX_FP_CTRL_PKT_FILTER_TLV_FLAGS2_CTRL_FRAME_EXT) 102062306a36Sopenharmony_ci 102162306a36Sopenharmony_ci#define HTT_RX_MON_MO_CTRL_FILTER_FLASG2 \ 102262306a36Sopenharmony_ci (HTT_RX_MO_CTRL_FILTER_FLASG2 | \ 102362306a36Sopenharmony_ci HTT_RX_MO_CTRL_PKT_FILTER_TLV_FLAGS2_CTRL_RESERVED_1 | \ 102462306a36Sopenharmony_ci HTT_RX_MO_CTRL_PKT_FILTER_TLV_FLAGS2_CTRL_RESERVED_2 | \ 102562306a36Sopenharmony_ci HTT_RX_MO_CTRL_PKT_FILTER_TLV_FLAGS2_CTRL_TRIGGER | \ 102662306a36Sopenharmony_ci HTT_RX_MO_CTRL_PKT_FILTER_TLV_FLAGS2_CTRL_RESERVED_4 | \ 102762306a36Sopenharmony_ci HTT_RX_MO_CTRL_PKT_FILTER_TLV_FLAGS2_CTRL_BF_REP_POLL | \ 102862306a36Sopenharmony_ci HTT_RX_MO_CTRL_PKT_FILTER_TLV_FLAGS2_CTRL_VHT_NDP | \ 102962306a36Sopenharmony_ci HTT_RX_MO_CTRL_PKT_FILTER_TLV_FLAGS2_CTRL_FRAME_EXT) 103062306a36Sopenharmony_ci 103162306a36Sopenharmony_ci#define HTT_RX_MON_FP_CTRL_FILTER_FLASG3 HTT_RX_FP_CTRL_FILTER_FLASG3 103262306a36Sopenharmony_ci 103362306a36Sopenharmony_ci#define HTT_RX_MON_MO_CTRL_FILTER_FLASG3 HTT_RX_MO_CTRL_FILTER_FLASG3 103462306a36Sopenharmony_ci 103562306a36Sopenharmony_ci#define HTT_RX_MON_FP_DATA_FILTER_FLASG3 HTT_RX_FP_DATA_FILTER_FLASG3 103662306a36Sopenharmony_ci 103762306a36Sopenharmony_ci#define HTT_RX_MON_MO_DATA_FILTER_FLASG3 HTT_RX_MO_DATA_FILTER_FLASG3 103862306a36Sopenharmony_ci 103962306a36Sopenharmony_ci#define HTT_RX_MON_FILTER_TLV_FLAGS \ 104062306a36Sopenharmony_ci (HTT_RX_FILTER_TLV_FLAGS_MPDU_START | \ 104162306a36Sopenharmony_ci HTT_RX_FILTER_TLV_FLAGS_PPDU_START | \ 104262306a36Sopenharmony_ci HTT_RX_FILTER_TLV_FLAGS_PPDU_END | \ 104362306a36Sopenharmony_ci HTT_RX_FILTER_TLV_FLAGS_PPDU_END_USER_STATS | \ 104462306a36Sopenharmony_ci HTT_RX_FILTER_TLV_FLAGS_PPDU_END_USER_STATS_EXT | \ 104562306a36Sopenharmony_ci HTT_RX_FILTER_TLV_FLAGS_PPDU_END_STATUS_DONE) 104662306a36Sopenharmony_ci 104762306a36Sopenharmony_ci#define HTT_RX_MON_FILTER_TLV_FLAGS_MON_STATUS_RING \ 104862306a36Sopenharmony_ci (HTT_RX_FILTER_TLV_FLAGS_MPDU_START | \ 104962306a36Sopenharmony_ci HTT_RX_FILTER_TLV_FLAGS_PPDU_START | \ 105062306a36Sopenharmony_ci HTT_RX_FILTER_TLV_FLAGS_PPDU_END | \ 105162306a36Sopenharmony_ci HTT_RX_FILTER_TLV_FLAGS_PPDU_END_USER_STATS | \ 105262306a36Sopenharmony_ci HTT_RX_FILTER_TLV_FLAGS_PPDU_END_USER_STATS_EXT | \ 105362306a36Sopenharmony_ci HTT_RX_FILTER_TLV_FLAGS_PPDU_END_STATUS_DONE) 105462306a36Sopenharmony_ci 105562306a36Sopenharmony_ci#define HTT_RX_MON_FILTER_TLV_FLAGS_MON_BUF_RING \ 105662306a36Sopenharmony_ci (HTT_RX_FILTER_TLV_FLAGS_MPDU_START | \ 105762306a36Sopenharmony_ci HTT_RX_FILTER_TLV_FLAGS_MSDU_START | \ 105862306a36Sopenharmony_ci HTT_RX_FILTER_TLV_FLAGS_RX_PACKET | \ 105962306a36Sopenharmony_ci HTT_RX_FILTER_TLV_FLAGS_MSDU_END | \ 106062306a36Sopenharmony_ci HTT_RX_FILTER_TLV_FLAGS_MPDU_END | \ 106162306a36Sopenharmony_ci HTT_RX_FILTER_TLV_FLAGS_PACKET_HEADER | \ 106262306a36Sopenharmony_ci HTT_RX_FILTER_TLV_FLAGS_PER_MSDU_HEADER | \ 106362306a36Sopenharmony_ci HTT_RX_FILTER_TLV_FLAGS_ATTENTION) 106462306a36Sopenharmony_ci 106562306a36Sopenharmony_ci/* msdu start. mpdu end, attention, rx hdr tlv's are not subscribed */ 106662306a36Sopenharmony_ci#define HTT_RX_TLV_FLAGS_RXDMA_RING \ 106762306a36Sopenharmony_ci (HTT_RX_FILTER_TLV_FLAGS_MPDU_START | \ 106862306a36Sopenharmony_ci HTT_RX_FILTER_TLV_FLAGS_RX_PACKET | \ 106962306a36Sopenharmony_ci HTT_RX_FILTER_TLV_FLAGS_MSDU_END) 107062306a36Sopenharmony_ci 107162306a36Sopenharmony_ci#define HTT_TX_RING_SELECTION_CFG_CMD_INFO0_MSG_TYPE GENMASK(7, 0) 107262306a36Sopenharmony_ci#define HTT_TX_RING_SELECTION_CFG_CMD_INFO0_PDEV_ID GENMASK(15, 8) 107362306a36Sopenharmony_ci 107462306a36Sopenharmony_cistruct htt_rx_ring_selection_cfg_cmd { 107562306a36Sopenharmony_ci __le32 info0; 107662306a36Sopenharmony_ci __le32 info1; 107762306a36Sopenharmony_ci __le32 pkt_type_en_flags0; 107862306a36Sopenharmony_ci __le32 pkt_type_en_flags1; 107962306a36Sopenharmony_ci __le32 pkt_type_en_flags2; 108062306a36Sopenharmony_ci __le32 pkt_type_en_flags3; 108162306a36Sopenharmony_ci __le32 rx_filter_tlv; 108262306a36Sopenharmony_ci __le32 rx_packet_offset; 108362306a36Sopenharmony_ci __le32 rx_mpdu_offset; 108462306a36Sopenharmony_ci __le32 rx_msdu_offset; 108562306a36Sopenharmony_ci __le32 rx_attn_offset; 108662306a36Sopenharmony_ci} __packed; 108762306a36Sopenharmony_ci 108862306a36Sopenharmony_cistruct htt_rx_ring_tlv_filter { 108962306a36Sopenharmony_ci u32 rx_filter; /* see htt_rx_filter_tlv_flags */ 109062306a36Sopenharmony_ci u32 pkt_filter_flags0; /* MGMT */ 109162306a36Sopenharmony_ci u32 pkt_filter_flags1; /* MGMT */ 109262306a36Sopenharmony_ci u32 pkt_filter_flags2; /* CTRL */ 109362306a36Sopenharmony_ci u32 pkt_filter_flags3; /* DATA */ 109462306a36Sopenharmony_ci bool offset_valid; 109562306a36Sopenharmony_ci u16 rx_packet_offset; 109662306a36Sopenharmony_ci u16 rx_header_offset; 109762306a36Sopenharmony_ci u16 rx_mpdu_end_offset; 109862306a36Sopenharmony_ci u16 rx_mpdu_start_offset; 109962306a36Sopenharmony_ci u16 rx_msdu_end_offset; 110062306a36Sopenharmony_ci u16 rx_msdu_start_offset; 110162306a36Sopenharmony_ci u16 rx_attn_offset; 110262306a36Sopenharmony_ci}; 110362306a36Sopenharmony_ci 110462306a36Sopenharmony_ci#define HTT_STATS_FRAME_CTRL_TYPE_MGMT 0x0 110562306a36Sopenharmony_ci#define HTT_STATS_FRAME_CTRL_TYPE_CTRL 0x1 110662306a36Sopenharmony_ci#define HTT_STATS_FRAME_CTRL_TYPE_DATA 0x2 110762306a36Sopenharmony_ci#define HTT_STATS_FRAME_CTRL_TYPE_RESV 0x3 110862306a36Sopenharmony_ci 110962306a36Sopenharmony_ci#define HTT_TX_RING_SELECTION_CFG_CMD_INFO0_MSG_TYPE GENMASK(7, 0) 111062306a36Sopenharmony_ci#define HTT_TX_RING_SELECTION_CFG_CMD_INFO0_PDEV_ID GENMASK(15, 8) 111162306a36Sopenharmony_ci#define HTT_TX_RING_SELECTION_CFG_CMD_INFO0_RING_ID GENMASK(23, 16) 111262306a36Sopenharmony_ci#define HTT_TX_RING_SELECTION_CFG_CMD_INFO0_SS BIT(24) 111362306a36Sopenharmony_ci#define HTT_TX_RING_SELECTION_CFG_CMD_INFO0_PS BIT(25) 111462306a36Sopenharmony_ci 111562306a36Sopenharmony_ci#define HTT_TX_RING_SELECTION_CFG_CMD_INFO1_RING_BUFF_SIZE GENMASK(15, 0) 111662306a36Sopenharmony_ci#define HTT_TX_RING_SELECTION_CFG_CMD_INFO1_PKT_TYPE GENMASK(18, 16) 111762306a36Sopenharmony_ci#define HTT_TX_RING_SELECTION_CFG_CMD_INFO1_CONF_LEN_MGMT GENMASK(21, 19) 111862306a36Sopenharmony_ci#define HTT_TX_RING_SELECTION_CFG_CMD_INFO1_CONF_LEN_CTRL GENMASK(24, 22) 111962306a36Sopenharmony_ci#define HTT_TX_RING_SELECTION_CFG_CMD_INFO1_CONF_LEN_DATA GENMASK(27, 25) 112062306a36Sopenharmony_ci 112162306a36Sopenharmony_ci#define HTT_TX_RING_SELECTION_CFG_CMD_INFO2_PKT_TYPE_EN_FLAG GENMASK(2, 0) 112262306a36Sopenharmony_ci 112362306a36Sopenharmony_cistruct htt_tx_ring_selection_cfg_cmd { 112462306a36Sopenharmony_ci __le32 info0; 112562306a36Sopenharmony_ci __le32 info1; 112662306a36Sopenharmony_ci __le32 info2; 112762306a36Sopenharmony_ci __le32 tlv_filter_mask_in0; 112862306a36Sopenharmony_ci __le32 tlv_filter_mask_in1; 112962306a36Sopenharmony_ci __le32 tlv_filter_mask_in2; 113062306a36Sopenharmony_ci __le32 tlv_filter_mask_in3; 113162306a36Sopenharmony_ci __le32 reserved[3]; 113262306a36Sopenharmony_ci} __packed; 113362306a36Sopenharmony_ci 113462306a36Sopenharmony_ci#define HTT_TX_RING_TLV_FILTER_MGMT_DMA_LEN GENMASK(3, 0) 113562306a36Sopenharmony_ci#define HTT_TX_RING_TLV_FILTER_CTRL_DMA_LEN GENMASK(7, 4) 113662306a36Sopenharmony_ci#define HTT_TX_RING_TLV_FILTER_DATA_DMA_LEN GENMASK(11, 8) 113762306a36Sopenharmony_ci 113862306a36Sopenharmony_ci#define HTT_TX_MON_FILTER_HYBRID_MODE \ 113962306a36Sopenharmony_ci (HTT_TX_FILTER_TLV_FLAGS0_RESPONSE_START_STATUS | \ 114062306a36Sopenharmony_ci HTT_TX_FILTER_TLV_FLAGS0_RESPONSE_END_STATUS | \ 114162306a36Sopenharmony_ci HTT_TX_FILTER_TLV_FLAGS0_TX_FES_STATUS_START | \ 114262306a36Sopenharmony_ci HTT_TX_FILTER_TLV_FLAGS0_TX_FES_STATUS_END | \ 114362306a36Sopenharmony_ci HTT_TX_FILTER_TLV_FLAGS0_TX_FES_STATUS_START_PPDU | \ 114462306a36Sopenharmony_ci HTT_TX_FILTER_TLV_FLAGS0_TX_FES_STATUS_USER_PPDU | \ 114562306a36Sopenharmony_ci HTT_TX_FILTER_TLV_FLAGS0_TX_FES_STATUS_ACK_OR_BA | \ 114662306a36Sopenharmony_ci HTT_TX_FILTER_TLV_FLAGS0_TX_FES_STATUS_1K_BA | \ 114762306a36Sopenharmony_ci HTT_TX_FILTER_TLV_FLAGS0_TX_FES_STATUS_START_PROT | \ 114862306a36Sopenharmony_ci HTT_TX_FILTER_TLV_FLAGS0_TX_FES_STATUS_PROT | \ 114962306a36Sopenharmony_ci HTT_TX_FILTER_TLV_FLAGS0_TX_FES_STATUS_USER_RESPONSE | \ 115062306a36Sopenharmony_ci HTT_TX_FILTER_TLV_FLAGS0_RECEIVED_RESPONSE_INFO | \ 115162306a36Sopenharmony_ci HTT_TX_FILTER_TLV_FLAGS0_RECEIVED_RESPONSE_INFO_PART2) 115262306a36Sopenharmony_ci 115362306a36Sopenharmony_cistruct htt_tx_ring_tlv_filter { 115462306a36Sopenharmony_ci u32 tx_mon_downstream_tlv_flags; 115562306a36Sopenharmony_ci u32 tx_mon_upstream_tlv_flags0; 115662306a36Sopenharmony_ci u32 tx_mon_upstream_tlv_flags1; 115762306a36Sopenharmony_ci u32 tx_mon_upstream_tlv_flags2; 115862306a36Sopenharmony_ci bool tx_mon_mgmt_filter; 115962306a36Sopenharmony_ci bool tx_mon_data_filter; 116062306a36Sopenharmony_ci bool tx_mon_ctrl_filter; 116162306a36Sopenharmony_ci u16 tx_mon_pkt_dma_len; 116262306a36Sopenharmony_ci} __packed; 116362306a36Sopenharmony_ci 116462306a36Sopenharmony_cienum htt_tx_mon_upstream_tlv_flags0 { 116562306a36Sopenharmony_ci HTT_TX_FILTER_TLV_FLAGS0_RESPONSE_START_STATUS = BIT(1), 116662306a36Sopenharmony_ci HTT_TX_FILTER_TLV_FLAGS0_RESPONSE_END_STATUS = BIT(2), 116762306a36Sopenharmony_ci HTT_TX_FILTER_TLV_FLAGS0_TX_FES_STATUS_START = BIT(3), 116862306a36Sopenharmony_ci HTT_TX_FILTER_TLV_FLAGS0_TX_FES_STATUS_END = BIT(4), 116962306a36Sopenharmony_ci HTT_TX_FILTER_TLV_FLAGS0_TX_FES_STATUS_START_PPDU = BIT(5), 117062306a36Sopenharmony_ci HTT_TX_FILTER_TLV_FLAGS0_TX_FES_STATUS_USER_PPDU = BIT(6), 117162306a36Sopenharmony_ci HTT_TX_FILTER_TLV_FLAGS0_TX_FES_STATUS_ACK_OR_BA = BIT(7), 117262306a36Sopenharmony_ci HTT_TX_FILTER_TLV_FLAGS0_TX_FES_STATUS_1K_BA = BIT(8), 117362306a36Sopenharmony_ci HTT_TX_FILTER_TLV_FLAGS0_TX_FES_STATUS_START_PROT = BIT(9), 117462306a36Sopenharmony_ci HTT_TX_FILTER_TLV_FLAGS0_TX_FES_STATUS_PROT = BIT(10), 117562306a36Sopenharmony_ci HTT_TX_FILTER_TLV_FLAGS0_TX_FES_STATUS_USER_RESPONSE = BIT(11), 117662306a36Sopenharmony_ci HTT_TX_FILTER_TLV_FLAGS0_RX_FRAME_BITMAP_ACK = BIT(12), 117762306a36Sopenharmony_ci HTT_TX_FILTER_TLV_FLAGS0_RX_FRAME_1K_BITMAP_ACK = BIT(13), 117862306a36Sopenharmony_ci HTT_TX_FILTER_TLV_FLAGS0_COEX_TX_STATUS = BIT(14), 117962306a36Sopenharmony_ci HTT_TX_FILTER_TLV_FLAGS0_RECEIVED_RESPONSE_INFO = BIT(15), 118062306a36Sopenharmony_ci HTT_TX_FILTER_TLV_FLAGS0_RECEIVED_RESPONSE_INFO_PART2 = BIT(16), 118162306a36Sopenharmony_ci}; 118262306a36Sopenharmony_ci 118362306a36Sopenharmony_ci#define HTT_TX_FILTER_TLV_FLAGS2_TXPCU_PHYTX_OTHER_TRANSMIT_INFO32 BIT(11) 118462306a36Sopenharmony_ci 118562306a36Sopenharmony_ci/* HTT message target->host */ 118662306a36Sopenharmony_ci 118762306a36Sopenharmony_cienum htt_t2h_msg_type { 118862306a36Sopenharmony_ci HTT_T2H_MSG_TYPE_VERSION_CONF, 118962306a36Sopenharmony_ci HTT_T2H_MSG_TYPE_PEER_MAP = 0x3, 119062306a36Sopenharmony_ci HTT_T2H_MSG_TYPE_PEER_UNMAP = 0x4, 119162306a36Sopenharmony_ci HTT_T2H_MSG_TYPE_RX_ADDBA = 0x5, 119262306a36Sopenharmony_ci HTT_T2H_MSG_TYPE_PKTLOG = 0x8, 119362306a36Sopenharmony_ci HTT_T2H_MSG_TYPE_SEC_IND = 0xb, 119462306a36Sopenharmony_ci HTT_T2H_MSG_TYPE_PEER_MAP2 = 0x1e, 119562306a36Sopenharmony_ci HTT_T2H_MSG_TYPE_PEER_UNMAP2 = 0x1f, 119662306a36Sopenharmony_ci HTT_T2H_MSG_TYPE_PPDU_STATS_IND = 0x1d, 119762306a36Sopenharmony_ci HTT_T2H_MSG_TYPE_EXT_STATS_CONF = 0x1c, 119862306a36Sopenharmony_ci HTT_T2H_MSG_TYPE_BKPRESSURE_EVENT_IND = 0x24, 119962306a36Sopenharmony_ci HTT_T2H_MSG_TYPE_MLO_TIMESTAMP_OFFSET_IND = 0x28, 120062306a36Sopenharmony_ci HTT_T2H_MSG_TYPE_PEER_MAP3 = 0x2b, 120162306a36Sopenharmony_ci HTT_T2H_MSG_TYPE_VDEV_TXRX_STATS_PERIODIC_IND = 0x2c, 120262306a36Sopenharmony_ci}; 120362306a36Sopenharmony_ci 120462306a36Sopenharmony_ci#define HTT_TARGET_VERSION_MAJOR 3 120562306a36Sopenharmony_ci 120662306a36Sopenharmony_ci#define HTT_T2H_MSG_TYPE GENMASK(7, 0) 120762306a36Sopenharmony_ci#define HTT_T2H_VERSION_CONF_MINOR GENMASK(15, 8) 120862306a36Sopenharmony_ci#define HTT_T2H_VERSION_CONF_MAJOR GENMASK(23, 16) 120962306a36Sopenharmony_ci 121062306a36Sopenharmony_cistruct htt_t2h_version_conf_msg { 121162306a36Sopenharmony_ci __le32 version; 121262306a36Sopenharmony_ci} __packed; 121362306a36Sopenharmony_ci 121462306a36Sopenharmony_ci#define HTT_T2H_PEER_MAP_INFO_VDEV_ID GENMASK(15, 8) 121562306a36Sopenharmony_ci#define HTT_T2H_PEER_MAP_INFO_PEER_ID GENMASK(31, 16) 121662306a36Sopenharmony_ci#define HTT_T2H_PEER_MAP_INFO1_MAC_ADDR_H16 GENMASK(15, 0) 121762306a36Sopenharmony_ci#define HTT_T2H_PEER_MAP_INFO1_HW_PEER_ID GENMASK(31, 16) 121862306a36Sopenharmony_ci#define HTT_T2H_PEER_MAP_INFO2_AST_HASH_VAL GENMASK(15, 0) 121962306a36Sopenharmony_ci#define HTT_T2H_PEER_MAP_INFO2_NEXT_HOP_M BIT(16) 122062306a36Sopenharmony_ci#define HTT_T2H_PEER_MAP_INFO2_NEXT_HOP_S 16 122162306a36Sopenharmony_ci 122262306a36Sopenharmony_cistruct htt_t2h_peer_map_event { 122362306a36Sopenharmony_ci __le32 info; 122462306a36Sopenharmony_ci __le32 mac_addr_l32; 122562306a36Sopenharmony_ci __le32 info1; 122662306a36Sopenharmony_ci __le32 info2; 122762306a36Sopenharmony_ci} __packed; 122862306a36Sopenharmony_ci 122962306a36Sopenharmony_ci#define HTT_T2H_PEER_UNMAP_INFO_VDEV_ID HTT_T2H_PEER_MAP_INFO_VDEV_ID 123062306a36Sopenharmony_ci#define HTT_T2H_PEER_UNMAP_INFO_PEER_ID HTT_T2H_PEER_MAP_INFO_PEER_ID 123162306a36Sopenharmony_ci#define HTT_T2H_PEER_UNMAP_INFO1_MAC_ADDR_H16 \ 123262306a36Sopenharmony_ci HTT_T2H_PEER_MAP_INFO1_MAC_ADDR_H16 123362306a36Sopenharmony_ci#define HTT_T2H_PEER_MAP_INFO1_NEXT_HOP_M HTT_T2H_PEER_MAP_INFO2_NEXT_HOP_M 123462306a36Sopenharmony_ci#define HTT_T2H_PEER_MAP_INFO1_NEXT_HOP_S HTT_T2H_PEER_MAP_INFO2_NEXT_HOP_S 123562306a36Sopenharmony_ci 123662306a36Sopenharmony_cistruct htt_t2h_peer_unmap_event { 123762306a36Sopenharmony_ci __le32 info; 123862306a36Sopenharmony_ci __le32 mac_addr_l32; 123962306a36Sopenharmony_ci __le32 info1; 124062306a36Sopenharmony_ci} __packed; 124162306a36Sopenharmony_ci 124262306a36Sopenharmony_cistruct htt_resp_msg { 124362306a36Sopenharmony_ci union { 124462306a36Sopenharmony_ci struct htt_t2h_version_conf_msg version_msg; 124562306a36Sopenharmony_ci struct htt_t2h_peer_map_event peer_map_ev; 124662306a36Sopenharmony_ci struct htt_t2h_peer_unmap_event peer_unmap_ev; 124762306a36Sopenharmony_ci }; 124862306a36Sopenharmony_ci} __packed; 124962306a36Sopenharmony_ci 125062306a36Sopenharmony_ci#define HTT_VDEV_GET_STATS_U64(msg_l32, msg_u32)\ 125162306a36Sopenharmony_ci (((u64)__le32_to_cpu(msg_u32) << 32) | (__le32_to_cpu(msg_l32))) 125262306a36Sopenharmony_ci#define HTT_T2H_VDEV_STATS_PERIODIC_MSG_TYPE GENMASK(7, 0) 125362306a36Sopenharmony_ci#define HTT_T2H_VDEV_STATS_PERIODIC_PDEV_ID GENMASK(15, 8) 125462306a36Sopenharmony_ci#define HTT_T2H_VDEV_STATS_PERIODIC_NUM_VDEV GENMASK(23, 16) 125562306a36Sopenharmony_ci#define HTT_T2H_VDEV_STATS_PERIODIC_PAYLOAD_BYTES GENMASK(15, 0) 125662306a36Sopenharmony_ci#define HTT_VDEV_TXRX_STATS_COMMON_TLV 0 125762306a36Sopenharmony_ci#define HTT_VDEV_TXRX_STATS_HW_STATS_TLV 1 125862306a36Sopenharmony_ci 125962306a36Sopenharmony_cistruct htt_t2h_vdev_txrx_stats_ind { 126062306a36Sopenharmony_ci __le32 vdev_id; 126162306a36Sopenharmony_ci __le32 rx_msdu_byte_cnt_lo; 126262306a36Sopenharmony_ci __le32 rx_msdu_byte_cnt_hi; 126362306a36Sopenharmony_ci __le32 rx_msdu_cnt_lo; 126462306a36Sopenharmony_ci __le32 rx_msdu_cnt_hi; 126562306a36Sopenharmony_ci __le32 tx_msdu_byte_cnt_lo; 126662306a36Sopenharmony_ci __le32 tx_msdu_byte_cnt_hi; 126762306a36Sopenharmony_ci __le32 tx_msdu_cnt_lo; 126862306a36Sopenharmony_ci __le32 tx_msdu_cnt_hi; 126962306a36Sopenharmony_ci __le32 tx_retry_cnt_lo; 127062306a36Sopenharmony_ci __le32 tx_retry_cnt_hi; 127162306a36Sopenharmony_ci __le32 tx_retry_byte_cnt_lo; 127262306a36Sopenharmony_ci __le32 tx_retry_byte_cnt_hi; 127362306a36Sopenharmony_ci __le32 tx_drop_cnt_lo; 127462306a36Sopenharmony_ci __le32 tx_drop_cnt_hi; 127562306a36Sopenharmony_ci __le32 tx_drop_byte_cnt_lo; 127662306a36Sopenharmony_ci __le32 tx_drop_byte_cnt_hi; 127762306a36Sopenharmony_ci __le32 msdu_ttl_cnt_lo; 127862306a36Sopenharmony_ci __le32 msdu_ttl_cnt_hi; 127962306a36Sopenharmony_ci __le32 msdu_ttl_byte_cnt_lo; 128062306a36Sopenharmony_ci __le32 msdu_ttl_byte_cnt_hi; 128162306a36Sopenharmony_ci} __packed; 128262306a36Sopenharmony_ci 128362306a36Sopenharmony_cistruct htt_t2h_vdev_common_stats_tlv { 128462306a36Sopenharmony_ci __le32 soc_drop_count_lo; 128562306a36Sopenharmony_ci __le32 soc_drop_count_hi; 128662306a36Sopenharmony_ci} __packed; 128762306a36Sopenharmony_ci 128862306a36Sopenharmony_ci/* ppdu stats 128962306a36Sopenharmony_ci * 129062306a36Sopenharmony_ci * @details 129162306a36Sopenharmony_ci * The following field definitions describe the format of the HTT target 129262306a36Sopenharmony_ci * to host ppdu stats indication message. 129362306a36Sopenharmony_ci * 129462306a36Sopenharmony_ci * 129562306a36Sopenharmony_ci * |31 16|15 12|11 10|9 8|7 0 | 129662306a36Sopenharmony_ci * |----------------------------------------------------------------------| 129762306a36Sopenharmony_ci * | payload_size | rsvd |pdev_id|mac_id | msg type | 129862306a36Sopenharmony_ci * |----------------------------------------------------------------------| 129962306a36Sopenharmony_ci * | ppdu_id | 130062306a36Sopenharmony_ci * |----------------------------------------------------------------------| 130162306a36Sopenharmony_ci * | Timestamp in us | 130262306a36Sopenharmony_ci * |----------------------------------------------------------------------| 130362306a36Sopenharmony_ci * | reserved | 130462306a36Sopenharmony_ci * |----------------------------------------------------------------------| 130562306a36Sopenharmony_ci * | type-specific stats info | 130662306a36Sopenharmony_ci * | (see htt_ppdu_stats.h) | 130762306a36Sopenharmony_ci * |----------------------------------------------------------------------| 130862306a36Sopenharmony_ci * Header fields: 130962306a36Sopenharmony_ci * - MSG_TYPE 131062306a36Sopenharmony_ci * Bits 7:0 131162306a36Sopenharmony_ci * Purpose: Identifies this is a PPDU STATS indication 131262306a36Sopenharmony_ci * message. 131362306a36Sopenharmony_ci * Value: 0x1d 131462306a36Sopenharmony_ci * - mac_id 131562306a36Sopenharmony_ci * Bits 9:8 131662306a36Sopenharmony_ci * Purpose: mac_id of this ppdu_id 131762306a36Sopenharmony_ci * Value: 0-3 131862306a36Sopenharmony_ci * - pdev_id 131962306a36Sopenharmony_ci * Bits 11:10 132062306a36Sopenharmony_ci * Purpose: pdev_id of this ppdu_id 132162306a36Sopenharmony_ci * Value: 0-3 132262306a36Sopenharmony_ci * 0 (for rings at SOC level), 132362306a36Sopenharmony_ci * 1/2/3 PDEV -> 0/1/2 132462306a36Sopenharmony_ci * - payload_size 132562306a36Sopenharmony_ci * Bits 31:16 132662306a36Sopenharmony_ci * Purpose: total tlv size 132762306a36Sopenharmony_ci * Value: payload_size in bytes 132862306a36Sopenharmony_ci */ 132962306a36Sopenharmony_ci 133062306a36Sopenharmony_ci#define HTT_T2H_PPDU_STATS_INFO_PDEV_ID GENMASK(11, 10) 133162306a36Sopenharmony_ci#define HTT_T2H_PPDU_STATS_INFO_PAYLOAD_SIZE GENMASK(31, 16) 133262306a36Sopenharmony_ci 133362306a36Sopenharmony_cistruct ath12k_htt_ppdu_stats_msg { 133462306a36Sopenharmony_ci __le32 info; 133562306a36Sopenharmony_ci __le32 ppdu_id; 133662306a36Sopenharmony_ci __le32 timestamp; 133762306a36Sopenharmony_ci __le32 rsvd; 133862306a36Sopenharmony_ci u8 data[]; 133962306a36Sopenharmony_ci} __packed; 134062306a36Sopenharmony_ci 134162306a36Sopenharmony_cistruct htt_tlv { 134262306a36Sopenharmony_ci __le32 header; 134362306a36Sopenharmony_ci u8 value[]; 134462306a36Sopenharmony_ci} __packed; 134562306a36Sopenharmony_ci 134662306a36Sopenharmony_ci#define HTT_TLV_TAG GENMASK(11, 0) 134762306a36Sopenharmony_ci#define HTT_TLV_LEN GENMASK(23, 12) 134862306a36Sopenharmony_ci 134962306a36Sopenharmony_cienum HTT_PPDU_STATS_BW { 135062306a36Sopenharmony_ci HTT_PPDU_STATS_BANDWIDTH_5MHZ = 0, 135162306a36Sopenharmony_ci HTT_PPDU_STATS_BANDWIDTH_10MHZ = 1, 135262306a36Sopenharmony_ci HTT_PPDU_STATS_BANDWIDTH_20MHZ = 2, 135362306a36Sopenharmony_ci HTT_PPDU_STATS_BANDWIDTH_40MHZ = 3, 135462306a36Sopenharmony_ci HTT_PPDU_STATS_BANDWIDTH_80MHZ = 4, 135562306a36Sopenharmony_ci HTT_PPDU_STATS_BANDWIDTH_160MHZ = 5, /* includes 80+80 */ 135662306a36Sopenharmony_ci HTT_PPDU_STATS_BANDWIDTH_DYN = 6, 135762306a36Sopenharmony_ci}; 135862306a36Sopenharmony_ci 135962306a36Sopenharmony_ci#define HTT_PPDU_STATS_CMN_FLAGS_FRAME_TYPE_M GENMASK(7, 0) 136062306a36Sopenharmony_ci#define HTT_PPDU_STATS_CMN_FLAGS_QUEUE_TYPE_M GENMASK(15, 8) 136162306a36Sopenharmony_ci/* bw - HTT_PPDU_STATS_BW */ 136262306a36Sopenharmony_ci#define HTT_PPDU_STATS_CMN_FLAGS_BW_M GENMASK(19, 16) 136362306a36Sopenharmony_ci 136462306a36Sopenharmony_cistruct htt_ppdu_stats_common { 136562306a36Sopenharmony_ci __le32 ppdu_id; 136662306a36Sopenharmony_ci __le16 sched_cmdid; 136762306a36Sopenharmony_ci u8 ring_id; 136862306a36Sopenharmony_ci u8 num_users; 136962306a36Sopenharmony_ci __le32 flags; /* %HTT_PPDU_STATS_COMMON_FLAGS_*/ 137062306a36Sopenharmony_ci __le32 chain_mask; 137162306a36Sopenharmony_ci __le32 fes_duration_us; /* frame exchange sequence */ 137262306a36Sopenharmony_ci __le32 ppdu_sch_eval_start_tstmp_us; 137362306a36Sopenharmony_ci __le32 ppdu_sch_end_tstmp_us; 137462306a36Sopenharmony_ci __le32 ppdu_start_tstmp_us; 137562306a36Sopenharmony_ci /* BIT [15 : 0] - phy mode (WLAN_PHY_MODE) with which ppdu was transmitted 137662306a36Sopenharmony_ci * BIT [31 : 16] - bandwidth (in MHz) with which ppdu was transmitted 137762306a36Sopenharmony_ci */ 137862306a36Sopenharmony_ci __le16 phy_mode; 137962306a36Sopenharmony_ci __le16 bw_mhz; 138062306a36Sopenharmony_ci} __packed; 138162306a36Sopenharmony_ci 138262306a36Sopenharmony_cienum htt_ppdu_stats_gi { 138362306a36Sopenharmony_ci HTT_PPDU_STATS_SGI_0_8_US, 138462306a36Sopenharmony_ci HTT_PPDU_STATS_SGI_0_4_US, 138562306a36Sopenharmony_ci HTT_PPDU_STATS_SGI_1_6_US, 138662306a36Sopenharmony_ci HTT_PPDU_STATS_SGI_3_2_US, 138762306a36Sopenharmony_ci}; 138862306a36Sopenharmony_ci 138962306a36Sopenharmony_ci#define HTT_PPDU_STATS_USER_RATE_INFO0_USER_POS_M GENMASK(3, 0) 139062306a36Sopenharmony_ci#define HTT_PPDU_STATS_USER_RATE_INFO0_MU_GROUP_ID_M GENMASK(11, 4) 139162306a36Sopenharmony_ci 139262306a36Sopenharmony_cienum HTT_PPDU_STATS_PPDU_TYPE { 139362306a36Sopenharmony_ci HTT_PPDU_STATS_PPDU_TYPE_SU, 139462306a36Sopenharmony_ci HTT_PPDU_STATS_PPDU_TYPE_MU_MIMO, 139562306a36Sopenharmony_ci HTT_PPDU_STATS_PPDU_TYPE_MU_OFDMA, 139662306a36Sopenharmony_ci HTT_PPDU_STATS_PPDU_TYPE_MU_MIMO_OFDMA, 139762306a36Sopenharmony_ci HTT_PPDU_STATS_PPDU_TYPE_UL_TRIG, 139862306a36Sopenharmony_ci HTT_PPDU_STATS_PPDU_TYPE_BURST_BCN, 139962306a36Sopenharmony_ci HTT_PPDU_STATS_PPDU_TYPE_UL_BSR_RESP, 140062306a36Sopenharmony_ci HTT_PPDU_STATS_PPDU_TYPE_UL_BSR_TRIG, 140162306a36Sopenharmony_ci HTT_PPDU_STATS_PPDU_TYPE_UL_RESP, 140262306a36Sopenharmony_ci HTT_PPDU_STATS_PPDU_TYPE_MAX 140362306a36Sopenharmony_ci}; 140462306a36Sopenharmony_ci 140562306a36Sopenharmony_ci#define HTT_PPDU_STATS_USER_RATE_INFO1_RESP_TYPE_VALD_M BIT(0) 140662306a36Sopenharmony_ci#define HTT_PPDU_STATS_USER_RATE_INFO1_PPDU_TYPE_M GENMASK(5, 1) 140762306a36Sopenharmony_ci 140862306a36Sopenharmony_ci#define HTT_PPDU_STATS_USER_RATE_FLAGS_LTF_SIZE_M GENMASK(1, 0) 140962306a36Sopenharmony_ci#define HTT_PPDU_STATS_USER_RATE_FLAGS_STBC_M BIT(2) 141062306a36Sopenharmony_ci#define HTT_PPDU_STATS_USER_RATE_FLAGS_HE_RE_M BIT(3) 141162306a36Sopenharmony_ci#define HTT_PPDU_STATS_USER_RATE_FLAGS_TXBF_M GENMASK(7, 4) 141262306a36Sopenharmony_ci#define HTT_PPDU_STATS_USER_RATE_FLAGS_BW_M GENMASK(11, 8) 141362306a36Sopenharmony_ci#define HTT_PPDU_STATS_USER_RATE_FLAGS_NSS_M GENMASK(15, 12) 141462306a36Sopenharmony_ci#define HTT_PPDU_STATS_USER_RATE_FLAGS_MCS_M GENMASK(19, 16) 141562306a36Sopenharmony_ci#define HTT_PPDU_STATS_USER_RATE_FLAGS_PREAMBLE_M GENMASK(23, 20) 141662306a36Sopenharmony_ci#define HTT_PPDU_STATS_USER_RATE_FLAGS_GI_M GENMASK(27, 24) 141762306a36Sopenharmony_ci#define HTT_PPDU_STATS_USER_RATE_FLAGS_DCM_M BIT(28) 141862306a36Sopenharmony_ci#define HTT_PPDU_STATS_USER_RATE_FLAGS_LDPC_M BIT(29) 141962306a36Sopenharmony_ci 142062306a36Sopenharmony_ci#define HTT_USR_RATE_PREAMBLE(_val) \ 142162306a36Sopenharmony_ci le32_get_bits(_val, HTT_PPDU_STATS_USER_RATE_FLAGS_PREAMBLE_M) 142262306a36Sopenharmony_ci#define HTT_USR_RATE_BW(_val) \ 142362306a36Sopenharmony_ci le32_get_bits(_val, HTT_PPDU_STATS_USER_RATE_FLAGS_BW_M) 142462306a36Sopenharmony_ci#define HTT_USR_RATE_NSS(_val) \ 142562306a36Sopenharmony_ci le32_get_bits(_val, HTT_PPDU_STATS_USER_RATE_FLAGS_NSS_M) 142662306a36Sopenharmony_ci#define HTT_USR_RATE_MCS(_val) \ 142762306a36Sopenharmony_ci le32_get_bits(_val, HTT_PPDU_STATS_USER_RATE_FLAGS_MCS_M) 142862306a36Sopenharmony_ci#define HTT_USR_RATE_GI(_val) \ 142962306a36Sopenharmony_ci le32_get_bits(_val, HTT_PPDU_STATS_USER_RATE_FLAGS_GI_M) 143062306a36Sopenharmony_ci#define HTT_USR_RATE_DCM(_val) \ 143162306a36Sopenharmony_ci le32_get_bits(_val, HTT_PPDU_STATS_USER_RATE_FLAGS_DCM_M) 143262306a36Sopenharmony_ci 143362306a36Sopenharmony_ci#define HTT_PPDU_STATS_USER_RATE_RESP_FLAGS_LTF_SIZE_M GENMASK(1, 0) 143462306a36Sopenharmony_ci#define HTT_PPDU_STATS_USER_RATE_RESP_FLAGS_STBC_M BIT(2) 143562306a36Sopenharmony_ci#define HTT_PPDU_STATS_USER_RATE_RESP_FLAGS_HE_RE_M BIT(3) 143662306a36Sopenharmony_ci#define HTT_PPDU_STATS_USER_RATE_RESP_FLAGS_TXBF_M GENMASK(7, 4) 143762306a36Sopenharmony_ci#define HTT_PPDU_STATS_USER_RATE_RESP_FLAGS_BW_M GENMASK(11, 8) 143862306a36Sopenharmony_ci#define HTT_PPDU_STATS_USER_RATE_RESP_FLAGS_NSS_M GENMASK(15, 12) 143962306a36Sopenharmony_ci#define HTT_PPDU_STATS_USER_RATE_RESP_FLAGS_MCS_M GENMASK(19, 16) 144062306a36Sopenharmony_ci#define HTT_PPDU_STATS_USER_RATE_RESP_FLAGS_PREAMBLE_M GENMASK(23, 20) 144162306a36Sopenharmony_ci#define HTT_PPDU_STATS_USER_RATE_RESP_FLAGS_GI_M GENMASK(27, 24) 144262306a36Sopenharmony_ci#define HTT_PPDU_STATS_USER_RATE_RESP_FLAGS_DCM_M BIT(28) 144362306a36Sopenharmony_ci#define HTT_PPDU_STATS_USER_RATE_RESP_FLAGS_LDPC_M BIT(29) 144462306a36Sopenharmony_ci 144562306a36Sopenharmony_cistruct htt_ppdu_stats_user_rate { 144662306a36Sopenharmony_ci u8 tid_num; 144762306a36Sopenharmony_ci u8 reserved0; 144862306a36Sopenharmony_ci __le16 sw_peer_id; 144962306a36Sopenharmony_ci __le32 info0; /* %HTT_PPDU_STATS_USER_RATE_INFO0_*/ 145062306a36Sopenharmony_ci __le16 ru_end; 145162306a36Sopenharmony_ci __le16 ru_start; 145262306a36Sopenharmony_ci __le16 resp_ru_end; 145362306a36Sopenharmony_ci __le16 resp_ru_start; 145462306a36Sopenharmony_ci __le32 info1; /* %HTT_PPDU_STATS_USER_RATE_INFO1_ */ 145562306a36Sopenharmony_ci __le32 rate_flags; /* %HTT_PPDU_STATS_USER_RATE_FLAGS_ */ 145662306a36Sopenharmony_ci /* Note: resp_rate_info is only valid for if resp_type is UL */ 145762306a36Sopenharmony_ci __le32 resp_rate_flags; /* %HTT_PPDU_STATS_USER_RATE_RESP_FLAGS_ */ 145862306a36Sopenharmony_ci} __packed; 145962306a36Sopenharmony_ci 146062306a36Sopenharmony_ci#define HTT_PPDU_STATS_TX_INFO_FLAGS_RATECODE_M GENMASK(7, 0) 146162306a36Sopenharmony_ci#define HTT_PPDU_STATS_TX_INFO_FLAGS_IS_AMPDU_M BIT(8) 146262306a36Sopenharmony_ci#define HTT_PPDU_STATS_TX_INFO_FLAGS_BA_ACK_FAILED_M GENMASK(10, 9) 146362306a36Sopenharmony_ci#define HTT_PPDU_STATS_TX_INFO_FLAGS_BW_M GENMASK(13, 11) 146462306a36Sopenharmony_ci#define HTT_PPDU_STATS_TX_INFO_FLAGS_SGI_M BIT(14) 146562306a36Sopenharmony_ci#define HTT_PPDU_STATS_TX_INFO_FLAGS_PEERID_M GENMASK(31, 16) 146662306a36Sopenharmony_ci 146762306a36Sopenharmony_ci#define HTT_TX_INFO_IS_AMSDU(_flags) \ 146862306a36Sopenharmony_ci u32_get_bits(_flags, HTT_PPDU_STATS_TX_INFO_FLAGS_IS_AMPDU_M) 146962306a36Sopenharmony_ci#define HTT_TX_INFO_BA_ACK_FAILED(_flags) \ 147062306a36Sopenharmony_ci u32_get_bits(_flags, HTT_PPDU_STATS_TX_INFO_FLAGS_BA_ACK_FAILED_M) 147162306a36Sopenharmony_ci#define HTT_TX_INFO_RATECODE(_flags) \ 147262306a36Sopenharmony_ci u32_get_bits(_flags, HTT_PPDU_STATS_TX_INFO_FLAGS_RATECODE_M) 147362306a36Sopenharmony_ci#define HTT_TX_INFO_PEERID(_flags) \ 147462306a36Sopenharmony_ci u32_get_bits(_flags, HTT_PPDU_STATS_TX_INFO_FLAGS_PEERID_M) 147562306a36Sopenharmony_ci 147662306a36Sopenharmony_cistruct htt_tx_ppdu_stats_info { 147762306a36Sopenharmony_ci struct htt_tlv tlv_hdr; 147862306a36Sopenharmony_ci __le32 tx_success_bytes; 147962306a36Sopenharmony_ci __le32 tx_retry_bytes; 148062306a36Sopenharmony_ci __le32 tx_failed_bytes; 148162306a36Sopenharmony_ci __le32 flags; /* %HTT_PPDU_STATS_TX_INFO_FLAGS_ */ 148262306a36Sopenharmony_ci __le16 tx_success_msdus; 148362306a36Sopenharmony_ci __le16 tx_retry_msdus; 148462306a36Sopenharmony_ci __le16 tx_failed_msdus; 148562306a36Sopenharmony_ci __le16 tx_duration; /* united in us */ 148662306a36Sopenharmony_ci} __packed; 148762306a36Sopenharmony_ci 148862306a36Sopenharmony_cienum htt_ppdu_stats_usr_compln_status { 148962306a36Sopenharmony_ci HTT_PPDU_STATS_USER_STATUS_OK, 149062306a36Sopenharmony_ci HTT_PPDU_STATS_USER_STATUS_FILTERED, 149162306a36Sopenharmony_ci HTT_PPDU_STATS_USER_STATUS_RESP_TIMEOUT, 149262306a36Sopenharmony_ci HTT_PPDU_STATS_USER_STATUS_RESP_MISMATCH, 149362306a36Sopenharmony_ci HTT_PPDU_STATS_USER_STATUS_ABORT, 149462306a36Sopenharmony_ci}; 149562306a36Sopenharmony_ci 149662306a36Sopenharmony_ci#define HTT_PPDU_STATS_USR_CMPLTN_CMN_FLAGS_LONG_RETRY_M GENMASK(3, 0) 149762306a36Sopenharmony_ci#define HTT_PPDU_STATS_USR_CMPLTN_CMN_FLAGS_SHORT_RETRY_M GENMASK(7, 4) 149862306a36Sopenharmony_ci#define HTT_PPDU_STATS_USR_CMPLTN_CMN_FLAGS_IS_AMPDU_M BIT(8) 149962306a36Sopenharmony_ci#define HTT_PPDU_STATS_USR_CMPLTN_CMN_FLAGS_RESP_TYPE_M GENMASK(12, 9) 150062306a36Sopenharmony_ci 150162306a36Sopenharmony_ci#define HTT_USR_CMPLTN_IS_AMPDU(_val) \ 150262306a36Sopenharmony_ci le32_get_bits(_val, HTT_PPDU_STATS_USR_CMPLTN_CMN_FLAGS_IS_AMPDU_M) 150362306a36Sopenharmony_ci#define HTT_USR_CMPLTN_LONG_RETRY(_val) \ 150462306a36Sopenharmony_ci le32_get_bits(_val, HTT_PPDU_STATS_USR_CMPLTN_CMN_FLAGS_LONG_RETRY_M) 150562306a36Sopenharmony_ci#define HTT_USR_CMPLTN_SHORT_RETRY(_val) \ 150662306a36Sopenharmony_ci le32_get_bits(_val, HTT_PPDU_STATS_USR_CMPLTN_CMN_FLAGS_SHORT_RETRY_M) 150762306a36Sopenharmony_ci 150862306a36Sopenharmony_cistruct htt_ppdu_stats_usr_cmpltn_cmn { 150962306a36Sopenharmony_ci u8 status; 151062306a36Sopenharmony_ci u8 tid_num; 151162306a36Sopenharmony_ci __le16 sw_peer_id; 151262306a36Sopenharmony_ci /* RSSI value of last ack packet (units = dB above noise floor) */ 151362306a36Sopenharmony_ci __le32 ack_rssi; 151462306a36Sopenharmony_ci __le16 mpdu_tried; 151562306a36Sopenharmony_ci __le16 mpdu_success; 151662306a36Sopenharmony_ci __le32 flags; /* %HTT_PPDU_STATS_USR_CMPLTN_CMN_FLAGS_LONG_RETRIES*/ 151762306a36Sopenharmony_ci} __packed; 151862306a36Sopenharmony_ci 151962306a36Sopenharmony_ci#define HTT_PPDU_STATS_ACK_BA_INFO_NUM_MPDU_M GENMASK(8, 0) 152062306a36Sopenharmony_ci#define HTT_PPDU_STATS_ACK_BA_INFO_NUM_MSDU_M GENMASK(24, 9) 152162306a36Sopenharmony_ci#define HTT_PPDU_STATS_ACK_BA_INFO_TID_NUM GENMASK(31, 25) 152262306a36Sopenharmony_ci 152362306a36Sopenharmony_ci#define HTT_PPDU_STATS_NON_QOS_TID 16 152462306a36Sopenharmony_ci 152562306a36Sopenharmony_cistruct htt_ppdu_stats_usr_cmpltn_ack_ba_status { 152662306a36Sopenharmony_ci __le32 ppdu_id; 152762306a36Sopenharmony_ci __le16 sw_peer_id; 152862306a36Sopenharmony_ci __le16 reserved0; 152962306a36Sopenharmony_ci __le32 info; /* %HTT_PPDU_STATS_USR_CMPLTN_CMN_INFO_ */ 153062306a36Sopenharmony_ci __le16 current_seq; 153162306a36Sopenharmony_ci __le16 start_seq; 153262306a36Sopenharmony_ci __le32 success_bytes; 153362306a36Sopenharmony_ci} __packed; 153462306a36Sopenharmony_ci 153562306a36Sopenharmony_cistruct htt_ppdu_user_stats { 153662306a36Sopenharmony_ci u16 peer_id; 153762306a36Sopenharmony_ci u16 delay_ba; 153862306a36Sopenharmony_ci u32 tlv_flags; 153962306a36Sopenharmony_ci bool is_valid_peer_id; 154062306a36Sopenharmony_ci struct htt_ppdu_stats_user_rate rate; 154162306a36Sopenharmony_ci struct htt_ppdu_stats_usr_cmpltn_cmn cmpltn_cmn; 154262306a36Sopenharmony_ci struct htt_ppdu_stats_usr_cmpltn_ack_ba_status ack_ba; 154362306a36Sopenharmony_ci}; 154462306a36Sopenharmony_ci 154562306a36Sopenharmony_ci#define HTT_PPDU_STATS_MAX_USERS 8 154662306a36Sopenharmony_ci#define HTT_PPDU_DESC_MAX_DEPTH 16 154762306a36Sopenharmony_ci 154862306a36Sopenharmony_cistruct htt_ppdu_stats { 154962306a36Sopenharmony_ci struct htt_ppdu_stats_common common; 155062306a36Sopenharmony_ci struct htt_ppdu_user_stats user_stats[HTT_PPDU_STATS_MAX_USERS]; 155162306a36Sopenharmony_ci}; 155262306a36Sopenharmony_ci 155362306a36Sopenharmony_cistruct htt_ppdu_stats_info { 155462306a36Sopenharmony_ci u32 tlv_bitmap; 155562306a36Sopenharmony_ci u32 ppdu_id; 155662306a36Sopenharmony_ci u32 frame_type; 155762306a36Sopenharmony_ci u32 frame_ctrl; 155862306a36Sopenharmony_ci u32 delay_ba; 155962306a36Sopenharmony_ci u32 bar_num_users; 156062306a36Sopenharmony_ci struct htt_ppdu_stats ppdu_stats; 156162306a36Sopenharmony_ci struct list_head list; 156262306a36Sopenharmony_ci}; 156362306a36Sopenharmony_ci 156462306a36Sopenharmony_ci/* @brief target -> host MLO offset indiciation message 156562306a36Sopenharmony_ci * 156662306a36Sopenharmony_ci * @details 156762306a36Sopenharmony_ci * The following field definitions describe the format of the HTT target 156862306a36Sopenharmony_ci * to host mlo offset indication message. 156962306a36Sopenharmony_ci * 157062306a36Sopenharmony_ci * 157162306a36Sopenharmony_ci * |31 29|28 |26|25 22|21 16|15 13|12 10 |9 8|7 0| 157262306a36Sopenharmony_ci * |---------------------------------------------------------------------| 157362306a36Sopenharmony_ci * | rsvd1 | mac_freq |chip_id |pdev_id|msgtype| 157462306a36Sopenharmony_ci * |---------------------------------------------------------------------| 157562306a36Sopenharmony_ci * | sync_timestamp_lo_us | 157662306a36Sopenharmony_ci * |---------------------------------------------------------------------| 157762306a36Sopenharmony_ci * | sync_timestamp_hi_us | 157862306a36Sopenharmony_ci * |---------------------------------------------------------------------| 157962306a36Sopenharmony_ci * | mlo_offset_lo | 158062306a36Sopenharmony_ci * |---------------------------------------------------------------------| 158162306a36Sopenharmony_ci * | mlo_offset_hi | 158262306a36Sopenharmony_ci * |---------------------------------------------------------------------| 158362306a36Sopenharmony_ci * | mlo_offset_clcks | 158462306a36Sopenharmony_ci * |---------------------------------------------------------------------| 158562306a36Sopenharmony_ci * | rsvd2 | mlo_comp_clks |mlo_comp_us | 158662306a36Sopenharmony_ci * |---------------------------------------------------------------------| 158762306a36Sopenharmony_ci * | rsvd3 |mlo_comp_timer | 158862306a36Sopenharmony_ci * |---------------------------------------------------------------------| 158962306a36Sopenharmony_ci * Header fields 159062306a36Sopenharmony_ci * - MSG_TYPE 159162306a36Sopenharmony_ci * Bits 7:0 159262306a36Sopenharmony_ci * Purpose: Identifies this is a MLO offset indication msg 159362306a36Sopenharmony_ci * - PDEV_ID 159462306a36Sopenharmony_ci * Bits 9:8 159562306a36Sopenharmony_ci * Purpose: Pdev of this MLO offset 159662306a36Sopenharmony_ci * - CHIP_ID 159762306a36Sopenharmony_ci * Bits 12:10 159862306a36Sopenharmony_ci * Purpose: chip_id of this MLO offset 159962306a36Sopenharmony_ci * - MAC_FREQ 160062306a36Sopenharmony_ci * Bits 28:13 160162306a36Sopenharmony_ci * - SYNC_TIMESTAMP_LO_US 160262306a36Sopenharmony_ci * Purpose: clock frequency of the mac HW block in MHz 160362306a36Sopenharmony_ci * Bits: 31:0 160462306a36Sopenharmony_ci * Purpose: lower 32 bits of the WLAN global time stamp at which 160562306a36Sopenharmony_ci * last sync interrupt was received 160662306a36Sopenharmony_ci * - SYNC_TIMESTAMP_HI_US 160762306a36Sopenharmony_ci * Bits: 31:0 160862306a36Sopenharmony_ci * Purpose: upper 32 bits of WLAN global time stamp at which 160962306a36Sopenharmony_ci * last sync interrupt was received 161062306a36Sopenharmony_ci * - MLO_OFFSET_LO 161162306a36Sopenharmony_ci * Bits: 31:0 161262306a36Sopenharmony_ci * Purpose: lower 32 bits of the MLO offset in us 161362306a36Sopenharmony_ci * - MLO_OFFSET_HI 161462306a36Sopenharmony_ci * Bits: 31:0 161562306a36Sopenharmony_ci * Purpose: upper 32 bits of the MLO offset in us 161662306a36Sopenharmony_ci * - MLO_COMP_US 161762306a36Sopenharmony_ci * Bits: 15:0 161862306a36Sopenharmony_ci * Purpose: MLO time stamp compensation applied in us 161962306a36Sopenharmony_ci * - MLO_COMP_CLCKS 162062306a36Sopenharmony_ci * Bits: 25:16 162162306a36Sopenharmony_ci * Purpose: MLO time stamp compensation applied in clock ticks 162262306a36Sopenharmony_ci * - MLO_COMP_TIMER 162362306a36Sopenharmony_ci * Bits: 21:0 162462306a36Sopenharmony_ci * Purpose: Periodic timer at which compensation is applied 162562306a36Sopenharmony_ci */ 162662306a36Sopenharmony_ci 162762306a36Sopenharmony_ci#define HTT_T2H_MLO_OFFSET_INFO_MSG_TYPE GENMASK(7, 0) 162862306a36Sopenharmony_ci#define HTT_T2H_MLO_OFFSET_INFO_PDEV_ID GENMASK(9, 8) 162962306a36Sopenharmony_ci 163062306a36Sopenharmony_cistruct ath12k_htt_mlo_offset_msg { 163162306a36Sopenharmony_ci __le32 info; 163262306a36Sopenharmony_ci __le32 sync_timestamp_lo_us; 163362306a36Sopenharmony_ci __le32 sync_timestamp_hi_us; 163462306a36Sopenharmony_ci __le32 mlo_offset_hi; 163562306a36Sopenharmony_ci __le32 mlo_offset_lo; 163662306a36Sopenharmony_ci __le32 mlo_offset_clks; 163762306a36Sopenharmony_ci __le32 mlo_comp_clks; 163862306a36Sopenharmony_ci __le32 mlo_comp_timer; 163962306a36Sopenharmony_ci} __packed; 164062306a36Sopenharmony_ci 164162306a36Sopenharmony_ci/* @brief host -> target FW extended statistics retrieve 164262306a36Sopenharmony_ci * 164362306a36Sopenharmony_ci * @details 164462306a36Sopenharmony_ci * The following field definitions describe the format of the HTT host 164562306a36Sopenharmony_ci * to target FW extended stats retrieve message. 164662306a36Sopenharmony_ci * The message specifies the type of stats the host wants to retrieve. 164762306a36Sopenharmony_ci * 164862306a36Sopenharmony_ci * |31 24|23 16|15 8|7 0| 164962306a36Sopenharmony_ci * |-----------------------------------------------------------| 165062306a36Sopenharmony_ci * | reserved | stats type | pdev_mask | msg type | 165162306a36Sopenharmony_ci * |-----------------------------------------------------------| 165262306a36Sopenharmony_ci * | config param [0] | 165362306a36Sopenharmony_ci * |-----------------------------------------------------------| 165462306a36Sopenharmony_ci * | config param [1] | 165562306a36Sopenharmony_ci * |-----------------------------------------------------------| 165662306a36Sopenharmony_ci * | config param [2] | 165762306a36Sopenharmony_ci * |-----------------------------------------------------------| 165862306a36Sopenharmony_ci * | config param [3] | 165962306a36Sopenharmony_ci * |-----------------------------------------------------------| 166062306a36Sopenharmony_ci * | reserved | 166162306a36Sopenharmony_ci * |-----------------------------------------------------------| 166262306a36Sopenharmony_ci * | cookie LSBs | 166362306a36Sopenharmony_ci * |-----------------------------------------------------------| 166462306a36Sopenharmony_ci * | cookie MSBs | 166562306a36Sopenharmony_ci * |-----------------------------------------------------------| 166662306a36Sopenharmony_ci * Header fields: 166762306a36Sopenharmony_ci * - MSG_TYPE 166862306a36Sopenharmony_ci * Bits 7:0 166962306a36Sopenharmony_ci * Purpose: identifies this is a extended stats upload request message 167062306a36Sopenharmony_ci * Value: 0x10 167162306a36Sopenharmony_ci * - PDEV_MASK 167262306a36Sopenharmony_ci * Bits 8:15 167362306a36Sopenharmony_ci * Purpose: identifies the mask of PDEVs to retrieve stats from 167462306a36Sopenharmony_ci * Value: This is a overloaded field, refer to usage and interpretation of 167562306a36Sopenharmony_ci * PDEV in interface document. 167662306a36Sopenharmony_ci * Bit 8 : Reserved for SOC stats 167762306a36Sopenharmony_ci * Bit 9 - 15 : Indicates PDEV_MASK in DBDC 167862306a36Sopenharmony_ci * Indicates MACID_MASK in DBS 167962306a36Sopenharmony_ci * - STATS_TYPE 168062306a36Sopenharmony_ci * Bits 23:16 168162306a36Sopenharmony_ci * Purpose: identifies which FW statistics to upload 168262306a36Sopenharmony_ci * Value: Defined by htt_dbg_ext_stats_type (see htt_stats.h) 168362306a36Sopenharmony_ci * - Reserved 168462306a36Sopenharmony_ci * Bits 31:24 168562306a36Sopenharmony_ci * - CONFIG_PARAM [0] 168662306a36Sopenharmony_ci * Bits 31:0 168762306a36Sopenharmony_ci * Purpose: give an opaque configuration value to the specified stats type 168862306a36Sopenharmony_ci * Value: stats-type specific configuration value 168962306a36Sopenharmony_ci * Refer to htt_stats.h for interpretation for each stats sub_type 169062306a36Sopenharmony_ci * - CONFIG_PARAM [1] 169162306a36Sopenharmony_ci * Bits 31:0 169262306a36Sopenharmony_ci * Purpose: give an opaque configuration value to the specified stats type 169362306a36Sopenharmony_ci * Value: stats-type specific configuration value 169462306a36Sopenharmony_ci * Refer to htt_stats.h for interpretation for each stats sub_type 169562306a36Sopenharmony_ci * - CONFIG_PARAM [2] 169662306a36Sopenharmony_ci * Bits 31:0 169762306a36Sopenharmony_ci * Purpose: give an opaque configuration value to the specified stats type 169862306a36Sopenharmony_ci * Value: stats-type specific configuration value 169962306a36Sopenharmony_ci * Refer to htt_stats.h for interpretation for each stats sub_type 170062306a36Sopenharmony_ci * - CONFIG_PARAM [3] 170162306a36Sopenharmony_ci * Bits 31:0 170262306a36Sopenharmony_ci * Purpose: give an opaque configuration value to the specified stats type 170362306a36Sopenharmony_ci * Value: stats-type specific configuration value 170462306a36Sopenharmony_ci * Refer to htt_stats.h for interpretation for each stats sub_type 170562306a36Sopenharmony_ci * - Reserved [31:0] for future use. 170662306a36Sopenharmony_ci * - COOKIE_LSBS 170762306a36Sopenharmony_ci * Bits 31:0 170862306a36Sopenharmony_ci * Purpose: Provide a mechanism to match a target->host stats confirmation 170962306a36Sopenharmony_ci * message with its preceding host->target stats request message. 171062306a36Sopenharmony_ci * Value: LSBs of the opaque cookie specified by the host-side requestor 171162306a36Sopenharmony_ci * - COOKIE_MSBS 171262306a36Sopenharmony_ci * Bits 31:0 171362306a36Sopenharmony_ci * Purpose: Provide a mechanism to match a target->host stats confirmation 171462306a36Sopenharmony_ci * message with its preceding host->target stats request message. 171562306a36Sopenharmony_ci * Value: MSBs of the opaque cookie specified by the host-side requestor 171662306a36Sopenharmony_ci */ 171762306a36Sopenharmony_ci 171862306a36Sopenharmony_cistruct htt_ext_stats_cfg_hdr { 171962306a36Sopenharmony_ci u8 msg_type; 172062306a36Sopenharmony_ci u8 pdev_mask; 172162306a36Sopenharmony_ci u8 stats_type; 172262306a36Sopenharmony_ci u8 reserved; 172362306a36Sopenharmony_ci} __packed; 172462306a36Sopenharmony_ci 172562306a36Sopenharmony_cistruct htt_ext_stats_cfg_cmd { 172662306a36Sopenharmony_ci struct htt_ext_stats_cfg_hdr hdr; 172762306a36Sopenharmony_ci __le32 cfg_param0; 172862306a36Sopenharmony_ci __le32 cfg_param1; 172962306a36Sopenharmony_ci __le32 cfg_param2; 173062306a36Sopenharmony_ci __le32 cfg_param3; 173162306a36Sopenharmony_ci __le32 reserved; 173262306a36Sopenharmony_ci __le32 cookie_lsb; 173362306a36Sopenharmony_ci __le32 cookie_msb; 173462306a36Sopenharmony_ci} __packed; 173562306a36Sopenharmony_ci 173662306a36Sopenharmony_ci/* htt stats config default params */ 173762306a36Sopenharmony_ci#define HTT_STAT_DEFAULT_RESET_START_OFFSET 0 173862306a36Sopenharmony_ci#define HTT_STAT_DEFAULT_CFG0_ALL_HWQS 0xffffffff 173962306a36Sopenharmony_ci#define HTT_STAT_DEFAULT_CFG0_ALL_TXQS 0xffffffff 174062306a36Sopenharmony_ci#define HTT_STAT_DEFAULT_CFG0_ALL_CMDQS 0xffff 174162306a36Sopenharmony_ci#define HTT_STAT_DEFAULT_CFG0_ALL_RINGS 0xffff 174262306a36Sopenharmony_ci#define HTT_STAT_DEFAULT_CFG0_ACTIVE_PEERS 0xff 174362306a36Sopenharmony_ci#define HTT_STAT_DEFAULT_CFG0_CCA_CUMULATIVE 0x00 174462306a36Sopenharmony_ci#define HTT_STAT_DEFAULT_CFG0_ACTIVE_VDEVS 0x00 174562306a36Sopenharmony_ci 174662306a36Sopenharmony_ci/* HTT_DBG_EXT_STATS_PEER_INFO 174762306a36Sopenharmony_ci * PARAMS: 174862306a36Sopenharmony_ci * @config_param0: 174962306a36Sopenharmony_ci * [Bit0] - [0] for sw_peer_id, [1] for mac_addr based request 175062306a36Sopenharmony_ci * [Bit15 : Bit 1] htt_peer_stats_req_mode_t 175162306a36Sopenharmony_ci * [Bit31 : Bit16] sw_peer_id 175262306a36Sopenharmony_ci * @config_param1: 175362306a36Sopenharmony_ci * peer_stats_req_type_mask:32 (enum htt_peer_stats_tlv_enum) 175462306a36Sopenharmony_ci * 0 bit htt_peer_stats_cmn_tlv 175562306a36Sopenharmony_ci * 1 bit htt_peer_details_tlv 175662306a36Sopenharmony_ci * 2 bit htt_tx_peer_rate_stats_tlv 175762306a36Sopenharmony_ci * 3 bit htt_rx_peer_rate_stats_tlv 175862306a36Sopenharmony_ci * 4 bit htt_tx_tid_stats_tlv/htt_tx_tid_stats_v1_tlv 175962306a36Sopenharmony_ci * 5 bit htt_rx_tid_stats_tlv 176062306a36Sopenharmony_ci * 6 bit htt_msdu_flow_stats_tlv 176162306a36Sopenharmony_ci * @config_param2: [Bit31 : Bit0] mac_addr31to0 176262306a36Sopenharmony_ci * @config_param3: [Bit15 : Bit0] mac_addr47to32 176362306a36Sopenharmony_ci * [Bit31 : Bit16] reserved 176462306a36Sopenharmony_ci */ 176562306a36Sopenharmony_ci#define HTT_STAT_PEER_INFO_MAC_ADDR BIT(0) 176662306a36Sopenharmony_ci#define HTT_STAT_DEFAULT_PEER_REQ_TYPE 0x7f 176762306a36Sopenharmony_ci 176862306a36Sopenharmony_ci/* Used to set different configs to the specified stats type.*/ 176962306a36Sopenharmony_cistruct htt_ext_stats_cfg_params { 177062306a36Sopenharmony_ci u32 cfg0; 177162306a36Sopenharmony_ci u32 cfg1; 177262306a36Sopenharmony_ci u32 cfg2; 177362306a36Sopenharmony_ci u32 cfg3; 177462306a36Sopenharmony_ci}; 177562306a36Sopenharmony_ci 177662306a36Sopenharmony_cienum vdev_stats_offload_timer_duration { 177762306a36Sopenharmony_ci ATH12K_STATS_TIMER_DUR_500MS = 1, 177862306a36Sopenharmony_ci ATH12K_STATS_TIMER_DUR_1SEC = 2, 177962306a36Sopenharmony_ci ATH12K_STATS_TIMER_DUR_2SEC = 3, 178062306a36Sopenharmony_ci}; 178162306a36Sopenharmony_ci 178262306a36Sopenharmony_cistatic inline void ath12k_dp_get_mac_addr(u32 addr_l32, u16 addr_h16, u8 *addr) 178362306a36Sopenharmony_ci{ 178462306a36Sopenharmony_ci memcpy(addr, &addr_l32, 4); 178562306a36Sopenharmony_ci memcpy(addr + 4, &addr_h16, ETH_ALEN - 4); 178662306a36Sopenharmony_ci} 178762306a36Sopenharmony_ci 178862306a36Sopenharmony_ciint ath12k_dp_service_srng(struct ath12k_base *ab, 178962306a36Sopenharmony_ci struct ath12k_ext_irq_grp *irq_grp, 179062306a36Sopenharmony_ci int budget); 179162306a36Sopenharmony_ciint ath12k_dp_htt_connect(struct ath12k_dp *dp); 179262306a36Sopenharmony_civoid ath12k_dp_vdev_tx_attach(struct ath12k *ar, struct ath12k_vif *arvif); 179362306a36Sopenharmony_civoid ath12k_dp_free(struct ath12k_base *ab); 179462306a36Sopenharmony_ciint ath12k_dp_alloc(struct ath12k_base *ab); 179562306a36Sopenharmony_civoid ath12k_dp_cc_config(struct ath12k_base *ab); 179662306a36Sopenharmony_ciint ath12k_dp_pdev_alloc(struct ath12k_base *ab); 179762306a36Sopenharmony_civoid ath12k_dp_pdev_pre_alloc(struct ath12k_base *ab); 179862306a36Sopenharmony_civoid ath12k_dp_pdev_free(struct ath12k_base *ab); 179962306a36Sopenharmony_ciint ath12k_dp_tx_htt_srng_setup(struct ath12k_base *ab, u32 ring_id, 180062306a36Sopenharmony_ci int mac_id, enum hal_ring_type ring_type); 180162306a36Sopenharmony_ciint ath12k_dp_peer_setup(struct ath12k *ar, int vdev_id, const u8 *addr); 180262306a36Sopenharmony_civoid ath12k_dp_peer_cleanup(struct ath12k *ar, int vdev_id, const u8 *addr); 180362306a36Sopenharmony_civoid ath12k_dp_srng_cleanup(struct ath12k_base *ab, struct dp_srng *ring); 180462306a36Sopenharmony_ciint ath12k_dp_srng_setup(struct ath12k_base *ab, struct dp_srng *ring, 180562306a36Sopenharmony_ci enum hal_ring_type type, int ring_num, 180662306a36Sopenharmony_ci int mac_id, int num_entries); 180762306a36Sopenharmony_civoid ath12k_dp_link_desc_cleanup(struct ath12k_base *ab, 180862306a36Sopenharmony_ci struct dp_link_desc_bank *desc_bank, 180962306a36Sopenharmony_ci u32 ring_type, struct dp_srng *ring); 181062306a36Sopenharmony_ciint ath12k_dp_link_desc_setup(struct ath12k_base *ab, 181162306a36Sopenharmony_ci struct dp_link_desc_bank *link_desc_banks, 181262306a36Sopenharmony_ci u32 ring_type, struct hal_srng *srng, 181362306a36Sopenharmony_ci u32 n_link_desc); 181462306a36Sopenharmony_cistruct ath12k_rx_desc_info *ath12k_dp_get_rx_desc(struct ath12k_base *ab, 181562306a36Sopenharmony_ci u32 cookie); 181662306a36Sopenharmony_cistruct ath12k_tx_desc_info *ath12k_dp_get_tx_desc(struct ath12k_base *ab, 181762306a36Sopenharmony_ci u32 desc_id); 181862306a36Sopenharmony_ci#endif 1819