xref: /wlan-driver/fw-api/hw/qcn6432/tx_fes_status_ack_or_ba.h (revision 5113495b16420b49004c444715d2daae2066e7dc)
1*5113495bSYour Name /*
2*5113495bSYour Name  * Copyright (c) 2023 Qualcomm Innovation Center, Inc. All rights reserved.
3*5113495bSYour Name  *
4*5113495bSYour Name  * Permission to use, copy, modify, and/or distribute this software for any
5*5113495bSYour Name  * purpose with or without fee is hereby granted, provided that the above
6*5113495bSYour Name  * copyright notice and this permission notice appear in all copies.
7*5113495bSYour Name  *
8*5113495bSYour Name  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
9*5113495bSYour Name  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
10*5113495bSYour Name  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
11*5113495bSYour Name  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
12*5113495bSYour Name  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
13*5113495bSYour Name  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
14*5113495bSYour Name  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
15*5113495bSYour Name  */
16*5113495bSYour Name 
17*5113495bSYour Name #ifndef _TX_FES_STATUS_ACK_OR_BA_H_
18*5113495bSYour Name #define _TX_FES_STATUS_ACK_OR_BA_H_
19*5113495bSYour Name #if !defined(__ASSEMBLER__)
20*5113495bSYour Name #endif
21*5113495bSYour Name 
22*5113495bSYour Name #define NUM_OF_DWORDS_TX_FES_STATUS_ACK_OR_BA 10
23*5113495bSYour Name 
24*5113495bSYour Name #define NUM_OF_QWORDS_TX_FES_STATUS_ACK_OR_BA 5
25*5113495bSYour Name 
26*5113495bSYour Name 
27*5113495bSYour Name struct tx_fes_status_ack_or_ba {
28*5113495bSYour Name #ifndef WIFI_BIT_ORDER_BIG_ENDIAN
29*5113495bSYour Name              uint32_t ack_ba_status_type                                      :  1, // [0:0]
30*5113495bSYour Name                       ba_type                                                 :  1, // [1:1]
31*5113495bSYour Name                       ba_tid                                                  :  4, // [5:2]
32*5113495bSYour Name                       unexpected_ack_or_ba                                    :  1, // [6:6]
33*5113495bSYour Name                       response_timeout                                        :  1, // [7:7]
34*5113495bSYour Name                       ack_frame_rssi                                          :  8, // [15:8]
35*5113495bSYour Name                       ssn                                                     : 12, // [27:16]
36*5113495bSYour Name                       reserved_0b                                             :  4; // [31:28]
37*5113495bSYour Name              uint32_t sw_peer_id                                              : 16, // [15:0]
38*5113495bSYour Name                       reserved_1a                                             : 16; // [31:16]
39*5113495bSYour Name              uint32_t ba_bitmap_31_0                                          : 32; // [31:0]
40*5113495bSYour Name              uint32_t ba_bitmap_63_32                                         : 32; // [31:0]
41*5113495bSYour Name              uint32_t ba_bitmap_95_64                                         : 32; // [31:0]
42*5113495bSYour Name              uint32_t ba_bitmap_127_96                                        : 32; // [31:0]
43*5113495bSYour Name              uint32_t ba_bitmap_159_128                                       : 32; // [31:0]
44*5113495bSYour Name              uint32_t ba_bitmap_191_160                                       : 32; // [31:0]
45*5113495bSYour Name              uint32_t ba_bitmap_223_192                                       : 32; // [31:0]
46*5113495bSYour Name              uint32_t ba_bitmap_255_224                                       : 32; // [31:0]
47*5113495bSYour Name #else
48*5113495bSYour Name              uint32_t reserved_0b                                             :  4, // [31:28]
49*5113495bSYour Name                       ssn                                                     : 12, // [27:16]
50*5113495bSYour Name                       ack_frame_rssi                                          :  8, // [15:8]
51*5113495bSYour Name                       response_timeout                                        :  1, // [7:7]
52*5113495bSYour Name                       unexpected_ack_or_ba                                    :  1, // [6:6]
53*5113495bSYour Name                       ba_tid                                                  :  4, // [5:2]
54*5113495bSYour Name                       ba_type                                                 :  1, // [1:1]
55*5113495bSYour Name                       ack_ba_status_type                                      :  1; // [0:0]
56*5113495bSYour Name              uint32_t reserved_1a                                             : 16, // [31:16]
57*5113495bSYour Name                       sw_peer_id                                              : 16; // [15:0]
58*5113495bSYour Name              uint32_t ba_bitmap_31_0                                          : 32; // [31:0]
59*5113495bSYour Name              uint32_t ba_bitmap_63_32                                         : 32; // [31:0]
60*5113495bSYour Name              uint32_t ba_bitmap_95_64                                         : 32; // [31:0]
61*5113495bSYour Name              uint32_t ba_bitmap_127_96                                        : 32; // [31:0]
62*5113495bSYour Name              uint32_t ba_bitmap_159_128                                       : 32; // [31:0]
63*5113495bSYour Name              uint32_t ba_bitmap_191_160                                       : 32; // [31:0]
64*5113495bSYour Name              uint32_t ba_bitmap_223_192                                       : 32; // [31:0]
65*5113495bSYour Name              uint32_t ba_bitmap_255_224                                       : 32; // [31:0]
66*5113495bSYour Name #endif
67*5113495bSYour Name };
68*5113495bSYour Name 
69*5113495bSYour Name 
70*5113495bSYour Name /* Description		ACK_BA_STATUS_TYPE
71*5113495bSYour Name 
72*5113495bSYour Name 			Consumer: SW
73*5113495bSYour Name 			Producer: RXPCU
74*5113495bSYour Name 
75*5113495bSYour Name 			<enum 0 Ack_type> This TLV represents an ACK reception.
76*5113495bSYour Name 
77*5113495bSYour Name 			<enum 1 BA_type>  This TLV represents an BA reception.
78*5113495bSYour Name 			 <legal 0-1>
79*5113495bSYour Name */
80*5113495bSYour Name 
81*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_ACK_BA_STATUS_TYPE_OFFSET                           0x0000000000000000
82*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_ACK_BA_STATUS_TYPE_LSB                              0
83*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_ACK_BA_STATUS_TYPE_MSB                              0
84*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_ACK_BA_STATUS_TYPE_MASK                             0x0000000000000001
85*5113495bSYour Name 
86*5113495bSYour Name 
87*5113495bSYour Name /* Description		BA_TYPE
88*5113495bSYour Name 
89*5113495bSYour Name 			Field only valid when  Ack_ba_status_type ==  BA_type
90*5113495bSYour Name 
91*5113495bSYour Name 			<enum 0 BA_TYPE_ACK>
92*5113495bSYour Name 			<enum 1 BA_TYPE_bitmap>
93*5113495bSYour Name 			<legal all>
94*5113495bSYour Name */
95*5113495bSYour Name 
96*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_BA_TYPE_OFFSET                                      0x0000000000000000
97*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_BA_TYPE_LSB                                         1
98*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_BA_TYPE_MSB                                         1
99*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_BA_TYPE_MASK                                        0x0000000000000002
100*5113495bSYour Name 
101*5113495bSYour Name 
102*5113495bSYour Name /* Description		BA_TID
103*5113495bSYour Name 
104*5113495bSYour Name 			Field only valid when  Ack_ba_status_type ==  BA_type
105*5113495bSYour Name 
106*5113495bSYour Name 			The TID field copied from the BA frame
107*5113495bSYour Name 			<legal all>
108*5113495bSYour Name */
109*5113495bSYour Name 
110*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_BA_TID_OFFSET                                       0x0000000000000000
111*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_BA_TID_LSB                                          2
112*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_BA_TID_MSB                                          5
113*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_BA_TID_MASK                                         0x000000000000003c
114*5113495bSYour Name 
115*5113495bSYour Name 
116*5113495bSYour Name /* Description		UNEXPECTED_ACK_OR_BA
117*5113495bSYour Name 
118*5113495bSYour Name 			Set when RXPCU received a BA for which there was no " RXPCU_USER_SETUP_EXT
119*5113495bSYour Name 			 TLV' received.
120*5113495bSYour Name 			This can happen when a BA for unexpected TID is received.
121*5113495bSYour Name 
122*5113495bSYour Name 
123*5113495bSYour Name 			This message enables SW to still pass this BA information
124*5113495bSYour Name 			 on to the right TQM queue.
125*5113495bSYour Name 			<legal all>
126*5113495bSYour Name */
127*5113495bSYour Name 
128*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_UNEXPECTED_ACK_OR_BA_OFFSET                         0x0000000000000000
129*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_UNEXPECTED_ACK_OR_BA_LSB                            6
130*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_UNEXPECTED_ACK_OR_BA_MSB                            6
131*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_UNEXPECTED_ACK_OR_BA_MASK                           0x0000000000000040
132*5113495bSYour Name 
133*5113495bSYour Name 
134*5113495bSYour Name /* Description		RESPONSE_TIMEOUT
135*5113495bSYour Name 
136*5113495bSYour Name 			When set, there was delay in RXPCU (likely due to AST fetch
137*5113495bSYour Name 			 delay) that resulted in TXPCU not being able to send the
138*5113495bSYour Name 			 RX_RESPONSE_REQUIRED_INFO TLV within a certain timeout
139*5113495bSYour Name 			from the falling edge of the frame. This status TLV is still
140*5113495bSYour Name 			 generated but RXPCU will NOT have generated the RX_RESPONSE_REQUIRED
141*5113495bSYour Name 			 TLV.
142*5113495bSYour Name 			<legal all>
143*5113495bSYour Name */
144*5113495bSYour Name 
145*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_RESPONSE_TIMEOUT_OFFSET                             0x0000000000000000
146*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_RESPONSE_TIMEOUT_LSB                                7
147*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_RESPONSE_TIMEOUT_MSB                                7
148*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_RESPONSE_TIMEOUT_MASK                               0x0000000000000080
149*5113495bSYour Name 
150*5113495bSYour Name 
151*5113495bSYour Name /* Description		ACK_FRAME_RSSI
152*5113495bSYour Name 
153*5113495bSYour Name 			RSSI of the received ACK, BA or M-BA frame.
154*5113495bSYour Name 
155*5113495bSYour Name 			<legal all>
156*5113495bSYour Name */
157*5113495bSYour Name 
158*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_ACK_FRAME_RSSI_OFFSET                               0x0000000000000000
159*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_ACK_FRAME_RSSI_LSB                                  8
160*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_ACK_FRAME_RSSI_MSB                                  15
161*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_ACK_FRAME_RSSI_MASK                                 0x000000000000ff00
162*5113495bSYour Name 
163*5113495bSYour Name 
164*5113495bSYour Name /* Description		SSN
165*5113495bSYour Name 
166*5113495bSYour Name 			Consumer: TQM/FW
167*5113495bSYour Name 			Producer: SW/RXPCU
168*5113495bSYour Name 
169*5113495bSYour Name 			Field only valid in case of the  Ack_ba_status_type indicating:
170*5113495bSYour Name 			BA_type
171*5113495bSYour Name 
172*5113495bSYour Name 			The starting Sequence number of the (B)ACK bitmap <legal
173*5113495bSYour Name 			 all>
174*5113495bSYour Name */
175*5113495bSYour Name 
176*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_SSN_OFFSET                                          0x0000000000000000
177*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_SSN_LSB                                             16
178*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_SSN_MSB                                             27
179*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_SSN_MASK                                            0x000000000fff0000
180*5113495bSYour Name 
181*5113495bSYour Name 
182*5113495bSYour Name /* Description		RESERVED_0B
183*5113495bSYour Name 
184*5113495bSYour Name 			<legal 0>
185*5113495bSYour Name */
186*5113495bSYour Name 
187*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_RESERVED_0B_OFFSET                                  0x0000000000000000
188*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_RESERVED_0B_LSB                                     28
189*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_RESERVED_0B_MSB                                     31
190*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_RESERVED_0B_MASK                                    0x00000000f0000000
191*5113495bSYour Name 
192*5113495bSYour Name 
193*5113495bSYour Name /* Description		SW_PEER_ID
194*5113495bSYour Name 
195*5113495bSYour Name 			The sw_peer_id for which the bitmap is requested.
196*5113495bSYour Name 
197*5113495bSYour Name 			SW could use this info to link this TLV back to the right
198*5113495bSYour Name 			 TQM queue (if needed)
199*5113495bSYour Name 			<legal all>
200*5113495bSYour Name */
201*5113495bSYour Name 
202*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_SW_PEER_ID_OFFSET                                   0x0000000000000000
203*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_SW_PEER_ID_LSB                                      32
204*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_SW_PEER_ID_MSB                                      47
205*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_SW_PEER_ID_MASK                                     0x0000ffff00000000
206*5113495bSYour Name 
207*5113495bSYour Name 
208*5113495bSYour Name /* Description		RESERVED_1A
209*5113495bSYour Name 
210*5113495bSYour Name 			<legal 0>
211*5113495bSYour Name */
212*5113495bSYour Name 
213*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_RESERVED_1A_OFFSET                                  0x0000000000000000
214*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_RESERVED_1A_LSB                                     48
215*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_RESERVED_1A_MSB                                     63
216*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_RESERVED_1A_MASK                                    0xffff000000000000
217*5113495bSYour Name 
218*5113495bSYour Name 
219*5113495bSYour Name /* Description		BA_BITMAP_31_0
220*5113495bSYour Name 
221*5113495bSYour Name 			Consumer: TQM/FW
222*5113495bSYour Name 			Producer: SW/RXPCU
223*5113495bSYour Name 
224*5113495bSYour Name 			Field only valid in case of the  Ack_ba_status_type indicating:
225*5113495bSYour Name 			BA_type
226*5113495bSYour Name 
227*5113495bSYour Name 			Ba_bitmap_31_0
228*5113495bSYour Name 			<legal all>
229*5113495bSYour Name */
230*5113495bSYour Name 
231*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_BA_BITMAP_31_0_OFFSET                               0x0000000000000008
232*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_BA_BITMAP_31_0_LSB                                  0
233*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_BA_BITMAP_31_0_MSB                                  31
234*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_BA_BITMAP_31_0_MASK                                 0x00000000ffffffff
235*5113495bSYour Name 
236*5113495bSYour Name 
237*5113495bSYour Name /* Description		BA_BITMAP_63_32
238*5113495bSYour Name 
239*5113495bSYour Name 			Consumer: TQM/FW
240*5113495bSYour Name 			Producer: SW/RXPCU
241*5113495bSYour Name 
242*5113495bSYour Name 			Field only valid in case of the  Ack_ba_status_type indicating:
243*5113495bSYour Name 			BA_type
244*5113495bSYour Name 
245*5113495bSYour Name 			Ba_bitmap_63_32
246*5113495bSYour Name 			<legal all>
247*5113495bSYour Name */
248*5113495bSYour Name 
249*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_BA_BITMAP_63_32_OFFSET                              0x0000000000000008
250*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_BA_BITMAP_63_32_LSB                                 32
251*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_BA_BITMAP_63_32_MSB                                 63
252*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_BA_BITMAP_63_32_MASK                                0xffffffff00000000
253*5113495bSYour Name 
254*5113495bSYour Name 
255*5113495bSYour Name /* Description		BA_BITMAP_95_64
256*5113495bSYour Name 
257*5113495bSYour Name 			Consumer: TQM/FW
258*5113495bSYour Name 			Producer: SW/RXPCU
259*5113495bSYour Name 
260*5113495bSYour Name 			Field only valid in case of the  Remove_acked_cmd_type
261*5113495bSYour Name 			indicating:
262*5113495bSYour Name 			remove_Block_Acked_mpdus
263*5113495bSYour Name 
264*5113495bSYour Name 			Ba_bitmap_95_64
265*5113495bSYour Name 			<legal all>
266*5113495bSYour Name */
267*5113495bSYour Name 
268*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_BA_BITMAP_95_64_OFFSET                              0x0000000000000010
269*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_BA_BITMAP_95_64_LSB                                 0
270*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_BA_BITMAP_95_64_MSB                                 31
271*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_BA_BITMAP_95_64_MASK                                0x00000000ffffffff
272*5113495bSYour Name 
273*5113495bSYour Name 
274*5113495bSYour Name /* Description		BA_BITMAP_127_96
275*5113495bSYour Name 
276*5113495bSYour Name 			Consumer: TQM/FW
277*5113495bSYour Name 			Producer: SW/RXPCU
278*5113495bSYour Name 
279*5113495bSYour Name 			Field only valid in case of the  Remove_acked_cmd_type
280*5113495bSYour Name 			indicating:
281*5113495bSYour Name 			remove_Block_Acked_mpdus
282*5113495bSYour Name 
283*5113495bSYour Name 			Ba_bitmap_127_96
284*5113495bSYour Name 			<legal all>
285*5113495bSYour Name */
286*5113495bSYour Name 
287*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_BA_BITMAP_127_96_OFFSET                             0x0000000000000010
288*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_BA_BITMAP_127_96_LSB                                32
289*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_BA_BITMAP_127_96_MSB                                63
290*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_BA_BITMAP_127_96_MASK                               0xffffffff00000000
291*5113495bSYour Name 
292*5113495bSYour Name 
293*5113495bSYour Name /* Description		BA_BITMAP_159_128
294*5113495bSYour Name 
295*5113495bSYour Name 			Consumer: TQM/FW
296*5113495bSYour Name 			Producer: SW/RXPCU
297*5113495bSYour Name 
298*5113495bSYour Name 			Field only valid in case of the  Remove_acked_cmd_type
299*5113495bSYour Name 			indicating:
300*5113495bSYour Name 			remove_Block_Acked_mpdus
301*5113495bSYour Name 
302*5113495bSYour Name 			Ba_bitmap_159_128
303*5113495bSYour Name 			<legal all>
304*5113495bSYour Name */
305*5113495bSYour Name 
306*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_BA_BITMAP_159_128_OFFSET                            0x0000000000000018
307*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_BA_BITMAP_159_128_LSB                               0
308*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_BA_BITMAP_159_128_MSB                               31
309*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_BA_BITMAP_159_128_MASK                              0x00000000ffffffff
310*5113495bSYour Name 
311*5113495bSYour Name 
312*5113495bSYour Name /* Description		BA_BITMAP_191_160
313*5113495bSYour Name 
314*5113495bSYour Name 			Consumer: TQM/FW
315*5113495bSYour Name 			Producer: SW/RXPCU
316*5113495bSYour Name 
317*5113495bSYour Name 			Field only valid in case of the  Remove_acked_cmd_type
318*5113495bSYour Name 			indicating:
319*5113495bSYour Name 			remove_Block_Acked_mpdus
320*5113495bSYour Name 
321*5113495bSYour Name 			Ba_bitmap_191_160
322*5113495bSYour Name 			<legal all>
323*5113495bSYour Name */
324*5113495bSYour Name 
325*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_BA_BITMAP_191_160_OFFSET                            0x0000000000000018
326*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_BA_BITMAP_191_160_LSB                               32
327*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_BA_BITMAP_191_160_MSB                               63
328*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_BA_BITMAP_191_160_MASK                              0xffffffff00000000
329*5113495bSYour Name 
330*5113495bSYour Name 
331*5113495bSYour Name /* Description		BA_BITMAP_223_192
332*5113495bSYour Name 
333*5113495bSYour Name 			Consumer: TQM/FW
334*5113495bSYour Name 			Producer: SW/RXPCU
335*5113495bSYour Name 
336*5113495bSYour Name 			Field only valid in case of the  Remove_acked_cmd_type
337*5113495bSYour Name 			indicating:
338*5113495bSYour Name 			remove_Block_Acked_mpdus
339*5113495bSYour Name 
340*5113495bSYour Name 			Ba_bitmap_223_192
341*5113495bSYour Name 			<legal all>
342*5113495bSYour Name */
343*5113495bSYour Name 
344*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_BA_BITMAP_223_192_OFFSET                            0x0000000000000020
345*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_BA_BITMAP_223_192_LSB                               0
346*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_BA_BITMAP_223_192_MSB                               31
347*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_BA_BITMAP_223_192_MASK                              0x00000000ffffffff
348*5113495bSYour Name 
349*5113495bSYour Name 
350*5113495bSYour Name /* Description		BA_BITMAP_255_224
351*5113495bSYour Name 
352*5113495bSYour Name 			Consumer: TQM/FW
353*5113495bSYour Name 			Producer: SW/RXPCU
354*5113495bSYour Name 
355*5113495bSYour Name 			Field only valid in case of the  Remove_acked_cmd_type
356*5113495bSYour Name 			indicating:
357*5113495bSYour Name 			remove_Block_Acked_mpdus
358*5113495bSYour Name 
359*5113495bSYour Name 			Ba_bitmap_255_224
360*5113495bSYour Name 			<legal all>
361*5113495bSYour Name */
362*5113495bSYour Name 
363*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_BA_BITMAP_255_224_OFFSET                            0x0000000000000020
364*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_BA_BITMAP_255_224_LSB                               32
365*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_BA_BITMAP_255_224_MSB                               63
366*5113495bSYour Name #define TX_FES_STATUS_ACK_OR_BA_BA_BITMAP_255_224_MASK                              0xffffffff00000000
367*5113495bSYour Name 
368*5113495bSYour Name 
369*5113495bSYour Name 
370*5113495bSYour Name #endif   // TX_FES_STATUS_ACK_OR_BA
371