1 /*
2  * Copyright (c) 2020 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 
17 // $ATH_LICENSE_HW_HDR_C$
18 //
19 // DO NOT EDIT!  This file is automatically generated
20 //               These definitions are tied to a particular hardware layout
21 
22 
23 #ifndef _RX_ATTENTION_H_
24 #define _RX_ATTENTION_H_
25 #if !defined(__ASSEMBLER__)
26 #endif
27 
28 
29 // ################ START SUMMARY #################
30 //
31 //	Dword	Fields
32 //	0	rxpcu_mpdu_filter_in_category[1:0], sw_frame_group_id[8:2], reserved_0[15:9], phy_ppdu_id[31:16]
33 //	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]
34 //	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]
35 //
36 // ################ END SUMMARY #################
37 
38 #define NUM_OF_DWORDS_RX_ATTENTION 3
39 
40 struct rx_attention {
41              uint32_t rxpcu_mpdu_filter_in_category   :  2, //[1:0]
42                       sw_frame_group_id               :  7, //[8:2]
43                       reserved_0                      :  7, //[15:9]
44                       phy_ppdu_id                     : 16; //[31:16]
45              uint32_t first_mpdu                      :  1, //[0]
46                       reserved_1a                     :  1, //[1]
47                       mcast_bcast                     :  1, //[2]
48                       ast_index_not_found             :  1, //[3]
49                       ast_index_timeout               :  1, //[4]
50                       power_mgmt                      :  1, //[5]
51                       non_qos                         :  1, //[6]
52                       null_data                       :  1, //[7]
53                       mgmt_type                       :  1, //[8]
54                       ctrl_type                       :  1, //[9]
55                       more_data                       :  1, //[10]
56                       eosp                            :  1, //[11]
57                       a_msdu_error                    :  1, //[12]
58                       fragment_flag                   :  1, //[13]
59                       order                           :  1, //[14]
60                       cce_match                       :  1, //[15]
61                       overflow_err                    :  1, //[16]
62                       msdu_length_err                 :  1, //[17]
63                       tcp_udp_chksum_fail             :  1, //[18]
64                       ip_chksum_fail                  :  1, //[19]
65                       sa_idx_invalid                  :  1, //[20]
66                       da_idx_invalid                  :  1, //[21]
67                       reserved_1b                     :  1, //[22]
68                       rx_in_tx_decrypt_byp            :  1, //[23]
69                       encrypt_required                :  1, //[24]
70                       directed                        :  1, //[25]
71                       buffer_fragment                 :  1, //[26]
72                       mpdu_length_err                 :  1, //[27]
73                       tkip_mic_err                    :  1, //[28]
74                       decrypt_err                     :  1, //[29]
75                       unencrypted_frame_err           :  1, //[30]
76                       fcs_err                         :  1; //[31]
77              uint32_t flow_idx_timeout                :  1, //[0]
78                       flow_idx_invalid                :  1, //[1]
79                       wifi_parser_error               :  1, //[2]
80                       amsdu_parser_error              :  1, //[3]
81                       sa_idx_timeout                  :  1, //[4]
82                       da_idx_timeout                  :  1, //[5]
83                       msdu_limit_error                :  1, //[6]
84                       da_is_valid                     :  1, //[7]
85                       da_is_mcbc                      :  1, //[8]
86                       sa_is_valid                     :  1, //[9]
87                       decrypt_status_code             :  3, //[12:10]
88                       rx_bitmap_not_updated           :  1, //[13]
89                       reserved_2                      : 17, //[30:14]
90                       msdu_done                       :  1; //[31]
91 };
92 
93 /*
94 
95 rxpcu_mpdu_filter_in_category
96 
97 			Field indicates what the reason was that this MPDU frame
98 			was allowed to come into the receive path by RXPCU
99 
100 			<enum 0 rxpcu_filter_pass> This MPDU passed the normal
101 			frame filter programming of rxpcu
102 
103 			<enum 1 rxpcu_monitor_client> This MPDU did NOT pass the
104 			regular frame filter and would have been dropped, were it
105 			not for the frame fitting into the 'monitor_client'
106 			category.
107 
108 			<enum 2 rxpcu_monitor_other> This MPDU did NOT pass the
109 			regular frame filter and also did not pass the
110 			rxpcu_monitor_client filter. It would have been dropped
111 			accept that it did pass the 'monitor_other' category.
112 
113 			<legal 0-2>
114 
115 sw_frame_group_id
116 
117 			SW processes frames based on certain classifications.
118 			This field indicates to what sw classification this MPDU is
119 			mapped.
120 
121 			The classification is given in priority order
122 
123 
124 
125 			<enum 0 sw_frame_group_NDP_frame>
126 
127 
128 
129 			<enum 1 sw_frame_group_Multicast_data>
130 
131 			<enum 2 sw_frame_group_Unicast_data>
132 
133 			<enum 3 sw_frame_group_Null_data > This includes mpdus
134 			of type Data Null as well as QoS Data Null
135 
136 
137 
138 			<enum 4 sw_frame_group_mgmt_0000 >
139 
140 			<enum 5 sw_frame_group_mgmt_0001 >
141 
142 			<enum 6 sw_frame_group_mgmt_0010 >
143 
144 			<enum 7 sw_frame_group_mgmt_0011 >
145 
146 			<enum 8 sw_frame_group_mgmt_0100 >
147 
148 			<enum 9 sw_frame_group_mgmt_0101 >
149 
150 			<enum 10 sw_frame_group_mgmt_0110 >
151 
152 			<enum 11 sw_frame_group_mgmt_0111 >
153 
154 			<enum 12 sw_frame_group_mgmt_1000 >
155 
156 			<enum 13 sw_frame_group_mgmt_1001 >
157 
158 			<enum 14 sw_frame_group_mgmt_1010 >
159 
160 			<enum 15 sw_frame_group_mgmt_1011 >
161 
162 			<enum 16 sw_frame_group_mgmt_1100 >
163 
164 			<enum 17 sw_frame_group_mgmt_1101 >
165 
166 			<enum 18 sw_frame_group_mgmt_1110 >
167 
168 			<enum 19 sw_frame_group_mgmt_1111 >
169 
170 
171 
172 			<enum 20 sw_frame_group_ctrl_0000 >
173 
174 			<enum 21 sw_frame_group_ctrl_0001 >
175 
176 			<enum 22 sw_frame_group_ctrl_0010 >
177 
178 			<enum 23 sw_frame_group_ctrl_0011 >
179 
180 			<enum 24 sw_frame_group_ctrl_0100 >
181 
182 			<enum 25 sw_frame_group_ctrl_0101 >
183 
184 			<enum 26 sw_frame_group_ctrl_0110 >
185 
186 			<enum 27 sw_frame_group_ctrl_0111 >
187 
188 			<enum 28 sw_frame_group_ctrl_1000 >
189 
190 			<enum 29 sw_frame_group_ctrl_1001 >
191 
192 			<enum 30 sw_frame_group_ctrl_1010 >
193 
194 			<enum 31 sw_frame_group_ctrl_1011 >
195 
196 			<enum 32 sw_frame_group_ctrl_1100 >
197 
198 			<enum 33 sw_frame_group_ctrl_1101 >
199 
200 			<enum 34 sw_frame_group_ctrl_1110 >
201 
202 			<enum 35 sw_frame_group_ctrl_1111 >
203 
204 
205 
206 			<enum 36 sw_frame_group_unsupported> This covers type 3
207 			and protocol version != 0
208 
209 
210 
211 
212 
213 
214 			<legal 0-37>
215 
216 reserved_0
217 
218 			<legal 0>
219 
220 phy_ppdu_id
221 
222 			A ppdu counter value that PHY increments for every PPDU
223 			received. The counter value wraps around
224 
225 			<legal all>
226 
227 first_mpdu
228 
229 			Indicates the first MSDU of the PPDU.  If both
230 			first_mpdu and last_mpdu are set in the MSDU then this is a
231 			not an A-MPDU frame but a stand alone MPDU.  Interior MPDU
232 			in an A-MPDU shall have both first_mpdu and last_mpdu bits
233 			set to 0.  The PPDU start status will only be valid when
234 			this bit is set.
235 
236 reserved_1a
237 
238 			<legal 0>
239 
240 mcast_bcast
241 
242 			Multicast / broadcast indicator.  Only set when the MAC
243 			address 1 bit 0 is set indicating mcast/bcast and the BSSID
244 			matches one of the 4 BSSID registers. Only set when
245 			first_msdu is set.
246 
247 ast_index_not_found
248 
249 			Only valid when first_msdu is set.
250 
251 
252 
253 			Indicates no AST matching entries within the the max
254 			search count.
255 
256 ast_index_timeout
257 
258 			Only valid when first_msdu is set.
259 
260 
261 
262 			Indicates an unsuccessful search in the address seach
263 			table due to timeout.
264 
265 power_mgmt
266 
267 			Power management bit set in the 802.11 header.  Only set
268 			when first_msdu is set.
269 
270 non_qos
271 
272 			Set if packet is not a non-QoS data frame.  Only set
273 			when first_msdu is set.
274 
275 null_data
276 
277 			Set if frame type indicates either null data or QoS null
278 			data format.  Only set when first_msdu is set.
279 
280 mgmt_type
281 
282 			Set if packet is a management packet.  Only set when
283 			first_msdu is set.
284 
285 ctrl_type
286 
287 			Set if packet is a control packet.  Only set when
288 			first_msdu is set.
289 
290 more_data
291 
292 			Set if more bit in frame control is set.  Only set when
293 			first_msdu is set.
294 
295 eosp
296 
297 			Set if the EOSP (end of service period) bit in the QoS
298 			control field is set.  Only set when first_msdu is set.
299 
300 a_msdu_error
301 
302 			Set if number of MSDUs in A-MSDU is above a threshold or
303 			if the size of the MSDU is invalid.  This receive buffer
304 			will contain all of the remainder of the MSDUs in this MPDU
305 			without decapsulation.
306 
307 fragment_flag
308 
309 			Indicates that this is an 802.11 fragment frame.  This
310 			is set when either the more_frag bit is set in the frame
311 			control or the fragment number is not zero.  Only set when
312 			first_msdu is set.
313 
314 order
315 
316 			Set if the order bit in the frame control is set.  Only
317 			set when first_msdu is set.
318 
319 cce_match
320 
321 			Indicates that this status has a corresponding MSDU that
322 			requires FW processing.  The OLE will have classification
323 			ring mask registers which will indicate the ring(s) for
324 			packets and descriptors which need FW attention.
325 
326 overflow_err
327 
328 			RXPCU Receive FIFO ran out of space to receive the full
329 			MPDU. Therefor this MPDU is terminated early and is thus
330 			corrupted.
331 
332 
333 
334 			This MPDU will not be ACKed.
335 
336 			RXPCU might still be able to correctly receive the
337 			following MPDUs in the PPDU if enough fifo space became
338 			available in time
339 
340 msdu_length_err
341 
342 			Indicates that the MSDU length from the 802.3
343 			encapsulated length field extends beyond the MPDU boundary
344 			or if the length is less than 14 bytes.
345 
346 			Merged with original other_msdu_err: Indicates that the
347 			MSDU threshold was exceeded and thus all the rest of the
348 			MSDUs will not be scattered and will not be decasulated but
349 			will be DMA'ed in RAW format as a single MSDU buffer
350 
351 tcp_udp_chksum_fail
352 
353 			Indicates that the computed checksum (tcp_udp_chksum)
354 			did not match the checksum in the TCP/UDP header.
355 
356 ip_chksum_fail
357 
358 			Indicates that the computed checksum did not match the
359 			checksum in the IP header.
360 
361 sa_idx_invalid
362 
363 			Indicates no matching entry was found in the address
364 			search table for the source MAC address.
365 
366 da_idx_invalid
367 
368 			Indicates no matching entry was found in the address
369 			search table for the destination MAC address.
370 
371 reserved_1b
372 
373 
374 rx_in_tx_decrypt_byp
375 
376 			Indicates that RX packet is not decrypted as Crypto is
377 			busy with TX packet processing.
378 
379 encrypt_required
380 
381 			Indicates that this data type frame is not encrypted
382 			even if the policy for this MPDU requires encryption as
383 			indicated in the peer entry key type.
384 
385 directed
386 
387 			MPDU is a directed packet which means that the RA
388 			matched our STA addresses.  In proxySTA it means that the TA
389 			matched an entry in our address search table with the
390 			corresponding no_ack bit is the address search entry
391 			cleared.
392 
393 buffer_fragment
394 
395 			Indicates that at least one of the rx buffers has been
396 			fragmented.  If set the FW should look at the rx_frag_info
397 			descriptor described below.
398 
399 mpdu_length_err
400 
401 			Indicates that the MPDU was pre-maturely terminated
402 			resulting in a truncated MPDU.  Don't trust the MPDU length
403 			field.
404 
405 tkip_mic_err
406 
407 			Indicates that the MPDU Michael integrity check failed
408 
409 decrypt_err
410 
411 			Indicates that the MPDU decrypt integrity check failed
412 			or CRYPTO received an encrypted frame, but did not get a
413 			valid corresponding key id in the peer entry.
414 
415 unencrypted_frame_err
416 
417 			Copied here by RX OLE from the RX_MPDU_END TLV
418 
419 fcs_err
420 
421 			Indicates that the MPDU FCS check failed
422 
423 flow_idx_timeout
424 
425 			Indicates an unsuccessful flow search due to the
426 			expiring of the search timer.
427 
428 			<legal all>
429 
430 flow_idx_invalid
431 
432 			flow id is not valid
433 
434 			<legal all>
435 
436 wifi_parser_error
437 
438 			Indicates that the WiFi frame has one of the following
439 			errors
440 
441 			o has less than minimum allowed bytes as per standard
442 
443 			o has incomplete VLAN LLC/SNAP (only for non A-MSDUs)
444 
445 			<legal all>
446 
447 amsdu_parser_error
448 
449 			A-MSDU could not be properly de-agregated.
450 
451 			<legal all>
452 
453 sa_idx_timeout
454 
455 			Indicates an unsuccessful MAC source address search due
456 			to the expiring of the search timer.
457 
458 da_idx_timeout
459 
460 			Indicates an unsuccessful MAC destination address search
461 			due to the expiring of the search timer.
462 
463 msdu_limit_error
464 
465 			Indicates that the MSDU threshold was exceeded and thus
466 			all the rest of the MSDUs will not be scattered and will not
467 			be decasulated but will be DMA'ed in RAW format as a single
468 			MSDU buffer
469 
470 da_is_valid
471 
472 			Indicates that OLE found a valid DA entry
473 
474 da_is_mcbc
475 
476 			Field Only valid if da_is_valid is set
477 
478 
479 
480 			Indicates the DA address was a Multicast of Broadcast
481 			address.
482 
483 sa_is_valid
484 
485 			Indicates that OLE found a valid SA entry
486 
487 decrypt_status_code
488 
489 			Field provides insight into the decryption performed
490 
491 
492 
493 			<enum 0 decrypt_ok> Frame had protection enabled and
494 			decrypted properly
495 
496 			<enum 1 decrypt_unprotected_frame > Frame is unprotected
497 			and hence bypassed
498 
499 			<enum 2 decrypt_data_err > Frame has protection enabled
500 			and could not be properly decrypted due to MIC/ICV mismatch
501 			etc.
502 
503 			<enum 3 decrypt_key_invalid > Frame has protection
504 			enabled but the key that was required to decrypt this frame
505 			was not valid
506 
507 			<enum 4 decrypt_peer_entry_invalid > Frame has
508 			protection enabled but the key that was required to decrypt
509 			this frame was not valid
510 
511 			<enum 5 decrypt_other > Reserved for other indications
512 
513 
514 
515 			<legal 0 - 5>
516 
517 rx_bitmap_not_updated
518 
519 			Frame is received, but RXPCU could not update the
520 			receive bitmap due to (temporary) fifo contraints.
521 
522 			<legal all>
523 
524 reserved_2
525 
526 			<legal 0>
527 
528 msdu_done
529 
530 			If set indicates that the RX packet data, RX header
531 			data, RX PPDU start descriptor, RX MPDU start/end
532 			descriptor, RX MSDU start/end descriptors and RX Attention
533 			descriptor are all valid.  This bit must be in the last
534 			octet of the descriptor.
535 */
536 
537 
538 /* Description		RX_ATTENTION_0_RXPCU_MPDU_FILTER_IN_CATEGORY
539 
540 			Field indicates what the reason was that this MPDU frame
541 			was allowed to come into the receive path by RXPCU
542 
543 			<enum 0 rxpcu_filter_pass> This MPDU passed the normal
544 			frame filter programming of rxpcu
545 
546 			<enum 1 rxpcu_monitor_client> This MPDU did NOT pass the
547 			regular frame filter and would have been dropped, were it
548 			not for the frame fitting into the 'monitor_client'
549 			category.
550 
551 			<enum 2 rxpcu_monitor_other> This MPDU did NOT pass the
552 			regular frame filter and also did not pass the
553 			rxpcu_monitor_client filter. It would have been dropped
554 			accept that it did pass the 'monitor_other' category.
555 
556 			<legal 0-2>
557 */
558 #define RX_ATTENTION_0_RXPCU_MPDU_FILTER_IN_CATEGORY_OFFSET          0x00000000
559 #define RX_ATTENTION_0_RXPCU_MPDU_FILTER_IN_CATEGORY_LSB             0
560 #define RX_ATTENTION_0_RXPCU_MPDU_FILTER_IN_CATEGORY_MASK            0x00000003
561 
562 /* Description		RX_ATTENTION_0_SW_FRAME_GROUP_ID
563 
564 			SW processes frames based on certain classifications.
565 			This field indicates to what sw classification this MPDU is
566 			mapped.
567 
568 			The classification is given in priority order
569 
570 
571 
572 			<enum 0 sw_frame_group_NDP_frame>
573 
574 
575 
576 			<enum 1 sw_frame_group_Multicast_data>
577 
578 			<enum 2 sw_frame_group_Unicast_data>
579 
580 			<enum 3 sw_frame_group_Null_data > This includes mpdus
581 			of type Data Null as well as QoS Data Null
582 
583 
584 
585 			<enum 4 sw_frame_group_mgmt_0000 >
586 
587 			<enum 5 sw_frame_group_mgmt_0001 >
588 
589 			<enum 6 sw_frame_group_mgmt_0010 >
590 
591 			<enum 7 sw_frame_group_mgmt_0011 >
592 
593 			<enum 8 sw_frame_group_mgmt_0100 >
594 
595 			<enum 9 sw_frame_group_mgmt_0101 >
596 
597 			<enum 10 sw_frame_group_mgmt_0110 >
598 
599 			<enum 11 sw_frame_group_mgmt_0111 >
600 
601 			<enum 12 sw_frame_group_mgmt_1000 >
602 
603 			<enum 13 sw_frame_group_mgmt_1001 >
604 
605 			<enum 14 sw_frame_group_mgmt_1010 >
606 
607 			<enum 15 sw_frame_group_mgmt_1011 >
608 
609 			<enum 16 sw_frame_group_mgmt_1100 >
610 
611 			<enum 17 sw_frame_group_mgmt_1101 >
612 
613 			<enum 18 sw_frame_group_mgmt_1110 >
614 
615 			<enum 19 sw_frame_group_mgmt_1111 >
616 
617 
618 
619 			<enum 20 sw_frame_group_ctrl_0000 >
620 
621 			<enum 21 sw_frame_group_ctrl_0001 >
622 
623 			<enum 22 sw_frame_group_ctrl_0010 >
624 
625 			<enum 23 sw_frame_group_ctrl_0011 >
626 
627 			<enum 24 sw_frame_group_ctrl_0100 >
628 
629 			<enum 25 sw_frame_group_ctrl_0101 >
630 
631 			<enum 26 sw_frame_group_ctrl_0110 >
632 
633 			<enum 27 sw_frame_group_ctrl_0111 >
634 
635 			<enum 28 sw_frame_group_ctrl_1000 >
636 
637 			<enum 29 sw_frame_group_ctrl_1001 >
638 
639 			<enum 30 sw_frame_group_ctrl_1010 >
640 
641 			<enum 31 sw_frame_group_ctrl_1011 >
642 
643 			<enum 32 sw_frame_group_ctrl_1100 >
644 
645 			<enum 33 sw_frame_group_ctrl_1101 >
646 
647 			<enum 34 sw_frame_group_ctrl_1110 >
648 
649 			<enum 35 sw_frame_group_ctrl_1111 >
650 
651 
652 
653 			<enum 36 sw_frame_group_unsupported> This covers type 3
654 			and protocol version != 0
655 
656 
657 
658 
659 
660 
661 			<legal 0-37>
662 */
663 #define RX_ATTENTION_0_SW_FRAME_GROUP_ID_OFFSET                      0x00000000
664 #define RX_ATTENTION_0_SW_FRAME_GROUP_ID_LSB                         2
665 #define RX_ATTENTION_0_SW_FRAME_GROUP_ID_MASK                        0x000001fc
666 
667 /* Description		RX_ATTENTION_0_RESERVED_0
668 
669 			<legal 0>
670 */
671 #define RX_ATTENTION_0_RESERVED_0_OFFSET                             0x00000000
672 #define RX_ATTENTION_0_RESERVED_0_LSB                                9
673 #define RX_ATTENTION_0_RESERVED_0_MASK                               0x0000fe00
674 
675 /* Description		RX_ATTENTION_0_PHY_PPDU_ID
676 
677 			A ppdu counter value that PHY increments for every PPDU
678 			received. The counter value wraps around
679 
680 			<legal all>
681 */
682 #define RX_ATTENTION_0_PHY_PPDU_ID_OFFSET                            0x00000000
683 #define RX_ATTENTION_0_PHY_PPDU_ID_LSB                               16
684 #define RX_ATTENTION_0_PHY_PPDU_ID_MASK                              0xffff0000
685 
686 /* Description		RX_ATTENTION_1_FIRST_MPDU
687 
688 			Indicates the first MSDU of the PPDU.  If both
689 			first_mpdu and last_mpdu are set in the MSDU then this is a
690 			not an A-MPDU frame but a stand alone MPDU.  Interior MPDU
691 			in an A-MPDU shall have both first_mpdu and last_mpdu bits
692 			set to 0.  The PPDU start status will only be valid when
693 			this bit is set.
694 */
695 #define RX_ATTENTION_1_FIRST_MPDU_OFFSET                             0x00000004
696 #define RX_ATTENTION_1_FIRST_MPDU_LSB                                0
697 #define RX_ATTENTION_1_FIRST_MPDU_MASK                               0x00000001
698 
699 /* Description		RX_ATTENTION_1_RESERVED_1A
700 
701 			<legal 0>
702 */
703 #define RX_ATTENTION_1_RESERVED_1A_OFFSET                            0x00000004
704 #define RX_ATTENTION_1_RESERVED_1A_LSB                               1
705 #define RX_ATTENTION_1_RESERVED_1A_MASK                              0x00000002
706 
707 /* Description		RX_ATTENTION_1_MCAST_BCAST
708 
709 			Multicast / broadcast indicator.  Only set when the MAC
710 			address 1 bit 0 is set indicating mcast/bcast and the BSSID
711 			matches one of the 4 BSSID registers. Only set when
712 			first_msdu is set.
713 */
714 #define RX_ATTENTION_1_MCAST_BCAST_OFFSET                            0x00000004
715 #define RX_ATTENTION_1_MCAST_BCAST_LSB                               2
716 #define RX_ATTENTION_1_MCAST_BCAST_MASK                              0x00000004
717 
718 /* Description		RX_ATTENTION_1_AST_INDEX_NOT_FOUND
719 
720 			Only valid when first_msdu is set.
721 
722 
723 
724 			Indicates no AST matching entries within the the max
725 			search count.
726 */
727 #define RX_ATTENTION_1_AST_INDEX_NOT_FOUND_OFFSET                    0x00000004
728 #define RX_ATTENTION_1_AST_INDEX_NOT_FOUND_LSB                       3
729 #define RX_ATTENTION_1_AST_INDEX_NOT_FOUND_MASK                      0x00000008
730 
731 /* Description		RX_ATTENTION_1_AST_INDEX_TIMEOUT
732 
733 			Only valid when first_msdu is set.
734 
735 
736 
737 			Indicates an unsuccessful search in the address seach
738 			table due to timeout.
739 */
740 #define RX_ATTENTION_1_AST_INDEX_TIMEOUT_OFFSET                      0x00000004
741 #define RX_ATTENTION_1_AST_INDEX_TIMEOUT_LSB                         4
742 #define RX_ATTENTION_1_AST_INDEX_TIMEOUT_MASK                        0x00000010
743 
744 /* Description		RX_ATTENTION_1_POWER_MGMT
745 
746 			Power management bit set in the 802.11 header.  Only set
747 			when first_msdu is set.
748 */
749 #define RX_ATTENTION_1_POWER_MGMT_OFFSET                             0x00000004
750 #define RX_ATTENTION_1_POWER_MGMT_LSB                                5
751 #define RX_ATTENTION_1_POWER_MGMT_MASK                               0x00000020
752 
753 /* Description		RX_ATTENTION_1_NON_QOS
754 
755 			Set if packet is not a non-QoS data frame.  Only set
756 			when first_msdu is set.
757 */
758 #define RX_ATTENTION_1_NON_QOS_OFFSET                                0x00000004
759 #define RX_ATTENTION_1_NON_QOS_LSB                                   6
760 #define RX_ATTENTION_1_NON_QOS_MASK                                  0x00000040
761 
762 /* Description		RX_ATTENTION_1_NULL_DATA
763 
764 			Set if frame type indicates either null data or QoS null
765 			data format.  Only set when first_msdu is set.
766 */
767 #define RX_ATTENTION_1_NULL_DATA_OFFSET                              0x00000004
768 #define RX_ATTENTION_1_NULL_DATA_LSB                                 7
769 #define RX_ATTENTION_1_NULL_DATA_MASK                                0x00000080
770 
771 /* Description		RX_ATTENTION_1_MGMT_TYPE
772 
773 			Set if packet is a management packet.  Only set when
774 			first_msdu is set.
775 */
776 #define RX_ATTENTION_1_MGMT_TYPE_OFFSET                              0x00000004
777 #define RX_ATTENTION_1_MGMT_TYPE_LSB                                 8
778 #define RX_ATTENTION_1_MGMT_TYPE_MASK                                0x00000100
779 
780 /* Description		RX_ATTENTION_1_CTRL_TYPE
781 
782 			Set if packet is a control packet.  Only set when
783 			first_msdu is set.
784 */
785 #define RX_ATTENTION_1_CTRL_TYPE_OFFSET                              0x00000004
786 #define RX_ATTENTION_1_CTRL_TYPE_LSB                                 9
787 #define RX_ATTENTION_1_CTRL_TYPE_MASK                                0x00000200
788 
789 /* Description		RX_ATTENTION_1_MORE_DATA
790 
791 			Set if more bit in frame control is set.  Only set when
792 			first_msdu is set.
793 */
794 #define RX_ATTENTION_1_MORE_DATA_OFFSET                              0x00000004
795 #define RX_ATTENTION_1_MORE_DATA_LSB                                 10
796 #define RX_ATTENTION_1_MORE_DATA_MASK                                0x00000400
797 
798 /* Description		RX_ATTENTION_1_EOSP
799 
800 			Set if the EOSP (end of service period) bit in the QoS
801 			control field is set.  Only set when first_msdu is set.
802 */
803 #define RX_ATTENTION_1_EOSP_OFFSET                                   0x00000004
804 #define RX_ATTENTION_1_EOSP_LSB                                      11
805 #define RX_ATTENTION_1_EOSP_MASK                                     0x00000800
806 
807 /* Description		RX_ATTENTION_1_A_MSDU_ERROR
808 
809 			Set if number of MSDUs in A-MSDU is above a threshold or
810 			if the size of the MSDU is invalid.  This receive buffer
811 			will contain all of the remainder of the MSDUs in this MPDU
812 			without decapsulation.
813 */
814 #define RX_ATTENTION_1_A_MSDU_ERROR_OFFSET                           0x00000004
815 #define RX_ATTENTION_1_A_MSDU_ERROR_LSB                              12
816 #define RX_ATTENTION_1_A_MSDU_ERROR_MASK                             0x00001000
817 
818 /* Description		RX_ATTENTION_1_FRAGMENT_FLAG
819 
820 			Indicates that this is an 802.11 fragment frame.  This
821 			is set when either the more_frag bit is set in the frame
822 			control or the fragment number is not zero.  Only set when
823 			first_msdu is set.
824 */
825 #define RX_ATTENTION_1_FRAGMENT_FLAG_OFFSET                          0x00000004
826 #define RX_ATTENTION_1_FRAGMENT_FLAG_LSB                             13
827 #define RX_ATTENTION_1_FRAGMENT_FLAG_MASK                            0x00002000
828 
829 /* Description		RX_ATTENTION_1_ORDER
830 
831 			Set if the order bit in the frame control is set.  Only
832 			set when first_msdu is set.
833 */
834 #define RX_ATTENTION_1_ORDER_OFFSET                                  0x00000004
835 #define RX_ATTENTION_1_ORDER_LSB                                     14
836 #define RX_ATTENTION_1_ORDER_MASK                                    0x00004000
837 
838 /* Description		RX_ATTENTION_1_CCE_MATCH
839 
840 			Indicates that this status has a corresponding MSDU that
841 			requires FW processing.  The OLE will have classification
842 			ring mask registers which will indicate the ring(s) for
843 			packets and descriptors which need FW attention.
844 */
845 #define RX_ATTENTION_1_CCE_MATCH_OFFSET                              0x00000004
846 #define RX_ATTENTION_1_CCE_MATCH_LSB                                 15
847 #define RX_ATTENTION_1_CCE_MATCH_MASK                                0x00008000
848 
849 /* Description		RX_ATTENTION_1_OVERFLOW_ERR
850 
851 			RXPCU Receive FIFO ran out of space to receive the full
852 			MPDU. Therefor this MPDU is terminated early and is thus
853 			corrupted.
854 
855 
856 
857 			This MPDU will not be ACKed.
858 
859 			RXPCU might still be able to correctly receive the
860 			following MPDUs in the PPDU if enough fifo space became
861 			available in time
862 */
863 #define RX_ATTENTION_1_OVERFLOW_ERR_OFFSET                           0x00000004
864 #define RX_ATTENTION_1_OVERFLOW_ERR_LSB                              16
865 #define RX_ATTENTION_1_OVERFLOW_ERR_MASK                             0x00010000
866 
867 /* Description		RX_ATTENTION_1_MSDU_LENGTH_ERR
868 
869 			Indicates that the MSDU length from the 802.3
870 			encapsulated length field extends beyond the MPDU boundary
871 			or if the length is less than 14 bytes.
872 
873 			Merged with original other_msdu_err: Indicates that the
874 			MSDU threshold was exceeded and thus all the rest of the
875 			MSDUs will not be scattered and will not be decasulated but
876 			will be DMA'ed in RAW format as a single MSDU buffer
877 */
878 #define RX_ATTENTION_1_MSDU_LENGTH_ERR_OFFSET                        0x00000004
879 #define RX_ATTENTION_1_MSDU_LENGTH_ERR_LSB                           17
880 #define RX_ATTENTION_1_MSDU_LENGTH_ERR_MASK                          0x00020000
881 
882 /* Description		RX_ATTENTION_1_TCP_UDP_CHKSUM_FAIL
883 
884 			Indicates that the computed checksum (tcp_udp_chksum)
885 			did not match the checksum in the TCP/UDP header.
886 */
887 #define RX_ATTENTION_1_TCP_UDP_CHKSUM_FAIL_OFFSET                    0x00000004
888 #define RX_ATTENTION_1_TCP_UDP_CHKSUM_FAIL_LSB                       18
889 #define RX_ATTENTION_1_TCP_UDP_CHKSUM_FAIL_MASK                      0x00040000
890 
891 /* Description		RX_ATTENTION_1_IP_CHKSUM_FAIL
892 
893 			Indicates that the computed checksum did not match the
894 			checksum in the IP header.
895 */
896 #define RX_ATTENTION_1_IP_CHKSUM_FAIL_OFFSET                         0x00000004
897 #define RX_ATTENTION_1_IP_CHKSUM_FAIL_LSB                            19
898 #define RX_ATTENTION_1_IP_CHKSUM_FAIL_MASK                           0x00080000
899 
900 /* Description		RX_ATTENTION_1_SA_IDX_INVALID
901 
902 			Indicates no matching entry was found in the address
903 			search table for the source MAC address.
904 */
905 #define RX_ATTENTION_1_SA_IDX_INVALID_OFFSET                         0x00000004
906 #define RX_ATTENTION_1_SA_IDX_INVALID_LSB                            20
907 #define RX_ATTENTION_1_SA_IDX_INVALID_MASK                           0x00100000
908 
909 /* Description		RX_ATTENTION_1_DA_IDX_INVALID
910 
911 			Indicates no matching entry was found in the address
912 			search table for the destination MAC address.
913 */
914 #define RX_ATTENTION_1_DA_IDX_INVALID_OFFSET                         0x00000004
915 #define RX_ATTENTION_1_DA_IDX_INVALID_LSB                            21
916 #define RX_ATTENTION_1_DA_IDX_INVALID_MASK                           0x00200000
917 
918 /* Description		RX_ATTENTION_1_RESERVED_1B
919 
920 */
921 #define RX_ATTENTION_1_RESERVED_1B_OFFSET                            0x00000004
922 #define RX_ATTENTION_1_RESERVED_1B_LSB                               22
923 #define RX_ATTENTION_1_RESERVED_1B_MASK                              0x00400000
924 
925 /* Description		RX_ATTENTION_1_RX_IN_TX_DECRYPT_BYP
926 
927 			Indicates that RX packet is not decrypted as Crypto is
928 			busy with TX packet processing.
929 */
930 #define RX_ATTENTION_1_RX_IN_TX_DECRYPT_BYP_OFFSET                   0x00000004
931 #define RX_ATTENTION_1_RX_IN_TX_DECRYPT_BYP_LSB                      23
932 #define RX_ATTENTION_1_RX_IN_TX_DECRYPT_BYP_MASK                     0x00800000
933 
934 /* Description		RX_ATTENTION_1_ENCRYPT_REQUIRED
935 
936 			Indicates that this data type frame is not encrypted
937 			even if the policy for this MPDU requires encryption as
938 			indicated in the peer entry key type.
939 */
940 #define RX_ATTENTION_1_ENCRYPT_REQUIRED_OFFSET                       0x00000004
941 #define RX_ATTENTION_1_ENCRYPT_REQUIRED_LSB                          24
942 #define RX_ATTENTION_1_ENCRYPT_REQUIRED_MASK                         0x01000000
943 
944 /* Description		RX_ATTENTION_1_DIRECTED
945 
946 			MPDU is a directed packet which means that the RA
947 			matched our STA addresses.  In proxySTA it means that the TA
948 			matched an entry in our address search table with the
949 			corresponding no_ack bit is the address search entry
950 			cleared.
951 */
952 #define RX_ATTENTION_1_DIRECTED_OFFSET                               0x00000004
953 #define RX_ATTENTION_1_DIRECTED_LSB                                  25
954 #define RX_ATTENTION_1_DIRECTED_MASK                                 0x02000000
955 
956 /* Description		RX_ATTENTION_1_BUFFER_FRAGMENT
957 
958 			Indicates that at least one of the rx buffers has been
959 			fragmented.  If set the FW should look at the rx_frag_info
960 			descriptor described below.
961 */
962 #define RX_ATTENTION_1_BUFFER_FRAGMENT_OFFSET                        0x00000004
963 #define RX_ATTENTION_1_BUFFER_FRAGMENT_LSB                           26
964 #define RX_ATTENTION_1_BUFFER_FRAGMENT_MASK                          0x04000000
965 
966 /* Description		RX_ATTENTION_1_MPDU_LENGTH_ERR
967 
968 			Indicates that the MPDU was pre-maturely terminated
969 			resulting in a truncated MPDU.  Don't trust the MPDU length
970 			field.
971 */
972 #define RX_ATTENTION_1_MPDU_LENGTH_ERR_OFFSET                        0x00000004
973 #define RX_ATTENTION_1_MPDU_LENGTH_ERR_LSB                           27
974 #define RX_ATTENTION_1_MPDU_LENGTH_ERR_MASK                          0x08000000
975 
976 /* Description		RX_ATTENTION_1_TKIP_MIC_ERR
977 
978 			Indicates that the MPDU Michael integrity check failed
979 */
980 #define RX_ATTENTION_1_TKIP_MIC_ERR_OFFSET                           0x00000004
981 #define RX_ATTENTION_1_TKIP_MIC_ERR_LSB                              28
982 #define RX_ATTENTION_1_TKIP_MIC_ERR_MASK                             0x10000000
983 
984 /* Description		RX_ATTENTION_1_DECRYPT_ERR
985 
986 			Indicates that the MPDU decrypt integrity check failed
987 			or CRYPTO received an encrypted frame, but did not get a
988 			valid corresponding key id in the peer entry.
989 */
990 #define RX_ATTENTION_1_DECRYPT_ERR_OFFSET                            0x00000004
991 #define RX_ATTENTION_1_DECRYPT_ERR_LSB                               29
992 #define RX_ATTENTION_1_DECRYPT_ERR_MASK                              0x20000000
993 
994 /* Description		RX_ATTENTION_1_UNENCRYPTED_FRAME_ERR
995 
996 			Copied here by RX OLE from the RX_MPDU_END TLV
997 */
998 #define RX_ATTENTION_1_UNENCRYPTED_FRAME_ERR_OFFSET                  0x00000004
999 #define RX_ATTENTION_1_UNENCRYPTED_FRAME_ERR_LSB                     30
1000 #define RX_ATTENTION_1_UNENCRYPTED_FRAME_ERR_MASK                    0x40000000
1001 
1002 /* Description		RX_ATTENTION_1_FCS_ERR
1003 
1004 			Indicates that the MPDU FCS check failed
1005 */
1006 #define RX_ATTENTION_1_FCS_ERR_OFFSET                                0x00000004
1007 #define RX_ATTENTION_1_FCS_ERR_LSB                                   31
1008 #define RX_ATTENTION_1_FCS_ERR_MASK                                  0x80000000
1009 
1010 /* Description		RX_ATTENTION_2_FLOW_IDX_TIMEOUT
1011 
1012 			Indicates an unsuccessful flow search due to the
1013 			expiring of the search timer.
1014 
1015 			<legal all>
1016 */
1017 #define RX_ATTENTION_2_FLOW_IDX_TIMEOUT_OFFSET                       0x00000008
1018 #define RX_ATTENTION_2_FLOW_IDX_TIMEOUT_LSB                          0
1019 #define RX_ATTENTION_2_FLOW_IDX_TIMEOUT_MASK                         0x00000001
1020 
1021 /* Description		RX_ATTENTION_2_FLOW_IDX_INVALID
1022 
1023 			flow id is not valid
1024 
1025 			<legal all>
1026 */
1027 #define RX_ATTENTION_2_FLOW_IDX_INVALID_OFFSET                       0x00000008
1028 #define RX_ATTENTION_2_FLOW_IDX_INVALID_LSB                          1
1029 #define RX_ATTENTION_2_FLOW_IDX_INVALID_MASK                         0x00000002
1030 
1031 /* Description		RX_ATTENTION_2_WIFI_PARSER_ERROR
1032 
1033 			Indicates that the WiFi frame has one of the following
1034 			errors
1035 
1036 			o has less than minimum allowed bytes as per standard
1037 
1038 			o has incomplete VLAN LLC/SNAP (only for non A-MSDUs)
1039 
1040 			<legal all>
1041 */
1042 #define RX_ATTENTION_2_WIFI_PARSER_ERROR_OFFSET                      0x00000008
1043 #define RX_ATTENTION_2_WIFI_PARSER_ERROR_LSB                         2
1044 #define RX_ATTENTION_2_WIFI_PARSER_ERROR_MASK                        0x00000004
1045 
1046 /* Description		RX_ATTENTION_2_AMSDU_PARSER_ERROR
1047 
1048 			A-MSDU could not be properly de-agregated.
1049 
1050 			<legal all>
1051 */
1052 #define RX_ATTENTION_2_AMSDU_PARSER_ERROR_OFFSET                     0x00000008
1053 #define RX_ATTENTION_2_AMSDU_PARSER_ERROR_LSB                        3
1054 #define RX_ATTENTION_2_AMSDU_PARSER_ERROR_MASK                       0x00000008
1055 
1056 /* Description		RX_ATTENTION_2_SA_IDX_TIMEOUT
1057 
1058 			Indicates an unsuccessful MAC source address search due
1059 			to the expiring of the search timer.
1060 */
1061 #define RX_ATTENTION_2_SA_IDX_TIMEOUT_OFFSET                         0x00000008
1062 #define RX_ATTENTION_2_SA_IDX_TIMEOUT_LSB                            4
1063 #define RX_ATTENTION_2_SA_IDX_TIMEOUT_MASK                           0x00000010
1064 
1065 /* Description		RX_ATTENTION_2_DA_IDX_TIMEOUT
1066 
1067 			Indicates an unsuccessful MAC destination address search
1068 			due to the expiring of the search timer.
1069 */
1070 #define RX_ATTENTION_2_DA_IDX_TIMEOUT_OFFSET                         0x00000008
1071 #define RX_ATTENTION_2_DA_IDX_TIMEOUT_LSB                            5
1072 #define RX_ATTENTION_2_DA_IDX_TIMEOUT_MASK                           0x00000020
1073 
1074 /* Description		RX_ATTENTION_2_MSDU_LIMIT_ERROR
1075 
1076 			Indicates that the MSDU threshold was exceeded and thus
1077 			all the rest of the MSDUs will not be scattered and will not
1078 			be decasulated but will be DMA'ed in RAW format as a single
1079 			MSDU buffer
1080 */
1081 #define RX_ATTENTION_2_MSDU_LIMIT_ERROR_OFFSET                       0x00000008
1082 #define RX_ATTENTION_2_MSDU_LIMIT_ERROR_LSB                          6
1083 #define RX_ATTENTION_2_MSDU_LIMIT_ERROR_MASK                         0x00000040
1084 
1085 /* Description		RX_ATTENTION_2_DA_IS_VALID
1086 
1087 			Indicates that OLE found a valid DA entry
1088 */
1089 #define RX_ATTENTION_2_DA_IS_VALID_OFFSET                            0x00000008
1090 #define RX_ATTENTION_2_DA_IS_VALID_LSB                               7
1091 #define RX_ATTENTION_2_DA_IS_VALID_MASK                              0x00000080
1092 
1093 /* Description		RX_ATTENTION_2_DA_IS_MCBC
1094 
1095 			Field Only valid if da_is_valid is set
1096 
1097 
1098 
1099 			Indicates the DA address was a Multicast of Broadcast
1100 			address.
1101 */
1102 #define RX_ATTENTION_2_DA_IS_MCBC_OFFSET                             0x00000008
1103 #define RX_ATTENTION_2_DA_IS_MCBC_LSB                                8
1104 #define RX_ATTENTION_2_DA_IS_MCBC_MASK                               0x00000100
1105 
1106 /* Description		RX_ATTENTION_2_SA_IS_VALID
1107 
1108 			Indicates that OLE found a valid SA entry
1109 */
1110 #define RX_ATTENTION_2_SA_IS_VALID_OFFSET                            0x00000008
1111 #define RX_ATTENTION_2_SA_IS_VALID_LSB                               9
1112 #define RX_ATTENTION_2_SA_IS_VALID_MASK                              0x00000200
1113 
1114 /* Description		RX_ATTENTION_2_DECRYPT_STATUS_CODE
1115 
1116 			Field provides insight into the decryption performed
1117 
1118 
1119 
1120 			<enum 0 decrypt_ok> Frame had protection enabled and
1121 			decrypted properly
1122 
1123 			<enum 1 decrypt_unprotected_frame > Frame is unprotected
1124 			and hence bypassed
1125 
1126 			<enum 2 decrypt_data_err > Frame has protection enabled
1127 			and could not be properly decrypted due to MIC/ICV mismatch
1128 			etc.
1129 
1130 			<enum 3 decrypt_key_invalid > Frame has protection
1131 			enabled but the key that was required to decrypt this frame
1132 			was not valid
1133 
1134 			<enum 4 decrypt_peer_entry_invalid > Frame has
1135 			protection enabled but the key that was required to decrypt
1136 			this frame was not valid
1137 
1138 			<enum 5 decrypt_other > Reserved for other indications
1139 
1140 
1141 
1142 			<legal 0 - 5>
1143 */
1144 #define RX_ATTENTION_2_DECRYPT_STATUS_CODE_OFFSET                    0x00000008
1145 #define RX_ATTENTION_2_DECRYPT_STATUS_CODE_LSB                       10
1146 #define RX_ATTENTION_2_DECRYPT_STATUS_CODE_MASK                      0x00001c00
1147 
1148 /* Description		RX_ATTENTION_2_RX_BITMAP_NOT_UPDATED
1149 
1150 			Frame is received, but RXPCU could not update the
1151 			receive bitmap due to (temporary) fifo contraints.
1152 
1153 			<legal all>
1154 */
1155 #define RX_ATTENTION_2_RX_BITMAP_NOT_UPDATED_OFFSET                  0x00000008
1156 #define RX_ATTENTION_2_RX_BITMAP_NOT_UPDATED_LSB                     13
1157 #define RX_ATTENTION_2_RX_BITMAP_NOT_UPDATED_MASK                    0x00002000
1158 
1159 /* Description		RX_ATTENTION_2_RESERVED_2
1160 
1161 			<legal 0>
1162 */
1163 #define RX_ATTENTION_2_RESERVED_2_OFFSET                             0x00000008
1164 #define RX_ATTENTION_2_RESERVED_2_LSB                                14
1165 #define RX_ATTENTION_2_RESERVED_2_MASK                               0x7fffc000
1166 
1167 /* Description		RX_ATTENTION_2_MSDU_DONE
1168 
1169 			If set indicates that the RX packet data, RX header
1170 			data, RX PPDU start descriptor, RX MPDU start/end
1171 			descriptor, RX MSDU start/end descriptors and RX Attention
1172 			descriptor are all valid.  This bit must be in the last
1173 			octet of the descriptor.
1174 */
1175 #define RX_ATTENTION_2_MSDU_DONE_OFFSET                              0x00000008
1176 #define RX_ATTENTION_2_MSDU_DONE_LSB                                 31
1177 #define RX_ATTENTION_2_MSDU_DONE_MASK                                0x80000000
1178 
1179 
1180 #endif // _RX_ATTENTION_H_
1181