rx_msdu_start.h 30 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042
  1. /*
  2. * Copyright (c) 2016-2017 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 _RX_MSDU_START_H_
  23. #define _RX_MSDU_START_H_
  24. #if !defined(__ASSEMBLER__)
  25. #endif
  26. // ################ START SUMMARY #################
  27. //
  28. // Dword Fields
  29. // 0 rxpcu_mpdu_filter_in_category[1:0], sw_frame_group_id[8:2], reserved_0[15:9], phy_ppdu_id[31:16]
  30. // 1 msdu_length[13:0], reserved_1a[14], ipsec_esp[15], l3_offset[22:16], ipsec_ah[23], l4_offset[31:24]
  31. // 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[17], reserved_2a[23:18], ip4_protocol_ip6_next_header[31:24]
  32. // 3 toeplitz_hash_2_or_4[31:0]
  33. // 4 flow_id_toeplitz[31:0]
  34. // 5 user_rssi[7:0], pkt_type[11:8], stbc[12], sgi[14:13], rate_mcs[18:15], receive_bandwidth[20:19], reception_type[22:21], nss[25:23], reserved_5[31:26]
  35. // 6 ppdu_start_timestamp[31:0]
  36. // 7 sw_phy_meta_data[31:0]
  37. //
  38. // ################ END SUMMARY #################
  39. #define NUM_OF_DWORDS_RX_MSDU_START 8
  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 : 1, //[17]
  61. reserved_2a : 6, //[23:18]
  62. ip4_protocol_ip6_next_header : 8; //[31:24]
  63. uint32_t toeplitz_hash_2_or_4 : 32; //[31:0]
  64. uint32_t flow_id_toeplitz : 32; //[31:0]
  65. uint32_t user_rssi : 8, //[7:0]
  66. pkt_type : 4, //[11:8]
  67. stbc : 1, //[12]
  68. sgi : 2, //[14:13]
  69. rate_mcs : 4, //[18:15]
  70. receive_bandwidth : 2, //[20:19]
  71. reception_type : 2, //[22:21]
  72. nss : 3, //[25:23]
  73. reserved_5 : 6; //[31:26]
  74. uint32_t ppdu_start_timestamp : 32; //[31:0]
  75. uint32_t sw_phy_meta_data : 32; //[31:0]
  76. };
  77. /*
  78. rxpcu_mpdu_filter_in_category
  79. Field indicates what the reason was that this MPDU frame
  80. was allowed to come into the receive path by RXPCU
  81. <enum 0 rxpcu_filter_pass> This MPDU passed the normal
  82. frame filter programming of rxpcu
  83. <enum 1 rxpcu_monitor_client> This MPDU did NOT pass the
  84. regular frame filter and would have been dropped, were it
  85. not for the frame fitting into the 'monitor_client'
  86. category.
  87. <enum 2 rxpcu_monitor_other> This MPDU did NOT pass the
  88. regular frame filter and also did not pass the
  89. rxpcu_monitor_client filter. It would have been dropped
  90. accept that it did pass the 'monitor_other' category.
  91. <legal 0-2>
  92. sw_frame_group_id
  93. SW processes frames based on certain classifications.
  94. This field indicates to what sw classification this MPDU is
  95. mapped.
  96. The classification is given in priority order
  97. <enum 0 sw_frame_group_NDP_frame>
  98. <enum 1 sw_frame_group_Multicast_data>
  99. <enum 2 sw_frame_group_Unicast_data>
  100. <enum 3 sw_frame_group_Null_data > This includes mpdus
  101. of type Data Null as well as QoS Data Null
  102. <enum 4 sw_frame_group_mgmt_0000 >
  103. <enum 5 sw_frame_group_mgmt_0001 >
  104. <enum 6 sw_frame_group_mgmt_0010 >
  105. <enum 7 sw_frame_group_mgmt_0011 >
  106. <enum 8 sw_frame_group_mgmt_0100 >
  107. <enum 9 sw_frame_group_mgmt_0101 >
  108. <enum 10 sw_frame_group_mgmt_0110 >
  109. <enum 11 sw_frame_group_mgmt_0111 >
  110. <enum 12 sw_frame_group_mgmt_1000 >
  111. <enum 13 sw_frame_group_mgmt_1001 >
  112. <enum 14 sw_frame_group_mgmt_1010 >
  113. <enum 15 sw_frame_group_mgmt_1011 >
  114. <enum 16 sw_frame_group_mgmt_1100 >
  115. <enum 17 sw_frame_group_mgmt_1101 >
  116. <enum 18 sw_frame_group_mgmt_1110 >
  117. <enum 19 sw_frame_group_mgmt_1111 >
  118. <enum 20 sw_frame_group_ctrl_0000 >
  119. <enum 21 sw_frame_group_ctrl_0001 >
  120. <enum 22 sw_frame_group_ctrl_0010 >
  121. <enum 23 sw_frame_group_ctrl_0011 >
  122. <enum 24 sw_frame_group_ctrl_0100 >
  123. <enum 25 sw_frame_group_ctrl_0101 >
  124. <enum 26 sw_frame_group_ctrl_0110 >
  125. <enum 27 sw_frame_group_ctrl_0111 >
  126. <enum 28 sw_frame_group_ctrl_1000 >
  127. <enum 29 sw_frame_group_ctrl_1001 >
  128. <enum 30 sw_frame_group_ctrl_1010 >
  129. <enum 31 sw_frame_group_ctrl_1011 >
  130. <enum 32 sw_frame_group_ctrl_1100 >
  131. <enum 33 sw_frame_group_ctrl_1101 >
  132. <enum 34 sw_frame_group_ctrl_1110 >
  133. <enum 35 sw_frame_group_ctrl_1111 >
  134. <enum 36 sw_frame_group_unsupported> This covers type 3
  135. and protocol version != 0
  136. <legal 0-37>
  137. reserved_0
  138. <legal 0>
  139. phy_ppdu_id
  140. A ppdu counter value that PHY increments for every PPDU
  141. received. The counter value wraps around
  142. <legal all>
  143. msdu_length
  144. MSDU length in bytes after decapsulation.
  145. This field is still valid for MPDU frames without
  146. reserved_1a
  147. <legal 0>
  148. ipsec_esp
  149. Set if IPv4/v6 packet is using IPsec ESP
  150. l3_offset
  151. Depending upon mode bit, this field either indicates the
  152. L3 offset in bytes from the start of the RX_HEADER or the IP
  153. offset in bytes from the start of the packet after
  154. decapsulation.  The latter is only valid if ipv4_proto or
  155. ipv6_proto is set.
  156. ipsec_ah
  157. Set if IPv4/v6 packet is using IPsec AH
  158. l4_offset
  159. Depending upon mode bit, this field either indicates the
  160. L4 offset nin bytes from the start of RX_HEADER(only valid
  161. if either ipv4_proto or ipv6_proto is set to 1) or indicates
  162. the offset in bytes to the start of TCP or UDP header from
  163. the start of the IP header after decapsulation(Only valid if
  164. tcp_proto or udp_proto is set).  The value 0 indicates that
  165. the offset is longer than 127 bytes.
  166. msdu_number
  167. Indicates the MSDU number within a MPDU. This value is
  168. reset to zero at the start of each MPDU. If the number of
  169. MSDU exceeds 255 this number will wrap using modulo 256.
  170. decap_format
  171. Indicates the format after decapsulation:
  172. <enum 0 RAW> No encapsulation
  173. <enum 1 Native_WiFi>
  174. <enum 2 Ethernet> Ethernet 2 (DIX) or 802.3 (uses
  175. SNAP/LLC)
  176. <enum 3 802_3> DO NOT USE. Indicate Ethernet
  177. <legal all>
  178. ipv4_proto
  179. Set if L2 layer indicates IPv4 protocol.
  180. ipv6_proto
  181. Set if L2 layer indicates IPv6 protocol.
  182. tcp_proto
  183. Set if the ipv4_proto or ipv6_proto are set and the IP
  184. protocol indicates TCP.
  185. udp_proto
  186. Set if the ipv4_proto or ipv6_proto are set and the IP
  187. protocol indicates UDP.
  188. ip_frag
  189. Indicates that either the IP More frag bit is set or IP
  190. frag number is non-zero. If set indicates that this is a
  191. fragmented IP packet.
  192. tcp_only_ack
  193. Set if only the TCP Ack bit is set in the TCP flags and
  194. if the TCP payload is 0.
  195. da_is_bcast_mcast
  196. The destination address is broadcast or multicast.
  197. toeplitz_hash
  198. Actual choosen Hash.
  199. 0 -> Toeplitz hash of 2-tuple (IP source address, IP
  200. destination address)1 -> Toeplitz hash of 4-tuple (IP source
  201. address, IP destination address, L4 (TCP/UDP) source port,
  202. L4 (TCP/UDP) destination port)
  203. reserved_2a
  204. <legal 0>
  205. ip4_protocol_ip6_next_header
  206. For IPv4 this is the 8 bit protocol field (when
  207. ipv4_proto is set). For IPv6 this is the 8 bit next_header
  208. field (when ipv6_proto is set).
  209. toeplitz_hash_2_or_4
  210. Controlled by RxOLE register - If register bit set to 0,
  211. Toeplitz hash is computed over 2-tuple IPv4 or IPv6 src/dest
  212. addresses; otherwise, toeplitz hash is computed over 4-tuple
  213. IPv4 or IPv6 src/dest addresses and src/dest ports
  214. flow_id_toeplitz
  215. Toeplitz hash of 5-tuple
  216. {IP source address, IP destination address, IP source
  217. port, IP destination port, L4 protocol} in case of
  218. non-IPSec.
  219. In case of IPSec - Toeplitz hash of 4-tuple
  220. {IP source address, IP destination address, SPI, L4
  221. protocol}
  222. The relevant Toeplitz key registers are provided in
  223. RxOLE's instance of common parser module. These registers
  224. are separate from the Toeplitz keys used by ASE/FSE modules
  225. inside RxOLE.The actual value will be passed on from common
  226. parser module to RxOLE in one of the WHO_* TLVs.
  227. <legal all>
  228. user_rssi
  229. RSSI for this user
  230. <legal all>
  231. pkt_type
  232. Packet type:
  233. <enum 0 dot11a>802.11a PPDU type
  234. <enum 1 dot11b>802.11b PPDU type
  235. <enum 2 dot11n_mm>802.11n Mixed Mode PPDU type
  236. <enum 3 dot11ac>802.11ac PPDU type
  237. <enum 4 dot11ax>802.11ax PPDU type
  238. stbc
  239. When set, use STBC transmission rates
  240. sgi
  241. Field only valid when pkt type is HT, VHT or HE.
  242. <enum 0 0_8_us_sgi > Legacy normal GI. Can also be
  243. used for HE
  244. <enum 1 0_4_us_sgi > Legacy short GI. Can also be
  245. used for HE
  246. <enum 2 1_6_us_sgi > HE related GI
  247. <enum 3 3_2_us_sgi > HE related GI
  248. <legal 0 - 3>
  249. rate_mcs
  250. For details, refer to MCS_TYPE description
  251. <legal all>
  252. receive_bandwidth
  253. Full receive Bandwidth
  254. <enum 0 full_rx_bw_20_mhz>
  255. <enum 1 full_rx_bw_40_mhz>
  256. <enum 2 full_rx_bw_80_mhz>
  257. <enum 3 full_rx_bw_160_mhz>
  258. <legal 0-3>
  259. reception_type
  260. Indicates what type of reception this is.
  261. <enum 0 reception_type_SU >
  262. <enum 1 reception_type_MU_MIMO >
  263. <enum 2 reception_type_MU_OFDMA >
  264. <enum 3 reception_type_MU_OFDMA_MIMO >
  265. <legal all>
  266. nss
  267. Field only valid when Reception_type =
  268. reception_type_MU_MIMO or reception_type_MU_OFDMA_MIMO
  269. Number of Spatial Streams occupied by the User
  270. <enum 0 1_spatial_stream>Single spatial stream
  271. <enum 1 2_spatial_streams>2 spatial streams
  272. <enum 2 3_spatial_streams>3 spatial streams
  273. <enum 3 4_spatial_streams>4 spatial streams
  274. <enum 4 5_spatial_streams>5 spatial streams
  275. <enum 5 6_spatial_streams>6 spatial streams
  276. <enum 6 7_spatial_streams>7 spatial streams
  277. <enum 7 8_spatial_streams>8 spatial streams
  278. reserved_5
  279. <legal 0>
  280. ppdu_start_timestamp
  281. Timestamp that indicates when the PPDU that contained
  282. this MPDU started on the medium.
  283. <legal all>
  284. sw_phy_meta_data
  285. SW programmed Meta data provided by the PHY.
  286. Can be used for SW to indicate the channel the device is
  287. on.
  288. <legal all>
  289. */
  290. /* Description RX_MSDU_START_0_RXPCU_MPDU_FILTER_IN_CATEGORY
  291. Field indicates what the reason was that this MPDU frame
  292. was allowed to come into the receive path by RXPCU
  293. <enum 0 rxpcu_filter_pass> This MPDU passed the normal
  294. frame filter programming of rxpcu
  295. <enum 1 rxpcu_monitor_client> This MPDU did NOT pass the
  296. regular frame filter and would have been dropped, were it
  297. not for the frame fitting into the 'monitor_client'
  298. category.
  299. <enum 2 rxpcu_monitor_other> This MPDU did NOT pass the
  300. regular frame filter and also did not pass the
  301. rxpcu_monitor_client filter. It would have been dropped
  302. accept that it did pass the 'monitor_other' category.
  303. <legal 0-2>
  304. */
  305. #define RX_MSDU_START_0_RXPCU_MPDU_FILTER_IN_CATEGORY_OFFSET 0x00000000
  306. #define RX_MSDU_START_0_RXPCU_MPDU_FILTER_IN_CATEGORY_LSB 0
  307. #define RX_MSDU_START_0_RXPCU_MPDU_FILTER_IN_CATEGORY_MASK 0x00000003
  308. /* Description RX_MSDU_START_0_SW_FRAME_GROUP_ID
  309. SW processes frames based on certain classifications.
  310. This field indicates to what sw classification this MPDU is
  311. mapped.
  312. The classification is given in priority order
  313. <enum 0 sw_frame_group_NDP_frame>
  314. <enum 1 sw_frame_group_Multicast_data>
  315. <enum 2 sw_frame_group_Unicast_data>
  316. <enum 3 sw_frame_group_Null_data > This includes mpdus
  317. of type Data Null as well as QoS Data Null
  318. <enum 4 sw_frame_group_mgmt_0000 >
  319. <enum 5 sw_frame_group_mgmt_0001 >
  320. <enum 6 sw_frame_group_mgmt_0010 >
  321. <enum 7 sw_frame_group_mgmt_0011 >
  322. <enum 8 sw_frame_group_mgmt_0100 >
  323. <enum 9 sw_frame_group_mgmt_0101 >
  324. <enum 10 sw_frame_group_mgmt_0110 >
  325. <enum 11 sw_frame_group_mgmt_0111 >
  326. <enum 12 sw_frame_group_mgmt_1000 >
  327. <enum 13 sw_frame_group_mgmt_1001 >
  328. <enum 14 sw_frame_group_mgmt_1010 >
  329. <enum 15 sw_frame_group_mgmt_1011 >
  330. <enum 16 sw_frame_group_mgmt_1100 >
  331. <enum 17 sw_frame_group_mgmt_1101 >
  332. <enum 18 sw_frame_group_mgmt_1110 >
  333. <enum 19 sw_frame_group_mgmt_1111 >
  334. <enum 20 sw_frame_group_ctrl_0000 >
  335. <enum 21 sw_frame_group_ctrl_0001 >
  336. <enum 22 sw_frame_group_ctrl_0010 >
  337. <enum 23 sw_frame_group_ctrl_0011 >
  338. <enum 24 sw_frame_group_ctrl_0100 >
  339. <enum 25 sw_frame_group_ctrl_0101 >
  340. <enum 26 sw_frame_group_ctrl_0110 >
  341. <enum 27 sw_frame_group_ctrl_0111 >
  342. <enum 28 sw_frame_group_ctrl_1000 >
  343. <enum 29 sw_frame_group_ctrl_1001 >
  344. <enum 30 sw_frame_group_ctrl_1010 >
  345. <enum 31 sw_frame_group_ctrl_1011 >
  346. <enum 32 sw_frame_group_ctrl_1100 >
  347. <enum 33 sw_frame_group_ctrl_1101 >
  348. <enum 34 sw_frame_group_ctrl_1110 >
  349. <enum 35 sw_frame_group_ctrl_1111 >
  350. <enum 36 sw_frame_group_unsupported> This covers type 3
  351. and protocol version != 0
  352. <legal 0-37>
  353. */
  354. #define RX_MSDU_START_0_SW_FRAME_GROUP_ID_OFFSET 0x00000000
  355. #define RX_MSDU_START_0_SW_FRAME_GROUP_ID_LSB 2
  356. #define RX_MSDU_START_0_SW_FRAME_GROUP_ID_MASK 0x000001fc
  357. /* Description RX_MSDU_START_0_RESERVED_0
  358. <legal 0>
  359. */
  360. #define RX_MSDU_START_0_RESERVED_0_OFFSET 0x00000000
  361. #define RX_MSDU_START_0_RESERVED_0_LSB 9
  362. #define RX_MSDU_START_0_RESERVED_0_MASK 0x0000fe00
  363. /* Description RX_MSDU_START_0_PHY_PPDU_ID
  364. A ppdu counter value that PHY increments for every PPDU
  365. received. The counter value wraps around
  366. <legal all>
  367. */
  368. #define RX_MSDU_START_0_PHY_PPDU_ID_OFFSET 0x00000000
  369. #define RX_MSDU_START_0_PHY_PPDU_ID_LSB 16
  370. #define RX_MSDU_START_0_PHY_PPDU_ID_MASK 0xffff0000
  371. /* Description RX_MSDU_START_1_MSDU_LENGTH
  372. MSDU length in bytes after decapsulation.
  373. This field is still valid for MPDU frames without
  374. */
  375. #define RX_MSDU_START_1_MSDU_LENGTH_OFFSET 0x00000004
  376. #define RX_MSDU_START_1_MSDU_LENGTH_LSB 0
  377. #define RX_MSDU_START_1_MSDU_LENGTH_MASK 0x00003fff
  378. /* Description RX_MSDU_START_1_RESERVED_1A
  379. <legal 0>
  380. */
  381. #define RX_MSDU_START_1_RESERVED_1A_OFFSET 0x00000004
  382. #define RX_MSDU_START_1_RESERVED_1A_LSB 14
  383. #define RX_MSDU_START_1_RESERVED_1A_MASK 0x00004000
  384. /* Description RX_MSDU_START_1_IPSEC_ESP
  385. Set if IPv4/v6 packet is using IPsec ESP
  386. */
  387. #define RX_MSDU_START_1_IPSEC_ESP_OFFSET 0x00000004
  388. #define RX_MSDU_START_1_IPSEC_ESP_LSB 15
  389. #define RX_MSDU_START_1_IPSEC_ESP_MASK 0x00008000
  390. /* Description RX_MSDU_START_1_L3_OFFSET
  391. Depending upon mode bit, this field either indicates the
  392. L3 offset in bytes from the start of the RX_HEADER or the IP
  393. offset in bytes from the start of the packet after
  394. decapsulation.  The latter is only valid if ipv4_proto or
  395. ipv6_proto is set.
  396. */
  397. #define RX_MSDU_START_1_L3_OFFSET_OFFSET 0x00000004
  398. #define RX_MSDU_START_1_L3_OFFSET_LSB 16
  399. #define RX_MSDU_START_1_L3_OFFSET_MASK 0x007f0000
  400. /* Description RX_MSDU_START_1_IPSEC_AH
  401. Set if IPv4/v6 packet is using IPsec AH
  402. */
  403. #define RX_MSDU_START_1_IPSEC_AH_OFFSET 0x00000004
  404. #define RX_MSDU_START_1_IPSEC_AH_LSB 23
  405. #define RX_MSDU_START_1_IPSEC_AH_MASK 0x00800000
  406. /* Description RX_MSDU_START_1_L4_OFFSET
  407. Depending upon mode bit, this field either indicates the
  408. L4 offset nin bytes from the start of RX_HEADER(only valid
  409. if either ipv4_proto or ipv6_proto is set to 1) or indicates
  410. the offset in bytes to the start of TCP or UDP header from
  411. the start of the IP header after decapsulation(Only valid if
  412. tcp_proto or udp_proto is set).  The value 0 indicates that
  413. the offset is longer than 127 bytes.
  414. */
  415. #define RX_MSDU_START_1_L4_OFFSET_OFFSET 0x00000004
  416. #define RX_MSDU_START_1_L4_OFFSET_LSB 24
  417. #define RX_MSDU_START_1_L4_OFFSET_MASK 0xff000000
  418. /* Description RX_MSDU_START_2_MSDU_NUMBER
  419. Indicates the MSDU number within a MPDU. This value is
  420. reset to zero at the start of each MPDU. If the number of
  421. MSDU exceeds 255 this number will wrap using modulo 256.
  422. */
  423. #define RX_MSDU_START_2_MSDU_NUMBER_OFFSET 0x00000008
  424. #define RX_MSDU_START_2_MSDU_NUMBER_LSB 0
  425. #define RX_MSDU_START_2_MSDU_NUMBER_MASK 0x000000ff
  426. /* Description RX_MSDU_START_2_DECAP_FORMAT
  427. Indicates the format after decapsulation:
  428. <enum 0 RAW> No encapsulation
  429. <enum 1 Native_WiFi>
  430. <enum 2 Ethernet> Ethernet 2 (DIX) or 802.3 (uses
  431. SNAP/LLC)
  432. <enum 3 802_3> DO NOT USE. Indicate Ethernet
  433. <legal all>
  434. */
  435. #define RX_MSDU_START_2_DECAP_FORMAT_OFFSET 0x00000008
  436. #define RX_MSDU_START_2_DECAP_FORMAT_LSB 8
  437. #define RX_MSDU_START_2_DECAP_FORMAT_MASK 0x00000300
  438. /* Description RX_MSDU_START_2_IPV4_PROTO
  439. Set if L2 layer indicates IPv4 protocol.
  440. */
  441. #define RX_MSDU_START_2_IPV4_PROTO_OFFSET 0x00000008
  442. #define RX_MSDU_START_2_IPV4_PROTO_LSB 10
  443. #define RX_MSDU_START_2_IPV4_PROTO_MASK 0x00000400
  444. /* Description RX_MSDU_START_2_IPV6_PROTO
  445. Set if L2 layer indicates IPv6 protocol.
  446. */
  447. #define RX_MSDU_START_2_IPV6_PROTO_OFFSET 0x00000008
  448. #define RX_MSDU_START_2_IPV6_PROTO_LSB 11
  449. #define RX_MSDU_START_2_IPV6_PROTO_MASK 0x00000800
  450. /* Description RX_MSDU_START_2_TCP_PROTO
  451. Set if the ipv4_proto or ipv6_proto are set and the IP
  452. protocol indicates TCP.
  453. */
  454. #define RX_MSDU_START_2_TCP_PROTO_OFFSET 0x00000008
  455. #define RX_MSDU_START_2_TCP_PROTO_LSB 12
  456. #define RX_MSDU_START_2_TCP_PROTO_MASK 0x00001000
  457. /* Description RX_MSDU_START_2_UDP_PROTO
  458. Set if the ipv4_proto or ipv6_proto are set and the IP
  459. protocol indicates UDP.
  460. */
  461. #define RX_MSDU_START_2_UDP_PROTO_OFFSET 0x00000008
  462. #define RX_MSDU_START_2_UDP_PROTO_LSB 13
  463. #define RX_MSDU_START_2_UDP_PROTO_MASK 0x00002000
  464. /* Description RX_MSDU_START_2_IP_FRAG
  465. Indicates that either the IP More frag bit is set or IP
  466. frag number is non-zero. If set indicates that this is a
  467. fragmented IP packet.
  468. */
  469. #define RX_MSDU_START_2_IP_FRAG_OFFSET 0x00000008
  470. #define RX_MSDU_START_2_IP_FRAG_LSB 14
  471. #define RX_MSDU_START_2_IP_FRAG_MASK 0x00004000
  472. /* Description RX_MSDU_START_2_TCP_ONLY_ACK
  473. Set if only the TCP Ack bit is set in the TCP flags and
  474. if the TCP payload is 0.
  475. */
  476. #define RX_MSDU_START_2_TCP_ONLY_ACK_OFFSET 0x00000008
  477. #define RX_MSDU_START_2_TCP_ONLY_ACK_LSB 15
  478. #define RX_MSDU_START_2_TCP_ONLY_ACK_MASK 0x00008000
  479. /* Description RX_MSDU_START_2_DA_IS_BCAST_MCAST
  480. The destination address is broadcast or multicast.
  481. */
  482. #define RX_MSDU_START_2_DA_IS_BCAST_MCAST_OFFSET 0x00000008
  483. #define RX_MSDU_START_2_DA_IS_BCAST_MCAST_LSB 16
  484. #define RX_MSDU_START_2_DA_IS_BCAST_MCAST_MASK 0x00010000
  485. /* Description RX_MSDU_START_2_TOEPLITZ_HASH
  486. Actual choosen Hash.
  487. 0 -> Toeplitz hash of 2-tuple (IP source address, IP
  488. destination address)1 -> Toeplitz hash of 4-tuple (IP source
  489. address, IP destination address, L4 (TCP/UDP) source port,
  490. L4 (TCP/UDP) destination port)
  491. */
  492. #define RX_MSDU_START_2_TOEPLITZ_HASH_OFFSET 0x00000008
  493. #define RX_MSDU_START_2_TOEPLITZ_HASH_LSB 17
  494. #define RX_MSDU_START_2_TOEPLITZ_HASH_MASK 0x00020000
  495. /* Description RX_MSDU_START_2_RESERVED_2A
  496. <legal 0>
  497. */
  498. #define RX_MSDU_START_2_RESERVED_2A_OFFSET 0x00000008
  499. #define RX_MSDU_START_2_RESERVED_2A_LSB 18
  500. #define RX_MSDU_START_2_RESERVED_2A_MASK 0x00fc0000
  501. /* Description RX_MSDU_START_2_IP4_PROTOCOL_IP6_NEXT_HEADER
  502. For IPv4 this is the 8 bit protocol field (when
  503. ipv4_proto is set). For IPv6 this is the 8 bit next_header
  504. field (when ipv6_proto is set).
  505. */
  506. #define RX_MSDU_START_2_IP4_PROTOCOL_IP6_NEXT_HEADER_OFFSET 0x00000008
  507. #define RX_MSDU_START_2_IP4_PROTOCOL_IP6_NEXT_HEADER_LSB 24
  508. #define RX_MSDU_START_2_IP4_PROTOCOL_IP6_NEXT_HEADER_MASK 0xff000000
  509. /* Description RX_MSDU_START_3_TOEPLITZ_HASH_2_OR_4
  510. Controlled by RxOLE register - If register bit set to 0,
  511. Toeplitz hash is computed over 2-tuple IPv4 or IPv6 src/dest
  512. addresses; otherwise, toeplitz hash is computed over 4-tuple
  513. IPv4 or IPv6 src/dest addresses and src/dest ports
  514. */
  515. #define RX_MSDU_START_3_TOEPLITZ_HASH_2_OR_4_OFFSET 0x0000000c
  516. #define RX_MSDU_START_3_TOEPLITZ_HASH_2_OR_4_LSB 0
  517. #define RX_MSDU_START_3_TOEPLITZ_HASH_2_OR_4_MASK 0xffffffff
  518. /* Description RX_MSDU_START_4_FLOW_ID_TOEPLITZ
  519. Toeplitz hash of 5-tuple
  520. {IP source address, IP destination address, IP source
  521. port, IP destination port, L4 protocol} in case of
  522. non-IPSec.
  523. In case of IPSec - Toeplitz hash of 4-tuple
  524. {IP source address, IP destination address, SPI, L4
  525. protocol}
  526. The relevant Toeplitz key registers are provided in
  527. RxOLE's instance of common parser module. These registers
  528. are separate from the Toeplitz keys used by ASE/FSE modules
  529. inside RxOLE.The actual value will be passed on from common
  530. parser module to RxOLE in one of the WHO_* TLVs.
  531. <legal all>
  532. */
  533. #define RX_MSDU_START_4_FLOW_ID_TOEPLITZ_OFFSET 0x00000010
  534. #define RX_MSDU_START_4_FLOW_ID_TOEPLITZ_LSB 0
  535. #define RX_MSDU_START_4_FLOW_ID_TOEPLITZ_MASK 0xffffffff
  536. /* Description RX_MSDU_START_5_USER_RSSI
  537. RSSI for this user
  538. <legal all>
  539. */
  540. #define RX_MSDU_START_5_USER_RSSI_OFFSET 0x00000014
  541. #define RX_MSDU_START_5_USER_RSSI_LSB 0
  542. #define RX_MSDU_START_5_USER_RSSI_MASK 0x000000ff
  543. /* Description RX_MSDU_START_5_PKT_TYPE
  544. Packet type:
  545. <enum 0 dot11a>802.11a PPDU type
  546. <enum 1 dot11b>802.11b PPDU type
  547. <enum 2 dot11n_mm>802.11n Mixed Mode PPDU type
  548. <enum 3 dot11ac>802.11ac PPDU type
  549. <enum 4 dot11ax>802.11ax PPDU type
  550. */
  551. #define RX_MSDU_START_5_PKT_TYPE_OFFSET 0x00000014
  552. #define RX_MSDU_START_5_PKT_TYPE_LSB 8
  553. #define RX_MSDU_START_5_PKT_TYPE_MASK 0x00000f00
  554. /* Description RX_MSDU_START_5_STBC
  555. When set, use STBC transmission rates
  556. */
  557. #define RX_MSDU_START_5_STBC_OFFSET 0x00000014
  558. #define RX_MSDU_START_5_STBC_LSB 12
  559. #define RX_MSDU_START_5_STBC_MASK 0x00001000
  560. /* Description RX_MSDU_START_5_SGI
  561. Field only valid when pkt type is HT, VHT or HE.
  562. <enum 0 0_8_us_sgi > Legacy normal GI. Can also be
  563. used for HE
  564. <enum 1 0_4_us_sgi > Legacy short GI. Can also be
  565. used for HE
  566. <enum 2 1_6_us_sgi > HE related GI
  567. <enum 3 3_2_us_sgi > HE related GI
  568. <legal 0 - 3>
  569. */
  570. #define RX_MSDU_START_5_SGI_OFFSET 0x00000014
  571. #define RX_MSDU_START_5_SGI_LSB 13
  572. #define RX_MSDU_START_5_SGI_MASK 0x00006000
  573. /* Description RX_MSDU_START_5_RATE_MCS
  574. For details, refer to MCS_TYPE description
  575. <legal all>
  576. */
  577. #define RX_MSDU_START_5_RATE_MCS_OFFSET 0x00000014
  578. #define RX_MSDU_START_5_RATE_MCS_LSB 15
  579. #define RX_MSDU_START_5_RATE_MCS_MASK 0x00078000
  580. /* Description RX_MSDU_START_5_RECEIVE_BANDWIDTH
  581. Full receive Bandwidth
  582. <enum 0 full_rx_bw_20_mhz>
  583. <enum 1 full_rx_bw_40_mhz>
  584. <enum 2 full_rx_bw_80_mhz>
  585. <enum 3 full_rx_bw_160_mhz>
  586. <legal 0-3>
  587. */
  588. #define RX_MSDU_START_5_RECEIVE_BANDWIDTH_OFFSET 0x00000014
  589. #define RX_MSDU_START_5_RECEIVE_BANDWIDTH_LSB 19
  590. #define RX_MSDU_START_5_RECEIVE_BANDWIDTH_MASK 0x00180000
  591. /* Description RX_MSDU_START_5_RECEPTION_TYPE
  592. Indicates what type of reception this is.
  593. <enum 0 reception_type_SU >
  594. <enum 1 reception_type_MU_MIMO >
  595. <enum 2 reception_type_MU_OFDMA >
  596. <enum 3 reception_type_MU_OFDMA_MIMO >
  597. <legal all>
  598. */
  599. #define RX_MSDU_START_5_RECEPTION_TYPE_OFFSET 0x00000014
  600. #define RX_MSDU_START_5_RECEPTION_TYPE_LSB 21
  601. #define RX_MSDU_START_5_RECEPTION_TYPE_MASK 0x00600000
  602. /* Description RX_MSDU_START_5_NSS
  603. Field only valid when Reception_type =
  604. reception_type_MU_MIMO or reception_type_MU_OFDMA_MIMO
  605. Number of Spatial Streams occupied by the User
  606. <enum 0 1_spatial_stream>Single spatial stream
  607. <enum 1 2_spatial_streams>2 spatial streams
  608. <enum 2 3_spatial_streams>3 spatial streams
  609. <enum 3 4_spatial_streams>4 spatial streams
  610. <enum 4 5_spatial_streams>5 spatial streams
  611. <enum 5 6_spatial_streams>6 spatial streams
  612. <enum 6 7_spatial_streams>7 spatial streams
  613. <enum 7 8_spatial_streams>8 spatial streams
  614. */
  615. #define RX_MSDU_START_5_NSS_OFFSET 0x00000014
  616. #define RX_MSDU_START_5_NSS_LSB 23
  617. #define RX_MSDU_START_5_NSS_MASK 0x03800000
  618. /* Description RX_MSDU_START_5_RESERVED_5
  619. <legal 0>
  620. */
  621. #define RX_MSDU_START_5_RESERVED_5_OFFSET 0x00000014
  622. #define RX_MSDU_START_5_RESERVED_5_LSB 26
  623. #define RX_MSDU_START_5_RESERVED_5_MASK 0xfc000000
  624. /* Description RX_MSDU_START_6_PPDU_START_TIMESTAMP
  625. Timestamp that indicates when the PPDU that contained
  626. this MPDU started on the medium.
  627. <legal all>
  628. */
  629. #define RX_MSDU_START_6_PPDU_START_TIMESTAMP_OFFSET 0x00000018
  630. #define RX_MSDU_START_6_PPDU_START_TIMESTAMP_LSB 0
  631. #define RX_MSDU_START_6_PPDU_START_TIMESTAMP_MASK 0xffffffff
  632. /* Description RX_MSDU_START_7_SW_PHY_META_DATA
  633. SW programmed Meta data provided by the PHY.
  634. Can be used for SW to indicate the channel the device is
  635. on.
  636. <legal all>
  637. */
  638. #define RX_MSDU_START_7_SW_PHY_META_DATA_OFFSET 0x0000001c
  639. #define RX_MSDU_START_7_SW_PHY_META_DATA_LSB 0
  640. #define RX_MSDU_START_7_SW_PHY_META_DATA_MASK 0xffffffff
  641. #endif // _RX_MSDU_START_H_