rx_msdu_start.h 31 KB

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