Path: blob/main/sys/contrib/dev/athk/ath11k/hal_rx.h
48375 views
/* SPDX-License-Identifier: BSD-3-Clause-Clear */1/*2* Copyright (c) 2018-2019 The Linux Foundation. All rights reserved.3*/45#ifndef ATH11K_HAL_RX_H6#define ATH11K_HAL_RX_H78struct hal_rx_wbm_rel_info {9u32 cookie;10enum hal_wbm_rel_src_module err_rel_src;11enum hal_reo_dest_ring_push_reason push_reason;12u32 err_code;13bool first_msdu;14bool last_msdu;15};1617#define HAL_INVALID_PEERID 0xffff18#define VHT_SIG_SU_NSS_MASK 0x71920#define HAL_RX_MAX_MCS 1221#define HAL_RX_MAX_NSS 82223struct hal_rx_mon_status_tlv_hdr {24u32 hdr;25u8 value[];26};2728enum hal_rx_su_mu_coding {29HAL_RX_SU_MU_CODING_BCC,30HAL_RX_SU_MU_CODING_LDPC,31HAL_RX_SU_MU_CODING_MAX,32};3334enum hal_rx_gi {35HAL_RX_GI_0_8_US,36HAL_RX_GI_0_4_US,37HAL_RX_GI_1_6_US,38HAL_RX_GI_3_2_US,39HAL_RX_GI_MAX,40};4142enum hal_rx_bw {43HAL_RX_BW_20MHZ,44HAL_RX_BW_40MHZ,45HAL_RX_BW_80MHZ,46HAL_RX_BW_160MHZ,47HAL_RX_BW_MAX,48};4950enum hal_rx_preamble {51HAL_RX_PREAMBLE_11A,52HAL_RX_PREAMBLE_11B,53HAL_RX_PREAMBLE_11N,54HAL_RX_PREAMBLE_11AC,55HAL_RX_PREAMBLE_11AX,56HAL_RX_PREAMBLE_MAX,57};5859enum hal_rx_reception_type {60HAL_RX_RECEPTION_TYPE_SU,61HAL_RX_RECEPTION_TYPE_MU_MIMO,62HAL_RX_RECEPTION_TYPE_MU_OFDMA,63HAL_RX_RECEPTION_TYPE_MU_OFDMA_MIMO,64HAL_RX_RECEPTION_TYPE_MAX,65};6667#define HAL_RX_FCS_LEN 46869enum hal_rx_mon_status {70HAL_RX_MON_STATUS_PPDU_NOT_DONE,71HAL_RX_MON_STATUS_PPDU_DONE,72HAL_RX_MON_STATUS_BUF_DONE,73};7475struct hal_rx_user_status {76u32 mcs:4,77nss:3,78ofdma_info_valid:1,79dl_ofdma_ru_start_index:7,80dl_ofdma_ru_width:7,81dl_ofdma_ru_size:8;82u32 ul_ofdma_user_v0_word0;83u32 ul_ofdma_user_v0_word1;84u32 ast_index;85u32 tid;86u16 tcp_msdu_count;87u16 udp_msdu_count;88u16 other_msdu_count;89u16 frame_control;90u8 frame_control_info_valid;91u8 data_sequence_control_info_valid;92u16 first_data_seq_ctrl;93u32 preamble_type;94u16 ht_flags;95u16 vht_flags;96u16 he_flags;97u8 rs_flags;98u32 mpdu_cnt_fcs_ok;99u32 mpdu_cnt_fcs_err;100u32 mpdu_fcs_ok_bitmap[8];101u32 mpdu_ok_byte_count;102u32 mpdu_err_byte_count;103};104105#define HAL_TLV_STATUS_PPDU_NOT_DONE HAL_RX_MON_STATUS_PPDU_NOT_DONE106#define HAL_TLV_STATUS_PPDU_DONE HAL_RX_MON_STATUS_PPDU_DONE107#define HAL_TLV_STATUS_BUF_DONE HAL_RX_MON_STATUS_BUF_DONE108109struct hal_sw_mon_ring_entries {110dma_addr_t mon_dst_paddr;111dma_addr_t mon_status_paddr;112u32 mon_dst_sw_cookie;113u32 mon_status_sw_cookie;114void *dst_buf_addr_info;115void *status_buf_addr_info;116u16 ppdu_id;117u8 status_buf_count;118u8 msdu_cnt;119bool end_of_ppdu;120bool drop_ppdu;121};122123struct hal_rx_mon_ppdu_info {124u32 ppdu_id;125u32 ppdu_ts;126u32 num_mpdu_fcs_ok;127u32 num_mpdu_fcs_err;128u32 preamble_type;129u16 chan_num;130u16 tcp_msdu_count;131u16 tcp_ack_msdu_count;132u16 udp_msdu_count;133u16 other_msdu_count;134u16 peer_id;135u8 rate;136u8 mcs;137u8 nss;138u8 bw;139u8 vht_flag_values1;140u8 vht_flag_values2;141u8 vht_flag_values3[4];142u8 vht_flag_values4;143u8 vht_flag_values5;144u16 vht_flag_values6;145u8 is_stbc;146u8 gi;147u8 ldpc;148u8 beamformed;149u8 rssi_comb;150u8 rssi_chain_pri20[HAL_RX_MAX_NSS];151u8 tid;152u16 ht_flags;153u16 vht_flags;154u16 he_flags;155u16 he_mu_flags;156u8 dcm;157u8 ru_alloc;158u8 reception_type;159u64 tsft;160u64 rx_duration;161u16 frame_control;162u32 ast_index;163u8 rs_fcs_err;164u8 rs_flags;165u8 cck_flag;166u8 ofdm_flag;167u8 ulofdma_flag;168u8 frame_control_info_valid;169u16 he_per_user_1;170u16 he_per_user_2;171u8 he_per_user_position;172u8 he_per_user_known;173u16 he_flags1;174u16 he_flags2;175u8 he_RU[4];176u16 he_data1;177u16 he_data2;178u16 he_data3;179u16 he_data4;180u16 he_data5;181u16 he_data6;182u32 ppdu_len;183u32 prev_ppdu_id;184u32 device_id;185u16 first_data_seq_ctrl;186u8 monitor_direct_used;187u8 data_sequence_control_info_valid;188u8 ltf_size;189u8 rxpcu_filter_pass;190char rssi_chain[8][8];191struct hal_rx_user_status userstats;192};193194#define HAL_RX_PPDU_START_INFO0_PPDU_ID GENMASK(15, 0)195196struct hal_rx_ppdu_start {197__le32 info0;198__le32 chan_num;199__le32 ppdu_start_ts;200} __packed;201202#define HAL_RX_PPDU_END_USER_STATS_INFO0_MPDU_CNT_FCS_ERR GENMASK(25, 16)203204#define HAL_RX_PPDU_END_USER_STATS_INFO1_MPDU_CNT_FCS_OK GENMASK(8, 0)205#define HAL_RX_PPDU_END_USER_STATS_INFO1_FC_VALID BIT(9)206#define HAL_RX_PPDU_END_USER_STATS_INFO1_QOS_CTRL_VALID BIT(10)207#define HAL_RX_PPDU_END_USER_STATS_INFO1_HT_CTRL_VALID BIT(11)208#define HAL_RX_PPDU_END_USER_STATS_INFO1_PKT_TYPE GENMASK(23, 20)209210#define HAL_RX_PPDU_END_USER_STATS_INFO2_AST_INDEX GENMASK(15, 0)211#define HAL_RX_PPDU_END_USER_STATS_INFO2_FRAME_CTRL GENMASK(31, 16)212213#define HAL_RX_PPDU_END_USER_STATS_INFO3_QOS_CTRL GENMASK(31, 16)214215#define HAL_RX_PPDU_END_USER_STATS_INFO4_UDP_MSDU_CNT GENMASK(15, 0)216#define HAL_RX_PPDU_END_USER_STATS_INFO4_TCP_MSDU_CNT GENMASK(31, 16)217218#define HAL_RX_PPDU_END_USER_STATS_INFO5_OTHER_MSDU_CNT GENMASK(15, 0)219#define HAL_RX_PPDU_END_USER_STATS_INFO5_TCP_ACK_MSDU_CNT GENMASK(31, 16)220221#define HAL_RX_PPDU_END_USER_STATS_INFO6_TID_BITMAP GENMASK(15, 0)222#define HAL_RX_PPDU_END_USER_STATS_INFO6_TID_EOSP_BITMAP GENMASK(31, 16)223224#define HAL_RX_PPDU_END_USER_STATS_RSVD2_6_MPDU_OK_BYTE_COUNT GENMASK(24, 0)225#define HAL_RX_PPDU_END_USER_STATS_RSVD2_8_MPDU_ERR_BYTE_COUNT GENMASK(24, 0)226227struct hal_rx_ppdu_end_user_stats {228__le32 rsvd0[2];229__le32 info0;230__le32 info1;231__le32 info2;232__le32 info3;233__le32 ht_ctrl;234__le32 rsvd1[2];235__le32 info4;236__le32 info5;237__le32 info6;238__le32 rsvd2[11];239} __packed;240241struct hal_rx_ppdu_end_user_stats_ext {242u32 info0;243u32 info1;244u32 info2;245u32 info3;246u32 info4;247u32 info5;248u32 info6;249} __packed;250251#define HAL_RX_HT_SIG_INFO_INFO0_MCS GENMASK(6, 0)252#define HAL_RX_HT_SIG_INFO_INFO0_BW BIT(7)253254#define HAL_RX_HT_SIG_INFO_INFO1_STBC GENMASK(5, 4)255#define HAL_RX_HT_SIG_INFO_INFO1_FEC_CODING BIT(6)256#define HAL_RX_HT_SIG_INFO_INFO1_GI BIT(7)257258struct hal_rx_ht_sig_info {259__le32 info0;260__le32 info1;261} __packed;262263#define HAL_RX_LSIG_B_INFO_INFO0_RATE GENMASK(3, 0)264#define HAL_RX_LSIG_B_INFO_INFO0_LEN GENMASK(15, 4)265266struct hal_rx_lsig_b_info {267__le32 info0;268} __packed;269270#define HAL_RX_LSIG_A_INFO_INFO0_RATE GENMASK(3, 0)271#define HAL_RX_LSIG_A_INFO_INFO0_LEN GENMASK(16, 5)272#define HAL_RX_LSIG_A_INFO_INFO0_PKT_TYPE GENMASK(27, 24)273274struct hal_rx_lsig_a_info {275__le32 info0;276} __packed;277278#define HAL_RX_VHT_SIG_A_INFO_INFO0_BW GENMASK(1, 0)279#define HAL_RX_VHT_SIG_A_INFO_INFO0_STBC BIT(3)280#define HAL_RX_VHT_SIG_A_INFO_INFO0_GROUP_ID GENMASK(9, 4)281#define HAL_RX_VHT_SIG_A_INFO_INFO0_NSTS GENMASK(21, 10)282283#define HAL_RX_VHT_SIG_A_INFO_INFO1_GI_SETTING GENMASK(1, 0)284#define HAL_RX_VHT_SIG_A_INFO_INFO1_SU_MU_CODING BIT(2)285#define HAL_RX_VHT_SIG_A_INFO_INFO1_MCS GENMASK(7, 4)286#define HAL_RX_VHT_SIG_A_INFO_INFO1_BEAMFORMED BIT(8)287288struct hal_rx_vht_sig_a_info {289__le32 info0;290__le32 info1;291} __packed;292293enum hal_rx_vht_sig_a_gi_setting {294HAL_RX_VHT_SIG_A_NORMAL_GI = 0,295HAL_RX_VHT_SIG_A_SHORT_GI = 1,296HAL_RX_VHT_SIG_A_SHORT_GI_AMBIGUITY = 3,297};298299#define HAL_RX_SU_MU_CODING_LDPC 0x01300301#define HE_GI_0_8 0302#define HE_GI_0_4 1303#define HE_GI_1_6 2304#define HE_GI_3_2 3305306#define HE_LTF_1_X 0307#define HE_LTF_2_X 1308#define HE_LTF_4_X 2309#define HE_LTF_UNKNOWN 3310311#define HAL_RX_HE_SIG_A_SU_INFO_INFO0_TRANSMIT_MCS GENMASK(6, 3)312#define HAL_RX_HE_SIG_A_SU_INFO_INFO0_DCM BIT(7)313#define HAL_RX_HE_SIG_A_SU_INFO_INFO0_TRANSMIT_BW GENMASK(20, 19)314#define HAL_RX_HE_SIG_A_SU_INFO_INFO0_CP_LTF_SIZE GENMASK(22, 21)315#define HAL_RX_HE_SIG_A_SU_INFO_INFO0_NSTS GENMASK(25, 23)316#define HAL_RX_HE_SIG_A_SU_INFO_INFO0_BSS_COLOR GENMASK(13, 8)317#define HAL_RX_HE_SIG_A_SU_INFO_INFO0_SPATIAL_REUSE GENMASK(18, 15)318#define HAL_RX_HE_SIG_A_SU_INFO_INFO0_FORMAT_IND BIT(0)319#define HAL_RX_HE_SIG_A_SU_INFO_INFO0_BEAM_CHANGE BIT(1)320#define HAL_RX_HE_SIG_A_SU_INFO_INFO0_DL_UL_FLAG BIT(2)321322#define HAL_RX_HE_SIG_A_SU_INFO_INFO1_TXOP_DURATION GENMASK(6, 0)323#define HAL_RX_HE_SIG_A_SU_INFO_INFO1_CODING BIT(7)324#define HAL_RX_HE_SIG_A_SU_INFO_INFO1_LDPC_EXTRA BIT(8)325#define HAL_RX_HE_SIG_A_SU_INFO_INFO1_STBC BIT(9)326#define HAL_RX_HE_SIG_A_SU_INFO_INFO1_TXBF BIT(10)327#define HAL_RX_HE_SIG_A_SU_INFO_INFO1_PKT_EXT_FACTOR GENMASK(12, 11)328#define HAL_RX_HE_SIG_A_SU_INFO_INFO1_PKT_EXT_PE_DISAM BIT(13)329#define HAL_RX_HE_SIG_A_SU_INFO_INFO1_DOPPLER_IND BIT(15)330331struct hal_rx_he_sig_a_su_info {332__le32 info0;333__le32 info1;334} __packed;335336#define HAL_RX_HE_SIG_A_MU_DL_INFO_INFO0_UL_FLAG BIT(1)337#define HAL_RX_HE_SIG_A_MU_DL_INFO_INFO0_MCS_OF_SIGB GENMASK(3, 1)338#define HAL_RX_HE_SIG_A_MU_DL_INFO_INFO0_DCM_OF_SIGB BIT(4)339#define HAL_RX_HE_SIG_A_MU_DL_INFO_INFO0_BSS_COLOR GENMASK(10, 5)340#define HAL_RX_HE_SIG_A_MU_DL_INFO_INFO0_SPATIAL_REUSE GENMASK(14, 11)341#define HAL_RX_HE_SIG_A_MU_DL_INFO_INFO0_TRANSMIT_BW GENMASK(17, 15)342#define HAL_RX_HE_SIG_A_MU_DL_INFO_INFO0_NUM_SIGB_SYMB GENMASK(21, 18)343#define HAL_RX_HE_SIG_A_MU_DL_INFO_INFO0_COMP_MODE_SIGB BIT(22)344#define HAL_RX_HE_SIG_A_MU_DL_INFO_INFO0_CP_LTF_SIZE GENMASK(24, 23)345#define HAL_RX_HE_SIG_A_MU_DL_INFO_INFO0_DOPPLER_INDICATION BIT(25)346347#define HAL_RX_HE_SIG_A_MU_DL_INFO_INFO1_TXOP_DURATION GENMASK(6, 0)348#define HAL_RX_HE_SIG_A_MU_DL_INFO_INFO1_CODING BIT(7)349#define HAL_RX_HE_SIG_A_MU_DL_INFO_INFO1_NUM_LTF_SYMB GENMASK(10, 8)350#define HAL_RX_HE_SIG_A_MU_DL_INFO_INFO1_LDPC_EXTRA BIT(11)351#define HAL_RX_HE_SIG_A_MU_DL_INFO_INFO1_STBC BIT(12)352#define HAL_RX_HE_SIG_A_MU_DL_INFO_INFO1_TXBF BIT(10)353#define HAL_RX_HE_SIG_A_MU_DL_INFO_INFO1_PKT_EXT_FACTOR GENMASK(14, 13)354#define HAL_RX_HE_SIG_A_MU_DL_INFO_INFO1_PKT_EXT_PE_DISAM BIT(15)355356struct hal_rx_he_sig_a_mu_dl_info {357__le32 info0;358__le32 info1;359} __packed;360361#define HAL_RX_HE_SIG_B1_MU_INFO_INFO0_RU_ALLOCATION GENMASK(7, 0)362363struct hal_rx_he_sig_b1_mu_info {364__le32 info0;365} __packed;366367#define HAL_RX_HE_SIG_B2_MU_INFO_INFO0_STA_ID GENMASK(10, 0)368#define HAL_RX_HE_SIG_B2_MU_INFO_INFO0_STA_MCS GENMASK(18, 15)369#define HAL_RX_HE_SIG_B2_MU_INFO_INFO0_STA_CODING BIT(20)370#define HAL_RX_HE_SIG_B2_MU_INFO_INFO0_STA_NSTS GENMASK(31, 29)371372struct hal_rx_he_sig_b2_mu_info {373__le32 info0;374} __packed;375376#define HAL_RX_HE_SIG_B2_OFDMA_INFO_INFO0_STA_ID GENMASK(10, 0)377#define HAL_RX_HE_SIG_B2_OFDMA_INFO_INFO0_STA_NSTS GENMASK(13, 11)378#define HAL_RX_HE_SIG_B2_OFDMA_INFO_INFO0_STA_TXBF BIT(19)379#define HAL_RX_HE_SIG_B2_OFDMA_INFO_INFO0_STA_MCS GENMASK(18, 15)380#define HAL_RX_HE_SIG_B2_OFDMA_INFO_INFO0_STA_DCM BIT(19)381#define HAL_RX_HE_SIG_B2_OFDMA_INFO_INFO0_STA_CODING BIT(20)382383struct hal_rx_he_sig_b2_ofdma_info {384__le32 info0;385} __packed;386387#define HAL_RX_PHYRX_RSSI_LEGACY_INFO_INFO0_RSSI_COMB GENMASK(15, 8)388389#define HAL_RX_PHYRX_RSSI_PREAMBLE_PRI20 GENMASK(7, 0)390391struct hal_rx_phyrx_chain_rssi {392__le32 rssi_2040;393__le32 rssi_80;394} __packed;395396struct hal_rx_phyrx_rssi_legacy_info {397__le32 rsvd[3];398struct hal_rx_phyrx_chain_rssi pre_rssi[HAL_RX_MAX_NSS];399struct hal_rx_phyrx_chain_rssi preamble[HAL_RX_MAX_NSS];400__le32 info0;401} __packed;402403#define HAL_RX_MPDU_INFO_INFO0_PEERID GENMASK(31, 16)404#define HAL_RX_MPDU_INFO_INFO0_PEERID_WCN6855 GENMASK(15, 0)405#define HAL_RX_MPDU_INFO_INFO1_MPDU_LEN GENMASK(13, 0)406407struct hal_rx_mpdu_info_ipq8074 {408__le32 rsvd0;409__le32 info0;410__le32 rsvd1[11];411__le32 info1;412__le32 rsvd2[9];413} __packed;414415struct hal_rx_mpdu_info_qcn9074 {416__le32 rsvd0[10];417__le32 info0;418__le32 rsvd1[2];419__le32 info1;420__le32 rsvd2[9];421} __packed;422423struct hal_rx_mpdu_info_wcn6855 {424__le32 rsvd0[8];425__le32 info0;426__le32 rsvd1[14];427} __packed;428429struct hal_rx_mpdu_info {430union {431struct hal_rx_mpdu_info_ipq8074 ipq8074;432struct hal_rx_mpdu_info_qcn9074 qcn9074;433struct hal_rx_mpdu_info_wcn6855 wcn6855;434} u;435} __packed;436437#define HAL_RX_PPDU_END_DURATION GENMASK(23, 0)438struct hal_rx_ppdu_end_duration {439__le32 rsvd0[9];440__le32 info0;441__le32 rsvd1[4];442} __packed;443444struct hal_rx_rxpcu_classification_overview {445u32 rsvd0;446} __packed;447448struct hal_rx_msdu_desc_info {449u32 msdu_flags;450u16 msdu_len; /* 14 bits for length */451};452453#define HAL_RX_NUM_MSDU_DESC 6454struct hal_rx_msdu_list {455struct hal_rx_msdu_desc_info msdu_info[HAL_RX_NUM_MSDU_DESC];456u32 sw_cookie[HAL_RX_NUM_MSDU_DESC];457u8 rbm[HAL_RX_NUM_MSDU_DESC];458};459460void ath11k_hal_reo_status_queue_stats(struct ath11k_base *ab, u32 *reo_desc,461struct hal_reo_status *status);462void ath11k_hal_reo_flush_queue_status(struct ath11k_base *ab, u32 *reo_desc,463struct hal_reo_status *status);464void ath11k_hal_reo_flush_cache_status(struct ath11k_base *ab, u32 *reo_desc,465struct hal_reo_status *status);466void ath11k_hal_reo_flush_cache_status(struct ath11k_base *ab, u32 *reo_desc,467struct hal_reo_status *status);468void ath11k_hal_reo_unblk_cache_status(struct ath11k_base *ab, u32 *reo_desc,469struct hal_reo_status *status);470void ath11k_hal_reo_flush_timeout_list_status(struct ath11k_base *ab,471u32 *reo_desc,472struct hal_reo_status *status);473void ath11k_hal_reo_desc_thresh_reached_status(struct ath11k_base *ab,474u32 *reo_desc,475struct hal_reo_status *status);476void ath11k_hal_reo_update_rx_reo_queue_status(struct ath11k_base *ab,477u32 *reo_desc,478struct hal_reo_status *status);479int ath11k_hal_reo_process_status(u8 *reo_desc, u8 *status);480void ath11k_hal_rx_msdu_link_info_get(void *link_desc, u32 *num_msdus,481u32 *msdu_cookies,482enum hal_rx_buf_return_buf_manager *rbm);483void ath11k_hal_rx_msdu_link_desc_set(struct ath11k_base *ab, void *desc,484void *link_desc,485enum hal_wbm_rel_bm_act action);486void ath11k_hal_rx_buf_addr_info_set(void *desc, dma_addr_t paddr,487u32 cookie, u8 manager);488void ath11k_hal_rx_buf_addr_info_get(void *desc, dma_addr_t *paddr,489u32 *cookie, u8 *rbm);490int ath11k_hal_desc_reo_parse_err(struct ath11k_base *ab, u32 *rx_desc,491dma_addr_t *paddr, u32 *desc_bank);492int ath11k_hal_wbm_desc_parse_err(struct ath11k_base *ab, void *desc,493struct hal_rx_wbm_rel_info *rel_info);494void ath11k_hal_rx_reo_ent_paddr_get(struct ath11k_base *ab, void *desc,495dma_addr_t *paddr, u32 *desc_bank);496void ath11k_hal_rx_reo_ent_buf_paddr_get(void *rx_desc,497dma_addr_t *paddr, u32 *sw_cookie,498void **pp_buf_addr_info, u8 *rbm,499u32 *msdu_cnt);500void501ath11k_hal_rx_sw_mon_ring_buf_paddr_get(void *rx_desc,502struct hal_sw_mon_ring_entries *sw_mon_ent);503enum hal_rx_mon_status504ath11k_hal_rx_parse_mon_status(struct ath11k_base *ab,505struct hal_rx_mon_ppdu_info *ppdu_info,506struct sk_buff *skb);507508#define REO_QUEUE_DESC_MAGIC_DEBUG_PATTERN_0 0xDDBEEF509#define REO_QUEUE_DESC_MAGIC_DEBUG_PATTERN_1 0xADBEEF510#define REO_QUEUE_DESC_MAGIC_DEBUG_PATTERN_2 0xBDBEEF511#define REO_QUEUE_DESC_MAGIC_DEBUG_PATTERN_3 0xCDBEEF512#endif513514515