xref: /wlan-driver/qca-wifi-host-cmn/hal/wifi3.0/rh/hal_rh_rx.h (revision 5113495b16420b49004c444715d2daae2066e7dc)
1*5113495bSYour Name /*
2*5113495bSYour Name  * Copyright (c) 2016-2021 The Linux Foundation. All rights reserved.
3*5113495bSYour Name  * Copyright (c) 2021-2023 Qualcomm Innovation Center, Inc. All rights reserved.
4*5113495bSYour Name  *
5*5113495bSYour Name  * Permission to use, copy, modify, and/or distribute this software for
6*5113495bSYour Name  * any purpose with or without fee is hereby granted, provided that the
7*5113495bSYour Name  * above copyright notice and this permission notice appear in all
8*5113495bSYour Name  * copies.
9*5113495bSYour Name  *
10*5113495bSYour Name  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
11*5113495bSYour Name  * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
12*5113495bSYour Name  * WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE
13*5113495bSYour Name  * AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
14*5113495bSYour Name  * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
15*5113495bSYour Name  * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
16*5113495bSYour Name  * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
17*5113495bSYour Name  * PERFORMANCE OF THIS SOFTWARE.
18*5113495bSYour Name  */
19*5113495bSYour Name 
20*5113495bSYour Name #ifndef _HAL_RH_RX_H_
21*5113495bSYour Name #define _HAL_RH_RX_H_
22*5113495bSYour Name 
23*5113495bSYour Name #include <hal_rx.h>
24*5113495bSYour Name 
25*5113495bSYour Name #define HAL_RX_BUF_COOKIE_GET(buff_addr_info)			\
26*5113495bSYour Name 	(_HAL_MS((*_OFFSET_TO_WORD_PTR(buff_addr_info,		\
27*5113495bSYour Name 		BUFFER_ADDR_INFO_1_SW_BUFFER_COOKIE_OFFSET)),	\
28*5113495bSYour Name 		BUFFER_ADDR_INFO_1_SW_BUFFER_COOKIE_MASK,	\
29*5113495bSYour Name 		BUFFER_ADDR_INFO_1_SW_BUFFER_COOKIE_LSB))
30*5113495bSYour Name 
31*5113495bSYour Name #define HAL_RX_BUF_RBM_GET(buff_addr_info)			\
32*5113495bSYour Name 	(_HAL_MS((*_OFFSET_TO_WORD_PTR(buff_addr_info,		\
33*5113495bSYour Name 		BUFFER_ADDR_INFO_1_RETURN_BUFFER_MANAGER_OFFSET)),\
34*5113495bSYour Name 		BUFFER_ADDR_INFO_1_RETURN_BUFFER_MANAGER_MASK,	\
35*5113495bSYour Name 		BUFFER_ADDR_INFO_1_RETURN_BUFFER_MANAGER_LSB))
36*5113495bSYour Name /*
37*5113495bSYour Name  * macro to set the cookie into the rxdma ring entry
38*5113495bSYour Name  */
39*5113495bSYour Name #define HAL_RXDMA_COOKIE_SET(buff_addr_info, cookie) \
40*5113495bSYour Name 		((*(((unsigned int *)buff_addr_info) + \
41*5113495bSYour Name 		(BUFFER_ADDR_INFO_1_SW_BUFFER_COOKIE_OFFSET >> 2))) &= \
42*5113495bSYour Name 		~BUFFER_ADDR_INFO_1_SW_BUFFER_COOKIE_MASK); \
43*5113495bSYour Name 		((*(((unsigned int *)buff_addr_info) + \
44*5113495bSYour Name 		(BUFFER_ADDR_INFO_1_SW_BUFFER_COOKIE_OFFSET >> 2))) |= \
45*5113495bSYour Name 		((cookie) << BUFFER_ADDR_INFO_1_SW_BUFFER_COOKIE_LSB) & \
46*5113495bSYour Name 		BUFFER_ADDR_INFO_1_SW_BUFFER_COOKIE_MASK)
47*5113495bSYour Name 
48*5113495bSYour Name /*
49*5113495bSYour Name  * macro to set the manager into the rxdma ring entry
50*5113495bSYour Name  */
51*5113495bSYour Name #define HAL_RXDMA_MANAGER_SET(buff_addr_info, manager) \
52*5113495bSYour Name 		((*(((unsigned int *)buff_addr_info) + \
53*5113495bSYour Name 		(BUFFER_ADDR_INFO_1_RETURN_BUFFER_MANAGER_OFFSET >> 2))) &= \
54*5113495bSYour Name 		~BUFFER_ADDR_INFO_1_RETURN_BUFFER_MANAGER_MASK); \
55*5113495bSYour Name 		((*(((unsigned int *)buff_addr_info) + \
56*5113495bSYour Name 		(BUFFER_ADDR_INFO_1_RETURN_BUFFER_MANAGER_OFFSET >> 2))) |= \
57*5113495bSYour Name 		((manager) << BUFFER_ADDR_INFO_1_RETURN_BUFFER_MANAGER_LSB) & \
58*5113495bSYour Name 		BUFFER_ADDR_INFO_1_RETURN_BUFFER_MANAGER_MASK)
59*5113495bSYour Name 
60*5113495bSYour Name /*
61*5113495bSYour Name  * NOTE: None of the following _GET macros need a right
62*5113495bSYour Name  * shift by the corresponding _LSB. This is because, they are
63*5113495bSYour Name  * finally taken and "OR'ed" into a single word again.
64*5113495bSYour Name  */
65*5113495bSYour Name 
66*5113495bSYour Name #define HAL_RX_MSDU_CONTINUATION_FLAG_GET(msdu_info_ptr)	\
67*5113495bSYour Name 	((*_OFFSET_TO_WORD_PTR(msdu_info_ptr,			\
68*5113495bSYour Name 		RX_MSDU_DESC_INFO_0_MSDU_CONTINUATION_OFFSET)) & \
69*5113495bSYour Name 		RX_MSDU_DESC_INFO_0_MSDU_CONTINUATION_MASK)
70*5113495bSYour Name 
71*5113495bSYour Name #define HAL_RX_MSDU_SA_IS_VALID_FLAG_GET(msdu_info_ptr)		\
72*5113495bSYour Name 	((*_OFFSET_TO_WORD_PTR(msdu_info_ptr,			\
73*5113495bSYour Name 		RX_MSDU_DESC_INFO_0_SA_IS_VALID_OFFSET)) &	\
74*5113495bSYour Name 		RX_MSDU_DESC_INFO_0_SA_IS_VALID_MASK)
75*5113495bSYour Name 
76*5113495bSYour Name #define HAL_RX_MSDU_SA_IDX_TIMEOUT_FLAG_GET(msdu_info_ptr)	\
77*5113495bSYour Name 	((*_OFFSET_TO_WORD_PTR(msdu_info_ptr,			\
78*5113495bSYour Name 		RX_MSDU_DESC_INFO_0_SA_IDX_TIMEOUT_OFFSET)) &	\
79*5113495bSYour Name 		RX_MSDU_DESC_INFO_0_SA_IDX_TIMEOUT_MASK)
80*5113495bSYour Name 
81*5113495bSYour Name #define HAL_RX_MSDU_DA_IS_VALID_FLAG_GET(msdu_info_ptr)		\
82*5113495bSYour Name 	((*_OFFSET_TO_WORD_PTR(msdu_info_ptr,			\
83*5113495bSYour Name 		RX_MSDU_DESC_INFO_0_DA_IS_VALID_OFFSET)) &	\
84*5113495bSYour Name 		RX_MSDU_DESC_INFO_0_DA_IS_VALID_MASK)
85*5113495bSYour Name 
86*5113495bSYour Name #define HAL_RX_MSDU_DA_IS_MCBC_FLAG_GET(msdu_info_ptr)		\
87*5113495bSYour Name 	((*_OFFSET_TO_WORD_PTR(msdu_info_ptr,			\
88*5113495bSYour Name 		RX_MSDU_DESC_INFO_0_DA_IS_MCBC_OFFSET)) &	\
89*5113495bSYour Name 		RX_MSDU_DESC_INFO_0_DA_IS_MCBC_MASK)
90*5113495bSYour Name 
91*5113495bSYour Name #define HAL_RX_MSDU_DA_IDX_TIMEOUT_FLAG_GET(msdu_info_ptr) \
92*5113495bSYour Name 	((*_OFFSET_TO_WORD_PTR(msdu_info_ptr,			\
93*5113495bSYour Name 		RX_MSDU_DESC_INFO_0_DA_IDX_TIMEOUT_OFFSET)) &	\
94*5113495bSYour Name 		RX_MSDU_DESC_INFO_0_DA_IDX_TIMEOUT_MASK)
95*5113495bSYour Name 
96*5113495bSYour Name /*
97*5113495bSYour Name  * Structures & Macros to obtain fields from the TLV's in the Rx packet
98*5113495bSYour Name  * pre-header.
99*5113495bSYour Name  */
100*5113495bSYour Name 
101*5113495bSYour Name /*
102*5113495bSYour Name  * Every Rx packet starts at an offset from the top of the buffer.
103*5113495bSYour Name  * If the host hasn't subscribed to any specific TLV, there is
104*5113495bSYour Name  * still space reserved for the following TLV's from the start of
105*5113495bSYour Name  * the buffer:
106*5113495bSYour Name  *	-- RX ATTENTION
107*5113495bSYour Name  *	-- RX MPDU START
108*5113495bSYour Name  *	-- RX MSDU START
109*5113495bSYour Name  *	-- RX MSDU END
110*5113495bSYour Name  *	-- RX MPDU END
111*5113495bSYour Name  *	-- RX PACKET HEADER (802.11)
112*5113495bSYour Name  * If the host subscribes to any of the TLV's above, that TLV
113*5113495bSYour Name  * if populated by the HW
114*5113495bSYour Name  */
115*5113495bSYour Name 
116*5113495bSYour Name #define NUM_DWORDS_TAG		1
117*5113495bSYour Name 
118*5113495bSYour Name /* By default the packet header TLV is 128 bytes */
119*5113495bSYour Name #define  NUM_OF_BYTES_RX_802_11_HDR_TLV		128
120*5113495bSYour Name #define  NUM_OF_DWORDS_RX_802_11_HDR_TLV	\
121*5113495bSYour Name 		(NUM_OF_BYTES_RX_802_11_HDR_TLV >> 2)
122*5113495bSYour Name 
123*5113495bSYour Name #define RX_PKT_OFFSET_WORDS					\
124*5113495bSYour Name 	(							\
125*5113495bSYour Name 	 NUM_OF_DWORDS_RX_ATTENTION + NUM_DWORDS_TAG		\
126*5113495bSYour Name 	 NUM_OF_DWORDS_RX_MPDU_START + NUM_DWORDS_TAG		\
127*5113495bSYour Name 	 NUM_OF_DWORDS_RX_MSDU_START + NUM_DWORDS_TAG		\
128*5113495bSYour Name 	 NUM_OF_DWORDS_RX_MSDU_END + NUM_DWORDS_TAG		\
129*5113495bSYour Name 	 NUM_OF_DWORDS_RX_MPDU_END + NUM_DWORDS_TAG		\
130*5113495bSYour Name 	 NUM_OF_DWORDS_RX_802_11_HDR_TLV + NUM_DWORDS_TAG	\
131*5113495bSYour Name 	)
132*5113495bSYour Name 
133*5113495bSYour Name #define RX_PKT_OFFSET_BYTES			\
134*5113495bSYour Name 	(RX_PKT_OFFSET_WORDS << 2)
135*5113495bSYour Name 
136*5113495bSYour Name #define RX_PKT_HDR_TLV_LEN		120
137*5113495bSYour Name 
138*5113495bSYour Name /*
139*5113495bSYour Name  * Each RX descriptor TLV is preceded by 1 DWORD "tag"
140*5113495bSYour Name  */
141*5113495bSYour Name struct rx_attention_tlv {
142*5113495bSYour Name 	uint32_t tag;
143*5113495bSYour Name 	struct rx_attention rx_attn;
144*5113495bSYour Name };
145*5113495bSYour Name 
146*5113495bSYour Name struct rx_mpdu_start_tlv {
147*5113495bSYour Name 	uint32_t tag;
148*5113495bSYour Name 	struct rx_mpdu_start rx_mpdu_start;
149*5113495bSYour Name };
150*5113495bSYour Name 
151*5113495bSYour Name struct rx_msdu_start_tlv {
152*5113495bSYour Name 	uint32_t tag;
153*5113495bSYour Name 	struct rx_msdu_start rx_msdu_start;
154*5113495bSYour Name };
155*5113495bSYour Name 
156*5113495bSYour Name struct rx_msdu_end_tlv {
157*5113495bSYour Name 	uint32_t tag;
158*5113495bSYour Name 	struct rx_msdu_end rx_msdu_end;
159*5113495bSYour Name };
160*5113495bSYour Name 
161*5113495bSYour Name struct rx_mpdu_end_tlv {
162*5113495bSYour Name 	uint32_t tag;
163*5113495bSYour Name 	struct rx_mpdu_end rx_mpdu_end;
164*5113495bSYour Name };
165*5113495bSYour Name 
166*5113495bSYour Name struct rx_pkt_hdr_tlv {
167*5113495bSYour Name 	uint32_t tag;				/* 4 B */
168*5113495bSYour Name 	uint32_t phy_ppdu_id;                   /* 4 B */
169*5113495bSYour Name 	char rx_pkt_hdr[RX_PKT_HDR_TLV_LEN];	/* 120 B */
170*5113495bSYour Name };
171*5113495bSYour Name 
172*5113495bSYour Name /* rx_pkt_tlvs structure should be used to process Data buffers, monitor status
173*5113495bSYour Name  * buffers, monitor destination buffers and monitor descriptor buffers.
174*5113495bSYour Name  */
175*5113495bSYour Name #ifdef RXDMA_OPTIMIZATION
176*5113495bSYour Name /*
177*5113495bSYour Name  * The RX_PADDING_BYTES is required so that the TLV's don't
178*5113495bSYour Name  * spread across the 128 byte boundary
179*5113495bSYour Name  * RXDMA optimization requires:
180*5113495bSYour Name  * 1) MSDU_END & ATTENTION TLV's follow in that order
181*5113495bSYour Name  * 2) TLV's don't span across 128 byte lines
182*5113495bSYour Name  * 3) Rx Buffer is nicely aligned on the 128 byte boundary
183*5113495bSYour Name  */
184*5113495bSYour Name #define RX_PADDING0_BYTES	4
185*5113495bSYour Name #define RX_PADDING1_BYTES	16
186*5113495bSYour Name struct rx_pkt_tlvs {
187*5113495bSYour Name 	struct rx_msdu_end_tlv   msdu_end_tlv;	/*  72 bytes */
188*5113495bSYour Name 	struct rx_attention_tlv  attn_tlv;	/*  16 bytes */
189*5113495bSYour Name 	struct rx_msdu_start_tlv msdu_start_tlv;/*  40 bytes */
190*5113495bSYour Name 	uint8_t rx_padding0[RX_PADDING0_BYTES];	/*   4 bytes */
191*5113495bSYour Name 	struct rx_mpdu_start_tlv mpdu_start_tlv;/*  96 bytes */
192*5113495bSYour Name 	struct rx_mpdu_end_tlv   mpdu_end_tlv;	/*  12 bytes */
193*5113495bSYour Name 	uint8_t rx_padding1[RX_PADDING1_BYTES];	/*  16 bytes */
194*5113495bSYour Name #ifndef NO_RX_PKT_HDR_TLV
195*5113495bSYour Name 	struct rx_pkt_hdr_tlv	 pkt_hdr_tlv;	/* 128 bytes */
196*5113495bSYour Name #endif
197*5113495bSYour Name };
198*5113495bSYour Name #else /* RXDMA_OPTIMIZATION */
199*5113495bSYour Name struct rx_pkt_tlvs {
200*5113495bSYour Name 	struct rx_attention_tlv  attn_tlv;
201*5113495bSYour Name 	struct rx_mpdu_start_tlv mpdu_start_tlv;
202*5113495bSYour Name 	struct rx_msdu_start_tlv msdu_start_tlv;
203*5113495bSYour Name 	struct rx_msdu_end_tlv   msdu_end_tlv;
204*5113495bSYour Name 	struct rx_mpdu_end_tlv   mpdu_end_tlv;
205*5113495bSYour Name 	struct rx_pkt_hdr_tlv	 pkt_hdr_tlv;
206*5113495bSYour Name };
207*5113495bSYour Name #endif /* RXDMA_OPTIMIZATION */
208*5113495bSYour Name 
209*5113495bSYour Name /* rx_mon_pkt_tlvs structure should be used to process monitor data buffers */
210*5113495bSYour Name #ifdef RXDMA_OPTIMIZATION
211*5113495bSYour Name struct rx_mon_pkt_tlvs {
212*5113495bSYour Name 	struct rx_msdu_end_tlv   msdu_end_tlv;	/*  72 bytes */
213*5113495bSYour Name 	struct rx_attention_tlv  attn_tlv;	/*  16 bytes */
214*5113495bSYour Name 	struct rx_msdu_start_tlv msdu_start_tlv;/*  40 bytes */
215*5113495bSYour Name 	uint8_t rx_padding0[RX_PADDING0_BYTES];	/*   4 bytes */
216*5113495bSYour Name 	struct rx_mpdu_start_tlv mpdu_start_tlv;/*  96 bytes */
217*5113495bSYour Name 	struct rx_mpdu_end_tlv   mpdu_end_tlv;	/*  12 bytes */
218*5113495bSYour Name 	uint8_t rx_padding1[RX_PADDING1_BYTES];	/*  16 bytes */
219*5113495bSYour Name 	struct rx_pkt_hdr_tlv	 pkt_hdr_tlv;	/* 128 bytes */
220*5113495bSYour Name };
221*5113495bSYour Name #else /* RXDMA_OPTIMIZATION */
222*5113495bSYour Name struct rx_mon_pkt_tlvs {
223*5113495bSYour Name 	struct rx_attention_tlv  attn_tlv;
224*5113495bSYour Name 	struct rx_mpdu_start_tlv mpdu_start_tlv;
225*5113495bSYour Name 	struct rx_msdu_start_tlv msdu_start_tlv;
226*5113495bSYour Name 	struct rx_msdu_end_tlv   msdu_end_tlv;
227*5113495bSYour Name 	struct rx_mpdu_end_tlv   mpdu_end_tlv;
228*5113495bSYour Name 	struct rx_pkt_hdr_tlv	 pkt_hdr_tlv;
229*5113495bSYour Name };
230*5113495bSYour Name #endif
231*5113495bSYour Name 
232*5113495bSYour Name #define SIZE_OF_MONITOR_TLV sizeof(struct rx_mon_pkt_tlvs)
233*5113495bSYour Name #define SIZE_OF_DATA_RX_TLV sizeof(struct rx_pkt_tlvs)
234*5113495bSYour Name 
235*5113495bSYour Name #define RX_PKT_TLVS_LEN		SIZE_OF_DATA_RX_TLV
236*5113495bSYour Name 
237*5113495bSYour Name #define RX_PKT_TLV_OFFSET(field) qdf_offsetof(struct rx_pkt_tlvs, field)
238*5113495bSYour Name 
239*5113495bSYour Name #define HAL_RX_PKT_TLV_MPDU_START_OFFSET(hal_soc) \
240*5113495bSYour Name 					RX_PKT_TLV_OFFSET(mpdu_start_tlv)
241*5113495bSYour Name #define HAL_RX_PKT_TLV_MPDU_END_OFFSET(hal_soc) RX_PKT_TLV_OFFSET(mpdu_end_tlv)
242*5113495bSYour Name #define HAL_RX_PKT_TLV_MSDU_START_OFFSET(hal_soc) \
243*5113495bSYour Name 					RX_PKT_TLV_OFFSET(msdu_start_tlv)
244*5113495bSYour Name #define HAL_RX_PKT_TLV_MSDU_END_OFFSET(hal_soc) RX_PKT_TLV_OFFSET(msdu_end_tlv)
245*5113495bSYour Name #define HAL_RX_PKT_TLV_ATTN_OFFSET(hal_soc) RX_PKT_TLV_OFFSET(attn_tlv)
246*5113495bSYour Name #define HAL_RX_PKT_TLV_PKT_HDR_OFFSET(hal_soc) RX_PKT_TLV_OFFSET(pkt_hdr_tlv)
247*5113495bSYour Name 
248*5113495bSYour Name /**
249*5113495bSYour Name  * hal_rx_get_pkt_tlvs(): Function to retrieve pkt tlvs from nbuf
250*5113495bSYour Name  *
251*5113495bSYour Name  * @rx_buf_start: Pointer to data buffer field
252*5113495bSYour Name  *
253*5113495bSYour Name  * Returns: pointer to rx_pkt_tlvs
254*5113495bSYour Name  */
255*5113495bSYour Name static inline
hal_rx_get_pkt_tlvs(uint8_t * rx_buf_start)256*5113495bSYour Name struct rx_pkt_tlvs *hal_rx_get_pkt_tlvs(uint8_t *rx_buf_start)
257*5113495bSYour Name {
258*5113495bSYour Name 	return (struct rx_pkt_tlvs *)rx_buf_start;
259*5113495bSYour Name }
260*5113495bSYour Name 
261*5113495bSYour Name /**
262*5113495bSYour Name  * hal_rx_get_mpdu_info(): Function to retrieve mpdu info from pkt tlvs
263*5113495bSYour Name  *
264*5113495bSYour Name  * @pkt_tlvs: Pointer to pkt_tlvs
265*5113495bSYour Name  * Returns: pointer to rx_mpdu_info structure
266*5113495bSYour Name  */
267*5113495bSYour Name static inline
hal_rx_get_mpdu_info(struct rx_pkt_tlvs * pkt_tlvs)268*5113495bSYour Name struct rx_mpdu_info *hal_rx_get_mpdu_info(struct rx_pkt_tlvs *pkt_tlvs)
269*5113495bSYour Name {
270*5113495bSYour Name 	return &pkt_tlvs->mpdu_start_tlv.rx_mpdu_start.rx_mpdu_info_details;
271*5113495bSYour Name }
272*5113495bSYour Name 
273*5113495bSYour Name /**
274*5113495bSYour Name  * hal_rx_mon_dest_get_buffer_info_from_tlv(): Retrieve mon dest frame info
275*5113495bSYour Name  * from the reserved bytes of rx_tlv_hdr.
276*5113495bSYour Name  * @buf: start of rx_tlv_hdr
277*5113495bSYour Name  * @buf_info: hal_rx_mon_dest_buf_info structure
278*5113495bSYour Name  *
279*5113495bSYour Name  * Return: void
280*5113495bSYour Name  */
hal_rx_mon_dest_get_buffer_info_from_tlv(uint8_t * buf,struct hal_rx_mon_dest_buf_info * buf_info)281*5113495bSYour Name static inline void hal_rx_mon_dest_get_buffer_info_from_tlv(
282*5113495bSYour Name 				uint8_t *buf,
283*5113495bSYour Name 				struct hal_rx_mon_dest_buf_info *buf_info)
284*5113495bSYour Name {
285*5113495bSYour Name 	struct rx_pkt_tlvs *pkt_tlvs = (struct rx_pkt_tlvs *)buf;
286*5113495bSYour Name 
287*5113495bSYour Name 	qdf_mem_copy(buf_info, pkt_tlvs->rx_padding0,
288*5113495bSYour Name 		     sizeof(struct hal_rx_mon_dest_buf_info));
289*5113495bSYour Name }
290*5113495bSYour Name 
291*5113495bSYour Name /*
292*5113495bSYour Name  * Get msdu_done bit from the RX_ATTENTION TLV
293*5113495bSYour Name  */
294*5113495bSYour Name #define HAL_RX_ATTN_MSDU_DONE_GET(_rx_attn)		\
295*5113495bSYour Name 	(_HAL_MS((*_OFFSET_TO_WORD_PTR(_rx_attn,	\
296*5113495bSYour Name 		RX_ATTENTION_2_MSDU_DONE_OFFSET)),	\
297*5113495bSYour Name 		RX_ATTENTION_2_MSDU_DONE_MASK,		\
298*5113495bSYour Name 		RX_ATTENTION_2_MSDU_DONE_LSB))
299*5113495bSYour Name 
300*5113495bSYour Name #define HAL_RX_ATTN_FIRST_MPDU_GET(_rx_attn)		\
301*5113495bSYour Name 	(_HAL_MS((*_OFFSET_TO_WORD_PTR(_rx_attn,	\
302*5113495bSYour Name 		RX_ATTENTION_1_FIRST_MPDU_OFFSET)),	\
303*5113495bSYour Name 		RX_ATTENTION_1_FIRST_MPDU_MASK,		\
304*5113495bSYour Name 		RX_ATTENTION_1_FIRST_MPDU_LSB))
305*5113495bSYour Name 
306*5113495bSYour Name #define HAL_RX_ATTN_TCP_UDP_CKSUM_FAIL_GET(_rx_attn)		\
307*5113495bSYour Name 	(_HAL_MS((*_OFFSET_TO_WORD_PTR(_rx_attn,		\
308*5113495bSYour Name 		RX_ATTENTION_1_TCP_UDP_CHKSUM_FAIL_OFFSET)),	\
309*5113495bSYour Name 		RX_ATTENTION_1_TCP_UDP_CHKSUM_FAIL_MASK,	\
310*5113495bSYour Name 		RX_ATTENTION_1_TCP_UDP_CHKSUM_FAIL_LSB))
311*5113495bSYour Name 
312*5113495bSYour Name /*
313*5113495bSYour Name  * hal_rx_attn_tcp_udp_cksum_fail_get(): get tcp_udp cksum fail bit
314*5113495bSYour Name  * from rx attention
315*5113495bSYour Name  * @buf: pointer to rx_pkt_tlvs
316*5113495bSYour Name  *
317*5113495bSYour Name  * Return: tcp_udp_cksum_fail
318*5113495bSYour Name  */
319*5113495bSYour Name static inline bool
hal_rx_attn_tcp_udp_cksum_fail_get(uint8_t * buf)320*5113495bSYour Name hal_rx_attn_tcp_udp_cksum_fail_get(uint8_t *buf)
321*5113495bSYour Name {
322*5113495bSYour Name 	struct rx_pkt_tlvs *pkt_tlvs = (struct rx_pkt_tlvs *)buf;
323*5113495bSYour Name 	struct rx_attention *rx_attn = &pkt_tlvs->attn_tlv.rx_attn;
324*5113495bSYour Name 	uint8_t tcp_udp_cksum_fail;
325*5113495bSYour Name 
326*5113495bSYour Name 	tcp_udp_cksum_fail = HAL_RX_ATTN_TCP_UDP_CKSUM_FAIL_GET(rx_attn);
327*5113495bSYour Name 
328*5113495bSYour Name 	return !!tcp_udp_cksum_fail;
329*5113495bSYour Name }
330*5113495bSYour Name 
331*5113495bSYour Name #define HAL_RX_ATTN_IP_CKSUM_FAIL_GET(_rx_attn)		\
332*5113495bSYour Name 	(_HAL_MS((*_OFFSET_TO_WORD_PTR(_rx_attn,	\
333*5113495bSYour Name 		RX_ATTENTION_1_IP_CHKSUM_FAIL_OFFSET)),	\
334*5113495bSYour Name 		RX_ATTENTION_1_IP_CHKSUM_FAIL_MASK,	\
335*5113495bSYour Name 		RX_ATTENTION_1_IP_CHKSUM_FAIL_LSB))
336*5113495bSYour Name 
337*5113495bSYour Name /*
338*5113495bSYour Name  * hal_rx_attn_ip_cksum_fail_get(): get ip cksum fail bit
339*5113495bSYour Name  * from rx attention
340*5113495bSYour Name  * @buf: pointer to rx_pkt_tlvs
341*5113495bSYour Name  *
342*5113495bSYour Name  * Return: ip_cksum_fail
343*5113495bSYour Name  */
344*5113495bSYour Name static inline bool
hal_rx_attn_ip_cksum_fail_get(uint8_t * buf)345*5113495bSYour Name hal_rx_attn_ip_cksum_fail_get(uint8_t *buf)
346*5113495bSYour Name {
347*5113495bSYour Name 	struct rx_pkt_tlvs *pkt_tlvs = (struct rx_pkt_tlvs *)buf;
348*5113495bSYour Name 	struct rx_attention *rx_attn = &pkt_tlvs->attn_tlv.rx_attn;
349*5113495bSYour Name 	uint8_t	 ip_cksum_fail;
350*5113495bSYour Name 
351*5113495bSYour Name 	ip_cksum_fail = HAL_RX_ATTN_IP_CKSUM_FAIL_GET(rx_attn);
352*5113495bSYour Name 
353*5113495bSYour Name 	return !!ip_cksum_fail;
354*5113495bSYour Name }
355*5113495bSYour Name 
356*5113495bSYour Name #define HAL_RX_ATTN_PHY_PPDU_ID_GET(_rx_attn)		\
357*5113495bSYour Name 	(_HAL_MS((*_OFFSET_TO_WORD_PTR(_rx_attn,	\
358*5113495bSYour Name 		RX_ATTENTION_0_PHY_PPDU_ID_OFFSET)),	\
359*5113495bSYour Name 		RX_ATTENTION_0_PHY_PPDU_ID_MASK,	\
360*5113495bSYour Name 		RX_ATTENTION_0_PHY_PPDU_ID_LSB))
361*5113495bSYour Name 
362*5113495bSYour Name #define HAL_RX_ATTN_CCE_MATCH_GET(_rx_attn)		\
363*5113495bSYour Name 	(_HAL_MS((*_OFFSET_TO_WORD_PTR(_rx_attn,	\
364*5113495bSYour Name 		RX_ATTENTION_1_CCE_MATCH_OFFSET)),		\
365*5113495bSYour Name 		RX_ATTENTION_1_CCE_MATCH_MASK,			\
366*5113495bSYour Name 		RX_ATTENTION_1_CCE_MATCH_LSB))
367*5113495bSYour Name 
368*5113495bSYour Name /*
369*5113495bSYour Name  * hal_rx_msdu_cce_match_get_rh(): get CCE match bit
370*5113495bSYour Name  * from rx attention
371*5113495bSYour Name  * @buf: pointer to rx_pkt_tlvs
372*5113495bSYour Name  * Return: CCE match value
373*5113495bSYour Name  */
374*5113495bSYour Name static inline bool
hal_rx_msdu_cce_match_get_rh(uint8_t * buf)375*5113495bSYour Name hal_rx_msdu_cce_match_get_rh(uint8_t *buf)
376*5113495bSYour Name {
377*5113495bSYour Name 	struct rx_pkt_tlvs *pkt_tlvs = (struct rx_pkt_tlvs *)buf;
378*5113495bSYour Name 	struct rx_attention *rx_attn = &pkt_tlvs->attn_tlv.rx_attn;
379*5113495bSYour Name 	uint8_t cce_match_val;
380*5113495bSYour Name 
381*5113495bSYour Name 	cce_match_val = HAL_RX_ATTN_CCE_MATCH_GET(rx_attn);
382*5113495bSYour Name 	return !!cce_match_val;
383*5113495bSYour Name }
384*5113495bSYour Name 
385*5113495bSYour Name /*
386*5113495bSYour Name  * Get peer_meta_data from RX_MPDU_INFO within RX_MPDU_START
387*5113495bSYour Name  */
388*5113495bSYour Name #define HAL_RX_MPDU_PEER_META_DATA_GET(_rx_mpdu_info)	\
389*5113495bSYour Name 	(_HAL_MS((*_OFFSET_TO_WORD_PTR(_rx_mpdu_info,	\
390*5113495bSYour Name 		RX_MPDU_INFO_8_PEER_META_DATA_OFFSET)),	\
391*5113495bSYour Name 		RX_MPDU_INFO_8_PEER_META_DATA_MASK,	\
392*5113495bSYour Name 		RX_MPDU_INFO_8_PEER_META_DATA_LSB))
393*5113495bSYour Name 
394*5113495bSYour Name static inline uint32_t
hal_rx_mpdu_peer_meta_data_get_rh(uint8_t * buf)395*5113495bSYour Name hal_rx_mpdu_peer_meta_data_get_rh(uint8_t *buf)
396*5113495bSYour Name {
397*5113495bSYour Name 	struct rx_pkt_tlvs *pkt_tlvs = (struct rx_pkt_tlvs *)buf;
398*5113495bSYour Name 	struct rx_mpdu_start *mpdu_start =
399*5113495bSYour Name 				 &pkt_tlvs->mpdu_start_tlv.rx_mpdu_start;
400*5113495bSYour Name 
401*5113495bSYour Name 	struct rx_mpdu_info *mpdu_info = &mpdu_start->rx_mpdu_info_details;
402*5113495bSYour Name 	uint32_t peer_meta_data;
403*5113495bSYour Name 
404*5113495bSYour Name 	peer_meta_data = HAL_RX_MPDU_PEER_META_DATA_GET(mpdu_info);
405*5113495bSYour Name 
406*5113495bSYour Name 	return peer_meta_data;
407*5113495bSYour Name }
408*5113495bSYour Name 
409*5113495bSYour Name #define HAL_RX_MPDU_INFO_AMPDU_FLAG_GET(_rx_mpdu_info)	\
410*5113495bSYour Name 	(_HAL_MS((*_OFFSET_TO_WORD_PTR(_rx_mpdu_info,	\
411*5113495bSYour Name 		RX_MPDU_INFO_12_AMPDU_FLAG_OFFSET)),	\
412*5113495bSYour Name 		RX_MPDU_INFO_12_AMPDU_FLAG_MASK,	\
413*5113495bSYour Name 		RX_MPDU_INFO_12_AMPDU_FLAG_LSB))
414*5113495bSYour Name 
415*5113495bSYour Name /*
416*5113495bSYour Name  * LRO information needed from the TLVs
417*5113495bSYour Name  */
418*5113495bSYour Name #define HAL_RX_TLV_GET_LRO_ELIGIBLE(buf) \
419*5113495bSYour Name 	(_HAL_MS( \
420*5113495bSYour Name 		 (*_OFFSET_TO_WORD_PTR(&(((struct rx_pkt_tlvs *)(buf))->\
421*5113495bSYour Name 			 msdu_end_tlv.rx_msdu_end), \
422*5113495bSYour Name 			 RX_MSDU_END_9_LRO_ELIGIBLE_OFFSET)), \
423*5113495bSYour Name 		RX_MSDU_END_9_LRO_ELIGIBLE_MASK, \
424*5113495bSYour Name 		RX_MSDU_END_9_LRO_ELIGIBLE_LSB))
425*5113495bSYour Name 
426*5113495bSYour Name #define HAL_RX_TLV_GET_TCP_ACK(buf) \
427*5113495bSYour Name 	(_HAL_MS( \
428*5113495bSYour Name 		 (*_OFFSET_TO_WORD_PTR(&(((struct rx_pkt_tlvs *)(buf))->\
429*5113495bSYour Name 			 msdu_end_tlv.rx_msdu_end), \
430*5113495bSYour Name 			 RX_MSDU_END_8_TCP_ACK_NUMBER_OFFSET)), \
431*5113495bSYour Name 		RX_MSDU_END_8_TCP_ACK_NUMBER_MASK, \
432*5113495bSYour Name 		RX_MSDU_END_8_TCP_ACK_NUMBER_LSB))
433*5113495bSYour Name 
434*5113495bSYour Name #define HAL_RX_TLV_GET_TCP_SEQ(buf) \
435*5113495bSYour Name 	(_HAL_MS( \
436*5113495bSYour Name 		 (*_OFFSET_TO_WORD_PTR(&(((struct rx_pkt_tlvs *)(buf))->\
437*5113495bSYour Name 			 msdu_end_tlv.rx_msdu_end), \
438*5113495bSYour Name 			 RX_MSDU_END_7_TCP_SEQ_NUMBER_OFFSET)), \
439*5113495bSYour Name 		RX_MSDU_END_7_TCP_SEQ_NUMBER_MASK, \
440*5113495bSYour Name 		RX_MSDU_END_7_TCP_SEQ_NUMBER_LSB))
441*5113495bSYour Name 
442*5113495bSYour Name #define HAL_RX_TLV_GET_TCP_WIN(buf) \
443*5113495bSYour Name 	(_HAL_MS( \
444*5113495bSYour Name 		 (*_OFFSET_TO_WORD_PTR(&(((struct rx_pkt_tlvs *)(buf))->\
445*5113495bSYour Name 			 msdu_end_tlv.rx_msdu_end), \
446*5113495bSYour Name 			 RX_MSDU_END_9_WINDOW_SIZE_OFFSET)), \
447*5113495bSYour Name 		RX_MSDU_END_9_WINDOW_SIZE_MASK, \
448*5113495bSYour Name 		RX_MSDU_END_9_WINDOW_SIZE_LSB))
449*5113495bSYour Name 
450*5113495bSYour Name #define HAL_RX_TLV_GET_TCP_PURE_ACK(buf) \
451*5113495bSYour Name 	(_HAL_MS( \
452*5113495bSYour Name 		 (*_OFFSET_TO_WORD_PTR(&(((struct rx_pkt_tlvs *)(buf))->\
453*5113495bSYour Name 			 msdu_start_tlv.rx_msdu_start), \
454*5113495bSYour Name 			 RX_MSDU_START_2_TCP_ONLY_ACK_OFFSET)), \
455*5113495bSYour Name 		RX_MSDU_START_2_TCP_ONLY_ACK_MASK, \
456*5113495bSYour Name 		RX_MSDU_START_2_TCP_ONLY_ACK_LSB))
457*5113495bSYour Name 
458*5113495bSYour Name #define HAL_RX_TLV_GET_TCP_PROTO(buf) \
459*5113495bSYour Name 	(_HAL_MS( \
460*5113495bSYour Name 		 (*_OFFSET_TO_WORD_PTR(&(((struct rx_pkt_tlvs *)(buf))->\
461*5113495bSYour Name 			 msdu_start_tlv.rx_msdu_start), \
462*5113495bSYour Name 			 RX_MSDU_START_2_TCP_PROTO_OFFSET)), \
463*5113495bSYour Name 		RX_MSDU_START_2_TCP_PROTO_MASK, \
464*5113495bSYour Name 		RX_MSDU_START_2_TCP_PROTO_LSB))
465*5113495bSYour Name 
466*5113495bSYour Name #define HAL_RX_TLV_GET_UDP_PROTO(buf) \
467*5113495bSYour Name 	(_HAL_MS( \
468*5113495bSYour Name 		 (*_OFFSET_TO_WORD_PTR(&(((struct rx_pkt_tlvs *)(buf))->\
469*5113495bSYour Name 			 msdu_start_tlv.rx_msdu_start), \
470*5113495bSYour Name 			 RX_MSDU_START_2_UDP_PROTO_OFFSET)), \
471*5113495bSYour Name 		RX_MSDU_START_2_UDP_PROTO_MASK, \
472*5113495bSYour Name 		RX_MSDU_START_2_UDP_PROTO_LSB))
473*5113495bSYour Name 
474*5113495bSYour Name #define HAL_RX_TLV_GET_IPV6(buf) \
475*5113495bSYour Name 	(_HAL_MS( \
476*5113495bSYour Name 		 (*_OFFSET_TO_WORD_PTR(&(((struct rx_pkt_tlvs *)(buf))->\
477*5113495bSYour Name 			 msdu_start_tlv.rx_msdu_start), \
478*5113495bSYour Name 			 RX_MSDU_START_2_IPV6_PROTO_OFFSET)), \
479*5113495bSYour Name 		RX_MSDU_START_2_IPV6_PROTO_MASK, \
480*5113495bSYour Name 		RX_MSDU_START_2_IPV6_PROTO_LSB))
481*5113495bSYour Name 
482*5113495bSYour Name #define HAL_RX_TLV_GET_IP_OFFSET(buf) \
483*5113495bSYour Name 	(_HAL_MS( \
484*5113495bSYour Name 		 (*_OFFSET_TO_WORD_PTR(&(((struct rx_pkt_tlvs *)(buf))->\
485*5113495bSYour Name 			 msdu_start_tlv.rx_msdu_start), \
486*5113495bSYour Name 			 RX_MSDU_START_1_L3_OFFSET_OFFSET)), \
487*5113495bSYour Name 		RX_MSDU_START_1_L3_OFFSET_MASK, \
488*5113495bSYour Name 		RX_MSDU_START_1_L3_OFFSET_LSB))
489*5113495bSYour Name 
490*5113495bSYour Name #define HAL_RX_TLV_GET_TCP_OFFSET(buf) \
491*5113495bSYour Name 	(_HAL_MS( \
492*5113495bSYour Name 		 (*_OFFSET_TO_WORD_PTR(&(((struct rx_pkt_tlvs *)(buf))->\
493*5113495bSYour Name 			 msdu_start_tlv.rx_msdu_start), \
494*5113495bSYour Name 			 RX_MSDU_START_1_L4_OFFSET_OFFSET)), \
495*5113495bSYour Name 		RX_MSDU_START_1_L4_OFFSET_MASK, \
496*5113495bSYour Name 		RX_MSDU_START_1_L4_OFFSET_LSB))
497*5113495bSYour Name 
498*5113495bSYour Name #define HAL_RX_TLV_GET_FLOW_ID_TOEPLITZ(buf) \
499*5113495bSYour Name 	(_HAL_MS( \
500*5113495bSYour Name 		 (*_OFFSET_TO_WORD_PTR(&(((struct rx_pkt_tlvs *)(buf))->\
501*5113495bSYour Name 			 msdu_start_tlv.rx_msdu_start), \
502*5113495bSYour Name 			 RX_MSDU_START_4_FLOW_ID_TOEPLITZ_OFFSET)), \
503*5113495bSYour Name 		RX_MSDU_START_4_FLOW_ID_TOEPLITZ_MASK, \
504*5113495bSYour Name 		RX_MSDU_START_4_FLOW_ID_TOEPLITZ_LSB))
505*5113495bSYour Name 
506*5113495bSYour Name #define HAL_RX_MSDU_START_MSDU_LEN_GET(_rx_msdu_start)		\
507*5113495bSYour Name 	(_HAL_MS((*_OFFSET_TO_WORD_PTR(_rx_msdu_start,		\
508*5113495bSYour Name 		RX_MSDU_START_1_MSDU_LENGTH_OFFSET)),		\
509*5113495bSYour Name 		RX_MSDU_START_1_MSDU_LENGTH_MASK,		\
510*5113495bSYour Name 		RX_MSDU_START_1_MSDU_LENGTH_LSB))
511*5113495bSYour Name 
512*5113495bSYour Name #define HAL_RX_MSDU_START_BW_GET(_rx_msdu_start)     \
513*5113495bSYour Name 	(_HAL_MS((*_OFFSET_TO_WORD_PTR((_rx_msdu_start),\
514*5113495bSYour Name 	RX_MSDU_START_5_RECEIVE_BANDWIDTH_OFFSET)), \
515*5113495bSYour Name 	RX_MSDU_START_5_RECEIVE_BANDWIDTH_MASK,     \
516*5113495bSYour Name 	RX_MSDU_START_5_RECEIVE_BANDWIDTH_LSB))
517*5113495bSYour Name 
518*5113495bSYour Name #define HAL_RX_MSDU_START_SGI_GET(_rx_msdu_start)	\
519*5113495bSYour Name 	(_HAL_MS((*_OFFSET_TO_WORD_PTR((_rx_msdu_start),\
520*5113495bSYour Name 		RX_MSDU_START_5_SGI_OFFSET)),		\
521*5113495bSYour Name 		RX_MSDU_START_5_SGI_MASK,		\
522*5113495bSYour Name 		RX_MSDU_START_5_SGI_LSB))
523*5113495bSYour Name 
524*5113495bSYour Name #define HAL_RX_MSDU_START_RATE_MCS_GET(_rx_msdu_start)	\
525*5113495bSYour Name 	(_HAL_MS((*_OFFSET_TO_WORD_PTR((_rx_msdu_start),\
526*5113495bSYour Name 		RX_MSDU_START_5_RATE_MCS_OFFSET)),	\
527*5113495bSYour Name 		RX_MSDU_START_5_RATE_MCS_MASK,		\
528*5113495bSYour Name 		RX_MSDU_START_5_RATE_MCS_LSB))
529*5113495bSYour Name 
530*5113495bSYour Name #define HAL_RX_ATTN_DECRYPT_STATUS_GET(_rx_attn)		\
531*5113495bSYour Name 	(_HAL_MS((*_OFFSET_TO_WORD_PTR(_rx_attn,		\
532*5113495bSYour Name 		RX_ATTENTION_2_DECRYPT_STATUS_CODE_OFFSET)),	\
533*5113495bSYour Name 		RX_ATTENTION_2_DECRYPT_STATUS_CODE_MASK,	\
534*5113495bSYour Name 		RX_ATTENTION_2_DECRYPT_STATUS_CODE_LSB))
535*5113495bSYour Name 
536*5113495bSYour Name /*
537*5113495bSYour Name  * Get key index from RX_MSDU_END
538*5113495bSYour Name  */
539*5113495bSYour Name #define HAL_RX_MSDU_END_KEYID_OCTET_GET(_rx_msdu_end)	\
540*5113495bSYour Name 	(_HAL_MS((*_OFFSET_TO_WORD_PTR(_rx_msdu_end,	\
541*5113495bSYour Name 		RX_MSDU_END_2_KEY_ID_OCTET_OFFSET)),	\
542*5113495bSYour Name 		RX_MSDU_END_2_KEY_ID_OCTET_MASK,	\
543*5113495bSYour Name 		RX_MSDU_END_2_KEY_ID_OCTET_LSB))
544*5113495bSYour Name 
545*5113495bSYour Name #define HAL_RX_MSDU_START_RSSI_GET(_rx_msdu_start)	\
546*5113495bSYour Name 	(_HAL_MS((*_OFFSET_TO_WORD_PTR(_rx_msdu_start,  \
547*5113495bSYour Name 		RX_MSDU_START_5_USER_RSSI_OFFSET)),	\
548*5113495bSYour Name 		RX_MSDU_START_5_USER_RSSI_MASK,		\
549*5113495bSYour Name 		RX_MSDU_START_5_USER_RSSI_LSB))
550*5113495bSYour Name 
551*5113495bSYour Name #define HAL_RX_MSDU_START_FREQ_GET(_rx_msdu_start)		\
552*5113495bSYour Name 	(_HAL_MS((*_OFFSET_TO_WORD_PTR(_rx_msdu_start,		\
553*5113495bSYour Name 		RX_MSDU_START_7_SW_PHY_META_DATA_OFFSET)),      \
554*5113495bSYour Name 		RX_MSDU_START_7_SW_PHY_META_DATA_MASK,		\
555*5113495bSYour Name 		RX_MSDU_START_7_SW_PHY_META_DATA_LSB))
556*5113495bSYour Name 
557*5113495bSYour Name #define HAL_RX_MSDU_START_PKT_TYPE_GET(_rx_msdu_start)	\
558*5113495bSYour Name 	(_HAL_MS((*_OFFSET_TO_WORD_PTR(_rx_msdu_start,  \
559*5113495bSYour Name 		RX_MSDU_START_5_PKT_TYPE_OFFSET)),      \
560*5113495bSYour Name 		RX_MSDU_START_5_PKT_TYPE_MASK,		\
561*5113495bSYour Name 		RX_MSDU_START_5_PKT_TYPE_LSB))
562*5113495bSYour Name 
563*5113495bSYour Name #define HAL_RX_MPDU_AD4_31_0_GET(_rx_mpdu_info)	\
564*5113495bSYour Name 	(_HAL_MS((*_OFFSET_TO_WORD_PTR(_rx_mpdu_info, \
565*5113495bSYour Name 		RX_MPDU_INFO_20_MAC_ADDR_AD4_31_0_OFFSET)), \
566*5113495bSYour Name 		RX_MPDU_INFO_20_MAC_ADDR_AD4_31_0_MASK,	\
567*5113495bSYour Name 		RX_MPDU_INFO_20_MAC_ADDR_AD4_31_0_LSB))
568*5113495bSYour Name 
569*5113495bSYour Name #define HAL_RX_MPDU_AD4_47_32_GET(_rx_mpdu_info)	\
570*5113495bSYour Name 	(_HAL_MS((*_OFFSET_TO_WORD_PTR(_rx_mpdu_info, \
571*5113495bSYour Name 		RX_MPDU_INFO_21_MAC_ADDR_AD4_47_32_OFFSET)), \
572*5113495bSYour Name 		RX_MPDU_INFO_21_MAC_ADDR_AD4_47_32_MASK,	\
573*5113495bSYour Name 		RX_MPDU_INFO_21_MAC_ADDR_AD4_47_32_LSB))
574*5113495bSYour Name 
575*5113495bSYour Name /*******************************************************************************
576*5113495bSYour Name  * RX ERROR APIS
577*5113495bSYour Name  ******************************************************************************/
578*5113495bSYour Name 
579*5113495bSYour Name #define HAL_RX_MPDU_END_DECRYPT_ERR_GET(_rx_mpdu_end)	\
580*5113495bSYour Name 	(_HAL_MS((*_OFFSET_TO_WORD_PTR((_rx_mpdu_end),\
581*5113495bSYour Name 		RX_MPDU_END_1_RX_IN_TX_DECRYPT_BYP_OFFSET)),	\
582*5113495bSYour Name 		RX_MPDU_END_1_RX_IN_TX_DECRYPT_BYP_MASK,	\
583*5113495bSYour Name 		RX_MPDU_END_1_RX_IN_TX_DECRYPT_BYP_LSB))
584*5113495bSYour Name 
585*5113495bSYour Name #define HAL_RX_MPDU_END_MIC_ERR_GET(_rx_mpdu_end)	\
586*5113495bSYour Name 	(_HAL_MS((*_OFFSET_TO_WORD_PTR((_rx_mpdu_end),\
587*5113495bSYour Name 		RX_MPDU_END_1_TKIP_MIC_ERR_OFFSET)),	\
588*5113495bSYour Name 		RX_MPDU_END_1_TKIP_MIC_ERR_MASK,	\
589*5113495bSYour Name 		RX_MPDU_END_1_TKIP_MIC_ERR_LSB))
590*5113495bSYour Name 
591*5113495bSYour Name #define HAL_RX_MPDU_GET_FRAME_CONTROL_FIELD(_rx_mpdu_info)	\
592*5113495bSYour Name 	(_HAL_MS((*_OFFSET_TO_WORD_PTR(_rx_mpdu_info,	\
593*5113495bSYour Name 		RX_MPDU_INFO_14_MPDU_FRAME_CONTROL_FIELD_OFFSET)),	\
594*5113495bSYour Name 		RX_MPDU_INFO_14_MPDU_FRAME_CONTROL_FIELD_MASK,	\
595*5113495bSYour Name 		RX_MPDU_INFO_14_MPDU_FRAME_CONTROL_FIELD_LSB))
596*5113495bSYour Name 
597*5113495bSYour Name /**
598*5113495bSYour Name  * hal_rx_attn_msdu_done_get_rh() - Get msdi done flag from RX TLV
599*5113495bSYour Name  * @buf: RX tlv address
600*5113495bSYour Name  *
601*5113495bSYour Name  * Return: msdu done flag
602*5113495bSYour Name  */
hal_rx_attn_msdu_done_get_rh(uint8_t * buf)603*5113495bSYour Name static inline uint32_t hal_rx_attn_msdu_done_get_rh(uint8_t *buf)
604*5113495bSYour Name {
605*5113495bSYour Name 	struct rx_pkt_tlvs *pkt_tlvs = (struct rx_pkt_tlvs *)buf;
606*5113495bSYour Name 	struct rx_attention *rx_attn = &pkt_tlvs->attn_tlv.rx_attn;
607*5113495bSYour Name 	uint32_t msdu_done;
608*5113495bSYour Name 
609*5113495bSYour Name 	msdu_done = HAL_RX_ATTN_MSDU_DONE_GET(rx_attn);
610*5113495bSYour Name 
611*5113495bSYour Name 	return msdu_done;
612*5113495bSYour Name }
613*5113495bSYour Name 
614*5113495bSYour Name #define HAL_RX_MSDU_FLAGS_GET(msdu_info_ptr) \
615*5113495bSYour Name 	(HAL_RX_FIRST_MSDU_IN_MPDU_FLAG_GET(msdu_info_ptr) | \
616*5113495bSYour Name 	HAL_RX_LAST_MSDU_IN_MPDU_FLAG_GET(msdu_info_ptr) | \
617*5113495bSYour Name 	HAL_RX_MSDU_CONTINUATION_FLAG_GET(msdu_info_ptr) | \
618*5113495bSYour Name 	HAL_RX_MSDU_SA_IS_VALID_FLAG_GET(msdu_info_ptr) | \
619*5113495bSYour Name 	HAL_RX_MSDU_SA_IDX_TIMEOUT_FLAG_GET(msdu_info_ptr) | \
620*5113495bSYour Name 	HAL_RX_MSDU_DA_IS_VALID_FLAG_GET(msdu_info_ptr) | \
621*5113495bSYour Name 	HAL_RX_MSDU_DA_IS_MCBC_FLAG_GET(msdu_info_ptr) | \
622*5113495bSYour Name 	HAL_RX_MSDU_DA_IDX_TIMEOUT_FLAG_GET(msdu_info_ptr))
623*5113495bSYour Name 
624*5113495bSYour Name /**
625*5113495bSYour Name  * hal_rx_msdu_flags_get_rh() - Get msdu flags from ring desc
626*5113495bSYour Name  * @msdu_desc_info_hdl: msdu desc info handle
627*5113495bSYour Name  *
628*5113495bSYour Name  * Return: msdu flags
629*5113495bSYour Name  */
630*5113495bSYour Name 	static inline
hal_rx_msdu_flags_get_rh(rx_msdu_desc_info_t msdu_desc_info_hdl)631*5113495bSYour Name uint32_t hal_rx_msdu_flags_get_rh(rx_msdu_desc_info_t msdu_desc_info_hdl)
632*5113495bSYour Name {
633*5113495bSYour Name 	struct rx_msdu_desc_info *msdu_desc_info =
634*5113495bSYour Name 		(struct rx_msdu_desc_info *)msdu_desc_info_hdl;
635*5113495bSYour Name 
636*5113495bSYour Name 	return HAL_RX_MSDU_FLAGS_GET(msdu_desc_info);
637*5113495bSYour Name }
638*5113495bSYour Name 
639*5113495bSYour Name #define HAL_RX_ATTN_MSDU_LEN_ERR_GET(_rx_attn)		\
640*5113495bSYour Name 	(_HAL_MS((*_OFFSET_TO_WORD_PTR(_rx_attn,	\
641*5113495bSYour Name 		RX_ATTENTION_1_MSDU_LENGTH_ERR_OFFSET)),	\
642*5113495bSYour Name 		RX_ATTENTION_1_MSDU_LENGTH_ERR_MASK,		\
643*5113495bSYour Name 		RX_ATTENTION_1_MSDU_LENGTH_ERR_LSB))
644*5113495bSYour Name 
645*5113495bSYour Name /**
646*5113495bSYour Name  * hal_rx_attn_msdu_len_err_get_rh(): Get msdu_len_err value from
647*5113495bSYour Name  *  rx attention tlvs
648*5113495bSYour Name  * @buf: pointer to rx pkt tlvs hdr
649*5113495bSYour Name  *
650*5113495bSYour Name  * Return: msdu_len_err value
651*5113495bSYour Name  */
652*5113495bSYour Name static inline uint32_t
hal_rx_attn_msdu_len_err_get_rh(uint8_t * buf)653*5113495bSYour Name hal_rx_attn_msdu_len_err_get_rh(uint8_t *buf)
654*5113495bSYour Name {
655*5113495bSYour Name 	struct rx_pkt_tlvs *pkt_tlvs = (struct rx_pkt_tlvs *)buf;
656*5113495bSYour Name 	struct rx_attention *rx_attn = &pkt_tlvs->attn_tlv.rx_attn;
657*5113495bSYour Name 
658*5113495bSYour Name 	return HAL_RX_ATTN_MSDU_LEN_ERR_GET(rx_attn);
659*5113495bSYour Name }
660*5113495bSYour Name #endif /* _HAL_RH_RX_H_ */
661