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