rx_msdu_start.h 32 KB

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