rx_rxpcu_classification_overview.h 8.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289
  1. /*
  2. * Copyright (c) 2020 The Linux Foundation. All rights reserved.
  3. *
  4. * Permission to use, copy, modify, and/or distribute this software for any
  5. * purpose with or without fee is hereby granted, provided that the above
  6. * copyright notice and this permission notice appear in all copies.
  7. *
  8. * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
  9. * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
  10. * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
  11. * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
  12. * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
  13. * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
  14. * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
  15. */
  16. // $ATH_LICENSE_HW_HDR_C$
  17. //
  18. // DO NOT EDIT! This file is automatically generated
  19. // These definitions are tied to a particular hardware layout
  20. #ifndef _RX_RXPCU_CLASSIFICATION_OVERVIEW_H_
  21. #define _RX_RXPCU_CLASSIFICATION_OVERVIEW_H_
  22. #if !defined(__ASSEMBLER__)
  23. #endif
  24. // ################ START SUMMARY #################
  25. //
  26. // Dword Fields
  27. // 0 filter_pass_mpdus[0], filter_pass_mpdus_fcs_ok[1], monitor_direct_mpdus[2], monitor_direct_mpdus_fcs_ok[3], monitor_other_mpdus[4], monitor_other_mpdus_fcs_ok[5], phyrx_abort_received[6], reserved_0[15:7], phy_ppdu_id[31:16]
  28. //
  29. // ################ END SUMMARY #################
  30. #define NUM_OF_DWORDS_RX_RXPCU_CLASSIFICATION_OVERVIEW 1
  31. struct rx_rxpcu_classification_overview {
  32. uint32_t filter_pass_mpdus : 1, //[0]
  33. filter_pass_mpdus_fcs_ok : 1, //[1]
  34. monitor_direct_mpdus : 1, //[2]
  35. monitor_direct_mpdus_fcs_ok : 1, //[3]
  36. monitor_other_mpdus : 1, //[4]
  37. monitor_other_mpdus_fcs_ok : 1, //[5]
  38. phyrx_abort_received : 1, //[6]
  39. reserved_0 : 9, //[15:7]
  40. phy_ppdu_id : 16; //[31:16]
  41. };
  42. /*
  43. filter_pass_mpdus
  44. When set, at least one Filter Pass MPDU has been
  45. received. FCS might or might not have been passing.
  46. For MU UL, in TLVs RX_PPDU_END and
  47. RX_PPDU_END_STATUS_DONE, this field is the OR of all the
  48. users.
  49. <legal all>
  50. filter_pass_mpdus_fcs_ok
  51. When set, at least one Filter Pass MPDU has been
  52. received that has a correct FCS.
  53. For MU UL, in TLVs RX_PPDU_END and
  54. RX_PPDU_END_STATUS_DONE, this field is the OR of all the
  55. users.
  56. <legal all>
  57. monitor_direct_mpdus
  58. When set, at least one Monitor Direct MPDU has been
  59. received. FCS might or might not have been passing
  60. For MU UL, in TLVs RX_PPDU_END and
  61. RX_PPDU_END_STATUS_DONE, this field is the OR of all the
  62. users.
  63. <legal all>
  64. monitor_direct_mpdus_fcs_ok
  65. When set, at least one Monitor Direct MPDU has been
  66. received that has a correct FCS.
  67. For MU UL, in TLVs RX_PPDU_END and
  68. RX_PPDU_END_STATUS_DONE, this field is the OR of all the
  69. users.
  70. <legal all>
  71. monitor_other_mpdus
  72. When set, at least one Monitor Direct MPDU has been
  73. received. FCS might or might not have been passing.
  74. For MU UL, in TLVs RX_PPDU_END and
  75. RX_PPDU_END_STATUS_DONE, this field is the OR of all the
  76. users.
  77. <legal all>
  78. monitor_other_mpdus_fcs_ok
  79. When set, at least one Monitor Direct MPDU has been
  80. received that has a correct FCS.
  81. For MU UL, in TLVs RX_PPDU_END and
  82. RX_PPDU_END_STATUS_DONE, this field is the OR of all the
  83. users.
  84. <legal all>
  85. phyrx_abort_received
  86. When set, PPDU reception was aborted by the PHY
  87. <legal all>
  88. reserved_0
  89. <legal 0>
  90. phy_ppdu_id
  91. A ppdu counter value that PHY increments for every PPDU
  92. received. The counter value wraps around
  93. <legal all>
  94. */
  95. /* Description RX_RXPCU_CLASSIFICATION_OVERVIEW_0_FILTER_PASS_MPDUS
  96. When set, at least one Filter Pass MPDU has been
  97. received. FCS might or might not have been passing.
  98. For MU UL, in TLVs RX_PPDU_END and
  99. RX_PPDU_END_STATUS_DONE, this field is the OR of all the
  100. users.
  101. <legal all>
  102. */
  103. #define RX_RXPCU_CLASSIFICATION_OVERVIEW_0_FILTER_PASS_MPDUS_OFFSET 0x00000000
  104. #define RX_RXPCU_CLASSIFICATION_OVERVIEW_0_FILTER_PASS_MPDUS_LSB 0
  105. #define RX_RXPCU_CLASSIFICATION_OVERVIEW_0_FILTER_PASS_MPDUS_MASK 0x00000001
  106. /* Description RX_RXPCU_CLASSIFICATION_OVERVIEW_0_FILTER_PASS_MPDUS_FCS_OK
  107. When set, at least one Filter Pass MPDU has been
  108. received that has a correct FCS.
  109. For MU UL, in TLVs RX_PPDU_END and
  110. RX_PPDU_END_STATUS_DONE, this field is the OR of all the
  111. users.
  112. <legal all>
  113. */
  114. #define RX_RXPCU_CLASSIFICATION_OVERVIEW_0_FILTER_PASS_MPDUS_FCS_OK_OFFSET 0x00000000
  115. #define RX_RXPCU_CLASSIFICATION_OVERVIEW_0_FILTER_PASS_MPDUS_FCS_OK_LSB 1
  116. #define RX_RXPCU_CLASSIFICATION_OVERVIEW_0_FILTER_PASS_MPDUS_FCS_OK_MASK 0x00000002
  117. /* Description RX_RXPCU_CLASSIFICATION_OVERVIEW_0_MONITOR_DIRECT_MPDUS
  118. When set, at least one Monitor Direct MPDU has been
  119. received. FCS might or might not have been passing
  120. For MU UL, in TLVs RX_PPDU_END and
  121. RX_PPDU_END_STATUS_DONE, this field is the OR of all the
  122. users.
  123. <legal all>
  124. */
  125. #define RX_RXPCU_CLASSIFICATION_OVERVIEW_0_MONITOR_DIRECT_MPDUS_OFFSET 0x00000000
  126. #define RX_RXPCU_CLASSIFICATION_OVERVIEW_0_MONITOR_DIRECT_MPDUS_LSB 2
  127. #define RX_RXPCU_CLASSIFICATION_OVERVIEW_0_MONITOR_DIRECT_MPDUS_MASK 0x00000004
  128. /* Description RX_RXPCU_CLASSIFICATION_OVERVIEW_0_MONITOR_DIRECT_MPDUS_FCS_OK
  129. When set, at least one Monitor Direct MPDU has been
  130. received that has a correct FCS.
  131. For MU UL, in TLVs RX_PPDU_END and
  132. RX_PPDU_END_STATUS_DONE, this field is the OR of all the
  133. users.
  134. <legal all>
  135. */
  136. #define RX_RXPCU_CLASSIFICATION_OVERVIEW_0_MONITOR_DIRECT_MPDUS_FCS_OK_OFFSET 0x00000000
  137. #define RX_RXPCU_CLASSIFICATION_OVERVIEW_0_MONITOR_DIRECT_MPDUS_FCS_OK_LSB 3
  138. #define RX_RXPCU_CLASSIFICATION_OVERVIEW_0_MONITOR_DIRECT_MPDUS_FCS_OK_MASK 0x00000008
  139. /* Description RX_RXPCU_CLASSIFICATION_OVERVIEW_0_MONITOR_OTHER_MPDUS
  140. When set, at least one Monitor Direct MPDU has been
  141. received. FCS might or might not have been passing.
  142. For MU UL, in TLVs RX_PPDU_END and
  143. RX_PPDU_END_STATUS_DONE, this field is the OR of all the
  144. users.
  145. <legal all>
  146. */
  147. #define RX_RXPCU_CLASSIFICATION_OVERVIEW_0_MONITOR_OTHER_MPDUS_OFFSET 0x00000000
  148. #define RX_RXPCU_CLASSIFICATION_OVERVIEW_0_MONITOR_OTHER_MPDUS_LSB 4
  149. #define RX_RXPCU_CLASSIFICATION_OVERVIEW_0_MONITOR_OTHER_MPDUS_MASK 0x00000010
  150. /* Description RX_RXPCU_CLASSIFICATION_OVERVIEW_0_MONITOR_OTHER_MPDUS_FCS_OK
  151. When set, at least one Monitor Direct MPDU has been
  152. received that has a correct FCS.
  153. For MU UL, in TLVs RX_PPDU_END and
  154. RX_PPDU_END_STATUS_DONE, this field is the OR of all the
  155. users.
  156. <legal all>
  157. */
  158. #define RX_RXPCU_CLASSIFICATION_OVERVIEW_0_MONITOR_OTHER_MPDUS_FCS_OK_OFFSET 0x00000000
  159. #define RX_RXPCU_CLASSIFICATION_OVERVIEW_0_MONITOR_OTHER_MPDUS_FCS_OK_LSB 5
  160. #define RX_RXPCU_CLASSIFICATION_OVERVIEW_0_MONITOR_OTHER_MPDUS_FCS_OK_MASK 0x00000020
  161. /* Description RX_RXPCU_CLASSIFICATION_OVERVIEW_0_PHYRX_ABORT_RECEIVED
  162. When set, PPDU reception was aborted by the PHY
  163. <legal all>
  164. */
  165. #define RX_RXPCU_CLASSIFICATION_OVERVIEW_0_PHYRX_ABORT_RECEIVED_OFFSET 0x00000000
  166. #define RX_RXPCU_CLASSIFICATION_OVERVIEW_0_PHYRX_ABORT_RECEIVED_LSB 6
  167. #define RX_RXPCU_CLASSIFICATION_OVERVIEW_0_PHYRX_ABORT_RECEIVED_MASK 0x00000040
  168. /* Description RX_RXPCU_CLASSIFICATION_OVERVIEW_0_RESERVED_0
  169. <legal 0>
  170. */
  171. #define RX_RXPCU_CLASSIFICATION_OVERVIEW_0_RESERVED_0_OFFSET 0x00000000
  172. #define RX_RXPCU_CLASSIFICATION_OVERVIEW_0_RESERVED_0_LSB 7
  173. #define RX_RXPCU_CLASSIFICATION_OVERVIEW_0_RESERVED_0_MASK 0x0000ff80
  174. /* Description RX_RXPCU_CLASSIFICATION_OVERVIEW_0_PHY_PPDU_ID
  175. A ppdu counter value that PHY increments for every PPDU
  176. received. The counter value wraps around
  177. <legal all>
  178. */
  179. #define RX_RXPCU_CLASSIFICATION_OVERVIEW_0_PHY_PPDU_ID_OFFSET 0x00000000
  180. #define RX_RXPCU_CLASSIFICATION_OVERVIEW_0_PHY_PPDU_ID_LSB 16
  181. #define RX_RXPCU_CLASSIFICATION_OVERVIEW_0_PHY_PPDU_ID_MASK 0xffff0000
  182. #endif // _RX_RXPCU_CLASSIFICATION_OVERVIEW_H_