15bd4f692SLarry Finger /* SPDX-License-Identifier: GPL-2.0 */
25bd4f692SLarry Finger /* Copyright(c) 2009-2012  Realtek Corporation.*/
3f1d2b4d3SLarry Finger 
4f1d2b4d3SLarry Finger #ifndef __RTL92DE_TRX_H__
5f1d2b4d3SLarry Finger #define __RTL92DE_TRX_H__
6f1d2b4d3SLarry Finger 
7f1d2b4d3SLarry Finger #define TX_DESC_SIZE				64
8f1d2b4d3SLarry Finger #define TX_DESC_AGGR_SUBFRAME_SIZE		32
9f1d2b4d3SLarry Finger 
10f1d2b4d3SLarry Finger #define RX_DESC_SIZE				32
11f1d2b4d3SLarry Finger #define RX_DRV_INFO_SIZE_UNIT			8
12f1d2b4d3SLarry Finger 
13f1d2b4d3SLarry Finger #define	TX_DESC_NEXT_DESC_OFFSET		40
14f1d2b4d3SLarry Finger #define USB_HWDESC_HEADER_LEN			32
15f1d2b4d3SLarry Finger #define CRCLENGTH				4
16f1d2b4d3SLarry Finger 
1750ebdaa2SBitterblue Smith enum rtl92d_rx_desc_enc {
1850ebdaa2SBitterblue Smith 	RX_DESC_ENC_NONE	= 0,
1950ebdaa2SBitterblue Smith 	RX_DESC_ENC_WEP40	= 1,
2050ebdaa2SBitterblue Smith 	RX_DESC_ENC_TKIP_WO_MIC	= 2,
2150ebdaa2SBitterblue Smith 	RX_DESC_ENC_TKIP_MIC	= 3,
2250ebdaa2SBitterblue Smith 	RX_DESC_ENC_AES		= 4,
2350ebdaa2SBitterblue Smith 	RX_DESC_ENC_WEP104	= 5,
2450ebdaa2SBitterblue Smith };
2550ebdaa2SBitterblue Smith 
26f1d2b4d3SLarry Finger /* macros to read/write various fields in RX or TX descriptors */
27f1d2b4d3SLarry Finger 
set_tx_desc_pkt_size(__le32 * __pdesc,u32 __val)2896c21a25SLarry Finger static inline void set_tx_desc_pkt_size(__le32 *__pdesc, u32 __val)
29fa2b36a3SLarry Finger {
3096c21a25SLarry Finger 	le32p_replace_bits(__pdesc, __val, GENMASK(15, 0));
31fa2b36a3SLarry Finger }
32f1d2b4d3SLarry Finger 
set_tx_desc_offset(__le32 * __pdesc,u32 __val)3396c21a25SLarry Finger static inline void set_tx_desc_offset(__le32 *__pdesc, u32 __val)
34fa2b36a3SLarry Finger {
3596c21a25SLarry Finger 	le32p_replace_bits(__pdesc, __val, GENMASK(23, 16));
36fa2b36a3SLarry Finger }
37f1d2b4d3SLarry Finger 
set_tx_desc_htc(__le32 * __pdesc,u32 __val)3896c21a25SLarry Finger static inline void set_tx_desc_htc(__le32 *__pdesc, u32 __val)
39fa2b36a3SLarry Finger {
4096c21a25SLarry Finger 	le32p_replace_bits(__pdesc, __val, BIT(25));
41fa2b36a3SLarry Finger }
42f1d2b4d3SLarry Finger 
set_tx_desc_last_seg(__le32 * __pdesc,u32 __val)4396c21a25SLarry Finger static inline void set_tx_desc_last_seg(__le32 *__pdesc, u32 __val)
44fa2b36a3SLarry Finger {
4596c21a25SLarry Finger 	le32p_replace_bits(__pdesc, __val, BIT(26));
46fa2b36a3SLarry Finger }
47f1d2b4d3SLarry Finger 
set_tx_desc_first_seg(__le32 * __pdesc,u32 __val)4896c21a25SLarry Finger static inline void set_tx_desc_first_seg(__le32 *__pdesc, u32 __val)
49fa2b36a3SLarry Finger {
5096c21a25SLarry Finger 	le32p_replace_bits(__pdesc, __val, BIT(27));
51fa2b36a3SLarry Finger }
52f1d2b4d3SLarry Finger 
set_tx_desc_linip(__le32 * __pdesc,u32 __val)5396c21a25SLarry Finger static inline void set_tx_desc_linip(__le32 *__pdesc, u32 __val)
54fa2b36a3SLarry Finger {
5596c21a25SLarry Finger 	le32p_replace_bits(__pdesc, __val, BIT(28));
56fa2b36a3SLarry Finger }
57f1d2b4d3SLarry Finger 
set_tx_desc_own(__le32 * __pdesc,u32 __val)5896c21a25SLarry Finger static inline void set_tx_desc_own(__le32 *__pdesc, u32 __val)
59fa2b36a3SLarry Finger {
6096c21a25SLarry Finger 	le32p_replace_bits(__pdesc, __val, BIT(31));
61fa2b36a3SLarry Finger }
62f1d2b4d3SLarry Finger 
get_tx_desc_own(__le32 * __pdesc)6396c21a25SLarry Finger static inline u32 get_tx_desc_own(__le32 *__pdesc)
64fa2b36a3SLarry Finger {
6596c21a25SLarry Finger 	return le32_get_bits(*__pdesc, BIT(31));
66fa2b36a3SLarry Finger }
67f1d2b4d3SLarry Finger 
set_tx_desc_macid(__le32 * __pdesc,u32 __val)6896c21a25SLarry Finger static inline void set_tx_desc_macid(__le32 *__pdesc, u32 __val)
69fa2b36a3SLarry Finger {
7096c21a25SLarry Finger 	le32p_replace_bits((__pdesc + 1), __val, GENMASK(4, 0));
71fa2b36a3SLarry Finger }
72f1d2b4d3SLarry Finger 
set_tx_desc_agg_enable(__le32 * __pdesc,u32 __val)7396c21a25SLarry Finger static inline void set_tx_desc_agg_enable(__le32 *__pdesc, u32 __val)
74fa2b36a3SLarry Finger {
7596c21a25SLarry Finger 	le32p_replace_bits((__pdesc + 1), __val, BIT(5));
76fa2b36a3SLarry Finger }
77f1d2b4d3SLarry Finger 
set_tx_desc_rdg_enable(__le32 * __pdesc,u32 __val)7896c21a25SLarry Finger static inline void set_tx_desc_rdg_enable(__le32 *__pdesc, u32 __val)
79fa2b36a3SLarry Finger {
8096c21a25SLarry Finger 	le32p_replace_bits((__pdesc + 1), __val, BIT(7));
81fa2b36a3SLarry Finger }
82f1d2b4d3SLarry Finger 
set_tx_desc_queue_sel(__le32 * __pdesc,u32 __val)8396c21a25SLarry Finger static inline void set_tx_desc_queue_sel(__le32 *__pdesc, u32 __val)
84fa2b36a3SLarry Finger {
8596c21a25SLarry Finger 	le32p_replace_bits((__pdesc + 1), __val, GENMASK(12, 8));
86fa2b36a3SLarry Finger }
87f1d2b4d3SLarry Finger 
set_tx_desc_rate_id(__le32 * __pdesc,u32 __val)8896c21a25SLarry Finger static inline void set_tx_desc_rate_id(__le32 *__pdesc, u32 __val)
89fa2b36a3SLarry Finger {
9096c21a25SLarry Finger 	le32p_replace_bits((__pdesc + 1), __val, GENMASK(19, 16));
91fa2b36a3SLarry Finger }
92f1d2b4d3SLarry Finger 
set_tx_desc_sec_type(__le32 * __pdesc,u32 __val)9396c21a25SLarry Finger static inline void set_tx_desc_sec_type(__le32 *__pdesc, u32 __val)
94fa2b36a3SLarry Finger {
9596c21a25SLarry Finger 	le32p_replace_bits((__pdesc + 1), __val, GENMASK(23, 22));
96fa2b36a3SLarry Finger }
97f1d2b4d3SLarry Finger 
set_tx_desc_pkt_offset(__le32 * __pdesc,u32 __val)9896c21a25SLarry Finger static inline void set_tx_desc_pkt_offset(__le32 *__pdesc, u32 __val)
99fa2b36a3SLarry Finger {
10096c21a25SLarry Finger 	le32p_replace_bits((__pdesc + 1), __val, GENMASK(30, 26));
101fa2b36a3SLarry Finger }
102f1d2b4d3SLarry Finger 
set_tx_desc_more_frag(__le32 * __pdesc,u32 __val)10396c21a25SLarry Finger static inline void set_tx_desc_more_frag(__le32 *__pdesc, u32 __val)
104fa2b36a3SLarry Finger {
10596c21a25SLarry Finger 	le32p_replace_bits((__pdesc + 2), __val, BIT(17));
106fa2b36a3SLarry Finger }
107f1d2b4d3SLarry Finger 
set_tx_desc_ampdu_density(__le32 * __pdesc,u32 __val)10896c21a25SLarry Finger static inline void set_tx_desc_ampdu_density(__le32 *__pdesc, u32 __val)
109fa2b36a3SLarry Finger {
11096c21a25SLarry Finger 	le32p_replace_bits((__pdesc + 2), __val, GENMASK(22, 20));
111fa2b36a3SLarry Finger }
112f1d2b4d3SLarry Finger 
set_tx_desc_seq(__le32 * __pdesc,u32 __val)11396c21a25SLarry Finger static inline void set_tx_desc_seq(__le32 *__pdesc, u32 __val)
114fa2b36a3SLarry Finger {
11596c21a25SLarry Finger 	le32p_replace_bits((__pdesc + 3), __val, GENMASK(27, 16));
116fa2b36a3SLarry Finger }
117fa2b36a3SLarry Finger 
set_tx_desc_pkt_id(__le32 * __pdesc,u32 __val)11896c21a25SLarry Finger static inline void set_tx_desc_pkt_id(__le32 *__pdesc, u32 __val)
119fa2b36a3SLarry Finger {
12096c21a25SLarry Finger 	le32p_replace_bits((__pdesc + 3), __val, GENMASK(31, 28));
121fa2b36a3SLarry Finger }
122fa2b36a3SLarry Finger 
set_tx_desc_rts_rate(__le32 * __pdesc,u32 __val)12396c21a25SLarry Finger static inline void set_tx_desc_rts_rate(__le32 *__pdesc, u32 __val)
124fa2b36a3SLarry Finger {
12596c21a25SLarry Finger 	le32p_replace_bits((__pdesc + 4), __val, GENMASK(4, 0));
126fa2b36a3SLarry Finger }
127fa2b36a3SLarry Finger 
set_tx_desc_qos(__le32 * __pdesc,u32 __val)12896c21a25SLarry Finger static inline void set_tx_desc_qos(__le32 *__pdesc, u32 __val)
129fa2b36a3SLarry Finger {
13096c21a25SLarry Finger 	le32p_replace_bits((__pdesc + 4), __val, BIT(6));
131fa2b36a3SLarry Finger }
132fa2b36a3SLarry Finger 
set_tx_desc_hwseq_en(__le32 * __pdesc,u32 __val)13396c21a25SLarry Finger static inline void set_tx_desc_hwseq_en(__le32 *__pdesc, u32 __val)
134fa2b36a3SLarry Finger {
13596c21a25SLarry Finger 	le32p_replace_bits((__pdesc + 4), __val, BIT(7));
136fa2b36a3SLarry Finger }
137fa2b36a3SLarry Finger 
set_tx_desc_use_rate(__le32 * __pdesc,u32 __val)13896c21a25SLarry Finger static inline void set_tx_desc_use_rate(__le32 *__pdesc, u32 __val)
139fa2b36a3SLarry Finger {
14096c21a25SLarry Finger 	le32p_replace_bits((__pdesc + 4), __val, BIT(8));
141fa2b36a3SLarry Finger }
142fa2b36a3SLarry Finger 
set_tx_desc_disable_fb(__le32 * __pdesc,u32 __val)14396c21a25SLarry Finger static inline void set_tx_desc_disable_fb(__le32 *__pdesc, u32 __val)
144fa2b36a3SLarry Finger {
14596c21a25SLarry Finger 	le32p_replace_bits((__pdesc + 4), __val, BIT(10));
146fa2b36a3SLarry Finger }
147fa2b36a3SLarry Finger 
set_tx_desc_cts2self(__le32 * __pdesc,u32 __val)14896c21a25SLarry Finger static inline void set_tx_desc_cts2self(__le32 *__pdesc, u32 __val)
149fa2b36a3SLarry Finger {
15096c21a25SLarry Finger 	le32p_replace_bits((__pdesc + 4), __val, BIT(11));
151fa2b36a3SLarry Finger }
152fa2b36a3SLarry Finger 
set_tx_desc_rts_enable(__le32 * __pdesc,u32 __val)15396c21a25SLarry Finger static inline void set_tx_desc_rts_enable(__le32 *__pdesc, u32 __val)
154fa2b36a3SLarry Finger {
15596c21a25SLarry Finger 	le32p_replace_bits((__pdesc + 4), __val, BIT(12));
156fa2b36a3SLarry Finger }
157fa2b36a3SLarry Finger 
set_tx_desc_hw_rts_enable(__le32 * __pdesc,u32 __val)15896c21a25SLarry Finger static inline void set_tx_desc_hw_rts_enable(__le32 *__pdesc, u32 __val)
159fa2b36a3SLarry Finger {
16096c21a25SLarry Finger 	le32p_replace_bits((__pdesc + 4), __val, BIT(13));
161fa2b36a3SLarry Finger }
162fa2b36a3SLarry Finger 
set_tx_desc_tx_sub_carrier(__le32 * __pdesc,u32 __val)16396c21a25SLarry Finger static inline void set_tx_desc_tx_sub_carrier(__le32 *__pdesc, u32 __val)
164fa2b36a3SLarry Finger {
16596c21a25SLarry Finger 	le32p_replace_bits((__pdesc + 4), __val, GENMASK(21, 20));
166fa2b36a3SLarry Finger }
167fa2b36a3SLarry Finger 
set_tx_desc_data_bw(__le32 * __pdesc,u32 __val)16896c21a25SLarry Finger static inline void set_tx_desc_data_bw(__le32 *__pdesc, u32 __val)
169fa2b36a3SLarry Finger {
17096c21a25SLarry Finger 	le32p_replace_bits((__pdesc + 4), __val, BIT(25));
171fa2b36a3SLarry Finger }
172fa2b36a3SLarry Finger 
set_tx_desc_rts_short(__le32 * __pdesc,u32 __val)17396c21a25SLarry Finger static inline void set_tx_desc_rts_short(__le32 *__pdesc, u32 __val)
174fa2b36a3SLarry Finger {
17596c21a25SLarry Finger 	le32p_replace_bits((__pdesc + 4), __val, BIT(26));
176fa2b36a3SLarry Finger }
177fa2b36a3SLarry Finger 
set_tx_desc_rts_bw(__le32 * __pdesc,u32 __val)17896c21a25SLarry Finger static inline void set_tx_desc_rts_bw(__le32 *__pdesc, u32 __val)
179fa2b36a3SLarry Finger {
18096c21a25SLarry Finger 	le32p_replace_bits((__pdesc + 4), __val, BIT(27));
181fa2b36a3SLarry Finger }
182fa2b36a3SLarry Finger 
set_tx_desc_rts_sc(__le32 * __pdesc,u32 __val)18396c21a25SLarry Finger static inline void set_tx_desc_rts_sc(__le32 *__pdesc, u32 __val)
184fa2b36a3SLarry Finger {
18596c21a25SLarry Finger 	le32p_replace_bits((__pdesc + 4), __val, GENMASK(29, 28));
186fa2b36a3SLarry Finger }
187fa2b36a3SLarry Finger 
set_tx_desc_rts_stbc(__le32 * __pdesc,u32 __val)18896c21a25SLarry Finger static inline void set_tx_desc_rts_stbc(__le32 *__pdesc, u32 __val)
189fa2b36a3SLarry Finger {
19096c21a25SLarry Finger 	le32p_replace_bits((__pdesc + 4), __val, GENMASK(31, 30));
191fa2b36a3SLarry Finger }
192fa2b36a3SLarry Finger 
set_tx_desc_tx_rate(__le32 * __pdesc,u32 __val)19396c21a25SLarry Finger static inline void set_tx_desc_tx_rate(__le32 *__pdesc, u32 __val)
194fa2b36a3SLarry Finger {
19596c21a25SLarry Finger 	le32p_replace_bits((__pdesc + 5), __val, GENMASK(5, 0));
196fa2b36a3SLarry Finger }
197fa2b36a3SLarry Finger 
set_tx_desc_data_shortgi(__le32 * __pdesc,u32 __val)19896c21a25SLarry Finger static inline void set_tx_desc_data_shortgi(__le32 *__pdesc, u32 __val)
199fa2b36a3SLarry Finger {
20096c21a25SLarry Finger 	le32p_replace_bits((__pdesc + 5), __val, BIT(6));
201fa2b36a3SLarry Finger }
202fa2b36a3SLarry Finger 
set_tx_desc_data_rate_fb_limit(__le32 * __pdesc,u32 __val)20396c21a25SLarry Finger static inline void set_tx_desc_data_rate_fb_limit(__le32 *__pdesc, u32 __val)
204fa2b36a3SLarry Finger {
20596c21a25SLarry Finger 	le32p_replace_bits((__pdesc + 5), __val, GENMASK(12, 8));
206fa2b36a3SLarry Finger }
207fa2b36a3SLarry Finger 
set_tx_desc_rts_rate_fb_limit(__le32 * __pdesc,u32 __val)20896c21a25SLarry Finger static inline void set_tx_desc_rts_rate_fb_limit(__le32 *__pdesc, u32 __val)
209fa2b36a3SLarry Finger {
21096c21a25SLarry Finger 	le32p_replace_bits((__pdesc + 5), __val, GENMASK(16, 13));
211fa2b36a3SLarry Finger }
212fa2b36a3SLarry Finger 
set_tx_desc_max_agg_num(__le32 * __pdesc,u32 __val)21396c21a25SLarry Finger static inline void set_tx_desc_max_agg_num(__le32 *__pdesc, u32 __val)
214fa2b36a3SLarry Finger {
21596c21a25SLarry Finger 	le32p_replace_bits((__pdesc + 6), __val, GENMASK(15, 11));
216fa2b36a3SLarry Finger }
217fa2b36a3SLarry Finger 
set_tx_desc_tx_buffer_size(__le32 * __pdesc,u32 __val)21896c21a25SLarry Finger static inline void set_tx_desc_tx_buffer_size(__le32 *__pdesc, u32 __val)
219fa2b36a3SLarry Finger {
22096c21a25SLarry Finger 	le32p_replace_bits((__pdesc + 7), __val, GENMASK(15, 0));
221fa2b36a3SLarry Finger }
222fa2b36a3SLarry Finger 
set_tx_desc_tx_buffer_address(__le32 * __pdesc,u32 __val)22396c21a25SLarry Finger static inline void set_tx_desc_tx_buffer_address(__le32 *__pdesc, u32 __val)
224fa2b36a3SLarry Finger {
22596c21a25SLarry Finger 	*(__pdesc + 8) = cpu_to_le32(__val);
226fa2b36a3SLarry Finger }
227fa2b36a3SLarry Finger 
get_tx_desc_tx_buffer_address(__le32 * __pdesc)22896c21a25SLarry Finger static inline u32 get_tx_desc_tx_buffer_address(__le32 *__pdesc)
229fa2b36a3SLarry Finger {
23096c21a25SLarry Finger 	return le32_to_cpu(*(__pdesc + 8));
231fa2b36a3SLarry Finger }
232fa2b36a3SLarry Finger 
set_tx_desc_next_desc_address(__le32 * __pdesc,u32 __val)23396c21a25SLarry Finger static inline void set_tx_desc_next_desc_address(__le32 *__pdesc, u32 __val)
234fa2b36a3SLarry Finger {
23596c21a25SLarry Finger 	*(__pdesc + 10) = cpu_to_le32(__val);
236fa2b36a3SLarry Finger }
237fa2b36a3SLarry Finger 
get_rx_desc_pkt_len(__le32 * __pdesc)23896c21a25SLarry Finger static inline u32 get_rx_desc_pkt_len(__le32 *__pdesc)
239fa2b36a3SLarry Finger {
24096c21a25SLarry Finger 	return le32_get_bits(*__pdesc, GENMASK(13, 0));
241fa2b36a3SLarry Finger }
242fa2b36a3SLarry Finger 
get_rx_desc_crc32(__le32 * __pdesc)24396c21a25SLarry Finger static inline u32 get_rx_desc_crc32(__le32 *__pdesc)
244fa2b36a3SLarry Finger {
24596c21a25SLarry Finger 	return le32_get_bits(*__pdesc, BIT(14));
246fa2b36a3SLarry Finger }
247fa2b36a3SLarry Finger 
get_rx_desc_icv(__le32 * __pdesc)24896c21a25SLarry Finger static inline u32 get_rx_desc_icv(__le32 *__pdesc)
249fa2b36a3SLarry Finger {
25096c21a25SLarry Finger 	return le32_get_bits(*__pdesc, BIT(15));
251fa2b36a3SLarry Finger }
252fa2b36a3SLarry Finger 
get_rx_desc_drv_info_size(__le32 * __pdesc)25396c21a25SLarry Finger static inline u32 get_rx_desc_drv_info_size(__le32 *__pdesc)
254fa2b36a3SLarry Finger {
25596c21a25SLarry Finger 	return le32_get_bits(*__pdesc, GENMASK(19, 16));
256fa2b36a3SLarry Finger }
257fa2b36a3SLarry Finger 
get_rx_desc_enc_type(__le32 * __pdesc)25850ebdaa2SBitterblue Smith static inline u32 get_rx_desc_enc_type(__le32 *__pdesc)
25950ebdaa2SBitterblue Smith {
26050ebdaa2SBitterblue Smith 	return le32_get_bits(*__pdesc, GENMASK(22, 20));
26150ebdaa2SBitterblue Smith }
26250ebdaa2SBitterblue Smith 
get_rx_desc_shift(__le32 * __pdesc)26396c21a25SLarry Finger static inline u32 get_rx_desc_shift(__le32 *__pdesc)
264fa2b36a3SLarry Finger {
26596c21a25SLarry Finger 	return le32_get_bits(*__pdesc, GENMASK(25, 24));
266fa2b36a3SLarry Finger }
267fa2b36a3SLarry Finger 
get_rx_desc_physt(__le32 * __pdesc)26896c21a25SLarry Finger static inline u32 get_rx_desc_physt(__le32 *__pdesc)
269fa2b36a3SLarry Finger {
27096c21a25SLarry Finger 	return le32_get_bits(*__pdesc, BIT(26));
271fa2b36a3SLarry Finger }
272fa2b36a3SLarry Finger 
get_rx_desc_swdec(__le32 * __pdesc)27396c21a25SLarry Finger static inline u32 get_rx_desc_swdec(__le32 *__pdesc)
274fa2b36a3SLarry Finger {
27596c21a25SLarry Finger 	return le32_get_bits(*__pdesc, BIT(27));
276fa2b36a3SLarry Finger }
277fa2b36a3SLarry Finger 
get_rx_desc_own(__le32 * __pdesc)27896c21a25SLarry Finger static inline u32 get_rx_desc_own(__le32 *__pdesc)
279fa2b36a3SLarry Finger {
28096c21a25SLarry Finger 	return le32_get_bits(*__pdesc, BIT(31));
281fa2b36a3SLarry Finger }
282fa2b36a3SLarry Finger 
set_rx_desc_pkt_len(__le32 * __pdesc,u32 __val)28396c21a25SLarry Finger static inline void set_rx_desc_pkt_len(__le32 *__pdesc, u32 __val)
284fa2b36a3SLarry Finger {
28596c21a25SLarry Finger 	le32p_replace_bits(__pdesc, __val, GENMASK(13, 0));
286fa2b36a3SLarry Finger }
287fa2b36a3SLarry Finger 
set_rx_desc_eor(__le32 * __pdesc,u32 __val)28896c21a25SLarry Finger static inline void set_rx_desc_eor(__le32 *__pdesc, u32 __val)
289fa2b36a3SLarry Finger {
29096c21a25SLarry Finger 	le32p_replace_bits(__pdesc, __val, BIT(30));
291fa2b36a3SLarry Finger }
292fa2b36a3SLarry Finger 
set_rx_desc_own(__le32 * __pdesc,u32 __val)29396c21a25SLarry Finger static inline void set_rx_desc_own(__le32 *__pdesc, u32 __val)
294fa2b36a3SLarry Finger {
29596c21a25SLarry Finger 	le32p_replace_bits(__pdesc, __val, BIT(31));
296fa2b36a3SLarry Finger }
297fa2b36a3SLarry Finger 
get_rx_desc_paggr(__le32 * __pdesc)29896c21a25SLarry Finger static inline u32 get_rx_desc_paggr(__le32 *__pdesc)
299fa2b36a3SLarry Finger {
30096c21a25SLarry Finger 	return le32_get_bits(*(__pdesc + 1), BIT(14));
301fa2b36a3SLarry Finger }
302fa2b36a3SLarry Finger 
get_rx_desc_faggr(__le32 * __pdesc)30396c21a25SLarry Finger static inline u32 get_rx_desc_faggr(__le32 *__pdesc)
304fa2b36a3SLarry Finger {
30596c21a25SLarry Finger 	return le32_get_bits(*(__pdesc + 1), BIT(15));
306fa2b36a3SLarry Finger }
307fa2b36a3SLarry Finger 
get_rx_desc_rxmcs(__le32 * __pdesc)30896c21a25SLarry Finger static inline u32 get_rx_desc_rxmcs(__le32 *__pdesc)
309fa2b36a3SLarry Finger {
31096c21a25SLarry Finger 	return le32_get_bits(*(__pdesc + 3), GENMASK(5, 0));
311fa2b36a3SLarry Finger }
312fa2b36a3SLarry Finger 
get_rx_desc_rxht(__le32 * __pdesc)31396c21a25SLarry Finger static inline u32 get_rx_desc_rxht(__le32 *__pdesc)
314fa2b36a3SLarry Finger {
31596c21a25SLarry Finger 	return le32_get_bits(*(__pdesc + 3), BIT(6));
316fa2b36a3SLarry Finger }
317fa2b36a3SLarry Finger 
get_rx_desc_splcp(__le32 * __pdesc)31896c21a25SLarry Finger static inline u32 get_rx_desc_splcp(__le32 *__pdesc)
319fa2b36a3SLarry Finger {
32096c21a25SLarry Finger 	return le32_get_bits(*(__pdesc + 3), BIT(8));
321fa2b36a3SLarry Finger }
322fa2b36a3SLarry Finger 
get_rx_desc_bw(__le32 * __pdesc)32396c21a25SLarry Finger static inline u32 get_rx_desc_bw(__le32 *__pdesc)
324fa2b36a3SLarry Finger {
32596c21a25SLarry Finger 	return le32_get_bits(*(__pdesc + 3), BIT(9));
326fa2b36a3SLarry Finger }
327fa2b36a3SLarry Finger 
get_rx_desc_tsfl(__le32 * __pdesc)32896c21a25SLarry Finger static inline u32 get_rx_desc_tsfl(__le32 *__pdesc)
329fa2b36a3SLarry Finger {
33096c21a25SLarry Finger 	return le32_to_cpu(*(__pdesc + 5));
331fa2b36a3SLarry Finger }
332fa2b36a3SLarry Finger 
get_rx_desc_buff_addr(__le32 * __pdesc)33396c21a25SLarry Finger static inline u32 get_rx_desc_buff_addr(__le32 *__pdesc)
334fa2b36a3SLarry Finger {
33596c21a25SLarry Finger 	return le32_to_cpu(*(__pdesc + 6));
336fa2b36a3SLarry Finger }
337fa2b36a3SLarry Finger 
set_rx_desc_buff_addr(__le32 * __pdesc,u32 __val)33896c21a25SLarry Finger static inline void set_rx_desc_buff_addr(__le32 *__pdesc, u32 __val)
339fa2b36a3SLarry Finger {
34096c21a25SLarry Finger 	*(__pdesc + 6) = cpu_to_le32(__val);
341fa2b36a3SLarry Finger }
342f1d2b4d3SLarry Finger 
clear_pci_tx_desc_content(__le32 * __pdesc,u32 _size)34396c21a25SLarry Finger static inline void clear_pci_tx_desc_content(__le32 *__pdesc, u32 _size)
34496c21a25SLarry Finger {
34596c21a25SLarry Finger 	memset((void *)__pdesc, 0,
34696c21a25SLarry Finger 	       min_t(size_t, _size, TX_DESC_NEXT_DESC_OFFSET));
34796c21a25SLarry Finger }
348f1d2b4d3SLarry Finger 
349f1d2b4d3SLarry Finger /* For 92D early mode */
set_earlymode_pktnum(__le32 * __paddr,u32 __value)35096c21a25SLarry Finger static inline void set_earlymode_pktnum(__le32 *__paddr, u32 __value)
351fa2b36a3SLarry Finger {
35296c21a25SLarry Finger 	le32p_replace_bits(__paddr, __value, GENMASK(2, 0));
353fa2b36a3SLarry Finger }
354fa2b36a3SLarry Finger 
set_earlymode_len0(__le32 * __paddr,u32 __value)35596c21a25SLarry Finger static inline void set_earlymode_len0(__le32 *__paddr, u32 __value)
356fa2b36a3SLarry Finger {
35796c21a25SLarry Finger 	le32p_replace_bits(__paddr, __value, GENMASK(15, 4));
358fa2b36a3SLarry Finger }
359fa2b36a3SLarry Finger 
set_earlymode_len1(__le32 * __paddr,u32 __value)36096c21a25SLarry Finger static inline void set_earlymode_len1(__le32 *__paddr, u32 __value)
361fa2b36a3SLarry Finger {
36296c21a25SLarry Finger 	le32p_replace_bits(__paddr, __value, GENMASK(27, 16));
363fa2b36a3SLarry Finger }
364fa2b36a3SLarry Finger 
set_earlymode_len2_1(__le32 * __paddr,u32 __value)36596c21a25SLarry Finger static inline void set_earlymode_len2_1(__le32 *__paddr, u32 __value)
366fa2b36a3SLarry Finger {
36796c21a25SLarry Finger 	le32p_replace_bits(__paddr, __value, GENMASK(31, 28));
368fa2b36a3SLarry Finger }
369fa2b36a3SLarry Finger 
set_earlymode_len2_2(__le32 * __paddr,u32 __value)37096c21a25SLarry Finger static inline void set_earlymode_len2_2(__le32 *__paddr, u32 __value)
371fa2b36a3SLarry Finger {
37296c21a25SLarry Finger 	le32p_replace_bits((__paddr + 1), __value, GENMASK(7, 0));
373fa2b36a3SLarry Finger }
374fa2b36a3SLarry Finger 
set_earlymode_len3(__le32 * __paddr,u32 __value)37596c21a25SLarry Finger static inline void set_earlymode_len3(__le32 *__paddr, u32 __value)
376fa2b36a3SLarry Finger {
37796c21a25SLarry Finger 	le32p_replace_bits((__paddr + 1), __value, GENMASK(19, 8));
378fa2b36a3SLarry Finger }
379fa2b36a3SLarry Finger 
set_earlymode_len4(__le32 * __paddr,u32 __value)38096c21a25SLarry Finger static inline void set_earlymode_len4(__le32 *__paddr, u32 __value)
381fa2b36a3SLarry Finger {
38296c21a25SLarry Finger 	le32p_replace_bits((__paddr + 1), __value, GENMASK(31, 20));
383fa2b36a3SLarry Finger }
384f1d2b4d3SLarry Finger 
385f1d2b4d3SLarry Finger struct rx_fwinfo_92d {
386f1d2b4d3SLarry Finger 	u8 gain_trsw[4];
387f1d2b4d3SLarry Finger 	u8 pwdb_all;
388f1d2b4d3SLarry Finger 	u8 cfosho[4];
389f1d2b4d3SLarry Finger 	u8 cfotail[4];
39008aba42fSArnd Bergmann 	s8 rxevm[2];
39108aba42fSArnd Bergmann 	s8 rxsnr[4];
392f1d2b4d3SLarry Finger 	u8 pdsnr[2];
393f1d2b4d3SLarry Finger 	u8 csi_current[2];
394f1d2b4d3SLarry Finger 	u8 csi_target[2];
395f1d2b4d3SLarry Finger 	u8 sigevm;
396f1d2b4d3SLarry Finger 	u8 max_ex_pwr;
3974c59282aSBitterblue Smith #ifdef __LITTLE_ENDIAN
398f1d2b4d3SLarry Finger 	u8 ex_intf_flag:1;
399f1d2b4d3SLarry Finger 	u8 sgi_en:1;
400f1d2b4d3SLarry Finger 	u8 rxsc:2;
401f1d2b4d3SLarry Finger 	u8 reserve:4;
4024c59282aSBitterblue Smith #else
4034c59282aSBitterblue Smith 	u8 reserve:4;
4044c59282aSBitterblue Smith 	u8 rxsc:2;
4054c59282aSBitterblue Smith 	u8 sgi_en:1;
4064c59282aSBitterblue Smith 	u8 ex_intf_flag:1;
4074c59282aSBitterblue Smith #endif
408f1d2b4d3SLarry Finger } __packed;
409f1d2b4d3SLarry Finger 
410f1d2b4d3SLarry Finger struct tx_desc_92d {
411f1d2b4d3SLarry Finger 	u32 pktsize:16;
412f1d2b4d3SLarry Finger 	u32 offset:8;
413f1d2b4d3SLarry Finger 	u32 bmc:1;
414f1d2b4d3SLarry Finger 	u32 htc:1;
415f1d2b4d3SLarry Finger 	u32 lastseg:1;
416f1d2b4d3SLarry Finger 	u32 firstseg:1;
417f1d2b4d3SLarry Finger 	u32 linip:1;
418f1d2b4d3SLarry Finger 	u32 noacm:1;
419f1d2b4d3SLarry Finger 	u32 gf:1;
420f1d2b4d3SLarry Finger 	u32 own:1;
421f1d2b4d3SLarry Finger 
422f1d2b4d3SLarry Finger 	u32 macid:5;
423f1d2b4d3SLarry Finger 	u32 agg_en:1;
424f1d2b4d3SLarry Finger 	u32 bk:1;
425f1d2b4d3SLarry Finger 	u32 rdg_en:1;
426f1d2b4d3SLarry Finger 	u32 queuesel:5;
427f1d2b4d3SLarry Finger 	u32 rd_nav_ext:1;
428f1d2b4d3SLarry Finger 	u32 lsig_txop_en:1;
429f1d2b4d3SLarry Finger 	u32 pifs:1;
430f1d2b4d3SLarry Finger 	u32 rateid:4;
431f1d2b4d3SLarry Finger 	u32 nav_usehdr:1;
432f1d2b4d3SLarry Finger 	u32 en_descid:1;
433f1d2b4d3SLarry Finger 	u32 sectype:2;
434f1d2b4d3SLarry Finger 	u32 pktoffset:8;
435f1d2b4d3SLarry Finger 
436f1d2b4d3SLarry Finger 	u32 rts_rc:6;
437f1d2b4d3SLarry Finger 	u32 data_rc:6;
438f1d2b4d3SLarry Finger 	u32 rsvd0:2;
439f1d2b4d3SLarry Finger 	u32 bar_retryht:2;
440f1d2b4d3SLarry Finger 	u32 rsvd1:1;
441f1d2b4d3SLarry Finger 	u32 morefrag:1;
442f1d2b4d3SLarry Finger 	u32 raw:1;
443f1d2b4d3SLarry Finger 	u32 ccx:1;
444f1d2b4d3SLarry Finger 	u32 ampdudensity:3;
445f1d2b4d3SLarry Finger 	u32 rsvd2:1;
446f1d2b4d3SLarry Finger 	u32 ant_sela:1;
447f1d2b4d3SLarry Finger 	u32 ant_selb:1;
448f1d2b4d3SLarry Finger 	u32 txant_cck:2;
449f1d2b4d3SLarry Finger 	u32 txant_l:2;
450f1d2b4d3SLarry Finger 	u32 txant_ht:2;
451f1d2b4d3SLarry Finger 
452f1d2b4d3SLarry Finger 	u32 nextheadpage:8;
453f1d2b4d3SLarry Finger 	u32 tailpage:8;
454f1d2b4d3SLarry Finger 	u32 seq:12;
455f1d2b4d3SLarry Finger 	u32 pktid:4;
456f1d2b4d3SLarry Finger 
457f1d2b4d3SLarry Finger 	u32 rtsrate:5;
458f1d2b4d3SLarry Finger 	u32 apdcfe:1;
459f1d2b4d3SLarry Finger 	u32 qos:1;
460f1d2b4d3SLarry Finger 	u32 hwseq_enable:1;
461f1d2b4d3SLarry Finger 	u32 userrate:1;
462f1d2b4d3SLarry Finger 	u32 dis_rtsfb:1;
463f1d2b4d3SLarry Finger 	u32 dis_datafb:1;
464f1d2b4d3SLarry Finger 	u32 cts2self:1;
465f1d2b4d3SLarry Finger 	u32 rts_en:1;
466f1d2b4d3SLarry Finger 	u32 hwrts_en:1;
467f1d2b4d3SLarry Finger 	u32 portid:1;
468f1d2b4d3SLarry Finger 	u32 rsvd3:3;
469f1d2b4d3SLarry Finger 	u32 waitdcts:1;
470f1d2b4d3SLarry Finger 	u32 cts2ap_en:1;
471f1d2b4d3SLarry Finger 	u32 txsc:2;
472f1d2b4d3SLarry Finger 	u32 stbc:2;
473f1d2b4d3SLarry Finger 	u32 txshort:1;
474f1d2b4d3SLarry Finger 	u32 txbw:1;
475f1d2b4d3SLarry Finger 	u32 rtsshort:1;
476f1d2b4d3SLarry Finger 	u32 rtsbw:1;
477f1d2b4d3SLarry Finger 	u32 rtssc:2;
478f1d2b4d3SLarry Finger 	u32 rtsstbc:2;
479f1d2b4d3SLarry Finger 
480f1d2b4d3SLarry Finger 	u32 txrate:6;
481f1d2b4d3SLarry Finger 	u32 shortgi:1;
482f1d2b4d3SLarry Finger 	u32 ccxt:1;
483f1d2b4d3SLarry Finger 	u32 txrate_fb_lmt:5;
484f1d2b4d3SLarry Finger 	u32 rtsrate_fb_lmt:4;
485f1d2b4d3SLarry Finger 	u32 retrylmt_en:1;
486f1d2b4d3SLarry Finger 	u32 txretrylmt:6;
487f1d2b4d3SLarry Finger 	u32 usb_txaggnum:8;
488f1d2b4d3SLarry Finger 
489f1d2b4d3SLarry Finger 	u32 txagca:5;
490f1d2b4d3SLarry Finger 	u32 txagcb:5;
491f1d2b4d3SLarry Finger 	u32 usemaxlen:1;
492f1d2b4d3SLarry Finger 	u32 maxaggnum:5;
493f1d2b4d3SLarry Finger 	u32 mcsg1maxlen:4;
494f1d2b4d3SLarry Finger 	u32 mcsg2maxlen:4;
495f1d2b4d3SLarry Finger 	u32 mcsg3maxlen:4;
496f1d2b4d3SLarry Finger 	u32 mcs7sgimaxlen:4;
497f1d2b4d3SLarry Finger 
498f1d2b4d3SLarry Finger 	u32 txbuffersize:16;
499f1d2b4d3SLarry Finger 	u32 mcsg4maxlen:4;
500f1d2b4d3SLarry Finger 	u32 mcsg5maxlen:4;
501f1d2b4d3SLarry Finger 	u32 mcsg6maxlen:4;
502f1d2b4d3SLarry Finger 	u32 mcsg15sgimaxlen:4;
503f1d2b4d3SLarry Finger 
504f1d2b4d3SLarry Finger 	u32 txbuffaddr;
505f1d2b4d3SLarry Finger 	u32 txbufferaddr64;
506f1d2b4d3SLarry Finger 	u32 nextdescaddress;
507f1d2b4d3SLarry Finger 	u32 nextdescaddress64;
508f1d2b4d3SLarry Finger 
509f1d2b4d3SLarry Finger 	u32 reserve_pass_pcie_mm_limit[4];
510f1d2b4d3SLarry Finger } __packed;
511f1d2b4d3SLarry Finger 
512f1d2b4d3SLarry Finger void rtl92de_tx_fill_desc(struct ieee80211_hw *hw,
513f1d2b4d3SLarry Finger 			  struct ieee80211_hdr *hdr, u8 *pdesc,
514f1d2b4d3SLarry Finger 			  u8 *pbd_desc_tx, struct ieee80211_tx_info *info,
515f1d2b4d3SLarry Finger 			  struct ieee80211_sta *sta,
516f1d2b4d3SLarry Finger 			  struct sk_buff *skb, u8 hw_queue,
517f1d2b4d3SLarry Finger 			  struct rtl_tcb_desc *ptcb_desc);
518f1d2b4d3SLarry Finger bool rtl92de_rx_query_desc(struct ieee80211_hw *hw,
519f1d2b4d3SLarry Finger 			   struct rtl_stats *stats,
520f1d2b4d3SLarry Finger 			   struct ieee80211_rx_status *rx_status,
521f1d2b4d3SLarry Finger 			   u8 *pdesc, struct sk_buff *skb);
522f1d2b4d3SLarry Finger void rtl92de_set_desc(struct ieee80211_hw *hw, u8 *pdesc, bool istx,
523f1d2b4d3SLarry Finger 		      u8 desc_name, u8 *val);
5240c07bd74SPing-Ke Shih u64 rtl92de_get_desc(struct ieee80211_hw *hw,
5250c07bd74SPing-Ke Shih 		     u8 *p_desc, bool istx, u8 desc_name);
5263155db76SLarry Finger bool rtl92de_is_tx_desc_closed(struct ieee80211_hw *hw,
5273155db76SLarry Finger 			       u8 hw_queue, u16 index);
528f1d2b4d3SLarry Finger void rtl92de_tx_polling(struct ieee80211_hw *hw, u8 hw_queue);
529f1d2b4d3SLarry Finger void rtl92de_tx_fill_cmddesc(struct ieee80211_hw *hw, u8 *pdesc,
530f1d2b4d3SLarry Finger 			     bool b_firstseg, bool b_lastseg,
531f1d2b4d3SLarry Finger 			     struct sk_buff *skb);
532f1d2b4d3SLarry Finger 
533f1d2b4d3SLarry Finger #endif
534