rx_mpdu_start.h 60 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974
  1. /*
  2. * Copyright (c) 2019, The Linux Foundation. All rights reserved.
  3. *
  4. * Permission to use, copy, modify, and/or distribute this software for any
  5. * purpose with or without fee is hereby granted, provided that the above
  6. * copyright notice and this permission notice appear in all copies.
  7. *
  8. * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
  9. * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
  10. * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
  11. * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
  12. * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
  13. * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
  14. * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
  15. */
  16. #ifndef _RX_MPDU_START_H_
  17. #define _RX_MPDU_START_H_
  18. #if !defined(__ASSEMBLER__)
  19. #endif
  20. #include "rx_mpdu_info.h"
  21. // ################ START SUMMARY #################
  22. //
  23. // Dword Fields
  24. // 0-22 struct rx_mpdu_info rx_mpdu_info_details;
  25. //
  26. // ################ END SUMMARY #################
  27. #define NUM_OF_DWORDS_RX_MPDU_START 23
  28. struct rx_mpdu_start {
  29. struct rx_mpdu_info rx_mpdu_info_details;
  30. };
  31. /*
  32. struct rx_mpdu_info rx_mpdu_info_details
  33. Structure containing all the MPDU header details that
  34. might be needed for other modules further down the received
  35. path
  36. */
  37. /* EXTERNAL REFERENCE : struct rx_mpdu_info rx_mpdu_info_details */
  38. /* EXTERNAL REFERENCE : struct rxpt_classify_info rxpt_classify_info_details */
  39. /* Description RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_REO_DESTINATION_INDICATION
  40. The ID of the REO exit ring where the MSDU frame shall
  41. push after (MPDU level) reordering has finished.
  42. <enum 0 reo_destination_tcl> Reo will push the frame
  43. into the REO2TCL ring
  44. <enum 1 reo_destination_sw1> Reo will push the frame
  45. into the REO2SW1 ring
  46. <enum 2 reo_destination_sw2> Reo will push the frame
  47. into the REO2SW2 ring
  48. <enum 3 reo_destination_sw3> Reo will push the frame
  49. into the REO2SW3 ring
  50. <enum 4 reo_destination_sw4> Reo will push the frame
  51. into the REO2SW4 ring
  52. <enum 5 reo_destination_release> Reo will push the frame
  53. into the REO_release ring
  54. <enum 6 reo_destination_fw> Reo will push the frame into
  55. the REO2FW ring
  56. <enum 7 reo_destination_sw5> Reo will push the frame
  57. into the REO2SW5 ring (REO remaps this in chips without
  58. REO2SW5 ring, e.g. Pine)
  59. <enum 8 reo_destination_sw6> Reo will push the frame
  60. into the REO2SW6 ring (REO remaps this in chips without
  61. REO2SW6 ring, e.g. Pine)
  62. <enum 9 reo_destination_9> REO remaps this <enum 10
  63. reo_destination_10> REO remaps this
  64. <enum 11 reo_destination_11> REO remaps this
  65. <enum 12 reo_destination_12> REO remaps this <enum 13
  66. reo_destination_13> REO remaps this
  67. <enum 14 reo_destination_14> REO remaps this
  68. <enum 15 reo_destination_15> REO remaps this
  69. <enum 16 reo_destination_16> REO remaps this
  70. <enum 17 reo_destination_17> REO remaps this
  71. <enum 18 reo_destination_18> REO remaps this
  72. <enum 19 reo_destination_19> REO remaps this
  73. <enum 20 reo_destination_20> REO remaps this
  74. <enum 21 reo_destination_21> REO remaps this
  75. <enum 22 reo_destination_22> REO remaps this
  76. <enum 23 reo_destination_23> REO remaps this
  77. <enum 24 reo_destination_24> REO remaps this
  78. <enum 25 reo_destination_25> REO remaps this
  79. <enum 26 reo_destination_26> REO remaps this
  80. <enum 27 reo_destination_27> REO remaps this
  81. <enum 28 reo_destination_28> REO remaps this
  82. <enum 29 reo_destination_29> REO remaps this
  83. <enum 30 reo_destination_30> REO remaps this
  84. <enum 31 reo_destination_31> REO remaps this
  85. <legal all>
  86. */
  87. #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_REO_DESTINATION_INDICATION_OFFSET 0x00000000
  88. #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_REO_DESTINATION_INDICATION_LSB 0
  89. #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_REO_DESTINATION_INDICATION_MASK 0x0000001f
  90. /* Description RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_LMAC_PEER_ID_MSB
  91. If use_flow_id_toeplitz_clfy is set and lmac_peer_id_'sb
  92. is 2'b00, Rx OLE uses a REO desination indicati'n of {1'b1,
  93. hash[3:0]} using the chosen Toeplitz hash from Common Parser
  94. if flow search fails.
  95. If use_flow_id_toeplitz_clfy is set and lmac_peer_id_msb
  96. 's not 2'b00, Rx OLE uses a REO desination indication of
  97. {lmac_peer_id_msb, hash[2:0]} using the chosen Toeplitz hash
  98. from Common Parser if flow search fails.
  99. This LMAC/peer-based routing is not supported in
  100. Hastings80 and HastingsPrime.
  101. <legal 0>
  102. */
  103. #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_LMAC_PEER_ID_MSB_OFFSET 0x00000000
  104. #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_LMAC_PEER_ID_MSB_LSB 5
  105. #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_LMAC_PEER_ID_MSB_MASK 0x00000060
  106. /* Description RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_USE_FLOW_ID_TOEPLITZ_CLFY
  107. Indication to Rx OLE to enable REO destination routing
  108. based on the chosen Toeplitz hash from Common Parser, in
  109. case flow search fails
  110. <legal all>
  111. */
  112. #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_USE_FLOW_ID_TOEPLITZ_CLFY_OFFSET 0x00000000
  113. #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_USE_FLOW_ID_TOEPLITZ_CLFY_LSB 7
  114. #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_USE_FLOW_ID_TOEPLITZ_CLFY_MASK 0x00000080
  115. /* Description RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_PKT_SELECTION_FP_UCAST_DATA
  116. Filter pass Unicast data frame (matching
  117. rxpcu_filter_pass and sw_frame_group_Unicast_data) routing
  118. selection
  119. 1'b0: source and destination rings are selected from the
  120. RxOLE register settings for the packet type
  121. 1'b1: source ring and destination ring is selected from
  122. the rxdma0_source_ring_selection and
  123. rxdma0_destination_ring_selection fields in this STRUCT
  124. <legal all>
  125. */
  126. #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_PKT_SELECTION_FP_UCAST_DATA_OFFSET 0x00000000
  127. #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_PKT_SELECTION_FP_UCAST_DATA_LSB 8
  128. #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_PKT_SELECTION_FP_UCAST_DATA_MASK 0x00000100
  129. /* Description RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_PKT_SELECTION_FP_MCAST_DATA
  130. Filter pass Multicast data frame (matching
  131. rxpcu_filter_pass and sw_frame_group_Multicast_data) routing
  132. selection
  133. 1'b0: source and destination rings are selected from the
  134. RxOLE register settings for the packet type
  135. 1'b1: source ring and destination ring is selected from
  136. the rxdma0_source_ring_selection and
  137. rxdma0_destination_ring_selection fields in this STRUCT
  138. <legal all>
  139. */
  140. #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_PKT_SELECTION_FP_MCAST_DATA_OFFSET 0x00000000
  141. #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_PKT_SELECTION_FP_MCAST_DATA_LSB 9
  142. #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_PKT_SELECTION_FP_MCAST_DATA_MASK 0x00000200
  143. /* Description RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_PKT_SELECTION_FP_1000
  144. Filter pass BAR frame (matching rxpcu_filter_pass and
  145. sw_frame_group_ctrl_1000) routing selection
  146. 1'b0: source and destination rings are selected from the
  147. RxOLE register settings for the packet type
  148. 1'b1: source ring and destination ring is selected from
  149. the rxdma0_source_ring_selection and
  150. rxdma0_destination_ring_selection fields in this STRUCT
  151. <legal all>
  152. */
  153. #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_PKT_SELECTION_FP_1000_OFFSET 0x00000000
  154. #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_PKT_SELECTION_FP_1000_LSB 10
  155. #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_PKT_SELECTION_FP_1000_MASK 0x00000400
  156. /* Description RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_RXDMA0_SOURCE_RING_SELECTION
  157. Field only valid when for the received frame type the
  158. corresponding pkt_selection_fp_... bit is set
  159. <enum 0 wbm2rxdma_buf_source_ring> The data buffer for
  160. <enum 1 fw2rxdma_buf_source_ring> The data buffer for
  161. this frame shall be sourced by fw2rxdma buffer source ring.
  162. <enum 2 sw2rxdma_buf_source_ring> The data buffer for
  163. this frame shall be sourced by sw2rxdma buffer source ring.
  164. <enum 3 no_buffer_ring> The frame shall not be written
  165. to any data buffer.
  166. <legal all>
  167. */
  168. #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_RXDMA0_SOURCE_RING_SELECTION_OFFSET 0x00000000
  169. #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_RXDMA0_SOURCE_RING_SELECTION_LSB 11
  170. #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_RXDMA0_SOURCE_RING_SELECTION_MASK 0x00001800
  171. /* Description RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_RXDMA0_DESTINATION_RING_SELECTION
  172. Field only valid when for the received frame type the
  173. corresponding pkt_selection_fp_... bit is set
  174. <enum 0 rxdma_release_ring> RXDMA0 shall push the frame
  175. to the Release ring. Effectively this means the frame needs
  176. to be dropped.
  177. <enum 1 rxdma2fw_ring> RXDMA0 shall push the frame to
  178. the FW ring.
  179. <enum 2 rxdma2sw_ring> RXDMA0 shall push the frame to
  180. the SW ring.
  181. <enum 3 rxdma2reo_ring> RXDMA0 shall push the frame to
  182. the REO entrance ring.
  183. <legal all>
  184. */
  185. #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_RXDMA0_DESTINATION_RING_SELECTION_OFFSET 0x00000000
  186. #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_RXDMA0_DESTINATION_RING_SELECTION_LSB 13
  187. #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_RXDMA0_DESTINATION_RING_SELECTION_MASK 0x00006000
  188. /* Description RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_RESERVED_0B
  189. <legal 0>
  190. */
  191. #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_RESERVED_0B_OFFSET 0x00000000
  192. #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_RESERVED_0B_LSB 15
  193. #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_RESERVED_0B_MASK 0xffff8000
  194. /* Description RX_MPDU_START_1_RX_MPDU_INFO_DETAILS_RX_REO_QUEUE_DESC_ADDR_31_0
  195. In case of ndp or phy_err or AST_based_lookup_valid ==
  196. 0, this field will be set to 0
  197. Address (lower 32 bits) of the REO queue descriptor.
  198. If no Peer entry lookup happened for this frame, the
  199. value wil be set to 0, and the frame shall never be pushed
  200. to REO entrance ring.
  201. <legal all>
  202. */
  203. #define RX_MPDU_START_1_RX_MPDU_INFO_DETAILS_RX_REO_QUEUE_DESC_ADDR_31_0_OFFSET 0x00000004
  204. #define RX_MPDU_START_1_RX_MPDU_INFO_DETAILS_RX_REO_QUEUE_DESC_ADDR_31_0_LSB 0
  205. #define RX_MPDU_START_1_RX_MPDU_INFO_DETAILS_RX_REO_QUEUE_DESC_ADDR_31_0_MASK 0xffffffff
  206. /* Description RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_RX_REO_QUEUE_DESC_ADDR_39_32
  207. In case of ndp or phy_err or AST_based_lookup_valid ==
  208. 0, this field will be set to 0
  209. Address (upper 8 bits) of the REO queue descriptor.
  210. If no Peer entry lookup happened for this frame, the
  211. value wil be set to 0, and the frame shall never be pushed
  212. to REO entrance ring.
  213. <legal all>
  214. */
  215. #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_RX_REO_QUEUE_DESC_ADDR_39_32_OFFSET 0x00000008
  216. #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_RX_REO_QUEUE_DESC_ADDR_39_32_LSB 0
  217. #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_RX_REO_QUEUE_DESC_ADDR_39_32_MASK 0x000000ff
  218. /* Description RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_RECEIVE_QUEUE_NUMBER
  219. In case of ndp or phy_err or AST_based_lookup_valid ==
  220. 0, this field will be set to 0
  221. Indicates the MPDU queue ID to which this MPDU link
  222. descriptor belongs
  223. Used for tracking and debugging
  224. <legal all>
  225. */
  226. #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_RECEIVE_QUEUE_NUMBER_OFFSET 0x00000008
  227. #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_RECEIVE_QUEUE_NUMBER_LSB 8
  228. #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_RECEIVE_QUEUE_NUMBER_MASK 0x00ffff00
  229. /* Description RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_PRE_DELIM_ERR_WARNING
  230. Indicates that a delimiter FCS error was found in
  231. between the Previous MPDU and this MPDU.
  232. Note that this is just a warning, and does not mean that
  233. this MPDU is corrupted in any way. If it is, there will be
  234. other errors indicated such as FCS or decrypt errors
  235. In case of ndp or phy_err, this field will indicate at
  236. least one of delimiters located after the last MPDU in the
  237. previous PPDU has been corrupted.
  238. */
  239. #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_PRE_DELIM_ERR_WARNING_OFFSET 0x00000008
  240. #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_PRE_DELIM_ERR_WARNING_LSB 24
  241. #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_PRE_DELIM_ERR_WARNING_MASK 0x01000000
  242. /* Description RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_FIRST_DELIM_ERR
  243. Indicates that the first delimiter had a FCS failure.
  244. Only valid when first_mpdu and first_msdu are set.
  245. */
  246. #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_FIRST_DELIM_ERR_OFFSET 0x00000008
  247. #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_FIRST_DELIM_ERR_LSB 25
  248. #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_FIRST_DELIM_ERR_MASK 0x02000000
  249. /* Description RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_RESERVED_2A
  250. <legal 0>
  251. */
  252. #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_RESERVED_2A_OFFSET 0x00000008
  253. #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_RESERVED_2A_LSB 26
  254. #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_RESERVED_2A_MASK 0xfc000000
  255. /* Description RX_MPDU_START_3_RX_MPDU_INFO_DETAILS_PN_31_0
  256. WEP: IV = {key_id_octet, pn2, pn1, pn0}. Only pn[23:0]
  257. is valid.
  258. TKIP: IV = {pn5, pn4, pn3, pn2, key_id_octet, pn0,
  259. WEPSeed[1], pn1}. Only pn[47:0] is valid.
  260. AES-CCM: IV = {pn5, pn4, pn3, pn2, key_id_octet, 0x0,
  261. pn1, pn0}. Only pn[47:0] is valid.
  262. WAPI: IV = {key_id_octet, 0x0, pn15, pn14, pn13, pn12,
  263. pn11, pn10, pn9, pn8, pn7, pn6, pn5, pn4, pn3, pn2, pn1,
  264. pn0}. pn[127:0] are valid.
  265. */
  266. #define RX_MPDU_START_3_RX_MPDU_INFO_DETAILS_PN_31_0_OFFSET 0x0000000c
  267. #define RX_MPDU_START_3_RX_MPDU_INFO_DETAILS_PN_31_0_LSB 0
  268. #define RX_MPDU_START_3_RX_MPDU_INFO_DETAILS_PN_31_0_MASK 0xffffffff
  269. /* Description RX_MPDU_START_4_RX_MPDU_INFO_DETAILS_PN_63_32
  270. Bits [63:32] of the PN number. See description for
  271. pn_31_0.
  272. */
  273. #define RX_MPDU_START_4_RX_MPDU_INFO_DETAILS_PN_63_32_OFFSET 0x00000010
  274. #define RX_MPDU_START_4_RX_MPDU_INFO_DETAILS_PN_63_32_LSB 0
  275. #define RX_MPDU_START_4_RX_MPDU_INFO_DETAILS_PN_63_32_MASK 0xffffffff
  276. /* Description RX_MPDU_START_5_RX_MPDU_INFO_DETAILS_PN_95_64
  277. Bits [95:64] of the PN number. See description for
  278. pn_31_0.
  279. */
  280. #define RX_MPDU_START_5_RX_MPDU_INFO_DETAILS_PN_95_64_OFFSET 0x00000014
  281. #define RX_MPDU_START_5_RX_MPDU_INFO_DETAILS_PN_95_64_LSB 0
  282. #define RX_MPDU_START_5_RX_MPDU_INFO_DETAILS_PN_95_64_MASK 0xffffffff
  283. /* Description RX_MPDU_START_6_RX_MPDU_INFO_DETAILS_PN_127_96
  284. Bits [127:96] of the PN number. See description for
  285. pn_31_0.
  286. */
  287. #define RX_MPDU_START_6_RX_MPDU_INFO_DETAILS_PN_127_96_OFFSET 0x00000018
  288. #define RX_MPDU_START_6_RX_MPDU_INFO_DETAILS_PN_127_96_LSB 0
  289. #define RX_MPDU_START_6_RX_MPDU_INFO_DETAILS_PN_127_96_MASK 0xffffffff
  290. /* Description RX_MPDU_START_7_RX_MPDU_INFO_DETAILS_EPD_EN
  291. Field only valid when AST_based_lookup_valid == 1.
  292. In case of ndp or phy_err or AST_based_lookup_valid ==
  293. 0, this field will be set to 0
  294. If set to one use EPD instead of LPD
  295. <legal all>
  296. */
  297. #define RX_MPDU_START_7_RX_MPDU_INFO_DETAILS_EPD_EN_OFFSET 0x0000001c
  298. #define RX_MPDU_START_7_RX_MPDU_INFO_DETAILS_EPD_EN_LSB 0
  299. #define RX_MPDU_START_7_RX_MPDU_INFO_DETAILS_EPD_EN_MASK 0x00000001
  300. /* Description RX_MPDU_START_7_RX_MPDU_INFO_DETAILS_ALL_FRAMES_SHALL_BE_ENCRYPTED
  301. In case of ndp or phy_err or AST_based_lookup_valid ==
  302. 0, this field will be set to 0
  303. When set, all frames (data only ?) shall be encrypted.
  304. If not, RX CRYPTO shall set an error flag.
  305. <legal all>
  306. */
  307. #define RX_MPDU_START_7_RX_MPDU_INFO_DETAILS_ALL_FRAMES_SHALL_BE_ENCRYPTED_OFFSET 0x0000001c
  308. #define RX_MPDU_START_7_RX_MPDU_INFO_DETAILS_ALL_FRAMES_SHALL_BE_ENCRYPTED_LSB 1
  309. #define RX_MPDU_START_7_RX_MPDU_INFO_DETAILS_ALL_FRAMES_SHALL_BE_ENCRYPTED_MASK 0x00000002
  310. /* Description RX_MPDU_START_7_RX_MPDU_INFO_DETAILS_ENCRYPT_TYPE
  311. In case of ndp or phy_err or AST_based_lookup_valid ==
  312. 0, this field will be set to 0
  313. Indicates type of decrypt cipher used (as defined in the
  314. peer entry)
  315. <enum 0 wep_40> WEP 40-bit
  316. <enum 1 wep_104> WEP 104-bit
  317. <enum 2 tkip_no_mic> TKIP without MIC
  318. <enum 3 wep_128> WEP 128-bit
  319. <enum 4 tkip_with_mic> TKIP with MIC
  320. <enum 5 wapi> WAPI
  321. <enum 6 aes_ccmp_128> AES CCMP 128
  322. <enum 7 no_cipher> No crypto
  323. <enum 8 aes_ccmp_256> AES CCMP 256
  324. <enum 9 aes_gcmp_128> AES CCMP 128
  325. <enum 10 aes_gcmp_256> AES CCMP 256
  326. <enum 11 wapi_gcm_sm4> WAPI GCM SM4
  327. <enum 12 wep_varied_width> WEP encryption. As for WEP
  328. per keyid the key bit width can vary, the key bit width for
  329. this MPDU will be indicated in field
  330. wep_key_width_for_variable key
  331. <legal 0-12>
  332. */
  333. #define RX_MPDU_START_7_RX_MPDU_INFO_DETAILS_ENCRYPT_TYPE_OFFSET 0x0000001c
  334. #define RX_MPDU_START_7_RX_MPDU_INFO_DETAILS_ENCRYPT_TYPE_LSB 2
  335. #define RX_MPDU_START_7_RX_MPDU_INFO_DETAILS_ENCRYPT_TYPE_MASK 0x0000003c
  336. /* Description RX_MPDU_START_7_RX_MPDU_INFO_DETAILS_WEP_KEY_WIDTH_FOR_VARIABLE_KEY
  337. Field only valid when key_type is set to
  338. wep_varied_width.
  339. This field indicates the size of the wep key for this
  340. MPDU.
  341. <enum 0 wep_varied_width_40> WEP 40-bit
  342. <enum 1 wep_varied_width_104> WEP 104-bit
  343. <enum 2 wep_varied_width_128> WEP 128-bit
  344. <legal 0-2>
  345. */
  346. #define RX_MPDU_START_7_RX_MPDU_INFO_DETAILS_WEP_KEY_WIDTH_FOR_VARIABLE_KEY_OFFSET 0x0000001c
  347. #define RX_MPDU_START_7_RX_MPDU_INFO_DETAILS_WEP_KEY_WIDTH_FOR_VARIABLE_KEY_LSB 6
  348. #define RX_MPDU_START_7_RX_MPDU_INFO_DETAILS_WEP_KEY_WIDTH_FOR_VARIABLE_KEY_MASK 0x000000c0
  349. /* Description RX_MPDU_START_7_RX_MPDU_INFO_DETAILS_MESH_STA
  350. In case of ndp or phy_err or AST_based_lookup_valid ==
  351. 0, this field will be set to 0
  352. When set, this is a Mesh (11s) STA.
  353. The interpretation of the A-MSDU 'Length' field in the
  354. MPDU (if any) is decided by the e-numerations below.
  355. <enum 0 MESH_DISABLE>
  356. <enum 1 MESH_Q2Q> A-MSDU 'Length' is big endian and
  357. includes the length of Mesh Control.
  358. <enum 2 MESH_11S_BE> A-MSDU 'Length' is big endian and
  359. excludes the length of Mesh Control.
  360. <enum 3 MESH_11S_LE> A-MSDU 'Length' is little endian
  361. and excludes the length of Mesh Control. This is
  362. 802.11s-compliant.
  363. <legal all>
  364. */
  365. #define RX_MPDU_START_7_RX_MPDU_INFO_DETAILS_MESH_STA_OFFSET 0x0000001c
  366. #define RX_MPDU_START_7_RX_MPDU_INFO_DETAILS_MESH_STA_LSB 8
  367. #define RX_MPDU_START_7_RX_MPDU_INFO_DETAILS_MESH_STA_MASK 0x00000300
  368. /* Description RX_MPDU_START_7_RX_MPDU_INFO_DETAILS_BSSID_HIT
  369. In case of ndp or phy_err or AST_based_lookup_valid ==
  370. 0, this field will be set to 0
  371. When set, the BSSID of the incoming frame matched one of
  372. the 8 BSSID register values
  373. <legal all>
  374. */
  375. #define RX_MPDU_START_7_RX_MPDU_INFO_DETAILS_BSSID_HIT_OFFSET 0x0000001c
  376. #define RX_MPDU_START_7_RX_MPDU_INFO_DETAILS_BSSID_HIT_LSB 10
  377. #define RX_MPDU_START_7_RX_MPDU_INFO_DETAILS_BSSID_HIT_MASK 0x00000400
  378. /* Description RX_MPDU_START_7_RX_MPDU_INFO_DETAILS_BSSID_NUMBER
  379. Field only valid when bssid_hit is set.
  380. This number indicates which one out of the 8 BSSID
  381. register values matched the incoming frame
  382. <legal all>
  383. */
  384. #define RX_MPDU_START_7_RX_MPDU_INFO_DETAILS_BSSID_NUMBER_OFFSET 0x0000001c
  385. #define RX_MPDU_START_7_RX_MPDU_INFO_DETAILS_BSSID_NUMBER_LSB 11
  386. #define RX_MPDU_START_7_RX_MPDU_INFO_DETAILS_BSSID_NUMBER_MASK 0x00007800
  387. /* Description RX_MPDU_START_7_RX_MPDU_INFO_DETAILS_TID
  388. Field only valid when mpdu_qos_control_valid is set
  389. The TID field in the QoS control field
  390. <legal all>
  391. */
  392. #define RX_MPDU_START_7_RX_MPDU_INFO_DETAILS_TID_OFFSET 0x0000001c
  393. #define RX_MPDU_START_7_RX_MPDU_INFO_DETAILS_TID_LSB 15
  394. #define RX_MPDU_START_7_RX_MPDU_INFO_DETAILS_TID_MASK 0x00078000
  395. /* Description RX_MPDU_START_7_RX_MPDU_INFO_DETAILS_RESERVED_7A
  396. <legal 0>
  397. */
  398. #define RX_MPDU_START_7_RX_MPDU_INFO_DETAILS_RESERVED_7A_OFFSET 0x0000001c
  399. #define RX_MPDU_START_7_RX_MPDU_INFO_DETAILS_RESERVED_7A_LSB 19
  400. #define RX_MPDU_START_7_RX_MPDU_INFO_DETAILS_RESERVED_7A_MASK 0xfff80000
  401. /* Description RX_MPDU_START_8_RX_MPDU_INFO_DETAILS_PEER_META_DATA
  402. In case of ndp or phy_err or AST_based_lookup_valid ==
  403. 0, this field will be set to 0
  404. Meta data that SW has programmed in the Peer table entry
  405. of the transmitting STA.
  406. <legal all>
  407. */
  408. #define RX_MPDU_START_8_RX_MPDU_INFO_DETAILS_PEER_META_DATA_OFFSET 0x00000020
  409. #define RX_MPDU_START_8_RX_MPDU_INFO_DETAILS_PEER_META_DATA_LSB 0
  410. #define RX_MPDU_START_8_RX_MPDU_INFO_DETAILS_PEER_META_DATA_MASK 0xffffffff
  411. /* Description RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_RXPCU_MPDU_FILTER_IN_CATEGORY
  412. Field indicates what the reason was that this MPDU frame
  413. was allowed to come into the receive path by RXPCU
  414. <enum 0 rxpcu_filter_pass> This MPDU passed the normal
  415. frame filter programming of rxpcu
  416. <enum 1 rxpcu_monitor_client> This MPDU did NOT pass the
  417. regular frame filter and would have been dropped, were it
  418. not for the frame fitting into the 'monitor_client'
  419. category.
  420. <enum 2 rxpcu_monitor_other> This MPDU did NOT pass the
  421. regular frame filter and also did not pass the
  422. rxpcu_monitor_client filter. It would have been dropped
  423. accept that it did pass the 'monitor_other' category.
  424. Note: for ndp frame, if it was expected because the
  425. preceding NDPA was filter_pass, the setting
  426. rxpcu_filter_pass will be used. This setting will also be
  427. used for every ndp frame in case Promiscuous mode is
  428. enabled.
  429. In case promiscuous is not enabled, and an NDP is not
  430. preceded by a NPDA filter pass frame, the only other setting
  431. that could appear here for the NDP is rxpcu_monitor_other.
  432. (rxpcu has a configuration bit specifically for this
  433. scenario)
  434. Note: for
  435. <legal 0-2>
  436. */
  437. #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_RXPCU_MPDU_FILTER_IN_CATEGORY_OFFSET 0x00000024
  438. #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_RXPCU_MPDU_FILTER_IN_CATEGORY_LSB 0
  439. #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_RXPCU_MPDU_FILTER_IN_CATEGORY_MASK 0x00000003
  440. /* Description RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_SW_FRAME_GROUP_ID
  441. SW processes frames based on certain classifications.
  442. This field indicates to what sw classification this MPDU is
  443. mapped.
  444. The classification is given in priority order
  445. <enum 0 sw_frame_group_NDP_frame> Note: The
  446. corresponding Rxpcu_Mpdu_filter_in_category can be
  447. rxpcu_filter_pass or rxpcu_monitor_other
  448. <enum 1 sw_frame_group_Multicast_data>
  449. <enum 2 sw_frame_group_Unicast_data>
  450. <enum 3 sw_frame_group_Null_data > This includes mpdus
  451. of type Data Null as well as QoS Data Null
  452. <enum 4 sw_frame_group_mgmt_0000 >
  453. <enum 5 sw_frame_group_mgmt_0001 >
  454. <enum 6 sw_frame_group_mgmt_0010 >
  455. <enum 7 sw_frame_group_mgmt_0011 >
  456. <enum 8 sw_frame_group_mgmt_0100 >
  457. <enum 9 sw_frame_group_mgmt_0101 >
  458. <enum 10 sw_frame_group_mgmt_0110 >
  459. <enum 11 sw_frame_group_mgmt_0111 >
  460. <enum 12 sw_frame_group_mgmt_1000 >
  461. <enum 13 sw_frame_group_mgmt_1001 >
  462. <enum 14 sw_frame_group_mgmt_1010 >
  463. <enum 15 sw_frame_group_mgmt_1011 >
  464. <enum 16 sw_frame_group_mgmt_1100 >
  465. <enum 17 sw_frame_group_mgmt_1101 >
  466. <enum 18 sw_frame_group_mgmt_1110 >
  467. <enum 19 sw_frame_group_mgmt_1111 >
  468. <enum 20 sw_frame_group_ctrl_0000 >
  469. <enum 21 sw_frame_group_ctrl_0001 >
  470. <enum 22 sw_frame_group_ctrl_0010 >
  471. <enum 23 sw_frame_group_ctrl_0011 >
  472. <enum 24 sw_frame_group_ctrl_0100 >
  473. <enum 25 sw_frame_group_ctrl_0101 >
  474. <enum 26 sw_frame_group_ctrl_0110 >
  475. <enum 27 sw_frame_group_ctrl_0111 >
  476. <enum 28 sw_frame_group_ctrl_1000 >
  477. <enum 29 sw_frame_group_ctrl_1001 >
  478. <enum 30 sw_frame_group_ctrl_1010 >
  479. <enum 31 sw_frame_group_ctrl_1011 >
  480. <enum 32 sw_frame_group_ctrl_1100 >
  481. <enum 33 sw_frame_group_ctrl_1101 >
  482. <enum 34 sw_frame_group_ctrl_1110 >
  483. <enum 35 sw_frame_group_ctrl_1111 >
  484. <enum 36 sw_frame_group_unsupported> This covers type 3
  485. and protocol version != 0
  486. Note: The corresponding Rxpcu_Mpdu_filter_in_category
  487. can only be rxpcu_monitor_other
  488. Note: The corresponding Rxpcu_Mpdu_filter_in_category
  489. can be rxpcu_filter_pass
  490. <legal 0-37>
  491. */
  492. #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_SW_FRAME_GROUP_ID_OFFSET 0x00000024
  493. #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_SW_FRAME_GROUP_ID_LSB 2
  494. #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_SW_FRAME_GROUP_ID_MASK 0x000001fc
  495. /* Description RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_NDP_FRAME
  496. When set, the received frame was an NDP frame, and thus
  497. there will be no MPDU data.
  498. <legal all>
  499. */
  500. #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_NDP_FRAME_OFFSET 0x00000024
  501. #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_NDP_FRAME_LSB 9
  502. #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_NDP_FRAME_MASK 0x00000200
  503. /* Description RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_PHY_ERR
  504. When set, a PHY error was received before MAC received
  505. any data, and thus there will be no MPDU data.
  506. <legal all>
  507. */
  508. #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_PHY_ERR_OFFSET 0x00000024
  509. #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_PHY_ERR_LSB 10
  510. #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_PHY_ERR_MASK 0x00000400
  511. /* Description RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_PHY_ERR_DURING_MPDU_HEADER
  512. When set, a PHY error was received before MAC received
  513. the complete MPDU header which was needed for proper
  514. decoding
  515. <legal all>
  516. */
  517. #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_PHY_ERR_DURING_MPDU_HEADER_OFFSET 0x00000024
  518. #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_PHY_ERR_DURING_MPDU_HEADER_LSB 11
  519. #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_PHY_ERR_DURING_MPDU_HEADER_MASK 0x00000800
  520. /* Description RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_PROTOCOL_VERSION_ERR
  521. Set when RXPCU detected a version error in the Frame
  522. control field
  523. <legal all>
  524. */
  525. #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_PROTOCOL_VERSION_ERR_OFFSET 0x00000024
  526. #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_PROTOCOL_VERSION_ERR_LSB 12
  527. #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_PROTOCOL_VERSION_ERR_MASK 0x00001000
  528. /* Description RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_AST_BASED_LOOKUP_VALID
  529. When set, AST based lookup for this frame has found a
  530. valid result.
  531. Note that for NDP frame this will never be set
  532. <legal all>
  533. */
  534. #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_AST_BASED_LOOKUP_VALID_OFFSET 0x00000024
  535. #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_AST_BASED_LOOKUP_VALID_LSB 13
  536. #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_AST_BASED_LOOKUP_VALID_MASK 0x00002000
  537. /* Description RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_RESERVED_9A
  538. <legal 0>
  539. */
  540. #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_RESERVED_9A_OFFSET 0x00000024
  541. #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_RESERVED_9A_LSB 14
  542. #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_RESERVED_9A_MASK 0x0000c000
  543. /* Description RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_PHY_PPDU_ID
  544. A ppdu counter value that PHY increments for every PPDU
  545. received. The counter value wraps around
  546. <legal all>
  547. */
  548. #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_PHY_PPDU_ID_OFFSET 0x00000024
  549. #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_PHY_PPDU_ID_LSB 16
  550. #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_PHY_PPDU_ID_MASK 0xffff0000
  551. /* Description RX_MPDU_START_10_RX_MPDU_INFO_DETAILS_AST_INDEX
  552. This field indicates the index of the AST entry
  553. corresponding to this MPDU. It is provided by the GSE module
  554. instantiated in RXPCU.
  555. A value of 0xFFFF indicates an invalid AST index,
  556. meaning that No AST entry was found or NO AST search was
  557. performed
  558. In case of ndp or phy_err, this field will be set to
  559. 0xFFFF
  560. <legal all>
  561. */
  562. #define RX_MPDU_START_10_RX_MPDU_INFO_DETAILS_AST_INDEX_OFFSET 0x00000028
  563. #define RX_MPDU_START_10_RX_MPDU_INFO_DETAILS_AST_INDEX_LSB 0
  564. #define RX_MPDU_START_10_RX_MPDU_INFO_DETAILS_AST_INDEX_MASK 0x0000ffff
  565. /* Description RX_MPDU_START_10_RX_MPDU_INFO_DETAILS_SW_PEER_ID
  566. In case of ndp or phy_err or AST_based_lookup_valid ==
  567. 0, this field will be set to 0
  568. This field indicates a unique peer identifier. It is set
  569. equal to field 'sw_peer_id' from the AST entry
  570. <legal all>
  571. */
  572. #define RX_MPDU_START_10_RX_MPDU_INFO_DETAILS_SW_PEER_ID_OFFSET 0x00000028
  573. #define RX_MPDU_START_10_RX_MPDU_INFO_DETAILS_SW_PEER_ID_LSB 16
  574. #define RX_MPDU_START_10_RX_MPDU_INFO_DETAILS_SW_PEER_ID_MASK 0xffff0000
  575. /* Description RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MPDU_FRAME_CONTROL_VALID
  576. When set, the field Mpdu_Frame_control_field has valid
  577. information
  578. <legal all>
  579. */
  580. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MPDU_FRAME_CONTROL_VALID_OFFSET 0x0000002c
  581. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MPDU_FRAME_CONTROL_VALID_LSB 0
  582. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MPDU_FRAME_CONTROL_VALID_MASK 0x00000001
  583. /* Description RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MPDU_DURATION_VALID
  584. When set, the field Mpdu_duration_field has valid
  585. information
  586. <legal all>
  587. */
  588. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MPDU_DURATION_VALID_OFFSET 0x0000002c
  589. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MPDU_DURATION_VALID_LSB 1
  590. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MPDU_DURATION_VALID_MASK 0x00000002
  591. /* Description RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD1_VALID
  592. When set, the fields mac_addr_ad1_..... have valid
  593. information
  594. <legal all>
  595. */
  596. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD1_VALID_OFFSET 0x0000002c
  597. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD1_VALID_LSB 2
  598. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD1_VALID_MASK 0x00000004
  599. /* Description RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD2_VALID
  600. When set, the fields mac_addr_ad2_..... have valid
  601. information
  602. <legal all>
  603. */
  604. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD2_VALID_OFFSET 0x0000002c
  605. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD2_VALID_LSB 3
  606. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD2_VALID_MASK 0x00000008
  607. /* Description RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD3_VALID
  608. When set, the fields mac_addr_ad3_..... have valid
  609. information
  610. <legal all>
  611. */
  612. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD3_VALID_OFFSET 0x0000002c
  613. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD3_VALID_LSB 4
  614. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD3_VALID_MASK 0x00000010
  615. /* Description RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD4_VALID
  616. When set, the fields mac_addr_ad4_..... have valid
  617. information
  618. <legal all>
  619. */
  620. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD4_VALID_OFFSET 0x0000002c
  621. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD4_VALID_LSB 5
  622. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD4_VALID_MASK 0x00000020
  623. /* Description RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MPDU_SEQUENCE_CONTROL_VALID
  624. When set, the fields mpdu_sequence_control_field and
  625. mpdu_sequence_number have valid information as well as field
  626. For MPDUs without a sequence control field, this field
  627. will not be set.
  628. <legal all>
  629. */
  630. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MPDU_SEQUENCE_CONTROL_VALID_OFFSET 0x0000002c
  631. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MPDU_SEQUENCE_CONTROL_VALID_LSB 6
  632. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MPDU_SEQUENCE_CONTROL_VALID_MASK 0x00000040
  633. /* Description RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MPDU_QOS_CONTROL_VALID
  634. When set, the field mpdu_qos_control_field has valid
  635. information
  636. For MPDUs without a QoS control field, this field will
  637. not be set.
  638. <legal all>
  639. */
  640. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MPDU_QOS_CONTROL_VALID_OFFSET 0x0000002c
  641. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MPDU_QOS_CONTROL_VALID_LSB 7
  642. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MPDU_QOS_CONTROL_VALID_MASK 0x00000080
  643. /* Description RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MPDU_HT_CONTROL_VALID
  644. When set, the field mpdu_HT_control_field has valid
  645. information
  646. For MPDUs without a HT control field, this field will
  647. not be set.
  648. <legal all>
  649. */
  650. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MPDU_HT_CONTROL_VALID_OFFSET 0x0000002c
  651. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MPDU_HT_CONTROL_VALID_LSB 8
  652. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MPDU_HT_CONTROL_VALID_MASK 0x00000100
  653. /* Description RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_FRAME_ENCRYPTION_INFO_VALID
  654. When set, the encryption related info fields, like IV
  655. and PN are valid
  656. For MPDUs that are not encrypted, this will not be set.
  657. <legal all>
  658. */
  659. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_FRAME_ENCRYPTION_INFO_VALID_OFFSET 0x0000002c
  660. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_FRAME_ENCRYPTION_INFO_VALID_LSB 9
  661. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_FRAME_ENCRYPTION_INFO_VALID_MASK 0x00000200
  662. /* Description RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MPDU_FRAGMENT_NUMBER
  663. Field only valid when Mpdu_sequence_control_valid is set
  664. AND Fragment_flag is set
  665. The fragment number from the 802.11 header
  666. <legal all>
  667. */
  668. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MPDU_FRAGMENT_NUMBER_OFFSET 0x0000002c
  669. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MPDU_FRAGMENT_NUMBER_LSB 10
  670. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MPDU_FRAGMENT_NUMBER_MASK 0x00003c00
  671. /* Description RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MORE_FRAGMENT_FLAG
  672. The More Fragment bit setting from the MPDU header of
  673. the received frame
  674. <legal all>
  675. */
  676. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MORE_FRAGMENT_FLAG_OFFSET 0x0000002c
  677. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MORE_FRAGMENT_FLAG_LSB 14
  678. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MORE_FRAGMENT_FLAG_MASK 0x00004000
  679. /* Description RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_RESERVED_11A
  680. <legal 0>
  681. */
  682. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_RESERVED_11A_OFFSET 0x0000002c
  683. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_RESERVED_11A_LSB 15
  684. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_RESERVED_11A_MASK 0x00008000
  685. /* Description RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_FR_DS
  686. Field only valid when Mpdu_frame_control_valid is set
  687. Set if the from DS bit is set in the frame control.
  688. <legal all>
  689. */
  690. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_FR_DS_OFFSET 0x0000002c
  691. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_FR_DS_LSB 16
  692. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_FR_DS_MASK 0x00010000
  693. /* Description RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_TO_DS
  694. Field only valid when Mpdu_frame_control_valid is set
  695. Set if the to DS bit is set in the frame control.
  696. <legal all>
  697. */
  698. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_TO_DS_OFFSET 0x0000002c
  699. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_TO_DS_LSB 17
  700. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_TO_DS_MASK 0x00020000
  701. /* Description RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_ENCRYPTED
  702. Field only valid when Mpdu_frame_control_valid is set.
  703. Protected bit from the frame control.
  704. <legal all>
  705. */
  706. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_ENCRYPTED_OFFSET 0x0000002c
  707. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_ENCRYPTED_LSB 18
  708. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_ENCRYPTED_MASK 0x00040000
  709. /* Description RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MPDU_RETRY
  710. Field only valid when Mpdu_frame_control_valid is set.
  711. Retry bit from the frame control. Only valid when
  712. first_msdu is set.
  713. <legal all>
  714. */
  715. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MPDU_RETRY_OFFSET 0x0000002c
  716. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MPDU_RETRY_LSB 19
  717. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MPDU_RETRY_MASK 0x00080000
  718. /* Description RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MPDU_SEQUENCE_NUMBER
  719. Field only valid when Mpdu_sequence_control_valid is
  720. set.
  721. The sequence number from the 802.11 header.
  722. <legal all>
  723. */
  724. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MPDU_SEQUENCE_NUMBER_OFFSET 0x0000002c
  725. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MPDU_SEQUENCE_NUMBER_LSB 20
  726. #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_MPDU_SEQUENCE_NUMBER_MASK 0xfff00000
  727. /* Description RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_KEY_ID_OCTET
  728. The key ID octet from the IV.
  729. In case of ndp or phy_err or AST_based_lookup_valid ==
  730. 0, this field will be set to 0
  731. <legal all>
  732. */
  733. #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_KEY_ID_OCTET_OFFSET 0x00000030
  734. #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_KEY_ID_OCTET_LSB 0
  735. #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_KEY_ID_OCTET_MASK 0x000000ff
  736. /* Description RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_NEW_PEER_ENTRY
  737. In case of ndp or phy_err or AST_based_lookup_valid ==
  738. 0, this field will be set to 0
  739. Set if new RX_PEER_ENTRY TLV follows. If clear,
  740. RX_PEER_ENTRY doesn't follow so RX DECRYPTION module either
  741. uses old peer entry or not decrypt.
  742. <legal all>
  743. */
  744. #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_NEW_PEER_ENTRY_OFFSET 0x00000030
  745. #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_NEW_PEER_ENTRY_LSB 8
  746. #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_NEW_PEER_ENTRY_MASK 0x00000100
  747. /* Description RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_DECRYPT_NEEDED
  748. In case of ndp or phy_err or AST_based_lookup_valid ==
  749. 0, this field will be set to 0
  750. Set if decryption is needed.
  751. Note:
  752. When RXPCU sets bit 'ast_index_not_found' and/or
  753. ast_index_timeout', RXPCU will also ensure that this bit is
  754. NOT set
  755. CRYPTO for that reason only needs to evaluate this bit
  756. and non of the other ones.
  757. <legal all>
  758. */
  759. #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_DECRYPT_NEEDED_OFFSET 0x00000030
  760. #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_DECRYPT_NEEDED_LSB 9
  761. #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_DECRYPT_NEEDED_MASK 0x00000200
  762. /* Description RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_DECAP_TYPE
  763. In case of ndp or phy_err or AST_based_lookup_valid ==
  764. 0, this field will be set to 0
  765. Used by the OLE during decapsulation.
  766. Indicates the decapsulation that HW will perform:
  767. <enum 0 RAW> No encapsulation
  768. <enum 1 Native_WiFi>
  769. <enum 2 Ethernet> Ethernet 2 (DIX) or 802.3 (uses
  770. SNAP/LLC)
  771. <enum 3 802_3> Indicate Ethernet
  772. <legal all>
  773. */
  774. #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_DECAP_TYPE_OFFSET 0x00000030
  775. #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_DECAP_TYPE_LSB 10
  776. #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_DECAP_TYPE_MASK 0x00000c00
  777. /* Description RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_RX_INSERT_VLAN_C_TAG_PADDING
  778. In case of ndp or phy_err or AST_based_lookup_valid ==
  779. 0, this field will be set to 0
  780. Insert 4 byte of all zeros as VLAN tag if the rx payload
  781. does not have VLAN. Used during decapsulation.
  782. <legal all>
  783. */
  784. #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_RX_INSERT_VLAN_C_TAG_PADDING_OFFSET 0x00000030
  785. #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_RX_INSERT_VLAN_C_TAG_PADDING_LSB 12
  786. #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_RX_INSERT_VLAN_C_TAG_PADDING_MASK 0x00001000
  787. /* Description RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_RX_INSERT_VLAN_S_TAG_PADDING
  788. In case of ndp or phy_err or AST_based_lookup_valid ==
  789. 0, this field will be set to 0
  790. Insert 4 byte of all zeros as double VLAN tag if the rx
  791. payload does not have VLAN. Used during
  792. <legal all>
  793. */
  794. #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_RX_INSERT_VLAN_S_TAG_PADDING_OFFSET 0x00000030
  795. #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_RX_INSERT_VLAN_S_TAG_PADDING_LSB 13
  796. #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_RX_INSERT_VLAN_S_TAG_PADDING_MASK 0x00002000
  797. /* Description RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_STRIP_VLAN_C_TAG_DECAP
  798. In case of ndp or phy_err or AST_based_lookup_valid ==
  799. 0, this field will be set to 0
  800. Strip the VLAN during decapsulation.  Used by the OLE.
  801. <legal all>
  802. */
  803. #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_STRIP_VLAN_C_TAG_DECAP_OFFSET 0x00000030
  804. #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_STRIP_VLAN_C_TAG_DECAP_LSB 14
  805. #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_STRIP_VLAN_C_TAG_DECAP_MASK 0x00004000
  806. /* Description RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_STRIP_VLAN_S_TAG_DECAP
  807. In case of ndp or phy_err or AST_based_lookup_valid ==
  808. 0, this field will be set to 0
  809. Strip the double VLAN during decapsulation.  Used by
  810. the OLE.
  811. <legal all>
  812. */
  813. #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_STRIP_VLAN_S_TAG_DECAP_OFFSET 0x00000030
  814. #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_STRIP_VLAN_S_TAG_DECAP_LSB 15
  815. #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_STRIP_VLAN_S_TAG_DECAP_MASK 0x00008000
  816. /* Description RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_PRE_DELIM_COUNT
  817. The number of delimiters before this MPDU.
  818. Note that this number is cleared at PPDU start.
  819. If this MPDU is the first received MPDU in the PPDU and
  820. this MPDU gets filtered-in, this field will indicate the
  821. number of delimiters located after the last MPDU in the
  822. previous PPDU.
  823. If this MPDU is located after the first received MPDU in
  824. an PPDU, this field will indicate the number of delimiters
  825. located between the previous MPDU and this MPDU.
  826. In case of ndp or phy_err, this field will indicate the
  827. number of delimiters located after the last MPDU in the
  828. previous PPDU.
  829. <legal all>
  830. */
  831. #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_PRE_DELIM_COUNT_OFFSET 0x00000030
  832. #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_PRE_DELIM_COUNT_LSB 16
  833. #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_PRE_DELIM_COUNT_MASK 0x0fff0000
  834. /* Description RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_AMPDU_FLAG
  835. When set, received frame was part of an A-MPDU.
  836. <legal all>
  837. */
  838. #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_AMPDU_FLAG_OFFSET 0x00000030
  839. #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_AMPDU_FLAG_LSB 28
  840. #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_AMPDU_FLAG_MASK 0x10000000
  841. /* Description RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_BAR_FRAME
  842. In case of ndp or phy_err or AST_based_lookup_valid ==
  843. 0, this field will be set to 0
  844. When set, received frame is a BAR frame
  845. <legal all>
  846. */
  847. #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_BAR_FRAME_OFFSET 0x00000030
  848. #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_BAR_FRAME_LSB 29
  849. #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_BAR_FRAME_MASK 0x20000000
  850. /* Description RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_RAW_MPDU
  851. Consumer: SW
  852. Producer: RXOLE
  853. RXPCU sets this field to 0 and RXOLE overwrites it.
  854. Set to 1 by RXOLE when it has not performed any 802.11
  855. to Ethernet/Natvie WiFi header conversion on this MPDU.
  856. <legal all>
  857. */
  858. #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_RAW_MPDU_OFFSET 0x00000030
  859. #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_RAW_MPDU_LSB 30
  860. #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_RAW_MPDU_MASK 0x40000000
  861. /* Description RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_RESERVED_12
  862. <legal 0>
  863. */
  864. #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_RESERVED_12_OFFSET 0x00000030
  865. #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_RESERVED_12_LSB 31
  866. #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_RESERVED_12_MASK 0x80000000
  867. /* Description RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_MPDU_LENGTH
  868. In case of ndp or phy_err this field will be set to 0
  869. MPDU length before decapsulation.
  870. <legal all>
  871. */
  872. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_MPDU_LENGTH_OFFSET 0x00000034
  873. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_MPDU_LENGTH_LSB 0
  874. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_MPDU_LENGTH_MASK 0x00003fff
  875. /* Description RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_FIRST_MPDU
  876. See definition in RX attention descriptor
  877. In case of ndp or phy_err, this field will be set. Note
  878. however that there will not actually be any data contents in
  879. the MPDU.
  880. <legal all>
  881. */
  882. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_FIRST_MPDU_OFFSET 0x00000034
  883. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_FIRST_MPDU_LSB 14
  884. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_FIRST_MPDU_MASK 0x00004000
  885. /* Description RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_MCAST_BCAST
  886. In case of ndp or phy_err or Phy_err_during_mpdu_header
  887. this field will be set to 0
  888. See definition in RX attention descriptor
  889. <legal all>
  890. */
  891. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_MCAST_BCAST_OFFSET 0x00000034
  892. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_MCAST_BCAST_LSB 15
  893. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_MCAST_BCAST_MASK 0x00008000
  894. /* Description RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_AST_INDEX_NOT_FOUND
  895. In case of ndp or phy_err or Phy_err_during_mpdu_header
  896. this field will be set to 0
  897. See definition in RX attention descriptor
  898. <legal all>
  899. */
  900. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_AST_INDEX_NOT_FOUND_OFFSET 0x00000034
  901. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_AST_INDEX_NOT_FOUND_LSB 16
  902. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_AST_INDEX_NOT_FOUND_MASK 0x00010000
  903. /* Description RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_AST_INDEX_TIMEOUT
  904. In case of ndp or phy_err or Phy_err_during_mpdu_header
  905. this field will be set to 0
  906. See definition in RX attention descriptor
  907. <legal all>
  908. */
  909. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_AST_INDEX_TIMEOUT_OFFSET 0x00000034
  910. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_AST_INDEX_TIMEOUT_LSB 17
  911. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_AST_INDEX_TIMEOUT_MASK 0x00020000
  912. /* Description RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_POWER_MGMT
  913. In case of ndp or phy_err or Phy_err_during_mpdu_header
  914. this field will be set to 0
  915. See definition in RX attention descriptor
  916. <legal all>
  917. */
  918. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_POWER_MGMT_OFFSET 0x00000034
  919. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_POWER_MGMT_LSB 18
  920. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_POWER_MGMT_MASK 0x00040000
  921. /* Description RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_NON_QOS
  922. In case of ndp or phy_err or Phy_err_during_mpdu_header
  923. this field will be set to 1
  924. See definition in RX attention descriptor
  925. <legal all>
  926. */
  927. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_NON_QOS_OFFSET 0x00000034
  928. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_NON_QOS_LSB 19
  929. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_NON_QOS_MASK 0x00080000
  930. /* Description RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_NULL_DATA
  931. In case of ndp or phy_err or Phy_err_during_mpdu_header
  932. this field will be set to 0
  933. See definition in RX attention descriptor
  934. <legal all>
  935. */
  936. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_NULL_DATA_OFFSET 0x00000034
  937. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_NULL_DATA_LSB 20
  938. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_NULL_DATA_MASK 0x00100000
  939. /* Description RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_MGMT_TYPE
  940. In case of ndp or phy_err or Phy_err_during_mpdu_header
  941. this field will be set to 0
  942. See definition in RX attention descriptor
  943. <legal all>
  944. */
  945. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_MGMT_TYPE_OFFSET 0x00000034
  946. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_MGMT_TYPE_LSB 21
  947. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_MGMT_TYPE_MASK 0x00200000
  948. /* Description RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_CTRL_TYPE
  949. In case of ndp or phy_err or Phy_err_during_mpdu_header
  950. this field will be set to 0
  951. See definition in RX attention descriptor
  952. <legal all>
  953. */
  954. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_CTRL_TYPE_OFFSET 0x00000034
  955. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_CTRL_TYPE_LSB 22
  956. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_CTRL_TYPE_MASK 0x00400000
  957. /* Description RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_MORE_DATA
  958. In case of ndp or phy_err or Phy_err_during_mpdu_header
  959. this field will be set to 0
  960. See definition in RX attention descriptor
  961. <legal all>
  962. */
  963. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_MORE_DATA_OFFSET 0x00000034
  964. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_MORE_DATA_LSB 23
  965. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_MORE_DATA_MASK 0x00800000
  966. /* Description RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_EOSP
  967. In case of ndp or phy_err or Phy_err_during_mpdu_header
  968. this field will be set to 0
  969. See definition in RX attention descriptor
  970. <legal all>
  971. */
  972. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_EOSP_OFFSET 0x00000034
  973. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_EOSP_LSB 24
  974. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_EOSP_MASK 0x01000000
  975. /* Description RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_FRAGMENT_FLAG
  976. In case of ndp or phy_err or Phy_err_during_mpdu_header
  977. this field will be set to 0
  978. See definition in RX attention descriptor
  979. <legal all>
  980. */
  981. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_FRAGMENT_FLAG_OFFSET 0x00000034
  982. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_FRAGMENT_FLAG_LSB 25
  983. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_FRAGMENT_FLAG_MASK 0x02000000
  984. /* Description RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_ORDER
  985. In case of ndp or phy_err or Phy_err_during_mpdu_header
  986. this field will be set to 0
  987. See definition in RX attention descriptor
  988. <legal all>
  989. */
  990. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_ORDER_OFFSET 0x00000034
  991. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_ORDER_LSB 26
  992. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_ORDER_MASK 0x04000000
  993. /* Description RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_U_APSD_TRIGGER
  994. In case of ndp or phy_err or Phy_err_during_mpdu_header
  995. this field will be set to 0
  996. See definition in RX attention descriptor
  997. <legal all>
  998. */
  999. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_U_APSD_TRIGGER_OFFSET 0x00000034
  1000. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_U_APSD_TRIGGER_LSB 27
  1001. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_U_APSD_TRIGGER_MASK 0x08000000
  1002. /* Description RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_ENCRYPT_REQUIRED
  1003. In case of ndp or phy_err or Phy_err_during_mpdu_header
  1004. this field will be set to 0
  1005. See definition in RX attention descriptor
  1006. <legal all>
  1007. */
  1008. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_ENCRYPT_REQUIRED_OFFSET 0x00000034
  1009. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_ENCRYPT_REQUIRED_LSB 28
  1010. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_ENCRYPT_REQUIRED_MASK 0x10000000
  1011. /* Description RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_DIRECTED
  1012. In case of ndp or phy_err or Phy_err_during_mpdu_header
  1013. this field will be set to 0
  1014. See definition in RX attention descriptor
  1015. <legal all>
  1016. */
  1017. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_DIRECTED_OFFSET 0x00000034
  1018. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_DIRECTED_LSB 29
  1019. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_DIRECTED_MASK 0x20000000
  1020. /* Description RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_AMSDU_PRESENT
  1021. Field only valid when Mpdu_qos_control_valid is set
  1022. The 'amsdu_present' bit within the QoS control field of
  1023. the MPDU
  1024. <legal all>
  1025. */
  1026. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_AMSDU_PRESENT_OFFSET 0x00000034
  1027. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_AMSDU_PRESENT_LSB 30
  1028. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_AMSDU_PRESENT_MASK 0x40000000
  1029. /* Description RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_RESERVED_13
  1030. <legal 0>
  1031. */
  1032. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_RESERVED_13_OFFSET 0x00000034
  1033. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_RESERVED_13_LSB 31
  1034. #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_RESERVED_13_MASK 0x80000000
  1035. /* Description RX_MPDU_START_14_RX_MPDU_INFO_DETAILS_MPDU_FRAME_CONTROL_FIELD
  1036. Field only valid when Mpdu_frame_control_valid is set
  1037. The frame control field of this received MPDU.
  1038. Field only valid when Ndp_frame and phy_err are NOT set
  1039. Bytes 0 + 1 of the received MPDU
  1040. <legal all>
  1041. */
  1042. #define RX_MPDU_START_14_RX_MPDU_INFO_DETAILS_MPDU_FRAME_CONTROL_FIELD_OFFSET 0x00000038
  1043. #define RX_MPDU_START_14_RX_MPDU_INFO_DETAILS_MPDU_FRAME_CONTROL_FIELD_LSB 0
  1044. #define RX_MPDU_START_14_RX_MPDU_INFO_DETAILS_MPDU_FRAME_CONTROL_FIELD_MASK 0x0000ffff
  1045. /* Description RX_MPDU_START_14_RX_MPDU_INFO_DETAILS_MPDU_DURATION_FIELD
  1046. Field only valid when Mpdu_duration_valid is set
  1047. The duration field of this received MPDU.
  1048. <legal all>
  1049. */
  1050. #define RX_MPDU_START_14_RX_MPDU_INFO_DETAILS_MPDU_DURATION_FIELD_OFFSET 0x00000038
  1051. #define RX_MPDU_START_14_RX_MPDU_INFO_DETAILS_MPDU_DURATION_FIELD_LSB 16
  1052. #define RX_MPDU_START_14_RX_MPDU_INFO_DETAILS_MPDU_DURATION_FIELD_MASK 0xffff0000
  1053. /* Description RX_MPDU_START_15_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD1_31_0
  1054. Field only valid when mac_addr_ad1_valid is set
  1055. The Least Significant 4 bytes of the Received Frames MAC
  1056. Address AD1
  1057. <legal all>
  1058. */
  1059. #define RX_MPDU_START_15_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD1_31_0_OFFSET 0x0000003c
  1060. #define RX_MPDU_START_15_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD1_31_0_LSB 0
  1061. #define RX_MPDU_START_15_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD1_31_0_MASK 0xffffffff
  1062. /* Description RX_MPDU_START_16_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD1_47_32
  1063. Field only valid when mac_addr_ad1_valid is set
  1064. The 2 most significant bytes of the Received Frames MAC
  1065. Address AD1
  1066. <legal all>
  1067. */
  1068. #define RX_MPDU_START_16_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD1_47_32_OFFSET 0x00000040
  1069. #define RX_MPDU_START_16_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD1_47_32_LSB 0
  1070. #define RX_MPDU_START_16_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD1_47_32_MASK 0x0000ffff
  1071. /* Description RX_MPDU_START_16_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD2_15_0
  1072. Field only valid when mac_addr_ad2_valid is set
  1073. The Least Significant 2 bytes of the Received Frames MAC
  1074. Address AD2
  1075. <legal all>
  1076. */
  1077. #define RX_MPDU_START_16_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD2_15_0_OFFSET 0x00000040
  1078. #define RX_MPDU_START_16_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD2_15_0_LSB 16
  1079. #define RX_MPDU_START_16_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD2_15_0_MASK 0xffff0000
  1080. /* Description RX_MPDU_START_17_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD2_47_16
  1081. Field only valid when mac_addr_ad2_valid is set
  1082. The 4 most significant bytes of the Received Frames MAC
  1083. Address AD2
  1084. <legal all>
  1085. */
  1086. #define RX_MPDU_START_17_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD2_47_16_OFFSET 0x00000044
  1087. #define RX_MPDU_START_17_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD2_47_16_LSB 0
  1088. #define RX_MPDU_START_17_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD2_47_16_MASK 0xffffffff
  1089. /* Description RX_MPDU_START_18_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD3_31_0
  1090. Field only valid when mac_addr_ad3_valid is set
  1091. The Least Significant 4 bytes of the Received Frames MAC
  1092. Address AD3
  1093. <legal all>
  1094. */
  1095. #define RX_MPDU_START_18_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD3_31_0_OFFSET 0x00000048
  1096. #define RX_MPDU_START_18_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD3_31_0_LSB 0
  1097. #define RX_MPDU_START_18_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD3_31_0_MASK 0xffffffff
  1098. /* Description RX_MPDU_START_19_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD3_47_32
  1099. Field only valid when mac_addr_ad3_valid is set
  1100. The 2 most significant bytes of the Received Frames MAC
  1101. Address AD3
  1102. <legal all>
  1103. */
  1104. #define RX_MPDU_START_19_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD3_47_32_OFFSET 0x0000004c
  1105. #define RX_MPDU_START_19_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD3_47_32_LSB 0
  1106. #define RX_MPDU_START_19_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD3_47_32_MASK 0x0000ffff
  1107. /* Description RX_MPDU_START_19_RX_MPDU_INFO_DETAILS_MPDU_SEQUENCE_CONTROL_FIELD
  1108. The sequence control field of the MPDU
  1109. <legal all>
  1110. */
  1111. #define RX_MPDU_START_19_RX_MPDU_INFO_DETAILS_MPDU_SEQUENCE_CONTROL_FIELD_OFFSET 0x0000004c
  1112. #define RX_MPDU_START_19_RX_MPDU_INFO_DETAILS_MPDU_SEQUENCE_CONTROL_FIELD_LSB 16
  1113. #define RX_MPDU_START_19_RX_MPDU_INFO_DETAILS_MPDU_SEQUENCE_CONTROL_FIELD_MASK 0xffff0000
  1114. /* Description RX_MPDU_START_20_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD4_31_0
  1115. Field only valid when mac_addr_ad4_valid is set
  1116. The Least Significant 4 bytes of the Received Frames MAC
  1117. Address AD4
  1118. <legal all>
  1119. */
  1120. #define RX_MPDU_START_20_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD4_31_0_OFFSET 0x00000050
  1121. #define RX_MPDU_START_20_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD4_31_0_LSB 0
  1122. #define RX_MPDU_START_20_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD4_31_0_MASK 0xffffffff
  1123. /* Description RX_MPDU_START_21_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD4_47_32
  1124. Field only valid when mac_addr_ad4_valid is set
  1125. The 2 most significant bytes of the Received Frames MAC
  1126. Address AD4
  1127. <legal all>
  1128. */
  1129. #define RX_MPDU_START_21_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD4_47_32_OFFSET 0x00000054
  1130. #define RX_MPDU_START_21_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD4_47_32_LSB 0
  1131. #define RX_MPDU_START_21_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD4_47_32_MASK 0x0000ffff
  1132. /* Description RX_MPDU_START_21_RX_MPDU_INFO_DETAILS_MPDU_QOS_CONTROL_FIELD
  1133. Field only valid when mpdu_qos_control_valid is set
  1134. The sequence control field of the MPDU
  1135. <legal all>
  1136. */
  1137. #define RX_MPDU_START_21_RX_MPDU_INFO_DETAILS_MPDU_QOS_CONTROL_FIELD_OFFSET 0x00000054
  1138. #define RX_MPDU_START_21_RX_MPDU_INFO_DETAILS_MPDU_QOS_CONTROL_FIELD_LSB 16
  1139. #define RX_MPDU_START_21_RX_MPDU_INFO_DETAILS_MPDU_QOS_CONTROL_FIELD_MASK 0xffff0000
  1140. /* Description RX_MPDU_START_22_RX_MPDU_INFO_DETAILS_MPDU_HT_CONTROL_FIELD
  1141. Field only valid when mpdu_qos_control_valid is set
  1142. The HT control field of the MPDU
  1143. <legal all>
  1144. */
  1145. #define RX_MPDU_START_22_RX_MPDU_INFO_DETAILS_MPDU_HT_CONTROL_FIELD_OFFSET 0x00000058
  1146. #define RX_MPDU_START_22_RX_MPDU_INFO_DETAILS_MPDU_HT_CONTROL_FIELD_LSB 0
  1147. #define RX_MPDU_START_22_RX_MPDU_INFO_DETAILS_MPDU_HT_CONTROL_FIELD_MASK 0xffffffff
  1148. #endif // _RX_MPDU_START_H_