l_sig_a_info.h 8.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264
  1. /*
  2. * Copyright (c) 2018 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. // $ATH_LICENSE_HW_HDR_C$
  19. //
  20. // DO NOT EDIT! This file is automatically generated
  21. // These definitions are tied to a particular hardware layout
  22. #ifndef _L_SIG_A_INFO_H_
  23. #define _L_SIG_A_INFO_H_
  24. #if !defined(__ASSEMBLER__)
  25. #endif
  26. // ################ START SUMMARY #################
  27. //
  28. // Dword Fields
  29. // 0 rate[3:0], lsig_reserved[4], length[16:5], parity[17], tail[23:18], pkt_type[27:24], captured_implicit_sounding[28], reserved[31:29]
  30. //
  31. // ################ END SUMMARY #################
  32. #define NUM_OF_DWORDS_L_SIG_A_INFO 1
  33. struct l_sig_a_info {
  34. uint32_t rate : 4, //[3:0]
  35. lsig_reserved : 1, //[4]
  36. length : 12, //[16:5]
  37. parity : 1, //[17]
  38. tail : 6, //[23:18]
  39. pkt_type : 4, //[27:24]
  40. captured_implicit_sounding : 1, //[28]
  41. reserved : 3; //[31:29]
  42. };
  43. /*
  44. rate
  45. This format is originally defined for OFDM as a 4 bit
  46. field but the 5th bit was added to indicate 11b formatted
  47. frames. In the standard bit [4] is specified as reserved.
  48. For 11b frames this L-SIG is transformed in the PHY into the
  49. 11b preamble format. The following are the rates:
  50. <enum 8 ofdm_48_mbps> 64-QAM 2/3 (48 Mbps)
  51. <enum 9 ofdm_24_mbps> 16-QAM 1/2 (24 Mbps)
  52. <enum 10 ofdm_12_mbps> QPSK 1/2 (12 Mbps)
  53. <enum 11 ofdm_6_mbps> BPSK 1/2 (6 Mbps)
  54. <enum 12 ofdm_54_mbps> 64-QAM 3/4 (54 Mbps)
  55. <enum 13 ofdm_36_mbps> 16-QAM 3/4 (36 Mbps)
  56. <enum 14 ofdm_18_mbps> QPSK 1/2 (18 Mbps)
  57. <enum 15 ofdm_9_mbps> BPSK 3/4 (9 Mbps)
  58. <legal 8-15>
  59. lsig_reserved
  60. Reserved: Should be set to 0 by the MAC and ignored by
  61. the PHY
  62. <legal 0>
  63. length
  64. The length indicates the number of octets in this MPDU.
  65. Note that when using mixed mode 11n preamble this length
  66. provides the spoofed length for the PPDU. This length
  67. provides part of the information to derive the actually PPDU
  68. length. For legacy OFDM and 11B frames the maximum length
  69. is
  70. <legal all>
  71. parity
  72. 11a/n/ac TX: This field provides even parity over the
  73. first 18 bits of the signal field which means that the sum
  74. of 1s in the signal field will always be even on
  75. 11a/n/ac RX: this field contains the received parity
  76. field from the L-SIG symbol for the current packet.
  77. <legal 0-1>
  78. tail
  79. The 6 bits of tail is always set to 0 is used to flush
  80. the BCC encoder and decoder. <legal 0>
  81. pkt_type
  82. Note: This is not really part of L-SIG
  83. Packet type:
  84. <enum 0 dot11a>802.11a PPDU type
  85. <enum 1 dot11b>802.11b PPDU type
  86. <enum 2 dot11n_mm>802.11n Mixed Mode PPDU type
  87. <enum 3 dot11ac>802.11ac PPDU type
  88. <enum 4 dot11ax>802.11ax PPDU type
  89. captured_implicit_sounding
  90. Only used on the RX side. This indicates that the PHY
  91. has captured implicit sounding.
  92. reserved
  93. Reserved: Should be set to 0 by the transmitting MAC and
  94. ignored by the PHY <legal 0>
  95. */
  96. /* Description L_SIG_A_INFO_0_RATE
  97. This format is originally defined for OFDM as a 4 bit
  98. field but the 5th bit was added to indicate 11b formatted
  99. frames. In the standard bit [4] is specified as reserved.
  100. For 11b frames this L-SIG is transformed in the PHY into the
  101. 11b preamble format. The following are the rates:
  102. <enum 8 ofdm_48_mbps> 64-QAM 2/3 (48 Mbps)
  103. <enum 9 ofdm_24_mbps> 16-QAM 1/2 (24 Mbps)
  104. <enum 10 ofdm_12_mbps> QPSK 1/2 (12 Mbps)
  105. <enum 11 ofdm_6_mbps> BPSK 1/2 (6 Mbps)
  106. <enum 12 ofdm_54_mbps> 64-QAM 3/4 (54 Mbps)
  107. <enum 13 ofdm_36_mbps> 16-QAM 3/4 (36 Mbps)
  108. <enum 14 ofdm_18_mbps> QPSK 1/2 (18 Mbps)
  109. <enum 15 ofdm_9_mbps> BPSK 3/4 (9 Mbps)
  110. <legal 8-15>
  111. */
  112. #define L_SIG_A_INFO_0_RATE_OFFSET 0x00000000
  113. #define L_SIG_A_INFO_0_RATE_LSB 0
  114. #define L_SIG_A_INFO_0_RATE_MASK 0x0000000f
  115. /* Description L_SIG_A_INFO_0_LSIG_RESERVED
  116. Reserved: Should be set to 0 by the MAC and ignored by
  117. the PHY
  118. <legal 0>
  119. */
  120. #define L_SIG_A_INFO_0_LSIG_RESERVED_OFFSET 0x00000000
  121. #define L_SIG_A_INFO_0_LSIG_RESERVED_LSB 4
  122. #define L_SIG_A_INFO_0_LSIG_RESERVED_MASK 0x00000010
  123. /* Description L_SIG_A_INFO_0_LENGTH
  124. The length indicates the number of octets in this MPDU.
  125. Note that when using mixed mode 11n preamble this length
  126. provides the spoofed length for the PPDU. This length
  127. provides part of the information to derive the actually PPDU
  128. length. For legacy OFDM and 11B frames the maximum length
  129. is
  130. <legal all>
  131. */
  132. #define L_SIG_A_INFO_0_LENGTH_OFFSET 0x00000000
  133. #define L_SIG_A_INFO_0_LENGTH_LSB 5
  134. #define L_SIG_A_INFO_0_LENGTH_MASK 0x0001ffe0
  135. /* Description L_SIG_A_INFO_0_PARITY
  136. 11a/n/ac TX: This field provides even parity over the
  137. first 18 bits of the signal field which means that the sum
  138. of 1s in the signal field will always be even on
  139. 11a/n/ac RX: this field contains the received parity
  140. field from the L-SIG symbol for the current packet.
  141. <legal 0-1>
  142. */
  143. #define L_SIG_A_INFO_0_PARITY_OFFSET 0x00000000
  144. #define L_SIG_A_INFO_0_PARITY_LSB 17
  145. #define L_SIG_A_INFO_0_PARITY_MASK 0x00020000
  146. /* Description L_SIG_A_INFO_0_TAIL
  147. The 6 bits of tail is always set to 0 is used to flush
  148. the BCC encoder and decoder. <legal 0>
  149. */
  150. #define L_SIG_A_INFO_0_TAIL_OFFSET 0x00000000
  151. #define L_SIG_A_INFO_0_TAIL_LSB 18
  152. #define L_SIG_A_INFO_0_TAIL_MASK 0x00fc0000
  153. /* Description L_SIG_A_INFO_0_PKT_TYPE
  154. Note: This is not really part of L-SIG
  155. Packet type:
  156. <enum 0 dot11a>802.11a PPDU type
  157. <enum 1 dot11b>802.11b PPDU type
  158. <enum 2 dot11n_mm>802.11n Mixed Mode PPDU type
  159. <enum 3 dot11ac>802.11ac PPDU type
  160. <enum 4 dot11ax>802.11ax PPDU type
  161. */
  162. #define L_SIG_A_INFO_0_PKT_TYPE_OFFSET 0x00000000
  163. #define L_SIG_A_INFO_0_PKT_TYPE_LSB 24
  164. #define L_SIG_A_INFO_0_PKT_TYPE_MASK 0x0f000000
  165. /* Description L_SIG_A_INFO_0_CAPTURED_IMPLICIT_SOUNDING
  166. Only used on the RX side. This indicates that the PHY
  167. has captured implicit sounding.
  168. */
  169. #define L_SIG_A_INFO_0_CAPTURED_IMPLICIT_SOUNDING_OFFSET 0x00000000
  170. #define L_SIG_A_INFO_0_CAPTURED_IMPLICIT_SOUNDING_LSB 28
  171. #define L_SIG_A_INFO_0_CAPTURED_IMPLICIT_SOUNDING_MASK 0x10000000
  172. /* Description L_SIG_A_INFO_0_RESERVED
  173. Reserved: Should be set to 0 by the transmitting MAC and
  174. ignored by the PHY <legal 0>
  175. */
  176. #define L_SIG_A_INFO_0_RESERVED_OFFSET 0x00000000
  177. #define L_SIG_A_INFO_0_RESERVED_LSB 29
  178. #define L_SIG_A_INFO_0_RESERVED_MASK 0xe0000000
  179. #endif // _L_SIG_A_INFO_H_