rx_msdu_details.h 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547
  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 _RX_MSDU_DETAILS_H_
  22. #define _RX_MSDU_DETAILS_H_
  23. #if !defined(__ASSEMBLER__)
  24. #endif
  25. #include "buffer_addr_info.h"
  26. #include "rx_msdu_desc_info.h"
  27. // ################ START SUMMARY #################
  28. //
  29. // Dword Fields
  30. // 0-1 struct buffer_addr_info buffer_addr_info_details;
  31. // 2-3 struct rx_msdu_desc_info rx_msdu_desc_info_details;
  32. //
  33. // ################ END SUMMARY #################
  34. #define NUM_OF_DWORDS_RX_MSDU_DETAILS 4
  35. struct rx_msdu_details {
  36. struct buffer_addr_info buffer_addr_info_details;
  37. struct rx_msdu_desc_info rx_msdu_desc_info_details;
  38. };
  39. /*
  40. struct buffer_addr_info buffer_addr_info_details
  41. Consumer: REO/SW
  42. Producer: RXDMA
  43. Details of the physical address of the buffer containing
  44. an MSDU (or entire MPDU)
  45. struct rx_msdu_desc_info rx_msdu_desc_info_details
  46. Consumer: REO/SW
  47. Producer: RXDMA
  48. General information related to the MSDU that should be
  49. passed on from RXDMA all the way to to the REO destination
  50. ring.
  51. */
  52. /* EXTERNAL REFERENCE : struct buffer_addr_info buffer_addr_info_details */
  53. /* Description RX_MSDU_DETAILS_0_BUFFER_ADDR_INFO_DETAILS_BUFFER_ADDR_31_0
  54. Address (lower 32 bits) of the MSDU buffer OR
  55. MSDU_EXTENSION descriptor OR Link Descriptor
  56. In case of 'NULL' pointer, this field is set to 0
  57. <legal all>
  58. */
  59. #define RX_MSDU_DETAILS_0_BUFFER_ADDR_INFO_DETAILS_BUFFER_ADDR_31_0_OFFSET 0x00000000
  60. #define RX_MSDU_DETAILS_0_BUFFER_ADDR_INFO_DETAILS_BUFFER_ADDR_31_0_LSB 0
  61. #define RX_MSDU_DETAILS_0_BUFFER_ADDR_INFO_DETAILS_BUFFER_ADDR_31_0_MASK 0xffffffff
  62. /* Description RX_MSDU_DETAILS_1_BUFFER_ADDR_INFO_DETAILS_BUFFER_ADDR_39_32
  63. Address (upper 8 bits) of the MSDU buffer OR
  64. MSDU_EXTENSION descriptor OR Link Descriptor
  65. In case of 'NULL' pointer, this field is set to 0
  66. <legal all>
  67. */
  68. #define RX_MSDU_DETAILS_1_BUFFER_ADDR_INFO_DETAILS_BUFFER_ADDR_39_32_OFFSET 0x00000004
  69. #define RX_MSDU_DETAILS_1_BUFFER_ADDR_INFO_DETAILS_BUFFER_ADDR_39_32_LSB 0
  70. #define RX_MSDU_DETAILS_1_BUFFER_ADDR_INFO_DETAILS_BUFFER_ADDR_39_32_MASK 0x000000ff
  71. /* Description RX_MSDU_DETAILS_1_BUFFER_ADDR_INFO_DETAILS_RETURN_BUFFER_MANAGER
  72. Consumer: WBM
  73. Producer: SW/FW
  74. In case of 'NULL' pointer, this field is set to 0
  75. Indicates to which buffer manager the buffer OR
  76. MSDU_EXTENSION descriptor OR link descriptor that is being
  77. pointed to shall be returned after the frame has been
  78. processed. It is used by WBM for routing purposes.
  79. <enum 0 WBM_IDLE_BUF_LIST> This buffer shall be returned
  80. to the WMB buffer idle list
  81. <enum 1 WBM_IDLE_DESC_LIST> This buffer shall be
  82. returned to the WMB idle link descriptor idle list
  83. <enum 2 FW_BM> This buffer shall be returned to the FW
  84. <enum 3 SW0_BM> This buffer shall be returned to the SW,
  85. ring 0
  86. <enum 4 SW1_BM> This buffer shall be returned to the SW,
  87. ring 1
  88. <enum 5 SW2_BM> This buffer shall be returned to the SW,
  89. ring 2
  90. <enum 6 SW3_BM> This buffer shall be returned to the SW,
  91. ring 3
  92. <enum 7 SW4_BM> This buffer shall be returned to the SW,
  93. ring 4
  94. <legal all>
  95. */
  96. #define RX_MSDU_DETAILS_1_BUFFER_ADDR_INFO_DETAILS_RETURN_BUFFER_MANAGER_OFFSET 0x00000004
  97. #define RX_MSDU_DETAILS_1_BUFFER_ADDR_INFO_DETAILS_RETURN_BUFFER_MANAGER_LSB 8
  98. #define RX_MSDU_DETAILS_1_BUFFER_ADDR_INFO_DETAILS_RETURN_BUFFER_MANAGER_MASK 0x00000700
  99. /* Description RX_MSDU_DETAILS_1_BUFFER_ADDR_INFO_DETAILS_SW_BUFFER_COOKIE
  100. Cookie field exclusively used by SW.
  101. In case of 'NULL' pointer, this field is set to 0
  102. HW ignores the contents, accept that it passes the
  103. programmed value on to other descriptors together with the
  104. physical address
  105. Field can be used by SW to for example associate the
  106. buffers physical address with the virtual address
  107. The bit definitions as used by SW are within SW HLD
  108. specification
  109. NOTE:
  110. The three most significant bits can have a special
  111. meaning in case this struct is embedded in a TX_MPDU_DETAILS
  112. STRUCT, and field transmit_bw_restriction is set
  113. In case of NON punctured transmission:
  114. Sw_buffer_cookie[20:19] = 2'b00: 20 MHz TX only
  115. Sw_buffer_cookie[20:19] = 2'b01: 40 MHz TX only
  116. Sw_buffer_cookie[20:19] = 2'b10: 80 MHz TX only
  117. Sw_buffer_cookie[20:19] = 2'b11: 160 MHz TX only
  118. In case of punctured transmission:
  119. Sw_buffer_cookie[20:18] = 3'b000: pattern 0 only
  120. Sw_buffer_cookie[20:18] = 3'b001: pattern 1 only
  121. Sw_buffer_cookie[20:18] = 3'b010: pattern 2 only
  122. Sw_buffer_cookie[20:18] = 3'b011: pattern 3 only
  123. Sw_buffer_cookie[20:18] = 3'b100: pattern 4 only
  124. Sw_buffer_cookie[20:18] = 3'b101: pattern 5 only
  125. Sw_buffer_cookie[20:18] = 3'b110: pattern 6 only
  126. Sw_buffer_cookie[20:18] = 3'b111: pattern 7 only
  127. Note: a punctured transmission is indicated by the
  128. presence of TLV TX_PUNCTURE_SETUP embedded in the scheduler
  129. TLV
  130. <legal all>
  131. */
  132. #define RX_MSDU_DETAILS_1_BUFFER_ADDR_INFO_DETAILS_SW_BUFFER_COOKIE_OFFSET 0x00000004
  133. #define RX_MSDU_DETAILS_1_BUFFER_ADDR_INFO_DETAILS_SW_BUFFER_COOKIE_LSB 11
  134. #define RX_MSDU_DETAILS_1_BUFFER_ADDR_INFO_DETAILS_SW_BUFFER_COOKIE_MASK 0xfffff800
  135. /* EXTERNAL REFERENCE : struct rx_msdu_desc_info rx_msdu_desc_info_details */
  136. /* Description RX_MSDU_DETAILS_2_RX_MSDU_DESC_INFO_DETAILS_FIRST_MSDU_IN_MPDU_FLAG
  137. Parsed from RX_MSDU_END TLV . In the case MSDU spans
  138. over multiple buffers, this field will be valid in the Last
  139. buffer used by the MSDU
  140. <enum 0 Not_first_msdu> This is not the first MSDU in
  141. the MPDU.
  142. <enum 1 first_msdu> This MSDU is the first one in the
  143. MPDU.
  144. <legal all>
  145. */
  146. #define RX_MSDU_DETAILS_2_RX_MSDU_DESC_INFO_DETAILS_FIRST_MSDU_IN_MPDU_FLAG_OFFSET 0x00000008
  147. #define RX_MSDU_DETAILS_2_RX_MSDU_DESC_INFO_DETAILS_FIRST_MSDU_IN_MPDU_FLAG_LSB 0
  148. #define RX_MSDU_DETAILS_2_RX_MSDU_DESC_INFO_DETAILS_FIRST_MSDU_IN_MPDU_FLAG_MASK 0x00000001
  149. /* Description RX_MSDU_DETAILS_2_RX_MSDU_DESC_INFO_DETAILS_LAST_MSDU_IN_MPDU_FLAG
  150. Consumer: WBM/REO/SW/FW
  151. Producer: RXDMA
  152. Parsed from RX_MSDU_END TLV . In the case MSDU spans
  153. over multiple buffers, this field will be valid in the Last
  154. buffer used by the MSDU
  155. <enum 0 Not_last_msdu> There are more MSDUs linked to
  156. this MSDU that belongs to this MPDU
  157. <enum 1 Last_msdu> this MSDU is the last one in the
  158. MPDU. This setting is only allowed in combination with
  159. 'Msdu_continuation' set to 0. This implies that when an msdu
  160. is spread out over multiple buffers and thus
  161. msdu_continuation is set, only for the very last buffer of
  162. the msdu, can the 'last_msdu_in_mpdu_flag' be set.
  163. When both first_msdu_in_mpdu_flag and
  164. last_msdu_in_mpdu_flag are set, the MPDU that this MSDU
  165. belongs to only contains a single MSDU.
  166. <legal all>
  167. */
  168. #define RX_MSDU_DETAILS_2_RX_MSDU_DESC_INFO_DETAILS_LAST_MSDU_IN_MPDU_FLAG_OFFSET 0x00000008
  169. #define RX_MSDU_DETAILS_2_RX_MSDU_DESC_INFO_DETAILS_LAST_MSDU_IN_MPDU_FLAG_LSB 1
  170. #define RX_MSDU_DETAILS_2_RX_MSDU_DESC_INFO_DETAILS_LAST_MSDU_IN_MPDU_FLAG_MASK 0x00000002
  171. /* Description RX_MSDU_DETAILS_2_RX_MSDU_DESC_INFO_DETAILS_MSDU_CONTINUATION
  172. When set, this MSDU buffer was not able to hold the
  173. entire MSDU. The next buffer will therefor contain
  174. additional information related to this MSDU.
  175. <legal all>
  176. */
  177. #define RX_MSDU_DETAILS_2_RX_MSDU_DESC_INFO_DETAILS_MSDU_CONTINUATION_OFFSET 0x00000008
  178. #define RX_MSDU_DETAILS_2_RX_MSDU_DESC_INFO_DETAILS_MSDU_CONTINUATION_LSB 2
  179. #define RX_MSDU_DETAILS_2_RX_MSDU_DESC_INFO_DETAILS_MSDU_CONTINUATION_MASK 0x00000004
  180. /* Description RX_MSDU_DETAILS_2_RX_MSDU_DESC_INFO_DETAILS_MSDU_LENGTH
  181. Parsed from RX_MSDU_START TLV . In the case MSDU spans
  182. over multiple buffers, this field will be valid in the First
  183. buffer used by MSDU.
  184. Full MSDU length in bytes after decapsulation.
  185. This field is still valid for MPDU frames without
  186. A-MSDU. It still represents MSDU length after decapsulation
  187. Or in case of RAW MPDUs, it indicates the length of the
  188. entire MPDU (without FCS field)
  189. <legal all>
  190. */
  191. #define RX_MSDU_DETAILS_2_RX_MSDU_DESC_INFO_DETAILS_MSDU_LENGTH_OFFSET 0x00000008
  192. #define RX_MSDU_DETAILS_2_RX_MSDU_DESC_INFO_DETAILS_MSDU_LENGTH_LSB 3
  193. #define RX_MSDU_DETAILS_2_RX_MSDU_DESC_INFO_DETAILS_MSDU_LENGTH_MASK 0x0001fff8
  194. /* Description RX_MSDU_DETAILS_2_RX_MSDU_DESC_INFO_DETAILS_REO_DESTINATION_INDICATION
  195. Parsed from RX_MSDU_END TLV . In the case MSDU spans
  196. over multiple buffers, this field will be valid in the Last
  197. buffer used by the MSDU
  198. The ID of the REO exit ring where the MSDU frame shall
  199. push after (MPDU level) reordering has finished.
  200. <enum 0 reo_destination_tcl> Reo will push the frame
  201. into the REO2TCL ring
  202. <enum 1 reo_destination_sw1> Reo will push the frame
  203. into the REO2SW1 ring
  204. <enum 2 reo_destination_sw2> Reo will push the frame
  205. into the REO2SW2 ring
  206. <enum 3 reo_destination_sw3> Reo will push the frame
  207. into the REO2SW3 ring
  208. <enum 4 reo_destination_sw4> Reo will push the frame
  209. into the REO2SW4 ring
  210. <enum 5 reo_destination_release> Reo will push the frame
  211. into the REO_release ring
  212. <enum 6 reo_destination_fw> Reo will push the frame into
  213. the REO2FW ring
  214. <enum 7 reo_destination_sw5> Reo will push the frame
  215. into the REO2SW5 ring (REO remaps this in chips without
  216. REO2SW5 ring, e.g. Pine)
  217. <enum 8 reo_destination_sw6> Reo will push the frame
  218. into the REO2SW6 ring (REO remaps this in chips without
  219. REO2SW6 ring, e.g. Pine)
  220. <enum 9 reo_destination_9> REO remaps this <enum 10
  221. reo_destination_10> REO remaps this
  222. <enum 11 reo_destination_11> REO remaps this
  223. <enum 12 reo_destination_12> REO remaps this <enum 13
  224. reo_destination_13> REO remaps this
  225. <enum 14 reo_destination_14> REO remaps this
  226. <enum 15 reo_destination_15> REO remaps this
  227. <enum 16 reo_destination_16> REO remaps this
  228. <enum 17 reo_destination_17> REO remaps this
  229. <enum 18 reo_destination_18> REO remaps this
  230. <enum 19 reo_destination_19> REO remaps this
  231. <enum 20 reo_destination_20> REO remaps this
  232. <enum 21 reo_destination_21> REO remaps this
  233. <enum 22 reo_destination_22> REO remaps this
  234. <enum 23 reo_destination_23> REO remaps this
  235. <enum 24 reo_destination_24> REO remaps this
  236. <enum 25 reo_destination_25> REO remaps this
  237. <enum 26 reo_destination_26> REO remaps this
  238. <enum 27 reo_destination_27> REO remaps this
  239. <enum 28 reo_destination_28> REO remaps this
  240. <enum 29 reo_destination_29> REO remaps this
  241. <enum 30 reo_destination_30> REO remaps this
  242. <enum 31 reo_destination_31> REO remaps this
  243. <legal all>
  244. */
  245. #define RX_MSDU_DETAILS_2_RX_MSDU_DESC_INFO_DETAILS_REO_DESTINATION_INDICATION_OFFSET 0x00000008
  246. #define RX_MSDU_DETAILS_2_RX_MSDU_DESC_INFO_DETAILS_REO_DESTINATION_INDICATION_LSB 17
  247. #define RX_MSDU_DETAILS_2_RX_MSDU_DESC_INFO_DETAILS_REO_DESTINATION_INDICATION_MASK 0x003e0000
  248. /* Description RX_MSDU_DETAILS_2_RX_MSDU_DESC_INFO_DETAILS_MSDU_DROP
  249. Parsed from RX_MSDU_END TLV . In the case MSDU spans
  250. over multiple buffers, this field will be valid in the Last
  251. buffer used by the MSDU
  252. When set, REO shall drop this MSDU and not forward it to
  253. any other ring...
  254. <legal all>
  255. */
  256. #define RX_MSDU_DETAILS_2_RX_MSDU_DESC_INFO_DETAILS_MSDU_DROP_OFFSET 0x00000008
  257. #define RX_MSDU_DETAILS_2_RX_MSDU_DESC_INFO_DETAILS_MSDU_DROP_LSB 22
  258. #define RX_MSDU_DETAILS_2_RX_MSDU_DESC_INFO_DETAILS_MSDU_DROP_MASK 0x00400000
  259. /* Description RX_MSDU_DETAILS_2_RX_MSDU_DESC_INFO_DETAILS_SA_IS_VALID
  260. Parsed from RX_MSDU_END TLV . In the case MSDU spans
  261. over multiple buffers, this field will be valid in the Last
  262. buffer used by the MSDU
  263. Indicates that OLE found a valid SA entry for this MSDU
  264. <legal all>
  265. */
  266. #define RX_MSDU_DETAILS_2_RX_MSDU_DESC_INFO_DETAILS_SA_IS_VALID_OFFSET 0x00000008
  267. #define RX_MSDU_DETAILS_2_RX_MSDU_DESC_INFO_DETAILS_SA_IS_VALID_LSB 23
  268. #define RX_MSDU_DETAILS_2_RX_MSDU_DESC_INFO_DETAILS_SA_IS_VALID_MASK 0x00800000
  269. /* Description RX_MSDU_DETAILS_2_RX_MSDU_DESC_INFO_DETAILS_SA_IDX_TIMEOUT
  270. Parsed from RX_MSDU_END TLV . In the case MSDU spans
  271. over multiple buffers, this field will be valid in the Last
  272. buffer used by the MSDU
  273. Indicates an unsuccessful MAC source address search due
  274. to the expiring of the search timer for this MSDU
  275. <legal all>
  276. */
  277. #define RX_MSDU_DETAILS_2_RX_MSDU_DESC_INFO_DETAILS_SA_IDX_TIMEOUT_OFFSET 0x00000008
  278. #define RX_MSDU_DETAILS_2_RX_MSDU_DESC_INFO_DETAILS_SA_IDX_TIMEOUT_LSB 24
  279. #define RX_MSDU_DETAILS_2_RX_MSDU_DESC_INFO_DETAILS_SA_IDX_TIMEOUT_MASK 0x01000000
  280. /* Description RX_MSDU_DETAILS_2_RX_MSDU_DESC_INFO_DETAILS_DA_IS_VALID
  281. Parsed from RX_MSDU_END TLV . In the case MSDU spans
  282. over multiple buffers, this field will be valid in the Last
  283. buffer used by the MSDU
  284. Indicates that OLE found a valid DA entry for this MSDU
  285. <legal all>
  286. */
  287. #define RX_MSDU_DETAILS_2_RX_MSDU_DESC_INFO_DETAILS_DA_IS_VALID_OFFSET 0x00000008
  288. #define RX_MSDU_DETAILS_2_RX_MSDU_DESC_INFO_DETAILS_DA_IS_VALID_LSB 25
  289. #define RX_MSDU_DETAILS_2_RX_MSDU_DESC_INFO_DETAILS_DA_IS_VALID_MASK 0x02000000
  290. /* Description RX_MSDU_DETAILS_2_RX_MSDU_DESC_INFO_DETAILS_DA_IS_MCBC
  291. Field Only valid if da_is_valid is set
  292. Indicates the DA address was a Multicast of Broadcast
  293. address for this MSDU
  294. <legal all>
  295. */
  296. #define RX_MSDU_DETAILS_2_RX_MSDU_DESC_INFO_DETAILS_DA_IS_MCBC_OFFSET 0x00000008
  297. #define RX_MSDU_DETAILS_2_RX_MSDU_DESC_INFO_DETAILS_DA_IS_MCBC_LSB 26
  298. #define RX_MSDU_DETAILS_2_RX_MSDU_DESC_INFO_DETAILS_DA_IS_MCBC_MASK 0x04000000
  299. /* Description RX_MSDU_DETAILS_2_RX_MSDU_DESC_INFO_DETAILS_DA_IDX_TIMEOUT
  300. Parsed from RX_MSDU_END TLV . In the case MSDU spans
  301. over multiple buffers, this field will be valid in the Last
  302. buffer used by the MSDU
  303. Indicates an unsuccessful MAC destination address search
  304. due to the expiring of the search timer for this MSDU
  305. <legal all>
  306. */
  307. #define RX_MSDU_DETAILS_2_RX_MSDU_DESC_INFO_DETAILS_DA_IDX_TIMEOUT_OFFSET 0x00000008
  308. #define RX_MSDU_DETAILS_2_RX_MSDU_DESC_INFO_DETAILS_DA_IDX_TIMEOUT_LSB 27
  309. #define RX_MSDU_DETAILS_2_RX_MSDU_DESC_INFO_DETAILS_DA_IDX_TIMEOUT_MASK 0x08000000
  310. /* Description RX_MSDU_DETAILS_2_RX_MSDU_DESC_INFO_DETAILS_RESERVED_0A
  311. <legal 0>
  312. */
  313. #define RX_MSDU_DETAILS_2_RX_MSDU_DESC_INFO_DETAILS_RESERVED_0A_OFFSET 0x00000008
  314. #define RX_MSDU_DETAILS_2_RX_MSDU_DESC_INFO_DETAILS_RESERVED_0A_LSB 28
  315. #define RX_MSDU_DETAILS_2_RX_MSDU_DESC_INFO_DETAILS_RESERVED_0A_MASK 0xf0000000
  316. /* Description RX_MSDU_DETAILS_3_RX_MSDU_DESC_INFO_DETAILS_RESERVED_1A
  317. <legal 0>
  318. */
  319. #define RX_MSDU_DETAILS_3_RX_MSDU_DESC_INFO_DETAILS_RESERVED_1A_OFFSET 0x0000000c
  320. #define RX_MSDU_DETAILS_3_RX_MSDU_DESC_INFO_DETAILS_RESERVED_1A_LSB 0
  321. #define RX_MSDU_DETAILS_3_RX_MSDU_DESC_INFO_DETAILS_RESERVED_1A_MASK 0xffffffff
  322. #endif // _RX_MSDU_DETAILS_H_