rx_msdu_details.h 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642
  1. /*
  2. * Copyright (c) 2023 Qualcomm Innovation Center, Inc. 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. #ifndef _RX_MSDU_DETAILS_H_
  17. #define _RX_MSDU_DETAILS_H_
  18. #if !defined(__ASSEMBLER__)
  19. #endif
  20. #include "rx_msdu_desc_info.h"
  21. #include "rx_msdu_ext_desc_info.h"
  22. #include "buffer_addr_info.h"
  23. #define NUM_OF_DWORDS_RX_MSDU_DETAILS 4
  24. struct rx_msdu_details {
  25. #ifndef WIFI_BIT_ORDER_BIG_ENDIAN
  26. struct buffer_addr_info buffer_addr_info_details;
  27. struct rx_msdu_desc_info rx_msdu_desc_info_details;
  28. struct rx_msdu_ext_desc_info rx_msdu_ext_desc_info_details;
  29. #else
  30. struct buffer_addr_info buffer_addr_info_details;
  31. struct rx_msdu_desc_info rx_msdu_desc_info_details;
  32. struct rx_msdu_ext_desc_info rx_msdu_ext_desc_info_details;
  33. #endif
  34. };
  35. /* Description BUFFER_ADDR_INFO_DETAILS
  36. Consumer: REO/SW
  37. Producer: RXDMA
  38. Details of the physical address of the buffer containing
  39. an MSDU (or entire MPDU)
  40. */
  41. /* Description BUFFER_ADDR_31_0
  42. Address (lower 32 bits) of the MSDU buffer OR MSDU_EXTENSION
  43. descriptor OR Link Descriptor
  44. In case of 'NULL' pointer, this field is set to 0
  45. <legal all>
  46. */
  47. #define RX_MSDU_DETAILS_BUFFER_ADDR_INFO_DETAILS_BUFFER_ADDR_31_0_OFFSET 0x00000000
  48. #define RX_MSDU_DETAILS_BUFFER_ADDR_INFO_DETAILS_BUFFER_ADDR_31_0_LSB 0
  49. #define RX_MSDU_DETAILS_BUFFER_ADDR_INFO_DETAILS_BUFFER_ADDR_31_0_MSB 31
  50. #define RX_MSDU_DETAILS_BUFFER_ADDR_INFO_DETAILS_BUFFER_ADDR_31_0_MASK 0xffffffff
  51. /* Description BUFFER_ADDR_39_32
  52. Address (upper 8 bits) of the MSDU buffer OR MSDU_EXTENSION
  53. descriptor OR Link Descriptor
  54. In case of 'NULL' pointer, this field is set to 0
  55. <legal all>
  56. */
  57. #define RX_MSDU_DETAILS_BUFFER_ADDR_INFO_DETAILS_BUFFER_ADDR_39_32_OFFSET 0x00000004
  58. #define RX_MSDU_DETAILS_BUFFER_ADDR_INFO_DETAILS_BUFFER_ADDR_39_32_LSB 0
  59. #define RX_MSDU_DETAILS_BUFFER_ADDR_INFO_DETAILS_BUFFER_ADDR_39_32_MSB 7
  60. #define RX_MSDU_DETAILS_BUFFER_ADDR_INFO_DETAILS_BUFFER_ADDR_39_32_MASK 0x000000ff
  61. /* Description RETURN_BUFFER_MANAGER
  62. Consumer: WBM
  63. Producer: SW/FW
  64. In case of 'NULL' pointer, this field is set to 0
  65. Indicates to which buffer manager the buffer OR MSDU_EXTENSION
  66. descriptor OR link descriptor that is being pointed to
  67. shall be returned after the frame has been processed. It
  68. is used by WBM for routing purposes.
  69. <enum 0 WBM_IDLE_BUF_LIST> This buffer shall be returned
  70. to the WMB buffer idle list
  71. <enum 1 WBM_CHIP0_IDLE_DESC_LIST> This buffer shall be returned
  72. to the WBM idle link descriptor idle list, where the chip
  73. 0 WBM is chosen in case of a multi-chip config
  74. <enum 2 WBM_CHIP1_IDLE_DESC_LIST> This buffer shall be returned
  75. to the chip 1 WBM idle link descriptor idle list
  76. <enum 3 WBM_CHIP2_IDLE_DESC_LIST> This buffer shall be returned
  77. to the chip 2 WBM idle link descriptor idle list
  78. <enum 12 WBM_CHIP3_IDLE_DESC_LIST> This buffer shall be
  79. returned to chip 3 WBM idle link descriptor idle list
  80. <enum 4 FW_BM> This buffer shall be returned to the FW
  81. <enum 5 SW0_BM> This buffer shall be returned to the SW,
  82. ring 0
  83. <enum 6 SW1_BM> This buffer shall be returned to the SW,
  84. ring 1
  85. <enum 7 SW2_BM> This buffer shall be returned to the SW,
  86. ring 2
  87. <enum 8 SW3_BM> This buffer shall be returned to the SW,
  88. ring 3
  89. <enum 9 SW4_BM> This buffer shall be returned to the SW,
  90. ring 4
  91. <enum 10 SW5_BM> This buffer shall be returned to the SW,
  92. ring 5
  93. <enum 11 SW6_BM> This buffer shall be returned to the SW,
  94. ring 6
  95. <legal 0-12>
  96. */
  97. #define RX_MSDU_DETAILS_BUFFER_ADDR_INFO_DETAILS_RETURN_BUFFER_MANAGER_OFFSET 0x00000004
  98. #define RX_MSDU_DETAILS_BUFFER_ADDR_INFO_DETAILS_RETURN_BUFFER_MANAGER_LSB 8
  99. #define RX_MSDU_DETAILS_BUFFER_ADDR_INFO_DETAILS_RETURN_BUFFER_MANAGER_MSB 11
  100. #define RX_MSDU_DETAILS_BUFFER_ADDR_INFO_DETAILS_RETURN_BUFFER_MANAGER_MASK 0x00000f00
  101. /* Description SW_BUFFER_COOKIE
  102. Cookie field exclusively used by SW.
  103. In case of 'NULL' pointer, this field is set to 0
  104. HW ignores the contents, accept that it passes the programmed
  105. value on to other descriptors together with the physical
  106. address
  107. Field can be used by SW to for example associate the buffers
  108. physical address with the virtual address
  109. The bit definitions as used by SW are within SW HLD specification
  110. NOTE1:
  111. The three most significant bits can have a special meaning
  112. in case this struct is embedded in a TX_MPDU_DETAILS STRUCT,
  113. and field transmit_bw_restriction is set
  114. In case of NON punctured transmission:
  115. Sw_buffer_cookie[19:17] = 3'b000: 20 MHz TX only
  116. Sw_buffer_cookie[19:17] = 3'b001: 40 MHz TX only
  117. Sw_buffer_cookie[19:17] = 3'b010: 80 MHz TX only
  118. Sw_buffer_cookie[19:17] = 3'b011: 160 MHz TX only
  119. Sw_buffer_cookie[19:17] = 3'b101: 240 MHz TX only
  120. Sw_buffer_cookie[19:17] = 3'b100: 320 MHz TX only
  121. Sw_buffer_cookie[19:18] = 2'b11: reserved
  122. In case of punctured transmission:
  123. Sw_buffer_cookie[19:16] = 4'b0000: pattern 0 only
  124. Sw_buffer_cookie[19:16] = 4'b0001: pattern 1 only
  125. Sw_buffer_cookie[19:16] = 4'b0010: pattern 2 only
  126. Sw_buffer_cookie[19:16] = 4'b0011: pattern 3 only
  127. Sw_buffer_cookie[19:16] = 4'b0100: pattern 4 only
  128. Sw_buffer_cookie[19:16] = 4'b0101: pattern 5 only
  129. Sw_buffer_cookie[19:16] = 4'b0110: pattern 6 only
  130. Sw_buffer_cookie[19:16] = 4'b0111: pattern 7 only
  131. Sw_buffer_cookie[19:16] = 4'b1000: pattern 8 only
  132. Sw_buffer_cookie[19:16] = 4'b1001: pattern 9 only
  133. Sw_buffer_cookie[19:16] = 4'b1010: pattern 10 only
  134. Sw_buffer_cookie[19:16] = 4'b1011: pattern 11 only
  135. Sw_buffer_cookie[19:18] = 2'b11: reserved
  136. Note: a punctured transmission is indicated by the presence
  137. of TLV TX_PUNCTURE_SETUP embedded in the scheduler TLV
  138. <legal all>
  139. */
  140. #define RX_MSDU_DETAILS_BUFFER_ADDR_INFO_DETAILS_SW_BUFFER_COOKIE_OFFSET 0x00000004
  141. #define RX_MSDU_DETAILS_BUFFER_ADDR_INFO_DETAILS_SW_BUFFER_COOKIE_LSB 12
  142. #define RX_MSDU_DETAILS_BUFFER_ADDR_INFO_DETAILS_SW_BUFFER_COOKIE_MSB 31
  143. #define RX_MSDU_DETAILS_BUFFER_ADDR_INFO_DETAILS_SW_BUFFER_COOKIE_MASK 0xfffff000
  144. /* Description RX_MSDU_DESC_INFO_DETAILS
  145. Consumer: REO/SW
  146. Producer: RXDMA
  147. General information related to the MSDU that should be passed
  148. on from RXDMA all the way to to the REO destination ring.
  149. */
  150. /* Description FIRST_MSDU_IN_MPDU_FLAG
  151. Parsed from RX_MSDU_END TLV . In the case MSDU spans over
  152. multiple buffers, this field will be valid in the Last
  153. buffer used by the MSDU
  154. <enum 0 Not_first_msdu> This is not the first MSDU in the
  155. MPDU.
  156. <enum 1 first_msdu> This MSDU is the first one in the MPDU.
  157. <legal all>
  158. */
  159. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_FIRST_MSDU_IN_MPDU_FLAG_OFFSET 0x00000008
  160. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_FIRST_MSDU_IN_MPDU_FLAG_LSB 0
  161. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_FIRST_MSDU_IN_MPDU_FLAG_MSB 0
  162. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_FIRST_MSDU_IN_MPDU_FLAG_MASK 0x00000001
  163. /* Description LAST_MSDU_IN_MPDU_FLAG
  164. Consumer: WBM/REO/SW/FW
  165. Producer: RXDMA
  166. Parsed from RX_MSDU_END TLV . In the case MSDU spans over
  167. multiple buffers, this field will be valid in the Last
  168. buffer used by the MSDU
  169. <enum 0 Not_last_msdu> There are more MSDUs linked to this
  170. MSDU that belongs to this MPDU
  171. <enum 1 Last_msdu> this MSDU is the last one in the MPDU.
  172. This setting is only allowed in combination with 'Msdu_continuation'
  173. set to 0. This implies that when an msdu is spread out over
  174. multiple buffers and thus msdu_continuation is set, only
  175. for the very last buffer of the msdu, can the 'last_msdu_in_mpdu_flag'
  176. be set.
  177. When both first_msdu_in_mpdu_flag and last_msdu_in_mpdu_flag
  178. are set, the MPDU that this MSDU belongs to only contains
  179. a single MSDU.
  180. <legal all>
  181. */
  182. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_LAST_MSDU_IN_MPDU_FLAG_OFFSET 0x00000008
  183. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_LAST_MSDU_IN_MPDU_FLAG_LSB 1
  184. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_LAST_MSDU_IN_MPDU_FLAG_MSB 1
  185. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_LAST_MSDU_IN_MPDU_FLAG_MASK 0x00000002
  186. /* Description MSDU_CONTINUATION
  187. When set, this MSDU buffer was not able to hold the entire
  188. MSDU. The next buffer will therefor contain additional
  189. information related to this MSDU.
  190. <legal all>
  191. */
  192. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_MSDU_CONTINUATION_OFFSET 0x00000008
  193. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_MSDU_CONTINUATION_LSB 2
  194. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_MSDU_CONTINUATION_MSB 2
  195. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_MSDU_CONTINUATION_MASK 0x00000004
  196. /* Description MSDU_LENGTH
  197. Parsed from RX_MSDU_START TLV . In the case MSDU spans over
  198. multiple buffers, this field will be valid in the First
  199. buffer used by MSDU.
  200. Full MSDU length in bytes after decapsulation.
  201. This field is still valid for MPDU frames without A-MSDU.
  202. It still represents MSDU length after decapsulation
  203. Or in case of RAW MPDUs, it indicates the length of the
  204. entire MPDU (without FCS field)
  205. <legal all>
  206. */
  207. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_MSDU_LENGTH_OFFSET 0x00000008
  208. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_MSDU_LENGTH_LSB 3
  209. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_MSDU_LENGTH_MSB 16
  210. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_MSDU_LENGTH_MASK 0x0001fff8
  211. /* Description MSDU_DROP
  212. Parsed from RX_MSDU_END TLV . In the case MSDU spans over
  213. multiple buffers, this field will be valid in the Last
  214. buffer used by the MSDU
  215. When set, REO shall drop this MSDU and not forward it to
  216. any other ring...
  217. <legal all>
  218. */
  219. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_MSDU_DROP_OFFSET 0x00000008
  220. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_MSDU_DROP_LSB 17
  221. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_MSDU_DROP_MSB 17
  222. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_MSDU_DROP_MASK 0x00020000
  223. /* Description SA_IS_VALID
  224. Parsed from RX_MSDU_END TLV . In the case MSDU spans over
  225. multiple buffers, this field will be valid in the Last
  226. buffer used by the MSDU
  227. Indicates that OLE found a valid SA entry for this MSDU
  228. <legal all>
  229. */
  230. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_SA_IS_VALID_OFFSET 0x00000008
  231. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_SA_IS_VALID_LSB 18
  232. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_SA_IS_VALID_MSB 18
  233. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_SA_IS_VALID_MASK 0x00040000
  234. /* Description DA_IS_VALID
  235. Parsed from RX_MSDU_END TLV . In the case MSDU spans over
  236. multiple buffers, this field will be valid in the Last
  237. buffer used by the MSDU
  238. Indicates that OLE found a valid DA entry for this MSDU
  239. <legal all>
  240. */
  241. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_DA_IS_VALID_OFFSET 0x00000008
  242. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_DA_IS_VALID_LSB 19
  243. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_DA_IS_VALID_MSB 19
  244. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_DA_IS_VALID_MASK 0x00080000
  245. /* Description DA_IS_MCBC
  246. Field Only valid if "da_is_valid" is set
  247. Indicates the DA address was a Multicast of Broadcast address
  248. for this MSDU
  249. <legal all>
  250. */
  251. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_DA_IS_MCBC_OFFSET 0x00000008
  252. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_DA_IS_MCBC_LSB 20
  253. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_DA_IS_MCBC_MSB 20
  254. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_DA_IS_MCBC_MASK 0x00100000
  255. /* Description L3_HEADER_PADDING_MSB
  256. Passed on from 'RX_MSDU_END' TLV (only the MSB is reported
  257. as the LSB is always zero)
  258. Number of bytes padded to make sure that the L3 header will
  259. always start of a Dword boundary
  260. <legal all>
  261. */
  262. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_L3_HEADER_PADDING_MSB_OFFSET 0x00000008
  263. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_L3_HEADER_PADDING_MSB_LSB 21
  264. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_L3_HEADER_PADDING_MSB_MSB 21
  265. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_L3_HEADER_PADDING_MSB_MASK 0x00200000
  266. /* Description TCP_UDP_CHKSUM_FAIL
  267. Passed on from 'RX_ATTENTION' TLV
  268. Indicates that the computed checksum did not match the checksum
  269. in the TCP/UDP header.
  270. <legal all>
  271. */
  272. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_TCP_UDP_CHKSUM_FAIL_OFFSET 0x00000008
  273. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_TCP_UDP_CHKSUM_FAIL_LSB 22
  274. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_TCP_UDP_CHKSUM_FAIL_MSB 22
  275. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_TCP_UDP_CHKSUM_FAIL_MASK 0x00400000
  276. /* Description IP_CHKSUM_FAIL
  277. Passed on from 'RX_ATTENTION' TLV
  278. Indicates that the computed checksum did not match the checksum
  279. in the IP header.
  280. <legal all>
  281. */
  282. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_IP_CHKSUM_FAIL_OFFSET 0x00000008
  283. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_IP_CHKSUM_FAIL_LSB 23
  284. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_IP_CHKSUM_FAIL_MSB 23
  285. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_IP_CHKSUM_FAIL_MASK 0x00800000
  286. /* Description FR_DS
  287. Passed on from 'RX_MPDU_INFO' structure in 'RX_MPDU_START'
  288. TLV
  289. Set if the 'from DS' bit is set in the frame control.
  290. <legal all>
  291. */
  292. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_FR_DS_OFFSET 0x00000008
  293. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_FR_DS_LSB 24
  294. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_FR_DS_MSB 24
  295. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_FR_DS_MASK 0x01000000
  296. /* Description TO_DS
  297. Passed on from 'RX_MPDU_INFO' structure in 'RX_MPDU_START'
  298. TLV
  299. Set if the 'to DS' bit is set in the frame control.
  300. <legal all>
  301. */
  302. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_TO_DS_OFFSET 0x00000008
  303. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_TO_DS_LSB 25
  304. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_TO_DS_MSB 25
  305. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_TO_DS_MASK 0x02000000
  306. /* Description INTRA_BSS
  307. This packet needs intra-BSS routing by SW as the 'vdev_id'
  308. for the destination is the same as the 'vdev_id' (from 'RX_MPDU_PCU_START')
  309. that this MSDU was got in.
  310. <legal all>
  311. */
  312. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_INTRA_BSS_OFFSET 0x00000008
  313. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_INTRA_BSS_LSB 26
  314. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_INTRA_BSS_MSB 26
  315. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_INTRA_BSS_MASK 0x04000000
  316. /* Description DEST_CHIP_ID
  317. If intra_bss is set, copied by RXOLE/RXDMA from 'ADDR_SEARCH_ENTRY'
  318. to support intra-BSS routing with multi-chip multi-link
  319. operation.
  320. This indicates into which chip's TCL the packet should be
  321. queued.
  322. <legal all>
  323. */
  324. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_DEST_CHIP_ID_OFFSET 0x00000008
  325. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_DEST_CHIP_ID_LSB 27
  326. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_DEST_CHIP_ID_MSB 28
  327. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_DEST_CHIP_ID_MASK 0x18000000
  328. /* Description DECAP_FORMAT
  329. Indicates the format after decapsulation:
  330. <enum 0 RAW> No encapsulation
  331. <enum 1 Native_WiFi>
  332. <enum 2 Ethernet> Ethernet 2 (DIX) or 802.3 (uses SNAP/LLC)
  333. <enum 3 802_3> Indicate Ethernet
  334. <legal all>
  335. */
  336. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_DECAP_FORMAT_OFFSET 0x00000008
  337. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_DECAP_FORMAT_LSB 29
  338. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_DECAP_FORMAT_MSB 30
  339. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_DECAP_FORMAT_MASK 0x60000000
  340. /* Description DEST_CHIP_PMAC_ID
  341. If intra_bss is set, copied by RXOLE/RXDMA from 'ADDR_SEARCH_ENTRY'
  342. to support intra-BSS routing with multi-chip multi-link
  343. operation.
  344. This indicates into which link/'vdev' the packet should
  345. be queued in TCL.
  346. <legal all>
  347. */
  348. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_DEST_CHIP_PMAC_ID_OFFSET 0x00000008
  349. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_DEST_CHIP_PMAC_ID_LSB 31
  350. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_DEST_CHIP_PMAC_ID_MSB 31
  351. #define RX_MSDU_DETAILS_RX_MSDU_DESC_INFO_DETAILS_DEST_CHIP_PMAC_ID_MASK 0x80000000
  352. /* Description RX_MSDU_EXT_DESC_INFO_DETAILS
  353. Consumer: REO/SW
  354. Producer: RXDMA
  355. Extended information related to the MSDU that is passed
  356. on from RXDMA to REO but not part of the REO destination
  357. ring. Some fields are passed on to PPE.
  358. */
  359. /* Description REO_DESTINATION_INDICATION
  360. Parsed from RX_MSDU_END TLV . In the case MSDU spans over
  361. multiple buffers, this field will be valid in the Last
  362. buffer used by the MSDU
  363. The ID of the REO exit ring where the MSDU frame shall push
  364. after (MPDU level) reordering has finished.
  365. <enum 0 reo_destination_sw0> Reo will push the frame into
  366. the REO2SW0 ring
  367. <enum 1 reo_destination_sw1> Reo will push the frame into
  368. the REO2SW1 ring
  369. <enum 2 reo_destination_sw2> Reo will push the frame into
  370. the REO2SW2 ring
  371. <enum 3 reo_destination_sw3> Reo will push the frame into
  372. the REO2SW3 ring
  373. <enum 4 reo_destination_sw4> Reo will push the frame into
  374. the REO2SW4 ring
  375. <enum 5 reo_destination_release> Reo will push the frame
  376. into the REO_release ring
  377. <enum 6 reo_destination_fw> Reo will push the frame into
  378. the REO2FW ring
  379. <enum 7 reo_destination_sw5> Reo will push the frame into
  380. the REO2SW5 ring (REO remaps this in chips without REO2SW5
  381. ring)
  382. <enum 8 reo_destination_sw6> Reo will push the frame into
  383. the REO2SW6 ring (REO remaps this in chips without REO2SW6
  384. ring)
  385. <enum 9 reo_destination_sw7> Reo will push the frame into
  386. the REO2SW7 ring (REO remaps this in chips without REO2SW7
  387. ring)
  388. <enum 10 reo_destination_sw8> Reo will push the frame into
  389. the REO2SW8 ring (REO remaps this in chips without REO2SW8
  390. ring)
  391. <enum 11 reo_destination_11> REO remaps this
  392. <enum 12 reo_destination_12> REO remaps this <enum 13 reo_destination_13>
  393. REO remaps this
  394. <enum 14 reo_destination_14> REO remaps this
  395. <enum 15 reo_destination_15> REO remaps this
  396. <enum 16 reo_destination_16> REO remaps this
  397. <enum 17 reo_destination_17> REO remaps this
  398. <enum 18 reo_destination_18> REO remaps this
  399. <enum 19 reo_destination_19> REO remaps this
  400. <enum 20 reo_destination_20> REO remaps this
  401. <enum 21 reo_destination_21> REO remaps this
  402. <enum 22 reo_destination_22> REO remaps this
  403. <enum 23 reo_destination_23> REO remaps this
  404. <enum 24 reo_destination_24> REO remaps this
  405. <enum 25 reo_destination_25> REO remaps this
  406. <enum 26 reo_destination_26> REO remaps this
  407. <enum 27 reo_destination_27> REO remaps this
  408. <enum 28 reo_destination_28> REO remaps this
  409. <enum 29 reo_destination_29> REO remaps this
  410. <enum 30 reo_destination_30> REO remaps this
  411. <enum 31 reo_destination_31> REO remaps this
  412. <legal all>
  413. */
  414. #define RX_MSDU_DETAILS_RX_MSDU_EXT_DESC_INFO_DETAILS_REO_DESTINATION_INDICATION_OFFSET 0x0000000c
  415. #define RX_MSDU_DETAILS_RX_MSDU_EXT_DESC_INFO_DETAILS_REO_DESTINATION_INDICATION_LSB 0
  416. #define RX_MSDU_DETAILS_RX_MSDU_EXT_DESC_INFO_DETAILS_REO_DESTINATION_INDICATION_MSB 4
  417. #define RX_MSDU_DETAILS_RX_MSDU_EXT_DESC_INFO_DETAILS_REO_DESTINATION_INDICATION_MASK 0x0000001f
  418. /* Description SERVICE_CODE
  419. Opaque service code between PPE and Wi-Fi
  420. This field gets passed on by REO to PPE in the EDMA descriptor
  421. ('REO_TO_PPE_RING').
  422. <legal all>
  423. */
  424. #define RX_MSDU_DETAILS_RX_MSDU_EXT_DESC_INFO_DETAILS_SERVICE_CODE_OFFSET 0x0000000c
  425. #define RX_MSDU_DETAILS_RX_MSDU_EXT_DESC_INFO_DETAILS_SERVICE_CODE_LSB 5
  426. #define RX_MSDU_DETAILS_RX_MSDU_EXT_DESC_INFO_DETAILS_SERVICE_CODE_MSB 13
  427. #define RX_MSDU_DETAILS_RX_MSDU_EXT_DESC_INFO_DETAILS_SERVICE_CODE_MASK 0x00003fe0
  428. /* Description PRIORITY_VALID
  429. This field gets passed on by REO to PPE in the EDMA descriptor
  430. ('REO_TO_PPE_RING').
  431. <legal all>
  432. */
  433. #define RX_MSDU_DETAILS_RX_MSDU_EXT_DESC_INFO_DETAILS_PRIORITY_VALID_OFFSET 0x0000000c
  434. #define RX_MSDU_DETAILS_RX_MSDU_EXT_DESC_INFO_DETAILS_PRIORITY_VALID_LSB 14
  435. #define RX_MSDU_DETAILS_RX_MSDU_EXT_DESC_INFO_DETAILS_PRIORITY_VALID_MSB 14
  436. #define RX_MSDU_DETAILS_RX_MSDU_EXT_DESC_INFO_DETAILS_PRIORITY_VALID_MASK 0x00004000
  437. /* Description DATA_OFFSET
  438. The offset to Rx packet data within the buffer (including
  439. Rx DMA offset programming and L3 header padding inserted
  440. by Rx OLE).
  441. This field gets passed on by REO to PPE in the EDMA descriptor
  442. ('REO_TO_PPE_RING').
  443. <legal all>
  444. */
  445. #define RX_MSDU_DETAILS_RX_MSDU_EXT_DESC_INFO_DETAILS_DATA_OFFSET_OFFSET 0x0000000c
  446. #define RX_MSDU_DETAILS_RX_MSDU_EXT_DESC_INFO_DETAILS_DATA_OFFSET_LSB 15
  447. #define RX_MSDU_DETAILS_RX_MSDU_EXT_DESC_INFO_DETAILS_DATA_OFFSET_MSB 26
  448. #define RX_MSDU_DETAILS_RX_MSDU_EXT_DESC_INFO_DETAILS_DATA_OFFSET_MASK 0x07ff8000
  449. /* Description SRC_LINK_ID
  450. Consumer: SW
  451. Producer: RXDMA
  452. Set to the link ID of the PMAC that received the frame
  453. <legal all>
  454. */
  455. #define RX_MSDU_DETAILS_RX_MSDU_EXT_DESC_INFO_DETAILS_SRC_LINK_ID_OFFSET 0x0000000c
  456. #define RX_MSDU_DETAILS_RX_MSDU_EXT_DESC_INFO_DETAILS_SRC_LINK_ID_LSB 27
  457. #define RX_MSDU_DETAILS_RX_MSDU_EXT_DESC_INFO_DETAILS_SRC_LINK_ID_MSB 29
  458. #define RX_MSDU_DETAILS_RX_MSDU_EXT_DESC_INFO_DETAILS_SRC_LINK_ID_MASK 0x38000000
  459. /* Description RESERVED_0A
  460. <legal 0>
  461. */
  462. #define RX_MSDU_DETAILS_RX_MSDU_EXT_DESC_INFO_DETAILS_RESERVED_0A_OFFSET 0x0000000c
  463. #define RX_MSDU_DETAILS_RX_MSDU_EXT_DESC_INFO_DETAILS_RESERVED_0A_LSB 30
  464. #define RX_MSDU_DETAILS_RX_MSDU_EXT_DESC_INFO_DETAILS_RESERVED_0A_MSB 31
  465. #define RX_MSDU_DETAILS_RX_MSDU_EXT_DESC_INFO_DETAILS_RESERVED_0A_MASK 0xc0000000
  466. #endif // RX_MSDU_DETAILS