rx_attention.h 38 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172
  1. /*
  2. * Copyright (c) 2016-2017 The Linux Foundation. All rights reserved.
  3. *
  4. * Permission to use, copy, modify, and/or distribute this software for
  5. * any purpose with or without fee is hereby granted, provided that the
  6. * above copyright notice and this permission notice appear in all
  7. * copies.
  8. *
  9. * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
  10. * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
  11. * WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE
  12. * AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
  13. * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
  14. * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
  15. * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
  16. * PERFORMANCE OF THIS SOFTWARE.
  17. */
  18. // $ATH_LICENSE_HW_HDR_C$
  19. //
  20. // DO NOT EDIT! This file is automatically generated
  21. // These definitions are tied to a particular hardware layout
  22. #ifndef _RX_ATTENTION_H_
  23. #define _RX_ATTENTION_H_
  24. #if !defined(__ASSEMBLER__)
  25. #endif
  26. // ################ START SUMMARY #################
  27. //
  28. // Dword Fields
  29. // 0 rxpcu_mpdu_filter_in_category[1:0], sw_frame_group_id[8:2], reserved_0[15:9], phy_ppdu_id[31:16]
  30. // 1 first_mpdu[0], reserved_1a[1], mcast_bcast[2], ast_index_not_found[3], ast_index_timeout[4], power_mgmt[5], non_qos[6], null_data[7], mgmt_type[8], ctrl_type[9], more_data[10], eosp[11], a_msdu_error[12], fragment_flag[13], order[14], cce_match[15], overflow_err[16], msdu_length_err[17], tcp_udp_chksum_fail[18], ip_chksum_fail[19], sa_idx_invalid[20], da_idx_invalid[21], reserved_1b[22], rx_in_tx_decrypt_byp[23], encrypt_required[24], directed[25], buffer_fragment[26], mpdu_length_err[27], tkip_mic_err[28], decrypt_err[29], unencrypted_frame_err[30], fcs_err[31]
  31. // 2 flow_idx_timeout[0], flow_idx_invalid[1], wifi_parser_error[2], amsdu_parser_error[3], sa_idx_timeout[4], da_idx_timeout[5], msdu_limit_error[6], da_is_valid[7], da_is_mcbc[8], sa_is_valid[9], decrypt_status_code[12:10], rx_bitmap_not_updated[13], reserved_2[30:14], msdu_done[31]
  32. //
  33. // ################ END SUMMARY #################
  34. #define NUM_OF_DWORDS_RX_ATTENTION 3
  35. struct rx_attention {
  36. uint32_t rxpcu_mpdu_filter_in_category : 2, //[1:0]
  37. sw_frame_group_id : 7, //[8:2]
  38. reserved_0 : 7, //[15:9]
  39. phy_ppdu_id : 16; //[31:16]
  40. uint32_t first_mpdu : 1, //[0]
  41. reserved_1a : 1, //[1]
  42. mcast_bcast : 1, //[2]
  43. ast_index_not_found : 1, //[3]
  44. ast_index_timeout : 1, //[4]
  45. power_mgmt : 1, //[5]
  46. non_qos : 1, //[6]
  47. null_data : 1, //[7]
  48. mgmt_type : 1, //[8]
  49. ctrl_type : 1, //[9]
  50. more_data : 1, //[10]
  51. eosp : 1, //[11]
  52. a_msdu_error : 1, //[12]
  53. fragment_flag : 1, //[13]
  54. order : 1, //[14]
  55. cce_match : 1, //[15]
  56. overflow_err : 1, //[16]
  57. msdu_length_err : 1, //[17]
  58. tcp_udp_chksum_fail : 1, //[18]
  59. ip_chksum_fail : 1, //[19]
  60. sa_idx_invalid : 1, //[20]
  61. da_idx_invalid : 1, //[21]
  62. reserved_1b : 1, //[22]
  63. rx_in_tx_decrypt_byp : 1, //[23]
  64. encrypt_required : 1, //[24]
  65. directed : 1, //[25]
  66. buffer_fragment : 1, //[26]
  67. mpdu_length_err : 1, //[27]
  68. tkip_mic_err : 1, //[28]
  69. decrypt_err : 1, //[29]
  70. unencrypted_frame_err : 1, //[30]
  71. fcs_err : 1; //[31]
  72. uint32_t flow_idx_timeout : 1, //[0]
  73. flow_idx_invalid : 1, //[1]
  74. wifi_parser_error : 1, //[2]
  75. amsdu_parser_error : 1, //[3]
  76. sa_idx_timeout : 1, //[4]
  77. da_idx_timeout : 1, //[5]
  78. msdu_limit_error : 1, //[6]
  79. da_is_valid : 1, //[7]
  80. da_is_mcbc : 1, //[8]
  81. sa_is_valid : 1, //[9]
  82. decrypt_status_code : 3, //[12:10]
  83. rx_bitmap_not_updated : 1, //[13]
  84. reserved_2 : 17, //[30:14]
  85. msdu_done : 1; //[31]
  86. };
  87. /*
  88. rxpcu_mpdu_filter_in_category
  89. Field indicates what the reason was that this MPDU frame
  90. was allowed to come into the receive path by RXPCU
  91. <enum 0 rxpcu_filter_pass> This MPDU passed the normal
  92. frame filter programming of rxpcu
  93. <enum 1 rxpcu_monitor_client> This MPDU did NOT pass the
  94. regular frame filter and would have been dropped, were it
  95. not for the frame fitting into the 'monitor_client'
  96. category.
  97. <enum 2 rxpcu_monitor_other> This MPDU did NOT pass the
  98. regular frame filter and also did not pass the
  99. rxpcu_monitor_client filter. It would have been dropped
  100. accept that it did pass the 'monitor_other' category.
  101. <legal 0-2>
  102. sw_frame_group_id
  103. SW processes frames based on certain classifications.
  104. This field indicates to what sw classification this MPDU is
  105. mapped.
  106. The classification is given in priority order
  107. <enum 0 sw_frame_group_NDP_frame>
  108. <enum 1 sw_frame_group_Multicast_data>
  109. <enum 2 sw_frame_group_Unicast_data>
  110. <enum 3 sw_frame_group_Null_data > This includes mpdus
  111. of type Data Null as well as QoS Data Null
  112. <enum 4 sw_frame_group_mgmt_0000 >
  113. <enum 5 sw_frame_group_mgmt_0001 >
  114. <enum 6 sw_frame_group_mgmt_0010 >
  115. <enum 7 sw_frame_group_mgmt_0011 >
  116. <enum 8 sw_frame_group_mgmt_0100 >
  117. <enum 9 sw_frame_group_mgmt_0101 >
  118. <enum 10 sw_frame_group_mgmt_0110 >
  119. <enum 11 sw_frame_group_mgmt_0111 >
  120. <enum 12 sw_frame_group_mgmt_1000 >
  121. <enum 13 sw_frame_group_mgmt_1001 >
  122. <enum 14 sw_frame_group_mgmt_1010 >
  123. <enum 15 sw_frame_group_mgmt_1011 >
  124. <enum 16 sw_frame_group_mgmt_1100 >
  125. <enum 17 sw_frame_group_mgmt_1101 >
  126. <enum 18 sw_frame_group_mgmt_1110 >
  127. <enum 19 sw_frame_group_mgmt_1111 >
  128. <enum 20 sw_frame_group_ctrl_0000 >
  129. <enum 21 sw_frame_group_ctrl_0001 >
  130. <enum 22 sw_frame_group_ctrl_0010 >
  131. <enum 23 sw_frame_group_ctrl_0011 >
  132. <enum 24 sw_frame_group_ctrl_0100 >
  133. <enum 25 sw_frame_group_ctrl_0101 >
  134. <enum 26 sw_frame_group_ctrl_0110 >
  135. <enum 27 sw_frame_group_ctrl_0111 >
  136. <enum 28 sw_frame_group_ctrl_1000 >
  137. <enum 29 sw_frame_group_ctrl_1001 >
  138. <enum 30 sw_frame_group_ctrl_1010 >
  139. <enum 31 sw_frame_group_ctrl_1011 >
  140. <enum 32 sw_frame_group_ctrl_1100 >
  141. <enum 33 sw_frame_group_ctrl_1101 >
  142. <enum 34 sw_frame_group_ctrl_1110 >
  143. <enum 35 sw_frame_group_ctrl_1111 >
  144. <enum 36 sw_frame_group_unsupported> This covers type 3
  145. and protocol version != 0
  146. <legal 0-37>
  147. reserved_0
  148. <legal 0>
  149. phy_ppdu_id
  150. A ppdu counter value that PHY increments for every PPDU
  151. received. The counter value wraps around
  152. <legal all>
  153. first_mpdu
  154. Indicates the first MSDU of the PPDU. If both
  155. first_mpdu and last_mpdu are set in the MSDU then this is a
  156. not an A-MPDU frame but a stand alone MPDU. Interior MPDU
  157. in an A-MPDU shall have both first_mpdu and last_mpdu bits
  158. set to 0. The PPDU start status will only be valid when
  159. this bit is set.
  160. reserved_1a
  161. <legal 0>
  162. mcast_bcast
  163. Multicast / broadcast indicator. Only set when the MAC
  164. address 1 bit 0 is set indicating mcast/bcast and the BSSID
  165. matches one of the 4 BSSID registers. Only set when
  166. first_msdu is set.
  167. ast_index_not_found
  168. Only valid when first_msdu is set.
  169. Indicates no AST matching entries within the the max
  170. search count.
  171. ast_index_timeout
  172. Only valid when first_msdu is set.
  173. Indicates an unsuccessful search in the address seach
  174. table due to timeout.
  175. power_mgmt
  176. Power management bit set in the 802.11 header. Only set
  177. when first_msdu is set.
  178. non_qos
  179. Set if packet is not a non-QoS data frame. Only set
  180. when first_msdu is set.
  181. null_data
  182. Set if frame type indicates either null data or QoS null
  183. data format. Only set when first_msdu is set.
  184. mgmt_type
  185. Set if packet is a management packet. Only set when
  186. first_msdu is set.
  187. ctrl_type
  188. Set if packet is a control packet. Only set when
  189. first_msdu is set.
  190. more_data
  191. Set if more bit in frame control is set. Only set when
  192. first_msdu is set.
  193. eosp
  194. Set if the EOSP (end of service period) bit in the QoS
  195. control field is set. Only set when first_msdu is set.
  196. a_msdu_error
  197. Set if number of MSDUs in A-MSDU is above a threshold or
  198. if the size of the MSDU is invalid. This receive buffer
  199. will contain all of the remainder of the MSDUs in this MPDU
  200. without decapsulation.
  201. fragment_flag
  202. Indicates that this is an 802.11 fragment frame. This
  203. is set when either the more_frag bit is set in the frame
  204. control or the fragment number is not zero. Only set when
  205. first_msdu is set.
  206. order
  207. Set if the order bit in the frame control is set. Only
  208. set when first_msdu is set.
  209. cce_match
  210. Indicates that this status has a corresponding MSDU that
  211. requires FW processing. The OLE will have classification
  212. ring mask registers which will indicate the ring(s) for
  213. packets and descriptors which need FW attention.
  214. overflow_err
  215. RXPCU Receive FIFO ran out of space to receive the full
  216. MPDU. Therefor this MPDU is terminated early and is thus
  217. corrupted.
  218. This MPDU will not be ACKed.
  219. RXPCU might still be able to correctly receive the
  220. following MPDUs in the PPDU if enough fifo space became
  221. available in time
  222. msdu_length_err
  223. Indicates that the MSDU length from the 802.3
  224. encapsulated length field extends beyond the MPDU boundary
  225. or if the length is less than 14 bytes.
  226. Merged with original other_msdu_err: Indicates that the
  227. MSDU threshold was exceeded and thus all the rest of the
  228. MSDUs will not be scattered and will not be decasulated but
  229. will be DMA'ed in RAW format as a single MSDU buffer
  230. tcp_udp_chksum_fail
  231. Indicates that the computed checksum (tcp_udp_chksum)
  232. did not match the checksum in the TCP/UDP header.
  233. ip_chksum_fail
  234. Indicates that the computed checksum did not match the
  235. checksum in the IP header.
  236. sa_idx_invalid
  237. Indicates no matching entry was found in the address
  238. search table for the source MAC address.
  239. da_idx_invalid
  240. Indicates no matching entry was found in the address
  241. search table for the destination MAC address.
  242. reserved_1b
  243. rx_in_tx_decrypt_byp
  244. Indicates that RX packet is not decrypted as Crypto is
  245. busy with TX packet processing.
  246. encrypt_required
  247. Indicates that this data type frame is not encrypted
  248. even if the policy for this MPDU requires encryption as
  249. indicated in the peer entry key type.
  250. directed
  251. MPDU is a directed packet which means that the RA
  252. matched our STA addresses. In proxySTA it means that the TA
  253. matched an entry in our address search table with the
  254. corresponding no_ack bit is the address search entry
  255. cleared.
  256. buffer_fragment
  257. Indicates that at least one of the rx buffers has been
  258. fragmented. If set the FW should look at the rx_frag_info
  259. descriptor described below.
  260. mpdu_length_err
  261. Indicates that the MPDU was pre-maturely terminated
  262. resulting in a truncated MPDU. Don't trust the MPDU length
  263. field.
  264. tkip_mic_err
  265. Indicates that the MPDU Michael integrity check failed
  266. decrypt_err
  267. Indicates that the MPDU decrypt integrity check failed
  268. or CRYPTO received an encrypted frame, but did not get a
  269. valid corresponding key id in the peer entry.
  270. unencrypted_frame_err
  271. Copied here by RX OLE from the RX_MPDU_END TLV
  272. fcs_err
  273. Indicates that the MPDU FCS check failed
  274. flow_idx_timeout
  275. Indicates an unsuccessful flow search due to the
  276. expiring of the search timer.
  277. <legal all>
  278. flow_idx_invalid
  279. flow id is not valid
  280. <legal all>
  281. wifi_parser_error
  282. TODO: add details to the description
  283. <legal all>
  284. amsdu_parser_error
  285. A-MSDU could not be properly de-agregated.
  286. <legal all>
  287. sa_idx_timeout
  288. Indicates an unsuccessful MAC source address search due
  289. to the expiring of the search timer.
  290. da_idx_timeout
  291. Indicates an unsuccessful MAC destination address search
  292. due to the expiring of the search timer.
  293. msdu_limit_error
  294. Indicates that the MSDU threshold was exceeded and thus
  295. all the rest of the MSDUs will not be scattered and will not
  296. be decasulated but will be DMA'ed in RAW format as a single
  297. MSDU buffer
  298. da_is_valid
  299. Indicates that OLE found a valid DA entry
  300. da_is_mcbc
  301. Field Only valid if da_is_valid is set
  302. Indicates the DA address was a Multicast of Broadcast
  303. address.
  304. sa_is_valid
  305. Indicates that OLE found a valid SA entry
  306. decrypt_status_code
  307. Field provides insight into the decryption performed
  308. <enum 0 decrypt_ok> Frame had protection enabled and
  309. decrypted properly
  310. <enum 1 decrypt_unprotected_frame > Frame is unprotected
  311. and hence bypassed
  312. <enum 2 decrypt_data_err > Frame has protection enabled
  313. and could not be properly decrypted due to MIC/ICV mismatch
  314. etc.
  315. <enum 3 decrypt_key_invalid > Frame has protection
  316. enabled but the key that was required to decrypt this frame
  317. was not valid
  318. <enum 4 decrypt_peer_entry_invalid > Frame has
  319. protection enabled but the key that was required to decrypt
  320. this frame was not valid
  321. <enum 5 decrypt_other > Reserved for other indications
  322. <legal 0 - 5>
  323. rx_bitmap_not_updated
  324. Frame is received, but RXPCU could not update the
  325. receive bitmap due to (temporary) fifo contraints.
  326. <legal all>
  327. reserved_2
  328. <legal 0>
  329. msdu_done
  330. If set indicates that the RX packet data, RX header
  331. data, RX PPDU start descriptor, RX MPDU start/end
  332. descriptor, RX MSDU start/end descriptors and RX Attention
  333. descriptor are all valid. This bit must be in the last
  334. octet of the descriptor.
  335. */
  336. /* Description RX_ATTENTION_0_RXPCU_MPDU_FILTER_IN_CATEGORY
  337. Field indicates what the reason was that this MPDU frame
  338. was allowed to come into the receive path by RXPCU
  339. <enum 0 rxpcu_filter_pass> This MPDU passed the normal
  340. frame filter programming of rxpcu
  341. <enum 1 rxpcu_monitor_client> This MPDU did NOT pass the
  342. regular frame filter and would have been dropped, were it
  343. not for the frame fitting into the 'monitor_client'
  344. category.
  345. <enum 2 rxpcu_monitor_other> This MPDU did NOT pass the
  346. regular frame filter and also did not pass the
  347. rxpcu_monitor_client filter. It would have been dropped
  348. accept that it did pass the 'monitor_other' category.
  349. <legal 0-2>
  350. */
  351. #define RX_ATTENTION_0_RXPCU_MPDU_FILTER_IN_CATEGORY_OFFSET 0x00000000
  352. #define RX_ATTENTION_0_RXPCU_MPDU_FILTER_IN_CATEGORY_LSB 0
  353. #define RX_ATTENTION_0_RXPCU_MPDU_FILTER_IN_CATEGORY_MASK 0x00000003
  354. /* Description RX_ATTENTION_0_SW_FRAME_GROUP_ID
  355. SW processes frames based on certain classifications.
  356. This field indicates to what sw classification this MPDU is
  357. mapped.
  358. The classification is given in priority order
  359. <enum 0 sw_frame_group_NDP_frame>
  360. <enum 1 sw_frame_group_Multicast_data>
  361. <enum 2 sw_frame_group_Unicast_data>
  362. <enum 3 sw_frame_group_Null_data > This includes mpdus
  363. of type Data Null as well as QoS Data Null
  364. <enum 4 sw_frame_group_mgmt_0000 >
  365. <enum 5 sw_frame_group_mgmt_0001 >
  366. <enum 6 sw_frame_group_mgmt_0010 >
  367. <enum 7 sw_frame_group_mgmt_0011 >
  368. <enum 8 sw_frame_group_mgmt_0100 >
  369. <enum 9 sw_frame_group_mgmt_0101 >
  370. <enum 10 sw_frame_group_mgmt_0110 >
  371. <enum 11 sw_frame_group_mgmt_0111 >
  372. <enum 12 sw_frame_group_mgmt_1000 >
  373. <enum 13 sw_frame_group_mgmt_1001 >
  374. <enum 14 sw_frame_group_mgmt_1010 >
  375. <enum 15 sw_frame_group_mgmt_1011 >
  376. <enum 16 sw_frame_group_mgmt_1100 >
  377. <enum 17 sw_frame_group_mgmt_1101 >
  378. <enum 18 sw_frame_group_mgmt_1110 >
  379. <enum 19 sw_frame_group_mgmt_1111 >
  380. <enum 20 sw_frame_group_ctrl_0000 >
  381. <enum 21 sw_frame_group_ctrl_0001 >
  382. <enum 22 sw_frame_group_ctrl_0010 >
  383. <enum 23 sw_frame_group_ctrl_0011 >
  384. <enum 24 sw_frame_group_ctrl_0100 >
  385. <enum 25 sw_frame_group_ctrl_0101 >
  386. <enum 26 sw_frame_group_ctrl_0110 >
  387. <enum 27 sw_frame_group_ctrl_0111 >
  388. <enum 28 sw_frame_group_ctrl_1000 >
  389. <enum 29 sw_frame_group_ctrl_1001 >
  390. <enum 30 sw_frame_group_ctrl_1010 >
  391. <enum 31 sw_frame_group_ctrl_1011 >
  392. <enum 32 sw_frame_group_ctrl_1100 >
  393. <enum 33 sw_frame_group_ctrl_1101 >
  394. <enum 34 sw_frame_group_ctrl_1110 >
  395. <enum 35 sw_frame_group_ctrl_1111 >
  396. <enum 36 sw_frame_group_unsupported> This covers type 3
  397. and protocol version != 0
  398. <legal 0-37>
  399. */
  400. #define RX_ATTENTION_0_SW_FRAME_GROUP_ID_OFFSET 0x00000000
  401. #define RX_ATTENTION_0_SW_FRAME_GROUP_ID_LSB 2
  402. #define RX_ATTENTION_0_SW_FRAME_GROUP_ID_MASK 0x000001fc
  403. /* Description RX_ATTENTION_0_RESERVED_0
  404. <legal 0>
  405. */
  406. #define RX_ATTENTION_0_RESERVED_0_OFFSET 0x00000000
  407. #define RX_ATTENTION_0_RESERVED_0_LSB 9
  408. #define RX_ATTENTION_0_RESERVED_0_MASK 0x0000fe00
  409. /* Description RX_ATTENTION_0_PHY_PPDU_ID
  410. A ppdu counter value that PHY increments for every PPDU
  411. received. The counter value wraps around
  412. <legal all>
  413. */
  414. #define RX_ATTENTION_0_PHY_PPDU_ID_OFFSET 0x00000000
  415. #define RX_ATTENTION_0_PHY_PPDU_ID_LSB 16
  416. #define RX_ATTENTION_0_PHY_PPDU_ID_MASK 0xffff0000
  417. /* Description RX_ATTENTION_1_FIRST_MPDU
  418. Indicates the first MSDU of the PPDU. If both
  419. first_mpdu and last_mpdu are set in the MSDU then this is a
  420. not an A-MPDU frame but a stand alone MPDU. Interior MPDU
  421. in an A-MPDU shall have both first_mpdu and last_mpdu bits
  422. set to 0. The PPDU start status will only be valid when
  423. this bit is set.
  424. */
  425. #define RX_ATTENTION_1_FIRST_MPDU_OFFSET 0x00000004
  426. #define RX_ATTENTION_1_FIRST_MPDU_LSB 0
  427. #define RX_ATTENTION_1_FIRST_MPDU_MASK 0x00000001
  428. /* Description RX_ATTENTION_1_RESERVED_1A
  429. <legal 0>
  430. */
  431. #define RX_ATTENTION_1_RESERVED_1A_OFFSET 0x00000004
  432. #define RX_ATTENTION_1_RESERVED_1A_LSB 1
  433. #define RX_ATTENTION_1_RESERVED_1A_MASK 0x00000002
  434. /* Description RX_ATTENTION_1_MCAST_BCAST
  435. Multicast / broadcast indicator. Only set when the MAC
  436. address 1 bit 0 is set indicating mcast/bcast and the BSSID
  437. matches one of the 4 BSSID registers. Only set when
  438. first_msdu is set.
  439. */
  440. #define RX_ATTENTION_1_MCAST_BCAST_OFFSET 0x00000004
  441. #define RX_ATTENTION_1_MCAST_BCAST_LSB 2
  442. #define RX_ATTENTION_1_MCAST_BCAST_MASK 0x00000004
  443. /* Description RX_ATTENTION_1_AST_INDEX_NOT_FOUND
  444. Only valid when first_msdu is set.
  445. Indicates no AST matching entries within the the max
  446. search count.
  447. */
  448. #define RX_ATTENTION_1_AST_INDEX_NOT_FOUND_OFFSET 0x00000004
  449. #define RX_ATTENTION_1_AST_INDEX_NOT_FOUND_LSB 3
  450. #define RX_ATTENTION_1_AST_INDEX_NOT_FOUND_MASK 0x00000008
  451. /* Description RX_ATTENTION_1_AST_INDEX_TIMEOUT
  452. Only valid when first_msdu is set.
  453. Indicates an unsuccessful search in the address seach
  454. table due to timeout.
  455. */
  456. #define RX_ATTENTION_1_AST_INDEX_TIMEOUT_OFFSET 0x00000004
  457. #define RX_ATTENTION_1_AST_INDEX_TIMEOUT_LSB 4
  458. #define RX_ATTENTION_1_AST_INDEX_TIMEOUT_MASK 0x00000010
  459. /* Description RX_ATTENTION_1_POWER_MGMT
  460. Power management bit set in the 802.11 header. Only set
  461. when first_msdu is set.
  462. */
  463. #define RX_ATTENTION_1_POWER_MGMT_OFFSET 0x00000004
  464. #define RX_ATTENTION_1_POWER_MGMT_LSB 5
  465. #define RX_ATTENTION_1_POWER_MGMT_MASK 0x00000020
  466. /* Description RX_ATTENTION_1_NON_QOS
  467. Set if packet is not a non-QoS data frame. Only set
  468. when first_msdu is set.
  469. */
  470. #define RX_ATTENTION_1_NON_QOS_OFFSET 0x00000004
  471. #define RX_ATTENTION_1_NON_QOS_LSB 6
  472. #define RX_ATTENTION_1_NON_QOS_MASK 0x00000040
  473. /* Description RX_ATTENTION_1_NULL_DATA
  474. Set if frame type indicates either null data or QoS null
  475. data format. Only set when first_msdu is set.
  476. */
  477. #define RX_ATTENTION_1_NULL_DATA_OFFSET 0x00000004
  478. #define RX_ATTENTION_1_NULL_DATA_LSB 7
  479. #define RX_ATTENTION_1_NULL_DATA_MASK 0x00000080
  480. /* Description RX_ATTENTION_1_MGMT_TYPE
  481. Set if packet is a management packet. Only set when
  482. first_msdu is set.
  483. */
  484. #define RX_ATTENTION_1_MGMT_TYPE_OFFSET 0x00000004
  485. #define RX_ATTENTION_1_MGMT_TYPE_LSB 8
  486. #define RX_ATTENTION_1_MGMT_TYPE_MASK 0x00000100
  487. /* Description RX_ATTENTION_1_CTRL_TYPE
  488. Set if packet is a control packet. Only set when
  489. first_msdu is set.
  490. */
  491. #define RX_ATTENTION_1_CTRL_TYPE_OFFSET 0x00000004
  492. #define RX_ATTENTION_1_CTRL_TYPE_LSB 9
  493. #define RX_ATTENTION_1_CTRL_TYPE_MASK 0x00000200
  494. /* Description RX_ATTENTION_1_MORE_DATA
  495. Set if more bit in frame control is set. Only set when
  496. first_msdu is set.
  497. */
  498. #define RX_ATTENTION_1_MORE_DATA_OFFSET 0x00000004
  499. #define RX_ATTENTION_1_MORE_DATA_LSB 10
  500. #define RX_ATTENTION_1_MORE_DATA_MASK 0x00000400
  501. /* Description RX_ATTENTION_1_EOSP
  502. Set if the EOSP (end of service period) bit in the QoS
  503. control field is set. Only set when first_msdu is set.
  504. */
  505. #define RX_ATTENTION_1_EOSP_OFFSET 0x00000004
  506. #define RX_ATTENTION_1_EOSP_LSB 11
  507. #define RX_ATTENTION_1_EOSP_MASK 0x00000800
  508. /* Description RX_ATTENTION_1_A_MSDU_ERROR
  509. Set if number of MSDUs in A-MSDU is above a threshold or
  510. if the size of the MSDU is invalid. This receive buffer
  511. will contain all of the remainder of the MSDUs in this MPDU
  512. without decapsulation.
  513. */
  514. #define RX_ATTENTION_1_A_MSDU_ERROR_OFFSET 0x00000004
  515. #define RX_ATTENTION_1_A_MSDU_ERROR_LSB 12
  516. #define RX_ATTENTION_1_A_MSDU_ERROR_MASK 0x00001000
  517. /* Description RX_ATTENTION_1_FRAGMENT_FLAG
  518. Indicates that this is an 802.11 fragment frame. This
  519. is set when either the more_frag bit is set in the frame
  520. control or the fragment number is not zero. Only set when
  521. first_msdu is set.
  522. */
  523. #define RX_ATTENTION_1_FRAGMENT_FLAG_OFFSET 0x00000004
  524. #define RX_ATTENTION_1_FRAGMENT_FLAG_LSB 13
  525. #define RX_ATTENTION_1_FRAGMENT_FLAG_MASK 0x00002000
  526. /* Description RX_ATTENTION_1_ORDER
  527. Set if the order bit in the frame control is set. Only
  528. set when first_msdu is set.
  529. */
  530. #define RX_ATTENTION_1_ORDER_OFFSET 0x00000004
  531. #define RX_ATTENTION_1_ORDER_LSB 14
  532. #define RX_ATTENTION_1_ORDER_MASK 0x00004000
  533. /* Description RX_ATTENTION_1_CCE_MATCH
  534. Indicates that this status has a corresponding MSDU that
  535. requires FW processing. The OLE will have classification
  536. ring mask registers which will indicate the ring(s) for
  537. packets and descriptors which need FW attention.
  538. */
  539. #define RX_ATTENTION_1_CCE_MATCH_OFFSET 0x00000004
  540. #define RX_ATTENTION_1_CCE_MATCH_LSB 15
  541. #define RX_ATTENTION_1_CCE_MATCH_MASK 0x00008000
  542. /* Description RX_ATTENTION_1_OVERFLOW_ERR
  543. RXPCU Receive FIFO ran out of space to receive the full
  544. MPDU. Therefor this MPDU is terminated early and is thus
  545. corrupted.
  546. This MPDU will not be ACKed.
  547. RXPCU might still be able to correctly receive the
  548. following MPDUs in the PPDU if enough fifo space became
  549. available in time
  550. */
  551. #define RX_ATTENTION_1_OVERFLOW_ERR_OFFSET 0x00000004
  552. #define RX_ATTENTION_1_OVERFLOW_ERR_LSB 16
  553. #define RX_ATTENTION_1_OVERFLOW_ERR_MASK 0x00010000
  554. /* Description RX_ATTENTION_1_MSDU_LENGTH_ERR
  555. Indicates that the MSDU length from the 802.3
  556. encapsulated length field extends beyond the MPDU boundary
  557. or if the length is less than 14 bytes.
  558. Merged with original other_msdu_err: Indicates that the
  559. MSDU threshold was exceeded and thus all the rest of the
  560. MSDUs will not be scattered and will not be decasulated but
  561. will be DMA'ed in RAW format as a single MSDU buffer
  562. */
  563. #define RX_ATTENTION_1_MSDU_LENGTH_ERR_OFFSET 0x00000004
  564. #define RX_ATTENTION_1_MSDU_LENGTH_ERR_LSB 17
  565. #define RX_ATTENTION_1_MSDU_LENGTH_ERR_MASK 0x00020000
  566. /* Description RX_ATTENTION_1_TCP_UDP_CHKSUM_FAIL
  567. Indicates that the computed checksum (tcp_udp_chksum)
  568. did not match the checksum in the TCP/UDP header.
  569. */
  570. #define RX_ATTENTION_1_TCP_UDP_CHKSUM_FAIL_OFFSET 0x00000004
  571. #define RX_ATTENTION_1_TCP_UDP_CHKSUM_FAIL_LSB 18
  572. #define RX_ATTENTION_1_TCP_UDP_CHKSUM_FAIL_MASK 0x00040000
  573. /* Description RX_ATTENTION_1_IP_CHKSUM_FAIL
  574. Indicates that the computed checksum did not match the
  575. checksum in the IP header.
  576. */
  577. #define RX_ATTENTION_1_IP_CHKSUM_FAIL_OFFSET 0x00000004
  578. #define RX_ATTENTION_1_IP_CHKSUM_FAIL_LSB 19
  579. #define RX_ATTENTION_1_IP_CHKSUM_FAIL_MASK 0x00080000
  580. /* Description RX_ATTENTION_1_SA_IDX_INVALID
  581. Indicates no matching entry was found in the address
  582. search table for the source MAC address.
  583. */
  584. #define RX_ATTENTION_1_SA_IDX_INVALID_OFFSET 0x00000004
  585. #define RX_ATTENTION_1_SA_IDX_INVALID_LSB 20
  586. #define RX_ATTENTION_1_SA_IDX_INVALID_MASK 0x00100000
  587. /* Description RX_ATTENTION_1_DA_IDX_INVALID
  588. Indicates no matching entry was found in the address
  589. search table for the destination MAC address.
  590. */
  591. #define RX_ATTENTION_1_DA_IDX_INVALID_OFFSET 0x00000004
  592. #define RX_ATTENTION_1_DA_IDX_INVALID_LSB 21
  593. #define RX_ATTENTION_1_DA_IDX_INVALID_MASK 0x00200000
  594. /* Description RX_ATTENTION_1_RESERVED_1B
  595. */
  596. #define RX_ATTENTION_1_RESERVED_1B_OFFSET 0x00000004
  597. #define RX_ATTENTION_1_RESERVED_1B_LSB 22
  598. #define RX_ATTENTION_1_RESERVED_1B_MASK 0x00400000
  599. /* Description RX_ATTENTION_1_RX_IN_TX_DECRYPT_BYP
  600. Indicates that RX packet is not decrypted as Crypto is
  601. busy with TX packet processing.
  602. */
  603. #define RX_ATTENTION_1_RX_IN_TX_DECRYPT_BYP_OFFSET 0x00000004
  604. #define RX_ATTENTION_1_RX_IN_TX_DECRYPT_BYP_LSB 23
  605. #define RX_ATTENTION_1_RX_IN_TX_DECRYPT_BYP_MASK 0x00800000
  606. /* Description RX_ATTENTION_1_ENCRYPT_REQUIRED
  607. Indicates that this data type frame is not encrypted
  608. even if the policy for this MPDU requires encryption as
  609. indicated in the peer entry key type.
  610. */
  611. #define RX_ATTENTION_1_ENCRYPT_REQUIRED_OFFSET 0x00000004
  612. #define RX_ATTENTION_1_ENCRYPT_REQUIRED_LSB 24
  613. #define RX_ATTENTION_1_ENCRYPT_REQUIRED_MASK 0x01000000
  614. /* Description RX_ATTENTION_1_DIRECTED
  615. MPDU is a directed packet which means that the RA
  616. matched our STA addresses. In proxySTA it means that the TA
  617. matched an entry in our address search table with the
  618. corresponding no_ack bit is the address search entry
  619. cleared.
  620. */
  621. #define RX_ATTENTION_1_DIRECTED_OFFSET 0x00000004
  622. #define RX_ATTENTION_1_DIRECTED_LSB 25
  623. #define RX_ATTENTION_1_DIRECTED_MASK 0x02000000
  624. /* Description RX_ATTENTION_1_BUFFER_FRAGMENT
  625. Indicates that at least one of the rx buffers has been
  626. fragmented. If set the FW should look at the rx_frag_info
  627. descriptor described below.
  628. */
  629. #define RX_ATTENTION_1_BUFFER_FRAGMENT_OFFSET 0x00000004
  630. #define RX_ATTENTION_1_BUFFER_FRAGMENT_LSB 26
  631. #define RX_ATTENTION_1_BUFFER_FRAGMENT_MASK 0x04000000
  632. /* Description RX_ATTENTION_1_MPDU_LENGTH_ERR
  633. Indicates that the MPDU was pre-maturely terminated
  634. resulting in a truncated MPDU. Don't trust the MPDU length
  635. field.
  636. */
  637. #define RX_ATTENTION_1_MPDU_LENGTH_ERR_OFFSET 0x00000004
  638. #define RX_ATTENTION_1_MPDU_LENGTH_ERR_LSB 27
  639. #define RX_ATTENTION_1_MPDU_LENGTH_ERR_MASK 0x08000000
  640. /* Description RX_ATTENTION_1_TKIP_MIC_ERR
  641. Indicates that the MPDU Michael integrity check failed
  642. */
  643. #define RX_ATTENTION_1_TKIP_MIC_ERR_OFFSET 0x00000004
  644. #define RX_ATTENTION_1_TKIP_MIC_ERR_LSB 28
  645. #define RX_ATTENTION_1_TKIP_MIC_ERR_MASK 0x10000000
  646. /* Description RX_ATTENTION_1_DECRYPT_ERR
  647. Indicates that the MPDU decrypt integrity check failed
  648. or CRYPTO received an encrypted frame, but did not get a
  649. valid corresponding key id in the peer entry.
  650. */
  651. #define RX_ATTENTION_1_DECRYPT_ERR_OFFSET 0x00000004
  652. #define RX_ATTENTION_1_DECRYPT_ERR_LSB 29
  653. #define RX_ATTENTION_1_DECRYPT_ERR_MASK 0x20000000
  654. /* Description RX_ATTENTION_1_UNENCRYPTED_FRAME_ERR
  655. Copied here by RX OLE from the RX_MPDU_END TLV
  656. */
  657. #define RX_ATTENTION_1_UNENCRYPTED_FRAME_ERR_OFFSET 0x00000004
  658. #define RX_ATTENTION_1_UNENCRYPTED_FRAME_ERR_LSB 30
  659. #define RX_ATTENTION_1_UNENCRYPTED_FRAME_ERR_MASK 0x40000000
  660. /* Description RX_ATTENTION_1_FCS_ERR
  661. Indicates that the MPDU FCS check failed
  662. */
  663. #define RX_ATTENTION_1_FCS_ERR_OFFSET 0x00000004
  664. #define RX_ATTENTION_1_FCS_ERR_LSB 31
  665. #define RX_ATTENTION_1_FCS_ERR_MASK 0x80000000
  666. /* Description RX_ATTENTION_2_FLOW_IDX_TIMEOUT
  667. Indicates an unsuccessful flow search due to the
  668. expiring of the search timer.
  669. <legal all>
  670. */
  671. #define RX_ATTENTION_2_FLOW_IDX_TIMEOUT_OFFSET 0x00000008
  672. #define RX_ATTENTION_2_FLOW_IDX_TIMEOUT_LSB 0
  673. #define RX_ATTENTION_2_FLOW_IDX_TIMEOUT_MASK 0x00000001
  674. /* Description RX_ATTENTION_2_FLOW_IDX_INVALID
  675. flow id is not valid
  676. <legal all>
  677. */
  678. #define RX_ATTENTION_2_FLOW_IDX_INVALID_OFFSET 0x00000008
  679. #define RX_ATTENTION_2_FLOW_IDX_INVALID_LSB 1
  680. #define RX_ATTENTION_2_FLOW_IDX_INVALID_MASK 0x00000002
  681. /* Description RX_ATTENTION_2_WIFI_PARSER_ERROR
  682. TODO: add details to the description
  683. <legal all>
  684. */
  685. #define RX_ATTENTION_2_WIFI_PARSER_ERROR_OFFSET 0x00000008
  686. #define RX_ATTENTION_2_WIFI_PARSER_ERROR_LSB 2
  687. #define RX_ATTENTION_2_WIFI_PARSER_ERROR_MASK 0x00000004
  688. /* Description RX_ATTENTION_2_AMSDU_PARSER_ERROR
  689. A-MSDU could not be properly de-agregated.
  690. <legal all>
  691. */
  692. #define RX_ATTENTION_2_AMSDU_PARSER_ERROR_OFFSET 0x00000008
  693. #define RX_ATTENTION_2_AMSDU_PARSER_ERROR_LSB 3
  694. #define RX_ATTENTION_2_AMSDU_PARSER_ERROR_MASK 0x00000008
  695. /* Description RX_ATTENTION_2_SA_IDX_TIMEOUT
  696. Indicates an unsuccessful MAC source address search due
  697. to the expiring of the search timer.
  698. */
  699. #define RX_ATTENTION_2_SA_IDX_TIMEOUT_OFFSET 0x00000008
  700. #define RX_ATTENTION_2_SA_IDX_TIMEOUT_LSB 4
  701. #define RX_ATTENTION_2_SA_IDX_TIMEOUT_MASK 0x00000010
  702. /* Description RX_ATTENTION_2_DA_IDX_TIMEOUT
  703. Indicates an unsuccessful MAC destination address search
  704. due to the expiring of the search timer.
  705. */
  706. #define RX_ATTENTION_2_DA_IDX_TIMEOUT_OFFSET 0x00000008
  707. #define RX_ATTENTION_2_DA_IDX_TIMEOUT_LSB 5
  708. #define RX_ATTENTION_2_DA_IDX_TIMEOUT_MASK 0x00000020
  709. /* Description RX_ATTENTION_2_MSDU_LIMIT_ERROR
  710. Indicates that the MSDU threshold was exceeded and thus
  711. all the rest of the MSDUs will not be scattered and will not
  712. be decasulated but will be DMA'ed in RAW format as a single
  713. MSDU buffer
  714. */
  715. #define RX_ATTENTION_2_MSDU_LIMIT_ERROR_OFFSET 0x00000008
  716. #define RX_ATTENTION_2_MSDU_LIMIT_ERROR_LSB 6
  717. #define RX_ATTENTION_2_MSDU_LIMIT_ERROR_MASK 0x00000040
  718. /* Description RX_ATTENTION_2_DA_IS_VALID
  719. Indicates that OLE found a valid DA entry
  720. */
  721. #define RX_ATTENTION_2_DA_IS_VALID_OFFSET 0x00000008
  722. #define RX_ATTENTION_2_DA_IS_VALID_LSB 7
  723. #define RX_ATTENTION_2_DA_IS_VALID_MASK 0x00000080
  724. /* Description RX_ATTENTION_2_DA_IS_MCBC
  725. Field Only valid if da_is_valid is set
  726. Indicates the DA address was a Multicast of Broadcast
  727. address.
  728. */
  729. #define RX_ATTENTION_2_DA_IS_MCBC_OFFSET 0x00000008
  730. #define RX_ATTENTION_2_DA_IS_MCBC_LSB 8
  731. #define RX_ATTENTION_2_DA_IS_MCBC_MASK 0x00000100
  732. /* Description RX_ATTENTION_2_SA_IS_VALID
  733. Indicates that OLE found a valid SA entry
  734. */
  735. #define RX_ATTENTION_2_SA_IS_VALID_OFFSET 0x00000008
  736. #define RX_ATTENTION_2_SA_IS_VALID_LSB 9
  737. #define RX_ATTENTION_2_SA_IS_VALID_MASK 0x00000200
  738. /* Description RX_ATTENTION_2_DECRYPT_STATUS_CODE
  739. Field provides insight into the decryption performed
  740. <enum 0 decrypt_ok> Frame had protection enabled and
  741. decrypted properly
  742. <enum 1 decrypt_unprotected_frame > Frame is unprotected
  743. and hence bypassed
  744. <enum 2 decrypt_data_err > Frame has protection enabled
  745. and could not be properly decrypted due to MIC/ICV mismatch
  746. etc.
  747. <enum 3 decrypt_key_invalid > Frame has protection
  748. enabled but the key that was required to decrypt this frame
  749. was not valid
  750. <enum 4 decrypt_peer_entry_invalid > Frame has
  751. protection enabled but the key that was required to decrypt
  752. this frame was not valid
  753. <enum 5 decrypt_other > Reserved for other indications
  754. <legal 0 - 5>
  755. */
  756. #define RX_ATTENTION_2_DECRYPT_STATUS_CODE_OFFSET 0x00000008
  757. #define RX_ATTENTION_2_DECRYPT_STATUS_CODE_LSB 10
  758. #define RX_ATTENTION_2_DECRYPT_STATUS_CODE_MASK 0x00001c00
  759. /* Description RX_ATTENTION_2_RX_BITMAP_NOT_UPDATED
  760. Frame is received, but RXPCU could not update the
  761. receive bitmap due to (temporary) fifo contraints.
  762. <legal all>
  763. */
  764. #define RX_ATTENTION_2_RX_BITMAP_NOT_UPDATED_OFFSET 0x00000008
  765. #define RX_ATTENTION_2_RX_BITMAP_NOT_UPDATED_LSB 13
  766. #define RX_ATTENTION_2_RX_BITMAP_NOT_UPDATED_MASK 0x00002000
  767. /* Description RX_ATTENTION_2_RESERVED_2
  768. <legal 0>
  769. */
  770. #define RX_ATTENTION_2_RESERVED_2_OFFSET 0x00000008
  771. #define RX_ATTENTION_2_RESERVED_2_LSB 14
  772. #define RX_ATTENTION_2_RESERVED_2_MASK 0x7fffc000
  773. /* Description RX_ATTENTION_2_MSDU_DONE
  774. If set indicates that the RX packet data, RX header
  775. data, RX PPDU start descriptor, RX MPDU start/end
  776. descriptor, RX MSDU start/end descriptors and RX Attention
  777. descriptor are all valid. This bit must be in the last
  778. octet of the descriptor.
  779. */
  780. #define RX_ATTENTION_2_MSDU_DONE_OFFSET 0x00000008
  781. #define RX_ATTENTION_2_MSDU_DONE_LSB 31
  782. #define RX_ATTENTION_2_MSDU_DONE_MASK 0x80000000
  783. #endif // _RX_ATTENTION_H_