phyrx_l_sig_a.h 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186
  1. /*
  2. * Copyright (c) 2020 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. //
  19. // DO NOT EDIT! This file is automatically generated
  20. // These definitions are tied to a particular hardware layout
  21. #ifndef _PHYRX_L_SIG_A_H_
  22. #define _PHYRX_L_SIG_A_H_
  23. #if !defined(__ASSEMBLER__)
  24. #endif
  25. #include "l_sig_a_info.h"
  26. // ################ START SUMMARY #################
  27. //
  28. // Dword Fields
  29. // 0 struct l_sig_a_info phyrx_l_sig_a_info_details;
  30. //
  31. // ################ END SUMMARY #################
  32. #define NUM_OF_DWORDS_PHYRX_L_SIG_A 1
  33. struct phyrx_l_sig_a {
  34. struct l_sig_a_info phyrx_l_sig_a_info_details;
  35. };
  36. /*
  37. struct l_sig_a_info phyrx_l_sig_a_info_details
  38. See detailed description of the STRUCT
  39. */
  40. /* EXTERNAL REFERENCE : struct l_sig_a_info phyrx_l_sig_a_info_details */
  41. /* Description PHYRX_L_SIG_A_0_PHYRX_L_SIG_A_INFO_DETAILS_RATE
  42. This format is originally defined for OFDM as a 4 bit
  43. field but the 5th bit was added to indicate 11b formatted
  44. frames. In the standard bit [4] is specified as reserved.
  45. For 11b frames this L-SIG is transformed in the PHY into the
  46. 11b preamble format. The following are the rates:
  47. <enum 8 ofdm_48_mbps> 64-QAM 2/3 (48 Mbps)
  48. <enum 9 ofdm_24_mbps> 16-QAM 1/2 (24 Mbps)
  49. <enum 10 ofdm_12_mbps> QPSK 1/2 (12 Mbps)
  50. <enum 11 ofdm_6_mbps> BPSK 1/2 (6 Mbps)
  51. <enum 12 ofdm_54_mbps> 64-QAM 3/4 (54 Mbps)
  52. <enum 13 ofdm_36_mbps> 16-QAM 3/4 (36 Mbps)
  53. <enum 14 ofdm_18_mbps> QPSK 1/2 (18 Mbps)
  54. <enum 15 ofdm_9_mbps> BPSK 3/4 (9 Mbps)
  55. <legal 8-15>
  56. */
  57. #define PHYRX_L_SIG_A_0_PHYRX_L_SIG_A_INFO_DETAILS_RATE_OFFSET 0x00000000
  58. #define PHYRX_L_SIG_A_0_PHYRX_L_SIG_A_INFO_DETAILS_RATE_LSB 0
  59. #define PHYRX_L_SIG_A_0_PHYRX_L_SIG_A_INFO_DETAILS_RATE_MASK 0x0000000f
  60. /* Description PHYRX_L_SIG_A_0_PHYRX_L_SIG_A_INFO_DETAILS_LSIG_RESERVED
  61. Reserved: Should be set to 0 by the MAC and ignored by
  62. the PHY
  63. <legal 0>
  64. */
  65. #define PHYRX_L_SIG_A_0_PHYRX_L_SIG_A_INFO_DETAILS_LSIG_RESERVED_OFFSET 0x00000000
  66. #define PHYRX_L_SIG_A_0_PHYRX_L_SIG_A_INFO_DETAILS_LSIG_RESERVED_LSB 4
  67. #define PHYRX_L_SIG_A_0_PHYRX_L_SIG_A_INFO_DETAILS_LSIG_RESERVED_MASK 0x00000010
  68. /* Description PHYRX_L_SIG_A_0_PHYRX_L_SIG_A_INFO_DETAILS_LENGTH
  69. The length indicates the number of octets in this MPDU.
  70. Note that when using mixed mode 11n preamble this length
  71. provides the spoofed length for the PPDU. This length
  72. provides part of the information to derive the actually PPDU
  73. length. For legacy OFDM and 11B frames the maximum length
  74. is
  75. <legal all>
  76. */
  77. #define PHYRX_L_SIG_A_0_PHYRX_L_SIG_A_INFO_DETAILS_LENGTH_OFFSET 0x00000000
  78. #define PHYRX_L_SIG_A_0_PHYRX_L_SIG_A_INFO_DETAILS_LENGTH_LSB 5
  79. #define PHYRX_L_SIG_A_0_PHYRX_L_SIG_A_INFO_DETAILS_LENGTH_MASK 0x0001ffe0
  80. /* Description PHYRX_L_SIG_A_0_PHYRX_L_SIG_A_INFO_DETAILS_PARITY
  81. 11a/n/ac TX: This field provides even parity over the
  82. first 18 bits of the signal field which means that the sum
  83. of 1s in the signal field will always be even on
  84. 11a/n/ac RX: this field contains the received parity
  85. field from the L-SIG symbol for the current packet.
  86. <legal 0-1>
  87. */
  88. #define PHYRX_L_SIG_A_0_PHYRX_L_SIG_A_INFO_DETAILS_PARITY_OFFSET 0x00000000
  89. #define PHYRX_L_SIG_A_0_PHYRX_L_SIG_A_INFO_DETAILS_PARITY_LSB 17
  90. #define PHYRX_L_SIG_A_0_PHYRX_L_SIG_A_INFO_DETAILS_PARITY_MASK 0x00020000
  91. /* Description PHYRX_L_SIG_A_0_PHYRX_L_SIG_A_INFO_DETAILS_TAIL
  92. The 6 bits of tail is always set to 0 is used to flush
  93. the BCC encoder and decoder. <legal 0>
  94. */
  95. #define PHYRX_L_SIG_A_0_PHYRX_L_SIG_A_INFO_DETAILS_TAIL_OFFSET 0x00000000
  96. #define PHYRX_L_SIG_A_0_PHYRX_L_SIG_A_INFO_DETAILS_TAIL_LSB 18
  97. #define PHYRX_L_SIG_A_0_PHYRX_L_SIG_A_INFO_DETAILS_TAIL_MASK 0x00fc0000
  98. /* Description PHYRX_L_SIG_A_0_PHYRX_L_SIG_A_INFO_DETAILS_PKT_TYPE
  99. Only used on the RX side.
  100. Note: This is not really part of L-SIG
  101. Packet type:
  102. <enum 0 dot11a>802.11a PPDU type
  103. <enum 1 dot11b>802.11b PPDU type
  104. <enum 2 dot11n_mm>802.11n Mixed Mode PPDU type
  105. <enum 3 dot11ac>802.11ac PPDU type
  106. <enum 4 dot11ax>802.11ax PPDU type
  107. <enum 5 dot11ba>802.11ba (WUR) PPDU type
  108. */
  109. #define PHYRX_L_SIG_A_0_PHYRX_L_SIG_A_INFO_DETAILS_PKT_TYPE_OFFSET 0x00000000
  110. #define PHYRX_L_SIG_A_0_PHYRX_L_SIG_A_INFO_DETAILS_PKT_TYPE_LSB 24
  111. #define PHYRX_L_SIG_A_0_PHYRX_L_SIG_A_INFO_DETAILS_PKT_TYPE_MASK 0x0f000000
  112. /* Description PHYRX_L_SIG_A_0_PHYRX_L_SIG_A_INFO_DETAILS_CAPTURED_IMPLICIT_SOUNDING
  113. Only used on the RX side.
  114. Note: This is not really part of L-SIG
  115. This indicates that the PHY has captured implicit
  116. sounding.
  117. */
  118. #define PHYRX_L_SIG_A_0_PHYRX_L_SIG_A_INFO_DETAILS_CAPTURED_IMPLICIT_SOUNDING_OFFSET 0x00000000
  119. #define PHYRX_L_SIG_A_0_PHYRX_L_SIG_A_INFO_DETAILS_CAPTURED_IMPLICIT_SOUNDING_LSB 28
  120. #define PHYRX_L_SIG_A_0_PHYRX_L_SIG_A_INFO_DETAILS_CAPTURED_IMPLICIT_SOUNDING_MASK 0x10000000
  121. /* Description PHYRX_L_SIG_A_0_PHYRX_L_SIG_A_INFO_DETAILS_RESERVED
  122. Reserved: Should be set to 0 by the transmitting MAC and
  123. ignored by the PHY <legal 0>
  124. */
  125. #define PHYRX_L_SIG_A_0_PHYRX_L_SIG_A_INFO_DETAILS_RESERVED_OFFSET 0x00000000
  126. #define PHYRX_L_SIG_A_0_PHYRX_L_SIG_A_INFO_DETAILS_RESERVED_LSB 29
  127. #define PHYRX_L_SIG_A_0_PHYRX_L_SIG_A_INFO_DETAILS_RESERVED_MASK 0xe0000000
  128. #endif // _PHYRX_L_SIG_A_H_