rx_msdu_start.h 35 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207
  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_START_H_
  22. #define _RX_MSDU_START_H_
  23. #if !defined(__ASSEMBLER__)
  24. #endif
  25. // ################ START SUMMARY #################
  26. //
  27. // Dword Fields
  28. // 0 rxpcu_mpdu_filter_in_category[1:0], sw_frame_group_id[8:2], reserved_0[15:9], phy_ppdu_id[31:16]
  29. // 1 msdu_length[13:0], reserved_1a[14], ipsec_esp[15], l3_offset[22:16], ipsec_ah[23], l4_offset[31:24]
  30. // 2 msdu_number[7:0], decap_format[9:8], ipv4_proto[10], ipv6_proto[11], tcp_proto[12], udp_proto[13], ip_frag[14], tcp_only_ack[15], da_is_bcast_mcast[16], toeplitz_hash_sel[18:17], ip_fixed_header_valid[19], ip_extn_header_valid[20], tcp_udp_header_valid[21], mesh_control_present[22], ldpc[23], ip4_protocol_ip6_next_header[31:24]
  31. // 3 toeplitz_hash_2_or_4[31:0]
  32. // 4 flow_id_toeplitz[31:0]
  33. // 5 user_rssi[7:0], pkt_type[11:8], stbc[12], sgi[14:13], rate_mcs[18:15], receive_bandwidth[20:19], reception_type[23:21], mimo_ss_bitmap[31:24]
  34. // 6 ppdu_start_timestamp[31:0]
  35. // 7 sw_phy_meta_data[31:0]
  36. // 8 vlan_ctag_ci[15:0], vlan_stag_ci[31:16]
  37. //
  38. // ################ END SUMMARY #################
  39. #define NUM_OF_DWORDS_RX_MSDU_START 9
  40. struct rx_msdu_start {
  41. uint32_t rxpcu_mpdu_filter_in_category : 2, //[1:0]
  42. sw_frame_group_id : 7, //[8:2]
  43. reserved_0 : 7, //[15:9]
  44. phy_ppdu_id : 16; //[31:16]
  45. uint32_t msdu_length : 14, //[13:0]
  46. reserved_1a : 1, //[14]
  47. ipsec_esp : 1, //[15]
  48. l3_offset : 7, //[22:16]
  49. ipsec_ah : 1, //[23]
  50. l4_offset : 8; //[31:24]
  51. uint32_t msdu_number : 8, //[7:0]
  52. decap_format : 2, //[9:8]
  53. ipv4_proto : 1, //[10]
  54. ipv6_proto : 1, //[11]
  55. tcp_proto : 1, //[12]
  56. udp_proto : 1, //[13]
  57. ip_frag : 1, //[14]
  58. tcp_only_ack : 1, //[15]
  59. da_is_bcast_mcast : 1, //[16]
  60. toeplitz_hash_sel : 2, //[18:17]
  61. ip_fixed_header_valid : 1, //[19]
  62. ip_extn_header_valid : 1, //[20]
  63. tcp_udp_header_valid : 1, //[21]
  64. mesh_control_present : 1, //[22]
  65. ldpc : 1, //[23]
  66. ip4_protocol_ip6_next_header : 8; //[31:24]
  67. uint32_t toeplitz_hash_2_or_4 : 32; //[31:0]
  68. uint32_t flow_id_toeplitz : 32; //[31:0]
  69. uint32_t user_rssi : 8, //[7:0]
  70. pkt_type : 4, //[11:8]
  71. stbc : 1, //[12]
  72. sgi : 2, //[14:13]
  73. rate_mcs : 4, //[18:15]
  74. receive_bandwidth : 2, //[20:19]
  75. reception_type : 3, //[23:21]
  76. mimo_ss_bitmap : 8; //[31:24]
  77. uint32_t ppdu_start_timestamp : 32; //[31:0]
  78. uint32_t sw_phy_meta_data : 32; //[31:0]
  79. uint32_t vlan_ctag_ci : 16, //[15:0]
  80. vlan_stag_ci : 16; //[31:16]
  81. };
  82. /*
  83. rxpcu_mpdu_filter_in_category
  84. Field indicates what the reason was that this MPDU frame
  85. was allowed to come into the receive path by RXPCU
  86. <enum 0 rxpcu_filter_pass> This MPDU passed the normal
  87. frame filter programming of rxpcu
  88. <enum 1 rxpcu_monitor_client> This MPDU did NOT pass the
  89. regular frame filter and would have been dropped, were it
  90. not for the frame fitting into the 'monitor_client'
  91. category.
  92. <enum 2 rxpcu_monitor_other> This MPDU did NOT pass the
  93. regular frame filter and also did not pass the
  94. rxpcu_monitor_client filter. It would have been dropped
  95. accept that it did pass the 'monitor_other' category.
  96. <legal 0-2>
  97. sw_frame_group_id
  98. SW processes frames based on certain classifications.
  99. This field indicates to what sw classification this MPDU is
  100. mapped.
  101. The classification is given in priority order
  102. <enum 0 sw_frame_group_NDP_frame>
  103. <enum 1 sw_frame_group_Multicast_data>
  104. <enum 2 sw_frame_group_Unicast_data>
  105. <enum 3 sw_frame_group_Null_data > This includes mpdus
  106. of type Data Null as well as QoS Data Null
  107. <enum 4 sw_frame_group_mgmt_0000 >
  108. <enum 5 sw_frame_group_mgmt_0001 >
  109. <enum 6 sw_frame_group_mgmt_0010 >
  110. <enum 7 sw_frame_group_mgmt_0011 >
  111. <enum 8 sw_frame_group_mgmt_0100 >
  112. <enum 9 sw_frame_group_mgmt_0101 >
  113. <enum 10 sw_frame_group_mgmt_0110 >
  114. <enum 11 sw_frame_group_mgmt_0111 >
  115. <enum 12 sw_frame_group_mgmt_1000 >
  116. <enum 13 sw_frame_group_mgmt_1001 >
  117. <enum 14 sw_frame_group_mgmt_1010 >
  118. <enum 15 sw_frame_group_mgmt_1011 >
  119. <enum 16 sw_frame_group_mgmt_1100 >
  120. <enum 17 sw_frame_group_mgmt_1101 >
  121. <enum 18 sw_frame_group_mgmt_1110 >
  122. <enum 19 sw_frame_group_mgmt_1111 >
  123. <enum 20 sw_frame_group_ctrl_0000 >
  124. <enum 21 sw_frame_group_ctrl_0001 >
  125. <enum 22 sw_frame_group_ctrl_0010 >
  126. <enum 23 sw_frame_group_ctrl_0011 >
  127. <enum 24 sw_frame_group_ctrl_0100 >
  128. <enum 25 sw_frame_group_ctrl_0101 >
  129. <enum 26 sw_frame_group_ctrl_0110 >
  130. <enum 27 sw_frame_group_ctrl_0111 >
  131. <enum 28 sw_frame_group_ctrl_1000 >
  132. <enum 29 sw_frame_group_ctrl_1001 >
  133. <enum 30 sw_frame_group_ctrl_1010 >
  134. <enum 31 sw_frame_group_ctrl_1011 >
  135. <enum 32 sw_frame_group_ctrl_1100 >
  136. <enum 33 sw_frame_group_ctrl_1101 >
  137. <enum 34 sw_frame_group_ctrl_1110 >
  138. <enum 35 sw_frame_group_ctrl_1111 >
  139. <enum 36 sw_frame_group_unsupported> This covers type 3
  140. and protocol version != 0
  141. <legal 0-37>
  142. reserved_0
  143. <legal 0>
  144. phy_ppdu_id
  145. A ppdu counter value that PHY increments for every PPDU
  146. received. The counter value wraps around
  147. <legal all>
  148. msdu_length
  149. MSDU length in bytes after decapsulation.
  150. This field is still valid for MPDU frames without
  151. reserved_1a
  152. <legal 0>
  153. ipsec_esp
  154. Set if IPv4/v6 packet is using IPsec ESP
  155. l3_offset
  156. Depending upon mode bit, this field either indicates the
  157. L3 offset in bytes from the start of the RX_HEADER or the IP
  158. offset in bytes from the start of the packet after
  159. decapsulation.  The latter is only valid if ipv4_proto or
  160. ipv6_proto is set.
  161. ipsec_ah
  162. Set if IPv4/v6 packet is using IPsec AH
  163. l4_offset
  164. Depending upon mode bit, this field either indicates the
  165. L4 offset nin bytes from the start of RX_HEADER(only valid
  166. if either ipv4_proto or ipv6_proto is set to 1) or indicates
  167. the offset in bytes to the start of TCP or UDP header from
  168. the start of the IP header after decapsulation(Only valid if
  169. tcp_proto or udp_proto is set).  The value 0 indicates that
  170. the offset is longer than 127 bytes.
  171. msdu_number
  172. Indicates the MSDU number within a MPDU. This value is
  173. reset to zero at the start of each MPDU. If the number of
  174. MSDU exceeds 255 this number will wrap using modulo 256.
  175. decap_format
  176. Indicates the format after decapsulation:
  177. <enum 0 RAW> No encapsulation
  178. <enum 1 Native_WiFi>
  179. <enum 2 Ethernet> Ethernet 2 (DIX) or 802.3 (uses
  180. SNAP/LLC)
  181. <enum 3 802_3> Indicate Ethernet
  182. <legal all>
  183. ipv4_proto
  184. Set if L2 layer indicates IPv4 protocol.
  185. ipv6_proto
  186. Set if L2 layer indicates IPv6 protocol.
  187. tcp_proto
  188. Set if the ipv4_proto or ipv6_proto are set and the IP
  189. protocol indicates TCP.
  190. udp_proto
  191. Set if the ipv4_proto or ipv6_proto are set and the IP
  192. protocol indicates UDP.
  193. ip_frag
  194. Indicates that either the IP More frag bit is set or IP
  195. frag number is non-zero. If set indicates that this is a
  196. fragmented IP packet.
  197. tcp_only_ack
  198. Set if only the TCP Ack bit is set in the TCP flags and
  199. if the TCP payload is 0.
  200. da_is_bcast_mcast
  201. The destination address is broadcast or multicast.
  202. toeplitz_hash_sel
  203. Actual choosen Hash.
  204. 0 -> Toeplitz hash of 2-tuple (IP source address, IP
  205. destination address)1 -> Toeplitz hash of 4-tuple (IP source
  206. address, IP destination address, L4 (TCP/UDP) source port,
  207. L4 (TCP/UDP) destination port)
  208. 2 -> Toeplitz of flow_id
  209. 3 -> Zero is used
  210. <legal all>
  211. ip_fixed_header_valid
  212. Fixed 20-byte IPv4 header or 40-byte IPv6 header parsed
  213. fully within first 256 bytes of the packet
  214. ip_extn_header_valid
  215. IPv6/IPv6 header, including IPv4 options and
  216. recognizable extension headers parsed fully within first 256
  217. bytes of the packet
  218. tcp_udp_header_valid
  219. Fixed 20-byte TCP (excluding TCP options) or 8-byte UDP
  220. header parsed fully within first 256 bytes of the packet
  221. mesh_control_present
  222. When set, this MSDU includes the 'Mesh Control' field
  223. <legal all>
  224. ldpc
  225. When set, indicates that LDPC coding was used.
  226. <legal all>
  227. ip4_protocol_ip6_next_header
  228. For IPv4 this is the 8 bit protocol field (when
  229. ipv4_proto is set). For IPv6 this is the 8 bit next_header
  230. field (when ipv6_proto is set).
  231. toeplitz_hash_2_or_4
  232. Controlled by multiple RxOLE registers for TCP/UDP over
  233. IPv4/IPv6 - Either, Toeplitz hash computed over 2-tuple IPv4
  234. or IPv6 src/dest addresses is reported; or, Toeplitz hash
  235. computed over 4-tuple IPv4 or IPv6 src/dest addresses and
  236. src/dest ports is reported. The Flow_id_toeplitz hash can
  237. also be reported here. Usually the hash reported here is the
  238. one used for hash-based REO routing (see
  239. use_flow_id_toeplitz_clfy in 'RXPT_CLASSIFY_INFO').
  240. In Pine, optionally the 3-tuple Toeplitz hash over IPv4
  241. or IPv6 src/dest addresses and L4 protocol can be reported
  242. here. (Unsupported in HastingsPrime)
  243. flow_id_toeplitz
  244. Toeplitz hash of 5-tuple
  245. {IP source address, IP destination address, IP source
  246. port, IP destination port, L4 protocol} in case of
  247. non-IPSec.
  248. In case of IPSec - Toeplitz hash of 4-tuple
  249. {IP source address, IP destination address, SPI, L4
  250. protocol}
  251. In Pine, optionally the 3-tuple Toeplitz hash over IPv4
  252. or IPv6 src/dest addresses and L4 protocol can be reported
  253. here. (Unsupported in HastingsPrime)
  254. The relevant Toeplitz key registers are provided in
  255. RxOLE's instance of common parser module. These registers
  256. are separate from the Toeplitz keys used by ASE/FSE modules
  257. inside RxOLE.The actual value will be passed on from common
  258. parser module to RxOLE in one of the WHO_* TLVs.
  259. <legal all>
  260. user_rssi
  261. RSSI for this user
  262. <legal all>
  263. pkt_type
  264. Packet type:
  265. <enum 0 dot11a>802.11a PPDU type
  266. <enum 1 dot11b>802.11b PPDU type
  267. <enum 2 dot11n_mm>802.11n Mixed Mode PPDU type
  268. <enum 3 dot11ac>802.11ac PPDU type
  269. <enum 4 dot11ax>802.11ax PPDU type
  270. <enum 5 dot11ba>802.11ba (WUR) PPDU type
  271. stbc
  272. When set, use STBC transmission rates
  273. sgi
  274. Field only valid when pkt type is HT, VHT or HE.
  275. <enum 0 0_8_us_sgi > Legacy normal GI. Can also be
  276. used for HE
  277. <enum 1 0_4_us_sgi > Legacy short GI. Can also be
  278. used for HE
  279. <enum 2 1_6_us_sgi > HE related GI
  280. <enum 3 3_2_us_sgi > HE related GI
  281. <legal 0 - 3>
  282. rate_mcs
  283. For details, refer to MCS_TYPE description
  284. Note: This is rate in case of 11a/11b
  285. <legal all>
  286. receive_bandwidth
  287. Full receive Bandwidth
  288. <enum 0 full_rx_bw_20_mhz>
  289. <enum 1 full_rx_bw_40_mhz>
  290. <enum 2 full_rx_bw_80_mhz>
  291. <enum 3 full_rx_bw_160_mhz>
  292. <legal 0-3>
  293. reception_type
  294. Indicates what type of reception this is.
  295. <enum 0 reception_type_SU > Basic SU reception (not
  296. part of OFDMA or MIMO)
  297. <enum 1 reception_type_MU_MIMO > This is related to
  298. DL type of reception
  299. <enum 2 reception_type_MU_OFDMA > This is related
  300. to DL type of reception
  301. <enum 3 reception_type_MU_OFDMA_MIMO > This is
  302. related to DL type of reception
  303. <enum 4 reception_type_UL_MU_MIMO > This is related
  304. to UL type of reception
  305. <enum 5 reception_type_UL_MU_OFDMA > This is
  306. related to UL type of reception
  307. <enum 6 reception_type_UL_MU_OFDMA_MIMO > This is
  308. related to UL type of reception
  309. <legal 0-6>
  310. mimo_ss_bitmap
  311. Field only valid when Reception_type for the MPDU from
  312. this STA is some form of MIMO reception
  313. Bitmap, with each bit indicating if the related spatial
  314. stream is used for this STA
  315. LSB related to SS 0
  316. 0: spatial stream not used for this reception
  317. 1: spatial stream used for this reception
  318. <legal all>
  319. ppdu_start_timestamp
  320. Timestamp that indicates when the PPDU that contained
  321. this MPDU started on the medium.
  322. <legal all>
  323. sw_phy_meta_data
  324. SW programmed Meta data provided by the PHY.
  325. Can be used for SW to indicate the channel the device is
  326. on.
  327. <legal all>
  328. vlan_ctag_ci
  329. 2 bytes of C-VLAN Tag Control Information from
  330. WHO_L2_LLC
  331. vlan_stag_ci
  332. 2 bytes of S-VLAN Tag Control Information from
  333. WHO_L2_LLC in case of double VLAN
  334. */
  335. /* Description RX_MSDU_START_0_RXPCU_MPDU_FILTER_IN_CATEGORY
  336. Field indicates what the reason was that this MPDU frame
  337. was allowed to come into the receive path by RXPCU
  338. <enum 0 rxpcu_filter_pass> This MPDU passed the normal
  339. frame filter programming of rxpcu
  340. <enum 1 rxpcu_monitor_client> This MPDU did NOT pass the
  341. regular frame filter and would have been dropped, were it
  342. not for the frame fitting into the 'monitor_client'
  343. category.
  344. <enum 2 rxpcu_monitor_other> This MPDU did NOT pass the
  345. regular frame filter and also did not pass the
  346. rxpcu_monitor_client filter. It would have been dropped
  347. accept that it did pass the 'monitor_other' category.
  348. <legal 0-2>
  349. */
  350. #define RX_MSDU_START_0_RXPCU_MPDU_FILTER_IN_CATEGORY_OFFSET 0x00000000
  351. #define RX_MSDU_START_0_RXPCU_MPDU_FILTER_IN_CATEGORY_LSB 0
  352. #define RX_MSDU_START_0_RXPCU_MPDU_FILTER_IN_CATEGORY_MASK 0x00000003
  353. /* Description RX_MSDU_START_0_SW_FRAME_GROUP_ID
  354. SW processes frames based on certain classifications.
  355. This field indicates to what sw classification this MPDU is
  356. mapped.
  357. The classification is given in priority order
  358. <enum 0 sw_frame_group_NDP_frame>
  359. <enum 1 sw_frame_group_Multicast_data>
  360. <enum 2 sw_frame_group_Unicast_data>
  361. <enum 3 sw_frame_group_Null_data > This includes mpdus
  362. of type Data Null as well as QoS Data Null
  363. <enum 4 sw_frame_group_mgmt_0000 >
  364. <enum 5 sw_frame_group_mgmt_0001 >
  365. <enum 6 sw_frame_group_mgmt_0010 >
  366. <enum 7 sw_frame_group_mgmt_0011 >
  367. <enum 8 sw_frame_group_mgmt_0100 >
  368. <enum 9 sw_frame_group_mgmt_0101 >
  369. <enum 10 sw_frame_group_mgmt_0110 >
  370. <enum 11 sw_frame_group_mgmt_0111 >
  371. <enum 12 sw_frame_group_mgmt_1000 >
  372. <enum 13 sw_frame_group_mgmt_1001 >
  373. <enum 14 sw_frame_group_mgmt_1010 >
  374. <enum 15 sw_frame_group_mgmt_1011 >
  375. <enum 16 sw_frame_group_mgmt_1100 >
  376. <enum 17 sw_frame_group_mgmt_1101 >
  377. <enum 18 sw_frame_group_mgmt_1110 >
  378. <enum 19 sw_frame_group_mgmt_1111 >
  379. <enum 20 sw_frame_group_ctrl_0000 >
  380. <enum 21 sw_frame_group_ctrl_0001 >
  381. <enum 22 sw_frame_group_ctrl_0010 >
  382. <enum 23 sw_frame_group_ctrl_0011 >
  383. <enum 24 sw_frame_group_ctrl_0100 >
  384. <enum 25 sw_frame_group_ctrl_0101 >
  385. <enum 26 sw_frame_group_ctrl_0110 >
  386. <enum 27 sw_frame_group_ctrl_0111 >
  387. <enum 28 sw_frame_group_ctrl_1000 >
  388. <enum 29 sw_frame_group_ctrl_1001 >
  389. <enum 30 sw_frame_group_ctrl_1010 >
  390. <enum 31 sw_frame_group_ctrl_1011 >
  391. <enum 32 sw_frame_group_ctrl_1100 >
  392. <enum 33 sw_frame_group_ctrl_1101 >
  393. <enum 34 sw_frame_group_ctrl_1110 >
  394. <enum 35 sw_frame_group_ctrl_1111 >
  395. <enum 36 sw_frame_group_unsupported> This covers type 3
  396. and protocol version != 0
  397. <legal 0-37>
  398. */
  399. #define RX_MSDU_START_0_SW_FRAME_GROUP_ID_OFFSET 0x00000000
  400. #define RX_MSDU_START_0_SW_FRAME_GROUP_ID_LSB 2
  401. #define RX_MSDU_START_0_SW_FRAME_GROUP_ID_MASK 0x000001fc
  402. /* Description RX_MSDU_START_0_RESERVED_0
  403. <legal 0>
  404. */
  405. #define RX_MSDU_START_0_RESERVED_0_OFFSET 0x00000000
  406. #define RX_MSDU_START_0_RESERVED_0_LSB 9
  407. #define RX_MSDU_START_0_RESERVED_0_MASK 0x0000fe00
  408. /* Description RX_MSDU_START_0_PHY_PPDU_ID
  409. A ppdu counter value that PHY increments for every PPDU
  410. received. The counter value wraps around
  411. <legal all>
  412. */
  413. #define RX_MSDU_START_0_PHY_PPDU_ID_OFFSET 0x00000000
  414. #define RX_MSDU_START_0_PHY_PPDU_ID_LSB 16
  415. #define RX_MSDU_START_0_PHY_PPDU_ID_MASK 0xffff0000
  416. /* Description RX_MSDU_START_1_MSDU_LENGTH
  417. MSDU length in bytes after decapsulation.
  418. This field is still valid for MPDU frames without
  419. */
  420. #define RX_MSDU_START_1_MSDU_LENGTH_OFFSET 0x00000004
  421. #define RX_MSDU_START_1_MSDU_LENGTH_LSB 0
  422. #define RX_MSDU_START_1_MSDU_LENGTH_MASK 0x00003fff
  423. /* Description RX_MSDU_START_1_RESERVED_1A
  424. <legal 0>
  425. */
  426. #define RX_MSDU_START_1_RESERVED_1A_OFFSET 0x00000004
  427. #define RX_MSDU_START_1_RESERVED_1A_LSB 14
  428. #define RX_MSDU_START_1_RESERVED_1A_MASK 0x00004000
  429. /* Description RX_MSDU_START_1_IPSEC_ESP
  430. Set if IPv4/v6 packet is using IPsec ESP
  431. */
  432. #define RX_MSDU_START_1_IPSEC_ESP_OFFSET 0x00000004
  433. #define RX_MSDU_START_1_IPSEC_ESP_LSB 15
  434. #define RX_MSDU_START_1_IPSEC_ESP_MASK 0x00008000
  435. /* Description RX_MSDU_START_1_L3_OFFSET
  436. Depending upon mode bit, this field either indicates the
  437. L3 offset in bytes from the start of the RX_HEADER or the IP
  438. offset in bytes from the start of the packet after
  439. decapsulation.  The latter is only valid if ipv4_proto or
  440. ipv6_proto is set.
  441. */
  442. #define RX_MSDU_START_1_L3_OFFSET_OFFSET 0x00000004
  443. #define RX_MSDU_START_1_L3_OFFSET_LSB 16
  444. #define RX_MSDU_START_1_L3_OFFSET_MASK 0x007f0000
  445. /* Description RX_MSDU_START_1_IPSEC_AH
  446. Set if IPv4/v6 packet is using IPsec AH
  447. */
  448. #define RX_MSDU_START_1_IPSEC_AH_OFFSET 0x00000004
  449. #define RX_MSDU_START_1_IPSEC_AH_LSB 23
  450. #define RX_MSDU_START_1_IPSEC_AH_MASK 0x00800000
  451. /* Description RX_MSDU_START_1_L4_OFFSET
  452. Depending upon mode bit, this field either indicates the
  453. L4 offset nin bytes from the start of RX_HEADER(only valid
  454. if either ipv4_proto or ipv6_proto is set to 1) or indicates
  455. the offset in bytes to the start of TCP or UDP header from
  456. the start of the IP header after decapsulation(Only valid if
  457. tcp_proto or udp_proto is set).  The value 0 indicates that
  458. the offset is longer than 127 bytes.
  459. */
  460. #define RX_MSDU_START_1_L4_OFFSET_OFFSET 0x00000004
  461. #define RX_MSDU_START_1_L4_OFFSET_LSB 24
  462. #define RX_MSDU_START_1_L4_OFFSET_MASK 0xff000000
  463. /* Description RX_MSDU_START_2_MSDU_NUMBER
  464. Indicates the MSDU number within a MPDU. This value is
  465. reset to zero at the start of each MPDU. If the number of
  466. MSDU exceeds 255 this number will wrap using modulo 256.
  467. */
  468. #define RX_MSDU_START_2_MSDU_NUMBER_OFFSET 0x00000008
  469. #define RX_MSDU_START_2_MSDU_NUMBER_LSB 0
  470. #define RX_MSDU_START_2_MSDU_NUMBER_MASK 0x000000ff
  471. /* Description RX_MSDU_START_2_DECAP_FORMAT
  472. Indicates the format after decapsulation:
  473. <enum 0 RAW> No encapsulation
  474. <enum 1 Native_WiFi>
  475. <enum 2 Ethernet> Ethernet 2 (DIX) or 802.3 (uses
  476. SNAP/LLC)
  477. <enum 3 802_3> Indicate Ethernet
  478. <legal all>
  479. */
  480. #define RX_MSDU_START_2_DECAP_FORMAT_OFFSET 0x00000008
  481. #define RX_MSDU_START_2_DECAP_FORMAT_LSB 8
  482. #define RX_MSDU_START_2_DECAP_FORMAT_MASK 0x00000300
  483. /* Description RX_MSDU_START_2_IPV4_PROTO
  484. Set if L2 layer indicates IPv4 protocol.
  485. */
  486. #define RX_MSDU_START_2_IPV4_PROTO_OFFSET 0x00000008
  487. #define RX_MSDU_START_2_IPV4_PROTO_LSB 10
  488. #define RX_MSDU_START_2_IPV4_PROTO_MASK 0x00000400
  489. /* Description RX_MSDU_START_2_IPV6_PROTO
  490. Set if L2 layer indicates IPv6 protocol.
  491. */
  492. #define RX_MSDU_START_2_IPV6_PROTO_OFFSET 0x00000008
  493. #define RX_MSDU_START_2_IPV6_PROTO_LSB 11
  494. #define RX_MSDU_START_2_IPV6_PROTO_MASK 0x00000800
  495. /* Description RX_MSDU_START_2_TCP_PROTO
  496. Set if the ipv4_proto or ipv6_proto are set and the IP
  497. protocol indicates TCP.
  498. */
  499. #define RX_MSDU_START_2_TCP_PROTO_OFFSET 0x00000008
  500. #define RX_MSDU_START_2_TCP_PROTO_LSB 12
  501. #define RX_MSDU_START_2_TCP_PROTO_MASK 0x00001000
  502. /* Description RX_MSDU_START_2_UDP_PROTO
  503. Set if the ipv4_proto or ipv6_proto are set and the IP
  504. protocol indicates UDP.
  505. */
  506. #define RX_MSDU_START_2_UDP_PROTO_OFFSET 0x00000008
  507. #define RX_MSDU_START_2_UDP_PROTO_LSB 13
  508. #define RX_MSDU_START_2_UDP_PROTO_MASK 0x00002000
  509. /* Description RX_MSDU_START_2_IP_FRAG
  510. Indicates that either the IP More frag bit is set or IP
  511. frag number is non-zero. If set indicates that this is a
  512. fragmented IP packet.
  513. */
  514. #define RX_MSDU_START_2_IP_FRAG_OFFSET 0x00000008
  515. #define RX_MSDU_START_2_IP_FRAG_LSB 14
  516. #define RX_MSDU_START_2_IP_FRAG_MASK 0x00004000
  517. /* Description RX_MSDU_START_2_TCP_ONLY_ACK
  518. Set if only the TCP Ack bit is set in the TCP flags and
  519. if the TCP payload is 0.
  520. */
  521. #define RX_MSDU_START_2_TCP_ONLY_ACK_OFFSET 0x00000008
  522. #define RX_MSDU_START_2_TCP_ONLY_ACK_LSB 15
  523. #define RX_MSDU_START_2_TCP_ONLY_ACK_MASK 0x00008000
  524. /* Description RX_MSDU_START_2_DA_IS_BCAST_MCAST
  525. The destination address is broadcast or multicast.
  526. */
  527. #define RX_MSDU_START_2_DA_IS_BCAST_MCAST_OFFSET 0x00000008
  528. #define RX_MSDU_START_2_DA_IS_BCAST_MCAST_LSB 16
  529. #define RX_MSDU_START_2_DA_IS_BCAST_MCAST_MASK 0x00010000
  530. /* Description RX_MSDU_START_2_TOEPLITZ_HASH_SEL
  531. Actual choosen Hash.
  532. 0 -> Toeplitz hash of 2-tuple (IP source address, IP
  533. destination address)1 -> Toeplitz hash of 4-tuple (IP source
  534. address, IP destination address, L4 (TCP/UDP) source port,
  535. L4 (TCP/UDP) destination port)
  536. 2 -> Toeplitz of flow_id
  537. 3 -> Zero is used
  538. <legal all>
  539. */
  540. #define RX_MSDU_START_2_TOEPLITZ_HASH_SEL_OFFSET 0x00000008
  541. #define RX_MSDU_START_2_TOEPLITZ_HASH_SEL_LSB 17
  542. #define RX_MSDU_START_2_TOEPLITZ_HASH_SEL_MASK 0x00060000
  543. /* Description RX_MSDU_START_2_IP_FIXED_HEADER_VALID
  544. Fixed 20-byte IPv4 header or 40-byte IPv6 header parsed
  545. fully within first 256 bytes of the packet
  546. */
  547. #define RX_MSDU_START_2_IP_FIXED_HEADER_VALID_OFFSET 0x00000008
  548. #define RX_MSDU_START_2_IP_FIXED_HEADER_VALID_LSB 19
  549. #define RX_MSDU_START_2_IP_FIXED_HEADER_VALID_MASK 0x00080000
  550. /* Description RX_MSDU_START_2_IP_EXTN_HEADER_VALID
  551. IPv6/IPv6 header, including IPv4 options and
  552. recognizable extension headers parsed fully within first 256
  553. bytes of the packet
  554. */
  555. #define RX_MSDU_START_2_IP_EXTN_HEADER_VALID_OFFSET 0x00000008
  556. #define RX_MSDU_START_2_IP_EXTN_HEADER_VALID_LSB 20
  557. #define RX_MSDU_START_2_IP_EXTN_HEADER_VALID_MASK 0x00100000
  558. /* Description RX_MSDU_START_2_TCP_UDP_HEADER_VALID
  559. Fixed 20-byte TCP (excluding TCP options) or 8-byte UDP
  560. header parsed fully within first 256 bytes of the packet
  561. */
  562. #define RX_MSDU_START_2_TCP_UDP_HEADER_VALID_OFFSET 0x00000008
  563. #define RX_MSDU_START_2_TCP_UDP_HEADER_VALID_LSB 21
  564. #define RX_MSDU_START_2_TCP_UDP_HEADER_VALID_MASK 0x00200000
  565. /* Description RX_MSDU_START_2_MESH_CONTROL_PRESENT
  566. When set, this MSDU includes the 'Mesh Control' field
  567. <legal all>
  568. */
  569. #define RX_MSDU_START_2_MESH_CONTROL_PRESENT_OFFSET 0x00000008
  570. #define RX_MSDU_START_2_MESH_CONTROL_PRESENT_LSB 22
  571. #define RX_MSDU_START_2_MESH_CONTROL_PRESENT_MASK 0x00400000
  572. /* Description RX_MSDU_START_2_LDPC
  573. When set, indicates that LDPC coding was used.
  574. <legal all>
  575. */
  576. #define RX_MSDU_START_2_LDPC_OFFSET 0x00000008
  577. #define RX_MSDU_START_2_LDPC_LSB 23
  578. #define RX_MSDU_START_2_LDPC_MASK 0x00800000
  579. /* Description RX_MSDU_START_2_IP4_PROTOCOL_IP6_NEXT_HEADER
  580. For IPv4 this is the 8 bit protocol field (when
  581. ipv4_proto is set). For IPv6 this is the 8 bit next_header
  582. field (when ipv6_proto is set).
  583. */
  584. #define RX_MSDU_START_2_IP4_PROTOCOL_IP6_NEXT_HEADER_OFFSET 0x00000008
  585. #define RX_MSDU_START_2_IP4_PROTOCOL_IP6_NEXT_HEADER_LSB 24
  586. #define RX_MSDU_START_2_IP4_PROTOCOL_IP6_NEXT_HEADER_MASK 0xff000000
  587. /* Description RX_MSDU_START_3_TOEPLITZ_HASH_2_OR_4
  588. Controlled by multiple RxOLE registers for TCP/UDP over
  589. IPv4/IPv6 - Either, Toeplitz hash computed over 2-tuple IPv4
  590. or IPv6 src/dest addresses is reported; or, Toeplitz hash
  591. computed over 4-tuple IPv4 or IPv6 src/dest addresses and
  592. src/dest ports is reported. The Flow_id_toeplitz hash can
  593. also be reported here. Usually the hash reported here is the
  594. one used for hash-based REO routing (see
  595. use_flow_id_toeplitz_clfy in 'RXPT_CLASSIFY_INFO').
  596. In Pine, optionally the 3-tuple Toeplitz hash over IPv4
  597. or IPv6 src/dest addresses and L4 protocol can be reported
  598. here. (Unsupported in HastingsPrime)
  599. */
  600. #define RX_MSDU_START_3_TOEPLITZ_HASH_2_OR_4_OFFSET 0x0000000c
  601. #define RX_MSDU_START_3_TOEPLITZ_HASH_2_OR_4_LSB 0
  602. #define RX_MSDU_START_3_TOEPLITZ_HASH_2_OR_4_MASK 0xffffffff
  603. /* Description RX_MSDU_START_4_FLOW_ID_TOEPLITZ
  604. Toeplitz hash of 5-tuple
  605. {IP source address, IP destination address, IP source
  606. port, IP destination port, L4 protocol} in case of
  607. non-IPSec.
  608. In case of IPSec - Toeplitz hash of 4-tuple
  609. {IP source address, IP destination address, SPI, L4
  610. protocol}
  611. In Pine, optionally the 3-tuple Toeplitz hash over IPv4
  612. or IPv6 src/dest addresses and L4 protocol can be reported
  613. here. (Unsupported in HastingsPrime)
  614. The relevant Toeplitz key registers are provided in
  615. RxOLE's instance of common parser module. These registers
  616. are separate from the Toeplitz keys used by ASE/FSE modules
  617. inside RxOLE.The actual value will be passed on from common
  618. parser module to RxOLE in one of the WHO_* TLVs.
  619. <legal all>
  620. */
  621. #define RX_MSDU_START_4_FLOW_ID_TOEPLITZ_OFFSET 0x00000010
  622. #define RX_MSDU_START_4_FLOW_ID_TOEPLITZ_LSB 0
  623. #define RX_MSDU_START_4_FLOW_ID_TOEPLITZ_MASK 0xffffffff
  624. /* Description RX_MSDU_START_5_USER_RSSI
  625. RSSI for this user
  626. <legal all>
  627. */
  628. #define RX_MSDU_START_5_USER_RSSI_OFFSET 0x00000014
  629. #define RX_MSDU_START_5_USER_RSSI_LSB 0
  630. #define RX_MSDU_START_5_USER_RSSI_MASK 0x000000ff
  631. /* Description RX_MSDU_START_5_PKT_TYPE
  632. Packet type:
  633. <enum 0 dot11a>802.11a PPDU type
  634. <enum 1 dot11b>802.11b PPDU type
  635. <enum 2 dot11n_mm>802.11n Mixed Mode PPDU type
  636. <enum 3 dot11ac>802.11ac PPDU type
  637. <enum 4 dot11ax>802.11ax PPDU type
  638. <enum 5 dot11ba>802.11ba (WUR) PPDU type
  639. */
  640. #define RX_MSDU_START_5_PKT_TYPE_OFFSET 0x00000014
  641. #define RX_MSDU_START_5_PKT_TYPE_LSB 8
  642. #define RX_MSDU_START_5_PKT_TYPE_MASK 0x00000f00
  643. /* Description RX_MSDU_START_5_STBC
  644. When set, use STBC transmission rates
  645. */
  646. #define RX_MSDU_START_5_STBC_OFFSET 0x00000014
  647. #define RX_MSDU_START_5_STBC_LSB 12
  648. #define RX_MSDU_START_5_STBC_MASK 0x00001000
  649. /* Description RX_MSDU_START_5_SGI
  650. Field only valid when pkt type is HT, VHT or HE.
  651. <enum 0 0_8_us_sgi > Legacy normal GI. Can also be
  652. used for HE
  653. <enum 1 0_4_us_sgi > Legacy short GI. Can also be
  654. used for HE
  655. <enum 2 1_6_us_sgi > HE related GI
  656. <enum 3 3_2_us_sgi > HE related GI
  657. <legal 0 - 3>
  658. */
  659. #define RX_MSDU_START_5_SGI_OFFSET 0x00000014
  660. #define RX_MSDU_START_5_SGI_LSB 13
  661. #define RX_MSDU_START_5_SGI_MASK 0x00006000
  662. /* Description RX_MSDU_START_5_RATE_MCS
  663. For details, refer to MCS_TYPE description
  664. Note: This is rate in case of 11a/11b
  665. <legal all>
  666. */
  667. #define RX_MSDU_START_5_RATE_MCS_OFFSET 0x00000014
  668. #define RX_MSDU_START_5_RATE_MCS_LSB 15
  669. #define RX_MSDU_START_5_RATE_MCS_MASK 0x00078000
  670. /* Description RX_MSDU_START_5_RECEIVE_BANDWIDTH
  671. Full receive Bandwidth
  672. <enum 0 full_rx_bw_20_mhz>
  673. <enum 1 full_rx_bw_40_mhz>
  674. <enum 2 full_rx_bw_80_mhz>
  675. <enum 3 full_rx_bw_160_mhz>
  676. <legal 0-3>
  677. */
  678. #define RX_MSDU_START_5_RECEIVE_BANDWIDTH_OFFSET 0x00000014
  679. #define RX_MSDU_START_5_RECEIVE_BANDWIDTH_LSB 19
  680. #define RX_MSDU_START_5_RECEIVE_BANDWIDTH_MASK 0x00180000
  681. /* Description RX_MSDU_START_5_RECEPTION_TYPE
  682. Indicates what type of reception this is.
  683. <enum 0 reception_type_SU > Basic SU reception (not
  684. part of OFDMA or MIMO)
  685. <enum 1 reception_type_MU_MIMO > This is related to
  686. DL type of reception
  687. <enum 2 reception_type_MU_OFDMA > This is related
  688. to DL type of reception
  689. <enum 3 reception_type_MU_OFDMA_MIMO > This is
  690. related to DL type of reception
  691. <enum 4 reception_type_UL_MU_MIMO > This is related
  692. to UL type of reception
  693. <enum 5 reception_type_UL_MU_OFDMA > This is
  694. related to UL type of reception
  695. <enum 6 reception_type_UL_MU_OFDMA_MIMO > This is
  696. related to UL type of reception
  697. <legal 0-6>
  698. */
  699. #define RX_MSDU_START_5_RECEPTION_TYPE_OFFSET 0x00000014
  700. #define RX_MSDU_START_5_RECEPTION_TYPE_LSB 21
  701. #define RX_MSDU_START_5_RECEPTION_TYPE_MASK 0x00e00000
  702. /* Description RX_MSDU_START_5_MIMO_SS_BITMAP
  703. Field only valid when Reception_type for the MPDU from
  704. this STA is some form of MIMO reception
  705. Bitmap, with each bit indicating if the related spatial
  706. stream is used for this STA
  707. LSB related to SS 0
  708. 0: spatial stream not used for this reception
  709. 1: spatial stream used for this reception
  710. <legal all>
  711. */
  712. #define RX_MSDU_START_5_MIMO_SS_BITMAP_OFFSET 0x00000014
  713. #define RX_MSDU_START_5_MIMO_SS_BITMAP_LSB 24
  714. #define RX_MSDU_START_5_MIMO_SS_BITMAP_MASK 0xff000000
  715. /* Description RX_MSDU_START_6_PPDU_START_TIMESTAMP
  716. Timestamp that indicates when the PPDU that contained
  717. this MPDU started on the medium.
  718. <legal all>
  719. */
  720. #define RX_MSDU_START_6_PPDU_START_TIMESTAMP_OFFSET 0x00000018
  721. #define RX_MSDU_START_6_PPDU_START_TIMESTAMP_LSB 0
  722. #define RX_MSDU_START_6_PPDU_START_TIMESTAMP_MASK 0xffffffff
  723. /* Description RX_MSDU_START_7_SW_PHY_META_DATA
  724. SW programmed Meta data provided by the PHY.
  725. Can be used for SW to indicate the channel the device is
  726. on.
  727. <legal all>
  728. */
  729. #define RX_MSDU_START_7_SW_PHY_META_DATA_OFFSET 0x0000001c
  730. #define RX_MSDU_START_7_SW_PHY_META_DATA_LSB 0
  731. #define RX_MSDU_START_7_SW_PHY_META_DATA_MASK 0xffffffff
  732. /* Description RX_MSDU_START_8_VLAN_CTAG_CI
  733. 2 bytes of C-VLAN Tag Control Information from
  734. WHO_L2_LLC
  735. */
  736. #define RX_MSDU_START_8_VLAN_CTAG_CI_OFFSET 0x00000020
  737. #define RX_MSDU_START_8_VLAN_CTAG_CI_LSB 0
  738. #define RX_MSDU_START_8_VLAN_CTAG_CI_MASK 0x0000ffff
  739. /* Description RX_MSDU_START_8_VLAN_STAG_CI
  740. 2 bytes of S-VLAN Tag Control Information from
  741. WHO_L2_LLC in case of double VLAN
  742. */
  743. #define RX_MSDU_START_8_VLAN_STAG_CI_OFFSET 0x00000020
  744. #define RX_MSDU_START_8_VLAN_STAG_CI_LSB 16
  745. #define RX_MSDU_START_8_VLAN_STAG_CI_MASK 0xffff0000
  746. #endif // _RX_MSDU_START_H_