cdp_txrx_extd_struct.h 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176
  1. /*
  2. * Copyright (c) 2016-2019 The Linux Foundation. All rights reserved.
  3. *
  4. * Permission to use, copy, modify, and/or distribute this software for
  5. * any purpose with or without fee is hereby granted, provided that the
  6. * above copyright notice and this permission notice appear in all
  7. * copies.
  8. *
  9. * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
  10. * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
  11. * WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE
  12. * AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
  13. * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
  14. * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
  15. * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
  16. * PERFORMANCE OF THIS SOFTWARE.
  17. */
  18. #ifndef _CDP_TXRX_EXTD_STRUCT_H_
  19. #define _CDP_TXRX_EXTD_STRUCT_H_
  20. /* Maximum number of receive chains */
  21. #define CDP_MAX_RX_CHAINS 8
  22. #ifdef WLAN_RX_PKT_CAPTURE_ENH
  23. #define RX_ENH_CB_BUF_SIZE 0
  24. #define RX_ENH_CB_BUF_RESERVATION 256
  25. #define RX_ENH_CB_BUF_ALIGNMENT 4
  26. #define RX_ENH_CAPTURE_TRAILER_LEN 8
  27. #define RX_ENH_CAPTURE_MODE_MASK 0x0F
  28. #define RX_ENH_CAPTURE_TRAILER_ENABLE_MASK 0x10
  29. /**
  30. * struct cdp_rx_indication_mpdu_info - Rx MPDU info
  31. * @ppdu_id: PPDU Id
  32. * @duration: PPDU duration
  33. * @bw: Bandwidth
  34. * <enum 0 bw_20_MHz>
  35. * <enum 1 bw_40_MHz>
  36. * <enum 2 bw_80_MHz>
  37. * <enum 3 bw_160_MHz>
  38. * @ofdma_info_valid: RU info valid
  39. * @ofdma_ru_start_index: RU index number(0-73)
  40. * @ofdma_ru_width: size of RU in units of 1(26tone)RU
  41. * @nss: NSS 1,2, ...8
  42. * @mcs: MCS index
  43. * @preamble: preamble
  44. * @gi: <enum 0 0_8_us_sgi > Legacy normal GI
  45. * <enum 1 0_4_us_sgi > Legacy short GI
  46. * <enum 2 1_6_us_sgi > HE related GI
  47. * <enum 3 3_2_us_sgi > HE
  48. * @ldpc: ldpc
  49. * @fcs_err: FCS error
  50. * @ppdu_type: SU/MU_MIMO/MU_OFDMA/MU_MIMO_OFDMA/UL_TRIG/BURST_BCN/UL_BSR_RESP/
  51. * UL_BSR_TRIG/UNKNOWN
  52. * @rate: legacy packet rate
  53. * @rssi_comb: Combined RSSI value (units = dB above noise floor)
  54. * @nf: noise floor
  55. * @timestamp: TSF at the reception of PPDU
  56. * @length: PPDU length
  57. * @per_chain_rssi: RSSI per chain
  58. * @channel: Channel informartion
  59. */
  60. struct cdp_rx_indication_mpdu_info {
  61. uint32_t ppdu_id;
  62. uint16_t duration;
  63. uint64_t bw:4,
  64. ofdma_info_valid:1,
  65. ofdma_ru_start_index:7,
  66. ofdma_ru_width:7,
  67. nss:4,
  68. mcs:4,
  69. preamble:4,
  70. gi:4,
  71. ldpc:1,
  72. fcs_err:1,
  73. ppdu_type:5,
  74. rate:8;
  75. uint32_t rssi_comb;
  76. uint32_t nf;
  77. uint64_t timestamp;
  78. uint32_t length;
  79. uint8_t per_chain_rssi[CDP_MAX_RX_CHAINS];
  80. uint8_t channel;
  81. };
  82. #ifdef __KERNEL__
  83. /**
  84. * struct cdp_rx_indication_mpdu- Rx MPDU plus MPDU info
  85. * @mpdu_info: defined in cdp_rx_indication_mpdu_info
  86. * @nbuf: nbuf of mpdu control block
  87. */
  88. struct cdp_rx_indication_mpdu {
  89. struct cdp_rx_indication_mpdu_info mpdu_info;
  90. qdf_nbuf_t nbuf;
  91. };
  92. #endif
  93. #endif /* WLAN_RX_PKT_CAPTURE_ENH */
  94. struct ol_ath_dbg_rx_rssi {
  95. uint8_t rx_rssi_pri20;
  96. uint8_t rx_rssi_sec20;
  97. uint8_t rx_rssi_sec40;
  98. uint8_t rx_rssi_sec80;
  99. };
  100. struct ol_ath_radiostats {
  101. uint64_t tx_beacon;
  102. uint32_t tx_buf_count;
  103. int32_t tx_mgmt;
  104. int32_t rx_mgmt;
  105. uint32_t rx_num_mgmt;
  106. uint32_t rx_num_ctl;
  107. uint32_t tx_rssi;
  108. uint32_t rx_rssi_comb;
  109. struct ol_ath_dbg_rx_rssi rx_rssi_chain0;
  110. struct ol_ath_dbg_rx_rssi rx_rssi_chain1;
  111. struct ol_ath_dbg_rx_rssi rx_rssi_chain2;
  112. struct ol_ath_dbg_rx_rssi rx_rssi_chain3;
  113. uint32_t rx_overrun;
  114. uint32_t rx_phyerr;
  115. uint32_t ackrcvbad;
  116. uint32_t rtsbad;
  117. uint32_t rtsgood;
  118. uint32_t fcsbad;
  119. uint32_t nobeacons;
  120. uint32_t mib_int_count;
  121. uint32_t rx_looplimit_start;
  122. uint32_t rx_looplimit_end;
  123. uint8_t ap_stats_tx_cal_enable;
  124. uint8_t self_bss_util;
  125. uint8_t obss_util;
  126. uint8_t ap_rx_util;
  127. uint8_t free_medium;
  128. uint8_t ap_tx_util;
  129. uint8_t obss_rx_util;
  130. uint8_t non_wifi_util;
  131. uint32_t tgt_asserts;
  132. int16_t chan_nf;
  133. int16_t chan_nf_sec80;
  134. uint64_t wmi_tx_mgmt;
  135. uint64_t wmi_tx_mgmt_completions;
  136. uint32_t wmi_tx_mgmt_completion_err;
  137. uint32_t rx_mgmt_rssi_drop;
  138. uint32_t tx_frame_count;
  139. uint32_t rx_frame_count;
  140. uint32_t rx_clear_count;
  141. uint32_t cycle_count;
  142. uint32_t phy_err_count;
  143. uint32_t chan_tx_pwr;
  144. uint32_t be_nobuf;
  145. uint32_t tx_packets;
  146. uint32_t rx_packets;
  147. uint32_t tx_num_data;
  148. uint32_t rx_num_data;
  149. uint32_t tx_mcs[10];
  150. uint32_t rx_mcs[10];
  151. uint64_t rx_bytes;
  152. uint64_t tx_bytes;
  153. uint32_t tx_compaggr;
  154. uint32_t rx_aggr;
  155. uint32_t tx_bawadv;
  156. uint32_t tx_compunaggr;
  157. uint32_t rx_badcrypt;
  158. uint32_t rx_badmic;
  159. uint32_t rx_crcerr;
  160. uint32_t rx_last_msdu_unset_cnt;
  161. uint32_t rx_data_bytes;
  162. uint32_t tx_retries;
  163. };
  164. /* Enumeration of PDEV Configuration parameter */
  165. enum _ol_hal_param_t {
  166. OL_HAL_CONFIG_DMA_BEACON_RESPONSE_TIME = 0
  167. };
  168. #endif /* _CDP_TXRX_EXTD_STRUCT_H_ */