1 // SPDX-License-Identifier: GPL-2.0
2 /* Copyright(c) 2009-2012  Realtek Corporation.*/
3 
4 #include "../wifi.h"
5 #include "../pci.h"
6 #include "../ps.h"
7 #include "../core.h"
8 #include "reg.h"
9 #include "def.h"
10 #include "phy.h"
11 #include "rf.h"
12 #include "dm.h"
13 #include "table.h"
14 #include "sw.h"
15 #include "hw.h"
16 
17 #define MAX_RF_IMR_INDEX			12
18 #define MAX_RF_IMR_INDEX_NORMAL			13
19 #define RF_REG_NUM_FOR_C_CUT_5G			6
20 #define RF_REG_NUM_FOR_C_CUT_5G_INTERNALPA	7
21 #define RF_REG_NUM_FOR_C_CUT_2G			5
22 #define RF_CHNL_NUM_5G				19
23 #define RF_CHNL_NUM_5G_40M			17
24 #define TARGET_CHNL_NUM_5G			221
25 #define TARGET_CHNL_NUM_2G			14
26 #define CV_CURVE_CNT				64
27 
28 static u32 rf_reg_for_5g_swchnl_normal[MAX_RF_IMR_INDEX_NORMAL] = {
29 	0, 0x2f, 0x30, 0x31, 0x32, 0x33, 0x34, 0x35, 0x36, 0x37, 0x38, 0x39, 0x0
30 };
31 
32 static u8 rf_reg_for_c_cut_5g[RF_REG_NUM_FOR_C_CUT_5G] = {
33 	RF_SYN_G1, RF_SYN_G2, RF_SYN_G3, RF_SYN_G4, RF_SYN_G5, RF_SYN_G6
34 };
35 
36 static u8 rf_reg_for_c_cut_2g[RF_REG_NUM_FOR_C_CUT_2G] = {
37 	RF_SYN_G1, RF_SYN_G2, RF_SYN_G3, RF_SYN_G7, RF_SYN_G8
38 };
39 
40 static u8 rf_for_c_cut_5g_internal_pa[RF_REG_NUM_FOR_C_CUT_5G_INTERNALPA] = {
41 	0x0B, 0x48, 0x49, 0x4B, 0x03, 0x04, 0x0E
42 };
43 
44 static u32 rf_reg_mask_for_c_cut_2g[RF_REG_NUM_FOR_C_CUT_2G] = {
45 	BIT(19) | BIT(18) | BIT(17) | BIT(14) | BIT(1),
46 	BIT(10) | BIT(9),
47 	BIT(18) | BIT(17) | BIT(16) | BIT(1),
48 	BIT(2) | BIT(1),
49 	BIT(15) | BIT(14) | BIT(13) | BIT(12) | BIT(11)
50 };
51 
52 static u8 rf_chnl_5g[RF_CHNL_NUM_5G] = {
53 	36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108,
54 	112, 116, 120, 124, 128, 132, 136, 140
55 };
56 
57 static u8 rf_chnl_5g_40m[RF_CHNL_NUM_5G_40M] = {
58 	38, 42, 46, 50, 54, 58, 62, 102, 106, 110, 114,
59 	118, 122, 126, 130, 134, 138
60 };
61 static u32 rf_reg_pram_c_5g[5][RF_REG_NUM_FOR_C_CUT_5G] = {
62 	{0xE43BE, 0xFC638, 0x77C0A, 0xDE471, 0xd7110, 0x8EB04},
63 	{0xE43BE, 0xFC078, 0xF7C1A, 0xE0C71, 0xD7550, 0xAEB04},
64 	{0xE43BF, 0xFF038, 0xF7C0A, 0xDE471, 0xE5550, 0xAEB04},
65 	{0xE43BF, 0xFF079, 0xF7C1A, 0xDE471, 0xE5550, 0xAEB04},
66 	{0xE43BF, 0xFF038, 0xF7C1A, 0xDE471, 0xd7550, 0xAEB04}
67 };
68 
69 static u32 rf_reg_param_for_c_cut_2g[3][RF_REG_NUM_FOR_C_CUT_2G] = {
70 	{0x643BC, 0xFC038, 0x77C1A, 0x41289, 0x01840},
71 	{0x643BC, 0xFC038, 0x07C1A, 0x41289, 0x01840},
72 	{0x243BC, 0xFC438, 0x07C1A, 0x4128B, 0x0FC41}
73 };
74 
75 static u32 rf_syn_g4_for_c_cut_2g = 0xD1C31 & 0x7FF;
76 
77 static u32 rf_pram_c_5g_int_pa[3][RF_REG_NUM_FOR_C_CUT_5G_INTERNALPA] = {
78 	{0x01a00, 0x40443, 0x00eb5, 0x89bec, 0x94a12, 0x94a12, 0x94a12},
79 	{0x01800, 0xc0443, 0x00730, 0x896ee, 0x94a52, 0x94a52, 0x94a52},
80 	{0x01800, 0xc0443, 0x00730, 0x896ee, 0x94a12, 0x94a12, 0x94a12}
81 };
82 
83 /* [mode][patha+b][reg] */
84 static u32 rf_imr_param_normal[1][3][MAX_RF_IMR_INDEX_NORMAL] = {
85 	{
86 		/* channel 1-14. */
87 		{
88 			0x70000, 0x00ff0, 0x4400f, 0x00ff0, 0x0, 0x0, 0x0,
89 			0x0, 0x0, 0x64888, 0xe266c, 0x00090, 0x22fff
90 		},
91 		/* path 36-64 */
92 		{
93 			0x70000, 0x22880, 0x4470f, 0x55880, 0x00070, 0x88000,
94 			0x0, 0x88080, 0x70000, 0x64a82, 0xe466c, 0x00090,
95 			0x32c9a
96 		},
97 		/* 100 -165 */
98 		{
99 			0x70000, 0x44880, 0x4477f, 0x77880, 0x00070, 0x88000,
100 			0x0, 0x880b0, 0x0, 0x64b82, 0xe466c, 0x00090, 0x32c9a
101 		}
102 	}
103 };
104 
105 static u32 curveindex_5g[TARGET_CHNL_NUM_5G] = {0};
106 
107 static u32 curveindex_2g[TARGET_CHNL_NUM_2G] = {0};
108 
109 static u32 targetchnl_5g[TARGET_CHNL_NUM_5G] = {
110 	25141, 25116, 25091, 25066, 25041,
111 	25016, 24991, 24966, 24941, 24917,
112 	24892, 24867, 24843, 24818, 24794,
113 	24770, 24765, 24721, 24697, 24672,
114 	24648, 24624, 24600, 24576, 24552,
115 	24528, 24504, 24480, 24457, 24433,
116 	24409, 24385, 24362, 24338, 24315,
117 	24291, 24268, 24245, 24221, 24198,
118 	24175, 24151, 24128, 24105, 24082,
119 	24059, 24036, 24013, 23990, 23967,
120 	23945, 23922, 23899, 23876, 23854,
121 	23831, 23809, 23786, 23764, 23741,
122 	23719, 23697, 23674, 23652, 23630,
123 	23608, 23586, 23564, 23541, 23519,
124 	23498, 23476, 23454, 23432, 23410,
125 	23388, 23367, 23345, 23323, 23302,
126 	23280, 23259, 23237, 23216, 23194,
127 	23173, 23152, 23130, 23109, 23088,
128 	23067, 23046, 23025, 23003, 22982,
129 	22962, 22941, 22920, 22899, 22878,
130 	22857, 22837, 22816, 22795, 22775,
131 	22754, 22733, 22713, 22692, 22672,
132 	22652, 22631, 22611, 22591, 22570,
133 	22550, 22530, 22510, 22490, 22469,
134 	22449, 22429, 22409, 22390, 22370,
135 	22350, 22336, 22310, 22290, 22271,
136 	22251, 22231, 22212, 22192, 22173,
137 	22153, 22134, 22114, 22095, 22075,
138 	22056, 22037, 22017, 21998, 21979,
139 	21960, 21941, 21921, 21902, 21883,
140 	21864, 21845, 21826, 21807, 21789,
141 	21770, 21751, 21732, 21713, 21695,
142 	21676, 21657, 21639, 21620, 21602,
143 	21583, 21565, 21546, 21528, 21509,
144 	21491, 21473, 21454, 21436, 21418,
145 	21400, 21381, 21363, 21345, 21327,
146 	21309, 21291, 21273, 21255, 21237,
147 	21219, 21201, 21183, 21166, 21148,
148 	21130, 21112, 21095, 21077, 21059,
149 	21042, 21024, 21007, 20989, 20972,
150 	25679, 25653, 25627, 25601, 25575,
151 	25549, 25523, 25497, 25471, 25446,
152 	25420, 25394, 25369, 25343, 25318,
153 	25292, 25267, 25242, 25216, 25191,
154 	25166
155 };
156 
157 /* channel 1~14 */
158 static u32 targetchnl_2g[TARGET_CHNL_NUM_2G] = {
159 	26084, 26030, 25976, 25923, 25869, 25816, 25764,
160 	25711, 25658, 25606, 25554, 25502, 25451, 25328
161 };
162 
163 static const u8 channel_all[59] = {
164 	1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14,
165 	36, 38, 40, 42, 44, 46, 48, 50, 52, 54, 56, 58,
166 	60, 62, 64, 100, 102, 104, 106, 108, 110, 112,
167 	114, 116, 118, 120, 122, 124, 126, 128,	130,
168 	132, 134, 136, 138, 140, 149, 151, 153, 155,
169 	157, 159, 161, 163, 165
170 };
171 
172 static u32 _rtl92d_phy_calculate_bit_shift(u32 bitmask)
173 {
174 	u32 i = ffs(bitmask);
175 
176 	return i ? i - 1 : 32;
177 }
178 
179 u32 rtl92d_phy_query_bb_reg(struct ieee80211_hw *hw, u32 regaddr, u32 bitmask)
180 {
181 	struct rtl_priv *rtlpriv = rtl_priv(hw);
182 	struct rtl_hal *rtlhal = rtl_hal(rtlpriv);
183 	u32 returnvalue, originalvalue, bitshift;
184 
185 	rtl_dbg(rtlpriv, COMP_RF, DBG_TRACE, "regaddr(%#x), bitmask(%#x)\n",
186 		regaddr, bitmask);
187 	if (rtlhal->during_mac1init_radioa || rtlhal->during_mac0init_radiob) {
188 		u8 dbi_direct = 0;
189 
190 		/* mac1 use phy0 read radio_b. */
191 		/* mac0 use phy1 read radio_b. */
192 		if (rtlhal->during_mac1init_radioa)
193 			dbi_direct = BIT(3);
194 		else if (rtlhal->during_mac0init_radiob)
195 			dbi_direct = BIT(3) | BIT(2);
196 		originalvalue = rtl92de_read_dword_dbi(hw, (u16)regaddr,
197 			dbi_direct);
198 	} else {
199 		originalvalue = rtl_read_dword(rtlpriv, regaddr);
200 	}
201 	bitshift = _rtl92d_phy_calculate_bit_shift(bitmask);
202 	returnvalue = (originalvalue & bitmask) >> bitshift;
203 	rtl_dbg(rtlpriv, COMP_RF, DBG_TRACE,
204 		"BBR MASK=0x%x Addr[0x%x]=0x%x\n",
205 		bitmask, regaddr, originalvalue);
206 	return returnvalue;
207 }
208 
209 void rtl92d_phy_set_bb_reg(struct ieee80211_hw *hw,
210 			   u32 regaddr, u32 bitmask, u32 data)
211 {
212 	struct rtl_priv *rtlpriv = rtl_priv(hw);
213 	struct rtl_hal *rtlhal = rtl_hal(rtlpriv);
214 	u8 dbi_direct = 0;
215 	u32 originalvalue, bitshift;
216 
217 	rtl_dbg(rtlpriv, COMP_RF, DBG_TRACE,
218 		"regaddr(%#x), bitmask(%#x), data(%#x)\n",
219 		regaddr, bitmask, data);
220 	if (rtlhal->during_mac1init_radioa)
221 		dbi_direct = BIT(3);
222 	else if (rtlhal->during_mac0init_radiob)
223 		/* mac0 use phy1 write radio_b. */
224 		dbi_direct = BIT(3) | BIT(2);
225 	if (bitmask != MASKDWORD) {
226 		if (rtlhal->during_mac1init_radioa ||
227 		    rtlhal->during_mac0init_radiob)
228 			originalvalue = rtl92de_read_dword_dbi(hw,
229 					(u16) regaddr,
230 					dbi_direct);
231 		else
232 			originalvalue = rtl_read_dword(rtlpriv, regaddr);
233 		bitshift = _rtl92d_phy_calculate_bit_shift(bitmask);
234 		data = ((originalvalue & (~bitmask)) | (data << bitshift));
235 	}
236 	if (rtlhal->during_mac1init_radioa || rtlhal->during_mac0init_radiob)
237 		rtl92de_write_dword_dbi(hw, (u16) regaddr, data, dbi_direct);
238 	else
239 		rtl_write_dword(rtlpriv, regaddr, data);
240 	rtl_dbg(rtlpriv, COMP_RF, DBG_TRACE,
241 		"regaddr(%#x), bitmask(%#x), data(%#x)\n",
242 		regaddr, bitmask, data);
243 }
244 
245 static u32 _rtl92d_phy_rf_serial_read(struct ieee80211_hw *hw,
246 				      enum radio_path rfpath, u32 offset)
247 {
248 
249 	struct rtl_priv *rtlpriv = rtl_priv(hw);
250 	struct rtl_phy *rtlphy = &(rtlpriv->phy);
251 	struct bb_reg_def *pphyreg = &rtlphy->phyreg_def[rfpath];
252 	u32 newoffset;
253 	u32 tmplong, tmplong2;
254 	u8 rfpi_enable = 0;
255 	u32 retvalue;
256 
257 	newoffset = offset;
258 	tmplong = rtl_get_bbreg(hw, RFPGA0_XA_HSSIPARAMETER2, MASKDWORD);
259 	if (rfpath == RF90_PATH_A)
260 		tmplong2 = tmplong;
261 	else
262 		tmplong2 = rtl_get_bbreg(hw, pphyreg->rfhssi_para2, MASKDWORD);
263 	tmplong2 = (tmplong2 & (~BLSSIREADADDRESS)) |
264 		(newoffset << 23) | BLSSIREADEDGE;
265 	rtl_set_bbreg(hw, RFPGA0_XA_HSSIPARAMETER2, MASKDWORD,
266 		tmplong & (~BLSSIREADEDGE));
267 	udelay(10);
268 	rtl_set_bbreg(hw, pphyreg->rfhssi_para2, MASKDWORD, tmplong2);
269 	udelay(50);
270 	udelay(50);
271 	rtl_set_bbreg(hw, RFPGA0_XA_HSSIPARAMETER2, MASKDWORD,
272 		tmplong | BLSSIREADEDGE);
273 	udelay(10);
274 	if (rfpath == RF90_PATH_A)
275 		rfpi_enable = (u8) rtl_get_bbreg(hw, RFPGA0_XA_HSSIPARAMETER1,
276 			      BIT(8));
277 	else if (rfpath == RF90_PATH_B)
278 		rfpi_enable = (u8) rtl_get_bbreg(hw, RFPGA0_XB_HSSIPARAMETER1,
279 			      BIT(8));
280 	if (rfpi_enable)
281 		retvalue = rtl_get_bbreg(hw, pphyreg->rf_rbpi,
282 			BLSSIREADBACKDATA);
283 	else
284 		retvalue = rtl_get_bbreg(hw, pphyreg->rf_rb,
285 			BLSSIREADBACKDATA);
286 	rtl_dbg(rtlpriv, COMP_RF, DBG_TRACE, "RFR-%d Addr[0x%x] = 0x%x\n",
287 		rfpath, pphyreg->rf_rb, retvalue);
288 	return retvalue;
289 }
290 
291 static void _rtl92d_phy_rf_serial_write(struct ieee80211_hw *hw,
292 					enum radio_path rfpath,
293 					u32 offset, u32 data)
294 {
295 	u32 data_and_addr;
296 	u32 newoffset;
297 	struct rtl_priv *rtlpriv = rtl_priv(hw);
298 	struct rtl_phy *rtlphy = &(rtlpriv->phy);
299 	struct bb_reg_def *pphyreg = &rtlphy->phyreg_def[rfpath];
300 
301 	newoffset = offset;
302 	/* T65 RF */
303 	data_and_addr = ((newoffset << 20) | (data & 0x000fffff)) & 0x0fffffff;
304 	rtl_set_bbreg(hw, pphyreg->rf3wire_offset, MASKDWORD, data_and_addr);
305 	rtl_dbg(rtlpriv, COMP_RF, DBG_TRACE, "RFW-%d Addr[0x%x]=0x%x\n",
306 		rfpath, pphyreg->rf3wire_offset, data_and_addr);
307 }
308 
309 u32 rtl92d_phy_query_rf_reg(struct ieee80211_hw *hw,
310 			    enum radio_path rfpath, u32 regaddr, u32 bitmask)
311 {
312 	struct rtl_priv *rtlpriv = rtl_priv(hw);
313 	u32 original_value, readback_value, bitshift;
314 
315 	rtl_dbg(rtlpriv, COMP_RF, DBG_TRACE,
316 		"regaddr(%#x), rfpath(%#x), bitmask(%#x)\n",
317 		regaddr, rfpath, bitmask);
318 	spin_lock(&rtlpriv->locks.rf_lock);
319 	original_value = _rtl92d_phy_rf_serial_read(hw, rfpath, regaddr);
320 	bitshift = _rtl92d_phy_calculate_bit_shift(bitmask);
321 	readback_value = (original_value & bitmask) >> bitshift;
322 	spin_unlock(&rtlpriv->locks.rf_lock);
323 	rtl_dbg(rtlpriv, COMP_RF, DBG_TRACE,
324 		"regaddr(%#x), rfpath(%#x), bitmask(%#x), original_value(%#x)\n",
325 		regaddr, rfpath, bitmask, original_value);
326 	return readback_value;
327 }
328 
329 void rtl92d_phy_set_rf_reg(struct ieee80211_hw *hw, enum radio_path rfpath,
330 	u32 regaddr, u32 bitmask, u32 data)
331 {
332 	struct rtl_priv *rtlpriv = rtl_priv(hw);
333 	struct rtl_phy *rtlphy = &(rtlpriv->phy);
334 	u32 original_value, bitshift;
335 
336 	rtl_dbg(rtlpriv, COMP_RF, DBG_TRACE,
337 		"regaddr(%#x), bitmask(%#x), data(%#x), rfpath(%#x)\n",
338 		regaddr, bitmask, data, rfpath);
339 	if (bitmask == 0)
340 		return;
341 	spin_lock(&rtlpriv->locks.rf_lock);
342 	if (rtlphy->rf_mode != RF_OP_BY_FW) {
343 		if (bitmask != RFREG_OFFSET_MASK) {
344 			original_value = _rtl92d_phy_rf_serial_read(hw,
345 				rfpath, regaddr);
346 			bitshift = _rtl92d_phy_calculate_bit_shift(bitmask);
347 			data = ((original_value & (~bitmask)) |
348 				(data << bitshift));
349 		}
350 		_rtl92d_phy_rf_serial_write(hw, rfpath, regaddr, data);
351 	}
352 	spin_unlock(&rtlpriv->locks.rf_lock);
353 	rtl_dbg(rtlpriv, COMP_RF, DBG_TRACE,
354 		"regaddr(%#x), bitmask(%#x), data(%#x), rfpath(%#x)\n",
355 		regaddr, bitmask, data, rfpath);
356 }
357 
358 bool rtl92d_phy_mac_config(struct ieee80211_hw *hw)
359 {
360 	struct rtl_priv *rtlpriv = rtl_priv(hw);
361 	u32 i;
362 	u32 arraylength;
363 	u32 *ptrarray;
364 
365 	rtl_dbg(rtlpriv, COMP_INIT, DBG_TRACE, "Read Rtl819XMACPHY_Array\n");
366 	arraylength = MAC_2T_ARRAYLENGTH;
367 	ptrarray = rtl8192de_mac_2tarray;
368 	rtl_dbg(rtlpriv, COMP_INIT, DBG_TRACE, "Img:Rtl819XMAC_Array\n");
369 	for (i = 0; i < arraylength; i = i + 2)
370 		rtl_write_byte(rtlpriv, ptrarray[i], (u8) ptrarray[i + 1]);
371 	if (rtlpriv->rtlhal.macphymode == SINGLEMAC_SINGLEPHY) {
372 		/* improve 2-stream TX EVM */
373 		/* rtl_write_byte(rtlpriv, 0x14,0x71); */
374 		/* AMPDU aggregation number 9 */
375 		/* rtl_write_word(rtlpriv, REG_MAX_AGGR_NUM, MAX_AGGR_NUM); */
376 		rtl_write_byte(rtlpriv, REG_MAX_AGGR_NUM, 0x0B);
377 	} else {
378 		/* 92D need to test to decide the num. */
379 		rtl_write_byte(rtlpriv, REG_MAX_AGGR_NUM, 0x07);
380 	}
381 	return true;
382 }
383 
384 static void _rtl92d_phy_init_bb_rf_register_definition(struct ieee80211_hw *hw)
385 {
386 	struct rtl_priv *rtlpriv = rtl_priv(hw);
387 	struct rtl_phy *rtlphy = &(rtlpriv->phy);
388 
389 	/* RF Interface Sowrtware Control */
390 	/* 16 LSBs if read 32-bit from 0x870 */
391 	rtlphy->phyreg_def[RF90_PATH_A].rfintfs = RFPGA0_XAB_RFINTERFACESW;
392 	/* 16 MSBs if read 32-bit from 0x870 (16-bit for 0x872) */
393 	rtlphy->phyreg_def[RF90_PATH_B].rfintfs = RFPGA0_XAB_RFINTERFACESW;
394 	/* 16 LSBs if read 32-bit from 0x874 */
395 	rtlphy->phyreg_def[RF90_PATH_C].rfintfs = RFPGA0_XCD_RFINTERFACESW;
396 	/* 16 MSBs if read 32-bit from 0x874 (16-bit for 0x876) */
397 
398 	rtlphy->phyreg_def[RF90_PATH_D].rfintfs = RFPGA0_XCD_RFINTERFACESW;
399 	/* RF Interface Readback Value */
400 	/* 16 LSBs if read 32-bit from 0x8E0 */
401 	rtlphy->phyreg_def[RF90_PATH_A].rfintfi = RFPGA0_XAB_RFINTERFACERB;
402 	/* 16 MSBs if read 32-bit from 0x8E0 (16-bit for 0x8E2) */
403 	rtlphy->phyreg_def[RF90_PATH_B].rfintfi = RFPGA0_XAB_RFINTERFACERB;
404 	/* 16 LSBs if read 32-bit from 0x8E4 */
405 	rtlphy->phyreg_def[RF90_PATH_C].rfintfi = RFPGA0_XCD_RFINTERFACERB;
406 	/* 16 MSBs if read 32-bit from 0x8E4 (16-bit for 0x8E6) */
407 	rtlphy->phyreg_def[RF90_PATH_D].rfintfi = RFPGA0_XCD_RFINTERFACERB;
408 
409 	/* RF Interface Output (and Enable) */
410 	/* 16 LSBs if read 32-bit from 0x860 */
411 	rtlphy->phyreg_def[RF90_PATH_A].rfintfo = RFPGA0_XA_RFINTERFACEOE;
412 	/* 16 LSBs if read 32-bit from 0x864 */
413 	rtlphy->phyreg_def[RF90_PATH_B].rfintfo = RFPGA0_XB_RFINTERFACEOE;
414 
415 	/* RF Interface (Output and)  Enable */
416 	/* 16 MSBs if read 32-bit from 0x860 (16-bit for 0x862) */
417 	rtlphy->phyreg_def[RF90_PATH_A].rfintfe = RFPGA0_XA_RFINTERFACEOE;
418 	/* 16 MSBs if read 32-bit from 0x864 (16-bit for 0x866) */
419 	rtlphy->phyreg_def[RF90_PATH_B].rfintfe = RFPGA0_XB_RFINTERFACEOE;
420 
421 	/* Addr of LSSI. Wirte RF register by driver */
422 	/* LSSI Parameter */
423 	rtlphy->phyreg_def[RF90_PATH_A].rf3wire_offset =
424 				 RFPGA0_XA_LSSIPARAMETER;
425 	rtlphy->phyreg_def[RF90_PATH_B].rf3wire_offset =
426 				 RFPGA0_XB_LSSIPARAMETER;
427 
428 	/* RF parameter */
429 	/* BB Band Select */
430 	rtlphy->phyreg_def[RF90_PATH_A].rflssi_select = RFPGA0_XAB_RFPARAMETER;
431 	rtlphy->phyreg_def[RF90_PATH_B].rflssi_select = RFPGA0_XAB_RFPARAMETER;
432 	rtlphy->phyreg_def[RF90_PATH_C].rflssi_select = RFPGA0_XCD_RFPARAMETER;
433 	rtlphy->phyreg_def[RF90_PATH_D].rflssi_select = RFPGA0_XCD_RFPARAMETER;
434 
435 	/* Tx AGC Gain Stage (same for all path. Should we remove this?) */
436 	/* Tx gain stage */
437 	rtlphy->phyreg_def[RF90_PATH_A].rftxgain_stage = RFPGA0_TXGAINSTAGE;
438 	/* Tx gain stage */
439 	rtlphy->phyreg_def[RF90_PATH_B].rftxgain_stage = RFPGA0_TXGAINSTAGE;
440 	/* Tx gain stage */
441 	rtlphy->phyreg_def[RF90_PATH_C].rftxgain_stage = RFPGA0_TXGAINSTAGE;
442 	/* Tx gain stage */
443 	rtlphy->phyreg_def[RF90_PATH_D].rftxgain_stage = RFPGA0_TXGAINSTAGE;
444 
445 	/* Tranceiver A~D HSSI Parameter-1 */
446 	/* wire control parameter1 */
447 	rtlphy->phyreg_def[RF90_PATH_A].rfhssi_para1 = RFPGA0_XA_HSSIPARAMETER1;
448 	/* wire control parameter1 */
449 	rtlphy->phyreg_def[RF90_PATH_B].rfhssi_para1 = RFPGA0_XB_HSSIPARAMETER1;
450 
451 	/* Tranceiver A~D HSSI Parameter-2 */
452 	/* wire control parameter2 */
453 	rtlphy->phyreg_def[RF90_PATH_A].rfhssi_para2 = RFPGA0_XA_HSSIPARAMETER2;
454 	/* wire control parameter2 */
455 	rtlphy->phyreg_def[RF90_PATH_B].rfhssi_para2 = RFPGA0_XB_HSSIPARAMETER2;
456 
457 	/* RF switch Control */
458 	/* TR/Ant switch control */
459 	rtlphy->phyreg_def[RF90_PATH_A].rfsw_ctrl = RFPGA0_XAB_SWITCHCONTROL;
460 	rtlphy->phyreg_def[RF90_PATH_B].rfsw_ctrl = RFPGA0_XAB_SWITCHCONTROL;
461 	rtlphy->phyreg_def[RF90_PATH_C].rfsw_ctrl = RFPGA0_XCD_SWITCHCONTROL;
462 	rtlphy->phyreg_def[RF90_PATH_D].rfsw_ctrl = RFPGA0_XCD_SWITCHCONTROL;
463 
464 	/* AGC control 1 */
465 	rtlphy->phyreg_def[RF90_PATH_A].rfagc_control1 = ROFDM0_XAAGCCORE1;
466 	rtlphy->phyreg_def[RF90_PATH_B].rfagc_control1 = ROFDM0_XBAGCCORE1;
467 	rtlphy->phyreg_def[RF90_PATH_C].rfagc_control1 = ROFDM0_XCAGCCORE1;
468 	rtlphy->phyreg_def[RF90_PATH_D].rfagc_control1 = ROFDM0_XDAGCCORE1;
469 
470 	/* AGC control 2  */
471 	rtlphy->phyreg_def[RF90_PATH_A].rfagc_control2 = ROFDM0_XAAGCCORE2;
472 	rtlphy->phyreg_def[RF90_PATH_B].rfagc_control2 = ROFDM0_XBAGCCORE2;
473 	rtlphy->phyreg_def[RF90_PATH_C].rfagc_control2 = ROFDM0_XCAGCCORE2;
474 	rtlphy->phyreg_def[RF90_PATH_D].rfagc_control2 = ROFDM0_XDAGCCORE2;
475 
476 	/* RX AFE control 1 */
477 	rtlphy->phyreg_def[RF90_PATH_A].rfrxiq_imbal = ROFDM0_XARXIQIMBALANCE;
478 	rtlphy->phyreg_def[RF90_PATH_B].rfrxiq_imbal = ROFDM0_XBRXIQIMBALANCE;
479 	rtlphy->phyreg_def[RF90_PATH_C].rfrxiq_imbal = ROFDM0_XCRXIQIMBALANCE;
480 	rtlphy->phyreg_def[RF90_PATH_D].rfrxiq_imbal = ROFDM0_XDRXIQIMBALANCE;
481 
482 	/*RX AFE control 1 */
483 	rtlphy->phyreg_def[RF90_PATH_A].rfrx_afe = ROFDM0_XARXAFE;
484 	rtlphy->phyreg_def[RF90_PATH_B].rfrx_afe = ROFDM0_XBRXAFE;
485 	rtlphy->phyreg_def[RF90_PATH_C].rfrx_afe = ROFDM0_XCRXAFE;
486 	rtlphy->phyreg_def[RF90_PATH_D].rfrx_afe = ROFDM0_XDRXAFE;
487 
488 	/* Tx AFE control 1 */
489 	rtlphy->phyreg_def[RF90_PATH_A].rftxiq_imbal = ROFDM0_XATXIQIMBALANCE;
490 	rtlphy->phyreg_def[RF90_PATH_B].rftxiq_imbal = ROFDM0_XBTXIQIMBALANCE;
491 	rtlphy->phyreg_def[RF90_PATH_C].rftxiq_imbal = ROFDM0_XCTXIQIMBALANCE;
492 	rtlphy->phyreg_def[RF90_PATH_D].rftxiq_imbal = ROFDM0_XDTXIQIMBALANCE;
493 
494 	/* Tx AFE control 2 */
495 	rtlphy->phyreg_def[RF90_PATH_A].rftx_afe = ROFDM0_XATXAFE;
496 	rtlphy->phyreg_def[RF90_PATH_B].rftx_afe = ROFDM0_XBTXAFE;
497 	rtlphy->phyreg_def[RF90_PATH_C].rftx_afe = ROFDM0_XCTXAFE;
498 	rtlphy->phyreg_def[RF90_PATH_D].rftx_afe = ROFDM0_XDTXAFE;
499 
500 	/* Tranceiver LSSI Readback SI mode */
501 	rtlphy->phyreg_def[RF90_PATH_A].rf_rb = RFPGA0_XA_LSSIREADBACK;
502 	rtlphy->phyreg_def[RF90_PATH_B].rf_rb = RFPGA0_XB_LSSIREADBACK;
503 	rtlphy->phyreg_def[RF90_PATH_C].rf_rb = RFPGA0_XC_LSSIREADBACK;
504 	rtlphy->phyreg_def[RF90_PATH_D].rf_rb = RFPGA0_XD_LSSIREADBACK;
505 
506 	/* Tranceiver LSSI Readback PI mode */
507 	rtlphy->phyreg_def[RF90_PATH_A].rf_rbpi = TRANSCEIVERA_HSPI_READBACK;
508 	rtlphy->phyreg_def[RF90_PATH_B].rf_rbpi = TRANSCEIVERB_HSPI_READBACK;
509 }
510 
511 static bool _rtl92d_phy_config_bb_with_headerfile(struct ieee80211_hw *hw,
512 	u8 configtype)
513 {
514 	int i;
515 	u32 *phy_regarray_table;
516 	u32 *agctab_array_table = NULL;
517 	u32 *agctab_5garray_table;
518 	u16 phy_reg_arraylen, agctab_arraylen = 0, agctab_5garraylen;
519 	struct rtl_priv *rtlpriv = rtl_priv(hw);
520 	struct rtl_hal *rtlhal = rtl_hal(rtl_priv(hw));
521 
522 	/* Normal chip,Mac0 use AGC_TAB.txt for 2G and 5G band. */
523 	if (rtlhal->interfaceindex == 0) {
524 		agctab_arraylen = AGCTAB_ARRAYLENGTH;
525 		agctab_array_table = rtl8192de_agctab_array;
526 		rtl_dbg(rtlpriv, COMP_INIT, DBG_LOUD,
527 			" ===> phy:MAC0, Rtl819XAGCTAB_Array\n");
528 	} else {
529 		if (rtlhal->current_bandtype == BAND_ON_2_4G) {
530 			agctab_arraylen = AGCTAB_2G_ARRAYLENGTH;
531 			agctab_array_table = rtl8192de_agctab_2garray;
532 			rtl_dbg(rtlpriv, COMP_INIT, DBG_LOUD,
533 				" ===> phy:MAC1, Rtl819XAGCTAB_2GArray\n");
534 		} else {
535 			agctab_5garraylen = AGCTAB_5G_ARRAYLENGTH;
536 			agctab_5garray_table = rtl8192de_agctab_5garray;
537 			rtl_dbg(rtlpriv, COMP_INIT, DBG_LOUD,
538 				" ===> phy:MAC1, Rtl819XAGCTAB_5GArray\n");
539 
540 		}
541 	}
542 	phy_reg_arraylen = PHY_REG_2T_ARRAYLENGTH;
543 	phy_regarray_table = rtl8192de_phy_reg_2tarray;
544 	rtl_dbg(rtlpriv, COMP_INIT, DBG_LOUD,
545 		" ===> phy:Rtl819XPHY_REG_Array_PG\n");
546 	if (configtype == BASEBAND_CONFIG_PHY_REG) {
547 		for (i = 0; i < phy_reg_arraylen; i = i + 2) {
548 			rtl_addr_delay(phy_regarray_table[i]);
549 			rtl_set_bbreg(hw, phy_regarray_table[i], MASKDWORD,
550 				      phy_regarray_table[i + 1]);
551 			udelay(1);
552 			rtl_dbg(rtlpriv, COMP_INIT, DBG_TRACE,
553 				"The phy_regarray_table[0] is %x Rtl819XPHY_REGArray[1] is %x\n",
554 				phy_regarray_table[i],
555 				phy_regarray_table[i + 1]);
556 		}
557 	} else if (configtype == BASEBAND_CONFIG_AGC_TAB) {
558 		if (rtlhal->interfaceindex == 0) {
559 			for (i = 0; i < agctab_arraylen; i = i + 2) {
560 				rtl_set_bbreg(hw, agctab_array_table[i],
561 					MASKDWORD,
562 					agctab_array_table[i + 1]);
563 				/* Add 1us delay between BB/RF register
564 				 * setting. */
565 				udelay(1);
566 				rtl_dbg(rtlpriv, COMP_INIT, DBG_TRACE,
567 					"The Rtl819XAGCTAB_Array_Table[0] is %u Rtl819XPHY_REGArray[1] is %u\n",
568 					agctab_array_table[i],
569 					agctab_array_table[i + 1]);
570 			}
571 			rtl_dbg(rtlpriv, COMP_INIT, DBG_LOUD,
572 				"Normal Chip, MAC0, load Rtl819XAGCTAB_Array\n");
573 		} else {
574 			if (rtlhal->current_bandtype == BAND_ON_2_4G) {
575 				for (i = 0; i < agctab_arraylen; i = i + 2) {
576 					rtl_set_bbreg(hw, agctab_array_table[i],
577 						MASKDWORD,
578 						agctab_array_table[i + 1]);
579 					/* Add 1us delay between BB/RF register
580 					 * setting. */
581 					udelay(1);
582 					rtl_dbg(rtlpriv, COMP_INIT, DBG_TRACE,
583 						"The Rtl819XAGCTAB_Array_Table[0] is %u Rtl819XPHY_REGArray[1] is %u\n",
584 						agctab_array_table[i],
585 						agctab_array_table[i + 1]);
586 				}
587 				rtl_dbg(rtlpriv, COMP_INIT, DBG_LOUD,
588 					"Load Rtl819XAGCTAB_2GArray\n");
589 			} else {
590 				for (i = 0; i < agctab_5garraylen; i = i + 2) {
591 					rtl_set_bbreg(hw,
592 						agctab_5garray_table[i],
593 						MASKDWORD,
594 						agctab_5garray_table[i + 1]);
595 					/* Add 1us delay between BB/RF registeri
596 					 * setting. */
597 					udelay(1);
598 					rtl_dbg(rtlpriv, COMP_INIT, DBG_TRACE,
599 						"The Rtl819XAGCTAB_5GArray_Table[0] is %u Rtl819XPHY_REGArray[1] is %u\n",
600 						agctab_5garray_table[i],
601 						agctab_5garray_table[i + 1]);
602 				}
603 				rtl_dbg(rtlpriv, COMP_INIT, DBG_LOUD,
604 					"Load Rtl819XAGCTAB_5GArray\n");
605 			}
606 		}
607 	}
608 	return true;
609 }
610 
611 static void _rtl92d_store_pwrindex_diffrate_offset(struct ieee80211_hw *hw,
612 						   u32 regaddr, u32 bitmask,
613 						   u32 data)
614 {
615 	struct rtl_priv *rtlpriv = rtl_priv(hw);
616 	struct rtl_phy *rtlphy = &(rtlpriv->phy);
617 	int index;
618 
619 	if (regaddr == RTXAGC_A_RATE18_06)
620 		index = 0;
621 	else if (regaddr == RTXAGC_A_RATE54_24)
622 		index = 1;
623 	else if (regaddr == RTXAGC_A_CCK1_MCS32)
624 		index = 6;
625 	else if (regaddr == RTXAGC_B_CCK11_A_CCK2_11 && bitmask == 0xffffff00)
626 		index = 7;
627 	else if (regaddr == RTXAGC_A_MCS03_MCS00)
628 		index = 2;
629 	else if (regaddr == RTXAGC_A_MCS07_MCS04)
630 		index = 3;
631 	else if (regaddr == RTXAGC_A_MCS11_MCS08)
632 		index = 4;
633 	else if (regaddr == RTXAGC_A_MCS15_MCS12)
634 		index = 5;
635 	else if (regaddr == RTXAGC_B_RATE18_06)
636 		index = 8;
637 	else if (regaddr == RTXAGC_B_RATE54_24)
638 		index = 9;
639 	else if (regaddr == RTXAGC_B_CCK1_55_MCS32)
640 		index = 14;
641 	else if (regaddr == RTXAGC_B_CCK11_A_CCK2_11 && bitmask == 0x000000ff)
642 		index = 15;
643 	else if (regaddr == RTXAGC_B_MCS03_MCS00)
644 		index = 10;
645 	else if (regaddr == RTXAGC_B_MCS07_MCS04)
646 		index = 11;
647 	else if (regaddr == RTXAGC_B_MCS11_MCS08)
648 		index = 12;
649 	else if (regaddr == RTXAGC_B_MCS15_MCS12)
650 		index = 13;
651 	else
652 		return;
653 
654 	rtlphy->mcs_offset[rtlphy->pwrgroup_cnt][index] = data;
655 	rtl_dbg(rtlpriv, COMP_INIT, DBG_TRACE,
656 		"MCSTxPowerLevelOriginalOffset[%d][%d] = 0x%x\n",
657 		rtlphy->pwrgroup_cnt, index,
658 		rtlphy->mcs_offset[rtlphy->pwrgroup_cnt][index]);
659 	if (index == 13)
660 		rtlphy->pwrgroup_cnt++;
661 }
662 
663 static bool _rtl92d_phy_config_bb_with_pgheaderfile(struct ieee80211_hw *hw,
664 	u8 configtype)
665 {
666 	struct rtl_priv *rtlpriv = rtl_priv(hw);
667 	int i;
668 	u32 *phy_regarray_table_pg;
669 	u16 phy_regarray_pg_len;
670 
671 	phy_regarray_pg_len = PHY_REG_ARRAY_PG_LENGTH;
672 	phy_regarray_table_pg = rtl8192de_phy_reg_array_pg;
673 	if (configtype == BASEBAND_CONFIG_PHY_REG) {
674 		for (i = 0; i < phy_regarray_pg_len; i = i + 3) {
675 			rtl_addr_delay(phy_regarray_table_pg[i]);
676 			_rtl92d_store_pwrindex_diffrate_offset(hw,
677 				phy_regarray_table_pg[i],
678 				phy_regarray_table_pg[i + 1],
679 				phy_regarray_table_pg[i + 2]);
680 		}
681 	} else {
682 		rtl_dbg(rtlpriv, COMP_SEND, DBG_TRACE,
683 			"configtype != BaseBand_Config_PHY_REG\n");
684 	}
685 	return true;
686 }
687 
688 static bool _rtl92d_phy_bb_config(struct ieee80211_hw *hw)
689 {
690 	struct rtl_priv *rtlpriv = rtl_priv(hw);
691 	struct rtl_phy *rtlphy = &(rtlpriv->phy);
692 	struct rtl_efuse *rtlefuse = rtl_efuse(rtl_priv(hw));
693 	bool rtstatus;
694 
695 	rtl_dbg(rtlpriv, COMP_INIT, DBG_TRACE, "==>\n");
696 	rtstatus = _rtl92d_phy_config_bb_with_headerfile(hw,
697 		BASEBAND_CONFIG_PHY_REG);
698 	if (!rtstatus) {
699 		pr_err("Write BB Reg Fail!!\n");
700 		return false;
701 	}
702 
703 	/* if (rtlphy->rf_type == RF_1T2R) {
704 	 *      _rtl92c_phy_bb_config_1t(hw);
705 	 *     rtl_dbg(rtlpriv, COMP_INIT, DBG_TRACE, "Config to 1T!!\n");
706 	 *} */
707 
708 	if (rtlefuse->autoload_failflag == false) {
709 		rtlphy->pwrgroup_cnt = 0;
710 		rtstatus = _rtl92d_phy_config_bb_with_pgheaderfile(hw,
711 			BASEBAND_CONFIG_PHY_REG);
712 	}
713 	if (!rtstatus) {
714 		pr_err("BB_PG Reg Fail!!\n");
715 		return false;
716 	}
717 	rtstatus = _rtl92d_phy_config_bb_with_headerfile(hw,
718 		BASEBAND_CONFIG_AGC_TAB);
719 	if (!rtstatus) {
720 		pr_err("AGC Table Fail\n");
721 		return false;
722 	}
723 	rtlphy->cck_high_power = (bool) (rtl_get_bbreg(hw,
724 		RFPGA0_XA_HSSIPARAMETER2, 0x200));
725 
726 	return true;
727 }
728 
729 bool rtl92d_phy_bb_config(struct ieee80211_hw *hw)
730 {
731 	struct rtl_priv *rtlpriv = rtl_priv(hw);
732 	u16 regval;
733 	u32 regvaldw;
734 	u8 value;
735 
736 	_rtl92d_phy_init_bb_rf_register_definition(hw);
737 	regval = rtl_read_word(rtlpriv, REG_SYS_FUNC_EN);
738 	rtl_write_word(rtlpriv, REG_SYS_FUNC_EN,
739 		       regval | BIT(13) | BIT(0) | BIT(1));
740 	rtl_write_byte(rtlpriv, REG_AFE_PLL_CTRL, 0x83);
741 	rtl_write_byte(rtlpriv, REG_AFE_PLL_CTRL + 1, 0xdb);
742 	/* 0x1f bit7 bit6 represent for mac0/mac1 driver ready */
743 	value = rtl_read_byte(rtlpriv, REG_RF_CTRL);
744 	rtl_write_byte(rtlpriv, REG_RF_CTRL, value | RF_EN | RF_RSTB |
745 		RF_SDMRSTB);
746 	rtl_write_byte(rtlpriv, REG_SYS_FUNC_EN, FEN_PPLL | FEN_PCIEA |
747 		FEN_DIO_PCIE | FEN_BB_GLB_RSTN | FEN_BBRSTB);
748 	rtl_write_byte(rtlpriv, REG_AFE_XTAL_CTRL + 1, 0x80);
749 	if (!(IS_92D_SINGLEPHY(rtlpriv->rtlhal.version))) {
750 		regvaldw = rtl_read_dword(rtlpriv, REG_LEDCFG0);
751 		rtl_write_dword(rtlpriv, REG_LEDCFG0, regvaldw | BIT(23));
752 	}
753 
754 	return _rtl92d_phy_bb_config(hw);
755 }
756 
757 bool rtl92d_phy_rf_config(struct ieee80211_hw *hw)
758 {
759 	return rtl92d_phy_rf6052_config(hw);
760 }
761 
762 bool rtl92d_phy_config_rf_with_headerfile(struct ieee80211_hw *hw,
763 					  enum rf_content content,
764 					  enum radio_path rfpath)
765 {
766 	int i;
767 	u32 *radioa_array_table;
768 	u32 *radiob_array_table;
769 	u16 radioa_arraylen, radiob_arraylen;
770 	struct rtl_priv *rtlpriv = rtl_priv(hw);
771 
772 	radioa_arraylen = RADIOA_2T_ARRAYLENGTH;
773 	radioa_array_table = rtl8192de_radioa_2tarray;
774 	radiob_arraylen = RADIOB_2T_ARRAYLENGTH;
775 	radiob_array_table = rtl8192de_radiob_2tarray;
776 	if (rtlpriv->efuse.internal_pa_5g[0]) {
777 		radioa_arraylen = RADIOA_2T_INT_PA_ARRAYLENGTH;
778 		radioa_array_table = rtl8192de_radioa_2t_int_paarray;
779 	}
780 	if (rtlpriv->efuse.internal_pa_5g[1]) {
781 		radiob_arraylen = RADIOB_2T_INT_PA_ARRAYLENGTH;
782 		radiob_array_table = rtl8192de_radiob_2t_int_paarray;
783 	}
784 	rtl_dbg(rtlpriv, COMP_INIT, DBG_LOUD,
785 		"PHY_ConfigRFWithHeaderFile() Radio_A:Rtl819XRadioA_1TArray\n");
786 	rtl_dbg(rtlpriv, COMP_INIT, DBG_LOUD,
787 		"PHY_ConfigRFWithHeaderFile() Radio_B:Rtl819XRadioB_1TArray\n");
788 	rtl_dbg(rtlpriv, COMP_INIT, DBG_TRACE, "Radio No %x\n", rfpath);
789 
790 	/* this only happens when DMDP, mac0 start on 2.4G,
791 	 * mac1 start on 5G, mac 0 has to set phy0&phy1
792 	 * pathA or mac1 has to set phy0&phy1 pathA */
793 	if ((content == radiob_txt) && (rfpath == RF90_PATH_A)) {
794 		rtl_dbg(rtlpriv, COMP_INIT, DBG_LOUD,
795 			" ===> althougth Path A, we load radiob.txt\n");
796 		radioa_arraylen = radiob_arraylen;
797 		radioa_array_table = radiob_array_table;
798 	}
799 	switch (rfpath) {
800 	case RF90_PATH_A:
801 		for (i = 0; i < radioa_arraylen; i = i + 2) {
802 			rtl_rfreg_delay(hw, rfpath, radioa_array_table[i],
803 					RFREG_OFFSET_MASK,
804 					radioa_array_table[i + 1]);
805 		}
806 		break;
807 	case RF90_PATH_B:
808 		for (i = 0; i < radiob_arraylen; i = i + 2) {
809 			rtl_rfreg_delay(hw, rfpath, radiob_array_table[i],
810 					RFREG_OFFSET_MASK,
811 					radiob_array_table[i + 1]);
812 		}
813 		break;
814 	case RF90_PATH_C:
815 	case RF90_PATH_D:
816 		pr_err("switch case %#x not processed\n", rfpath);
817 		break;
818 	}
819 	return true;
820 }
821 
822 void rtl92d_phy_get_hw_reg_originalvalue(struct ieee80211_hw *hw)
823 {
824 	struct rtl_priv *rtlpriv = rtl_priv(hw);
825 	struct rtl_phy *rtlphy = &(rtlpriv->phy);
826 
827 	rtlphy->default_initialgain[0] =
828 	    (u8) rtl_get_bbreg(hw, ROFDM0_XAAGCCORE1, MASKBYTE0);
829 	rtlphy->default_initialgain[1] =
830 	    (u8) rtl_get_bbreg(hw, ROFDM0_XBAGCCORE1, MASKBYTE0);
831 	rtlphy->default_initialgain[2] =
832 	    (u8) rtl_get_bbreg(hw, ROFDM0_XCAGCCORE1, MASKBYTE0);
833 	rtlphy->default_initialgain[3] =
834 	    (u8) rtl_get_bbreg(hw, ROFDM0_XDAGCCORE1, MASKBYTE0);
835 	rtl_dbg(rtlpriv, COMP_INIT, DBG_TRACE,
836 		"Default initial gain (c50=0x%x, c58=0x%x, c60=0x%x, c68=0x%x\n",
837 		rtlphy->default_initialgain[0],
838 		rtlphy->default_initialgain[1],
839 		rtlphy->default_initialgain[2],
840 		rtlphy->default_initialgain[3]);
841 	rtlphy->framesync = (u8)rtl_get_bbreg(hw, ROFDM0_RXDETECTOR3,
842 					      MASKBYTE0);
843 	rtlphy->framesync_c34 = rtl_get_bbreg(hw, ROFDM0_RXDETECTOR2,
844 					      MASKDWORD);
845 	rtl_dbg(rtlpriv, COMP_INIT, DBG_TRACE,
846 		"Default framesync (0x%x) = 0x%x\n",
847 		ROFDM0_RXDETECTOR3, rtlphy->framesync);
848 }
849 
850 static void _rtl92d_get_txpower_index(struct ieee80211_hw *hw, u8 channel,
851 	u8 *cckpowerlevel, u8 *ofdmpowerlevel)
852 {
853 	struct rtl_priv *rtlpriv = rtl_priv(hw);
854 	struct rtl_phy *rtlphy = &(rtlpriv->phy);
855 	struct rtl_hal *rtlhal = &(rtlpriv->rtlhal);
856 	struct rtl_efuse *rtlefuse = rtl_efuse(rtl_priv(hw));
857 	u8 index = (channel - 1);
858 
859 	/* 1. CCK */
860 	if (rtlhal->current_bandtype == BAND_ON_2_4G) {
861 		/* RF-A */
862 		cckpowerlevel[RF90_PATH_A] =
863 				 rtlefuse->txpwrlevel_cck[RF90_PATH_A][index];
864 		/* RF-B */
865 		cckpowerlevel[RF90_PATH_B] =
866 				 rtlefuse->txpwrlevel_cck[RF90_PATH_B][index];
867 	} else {
868 		cckpowerlevel[RF90_PATH_A] = 0;
869 		cckpowerlevel[RF90_PATH_B] = 0;
870 	}
871 	/* 2. OFDM for 1S or 2S */
872 	if (rtlphy->rf_type == RF_1T2R || rtlphy->rf_type == RF_1T1R) {
873 		/*  Read HT 40 OFDM TX power */
874 		ofdmpowerlevel[RF90_PATH_A] =
875 		    rtlefuse->txpwrlevel_ht40_1s[RF90_PATH_A][index];
876 		ofdmpowerlevel[RF90_PATH_B] =
877 		    rtlefuse->txpwrlevel_ht40_1s[RF90_PATH_B][index];
878 	} else if (rtlphy->rf_type == RF_2T2R) {
879 		/* Read HT 40 OFDM TX power */
880 		ofdmpowerlevel[RF90_PATH_A] =
881 		    rtlefuse->txpwrlevel_ht40_2s[RF90_PATH_A][index];
882 		ofdmpowerlevel[RF90_PATH_B] =
883 		    rtlefuse->txpwrlevel_ht40_2s[RF90_PATH_B][index];
884 	}
885 }
886 
887 static void _rtl92d_ccxpower_index_check(struct ieee80211_hw *hw,
888 	u8 channel, u8 *cckpowerlevel, u8 *ofdmpowerlevel)
889 {
890 	struct rtl_priv *rtlpriv = rtl_priv(hw);
891 	struct rtl_phy *rtlphy = &(rtlpriv->phy);
892 
893 	rtlphy->cur_cck_txpwridx = cckpowerlevel[0];
894 	rtlphy->cur_ofdm24g_txpwridx = ofdmpowerlevel[0];
895 }
896 
897 static u8 _rtl92c_phy_get_rightchnlplace(u8 chnl)
898 {
899 	u8 place = chnl;
900 
901 	if (chnl > 14) {
902 		for (place = 14; place < ARRAY_SIZE(channel5g); place++) {
903 			if (channel5g[place] == chnl) {
904 				place++;
905 				break;
906 			}
907 		}
908 	}
909 	return place;
910 }
911 
912 void rtl92d_phy_set_txpower_level(struct ieee80211_hw *hw, u8 channel)
913 {
914 	struct rtl_efuse *rtlefuse = rtl_efuse(rtl_priv(hw));
915 	struct rtl_priv *rtlpriv = rtl_priv(hw);
916 	u8 cckpowerlevel[2], ofdmpowerlevel[2];
917 
918 	if (!rtlefuse->txpwr_fromeprom)
919 		return;
920 	channel = _rtl92c_phy_get_rightchnlplace(channel);
921 	_rtl92d_get_txpower_index(hw, channel, &cckpowerlevel[0],
922 		&ofdmpowerlevel[0]);
923 	if (rtlpriv->rtlhal.current_bandtype == BAND_ON_2_4G)
924 		_rtl92d_ccxpower_index_check(hw, channel, &cckpowerlevel[0],
925 				&ofdmpowerlevel[0]);
926 	if (rtlpriv->rtlhal.current_bandtype == BAND_ON_2_4G)
927 		rtl92d_phy_rf6052_set_cck_txpower(hw, &cckpowerlevel[0]);
928 	rtl92d_phy_rf6052_set_ofdm_txpower(hw, &ofdmpowerlevel[0], channel);
929 }
930 
931 void rtl92d_phy_set_bw_mode(struct ieee80211_hw *hw,
932 			    enum nl80211_channel_type ch_type)
933 {
934 	struct rtl_priv *rtlpriv = rtl_priv(hw);
935 	struct rtl_phy *rtlphy = &(rtlpriv->phy);
936 	struct rtl_hal *rtlhal = rtl_hal(rtl_priv(hw));
937 	struct rtl_mac *mac = rtl_mac(rtl_priv(hw));
938 	unsigned long flag = 0;
939 	u8 reg_prsr_rsc;
940 	u8 reg_bw_opmode;
941 
942 	if (rtlphy->set_bwmode_inprogress)
943 		return;
944 	if ((is_hal_stop(rtlhal)) || (RT_CANNOT_IO(hw))) {
945 		rtl_dbg(rtlpriv, COMP_ERR, DBG_WARNING,
946 			"FALSE driver sleep or unload\n");
947 		return;
948 	}
949 	rtlphy->set_bwmode_inprogress = true;
950 	rtl_dbg(rtlpriv, COMP_SCAN, DBG_TRACE, "Switch to %s bandwidth\n",
951 		rtlphy->current_chan_bw == HT_CHANNEL_WIDTH_20 ?
952 		"20MHz" : "40MHz");
953 	reg_bw_opmode = rtl_read_byte(rtlpriv, REG_BWOPMODE);
954 	reg_prsr_rsc = rtl_read_byte(rtlpriv, REG_RRSR + 2);
955 	switch (rtlphy->current_chan_bw) {
956 	case HT_CHANNEL_WIDTH_20:
957 		reg_bw_opmode |= BW_OPMODE_20MHZ;
958 		rtl_write_byte(rtlpriv, REG_BWOPMODE, reg_bw_opmode);
959 		break;
960 	case HT_CHANNEL_WIDTH_20_40:
961 		reg_bw_opmode &= ~BW_OPMODE_20MHZ;
962 		rtl_write_byte(rtlpriv, REG_BWOPMODE, reg_bw_opmode);
963 
964 		reg_prsr_rsc = (reg_prsr_rsc & 0x90) |
965 			(mac->cur_40_prime_sc << 5);
966 		rtl_write_byte(rtlpriv, REG_RRSR + 2, reg_prsr_rsc);
967 		break;
968 	default:
969 		pr_err("unknown bandwidth: %#X\n",
970 		       rtlphy->current_chan_bw);
971 		break;
972 	}
973 	switch (rtlphy->current_chan_bw) {
974 	case HT_CHANNEL_WIDTH_20:
975 		rtl_set_bbreg(hw, RFPGA0_RFMOD, BRFMOD, 0x0);
976 		rtl_set_bbreg(hw, RFPGA1_RFMOD, BRFMOD, 0x0);
977 		/* SET BIT10 BIT11  for receive cck */
978 		rtl_set_bbreg(hw, RFPGA0_ANALOGPARAMETER2, BIT(10) |
979 			      BIT(11), 3);
980 		break;
981 	case HT_CHANNEL_WIDTH_20_40:
982 		rtl_set_bbreg(hw, RFPGA0_RFMOD, BRFMOD, 0x1);
983 		rtl_set_bbreg(hw, RFPGA1_RFMOD, BRFMOD, 0x1);
984 		/* Set Control channel to upper or lower.
985 		 * These settings are required only for 40MHz */
986 		if (rtlhal->current_bandtype == BAND_ON_2_4G) {
987 			rtl92d_acquire_cckandrw_pagea_ctl(hw, &flag);
988 			rtl_set_bbreg(hw, RCCK0_SYSTEM, BCCKSIDEBAND,
989 				(mac->cur_40_prime_sc >> 1));
990 			rtl92d_release_cckandrw_pagea_ctl(hw, &flag);
991 		}
992 		rtl_set_bbreg(hw, ROFDM1_LSTF, 0xC00, mac->cur_40_prime_sc);
993 		/* SET BIT10 BIT11  for receive cck */
994 		rtl_set_bbreg(hw, RFPGA0_ANALOGPARAMETER2, BIT(10) |
995 			      BIT(11), 0);
996 		rtl_set_bbreg(hw, 0x818, (BIT(26) | BIT(27)),
997 			(mac->cur_40_prime_sc ==
998 			HAL_PRIME_CHNL_OFFSET_LOWER) ? 2 : 1);
999 		break;
1000 	default:
1001 		pr_err("unknown bandwidth: %#X\n",
1002 		       rtlphy->current_chan_bw);
1003 		break;
1004 
1005 	}
1006 	rtl92d_phy_rf6052_set_bandwidth(hw, rtlphy->current_chan_bw);
1007 	rtlphy->set_bwmode_inprogress = false;
1008 	rtl_dbg(rtlpriv, COMP_SCAN, DBG_TRACE, "<==\n");
1009 }
1010 
1011 static void _rtl92d_phy_stop_trx_before_changeband(struct ieee80211_hw *hw)
1012 {
1013 	rtl_set_bbreg(hw, RFPGA0_RFMOD, BCCKEN, 0);
1014 	rtl_set_bbreg(hw, RFPGA0_RFMOD, BOFDMEN, 0);
1015 	rtl_set_bbreg(hw, ROFDM0_TRXPATHENABLE, MASKBYTE0, 0x00);
1016 	rtl_set_bbreg(hw, ROFDM1_TRXPATHENABLE, BDWORD, 0x0);
1017 }
1018 
1019 static void rtl92d_phy_switch_wirelessband(struct ieee80211_hw *hw, u8 band)
1020 {
1021 	struct rtl_priv *rtlpriv = rtl_priv(hw);
1022 	struct rtl_hal *rtlhal = rtl_hal(rtl_priv(hw));
1023 	u8 value8;
1024 
1025 	rtl_dbg(rtlpriv, COMP_INIT, DBG_LOUD, "==>\n");
1026 	rtlhal->bandset = band;
1027 	rtlhal->current_bandtype = band;
1028 	if (IS_92D_SINGLEPHY(rtlhal->version))
1029 		rtlhal->bandset = BAND_ON_BOTH;
1030 	/* stop RX/Tx */
1031 	_rtl92d_phy_stop_trx_before_changeband(hw);
1032 	/* reconfig BB/RF according to wireless mode */
1033 	if (rtlhal->current_bandtype == BAND_ON_2_4G) {
1034 		/* BB & RF Config */
1035 		rtl_dbg(rtlpriv, COMP_CMD, DBG_DMESG, "====>2.4G\n");
1036 		if (rtlhal->interfaceindex == 1)
1037 			_rtl92d_phy_config_bb_with_headerfile(hw,
1038 				BASEBAND_CONFIG_AGC_TAB);
1039 	} else {
1040 		/* 5G band */
1041 		rtl_dbg(rtlpriv, COMP_CMD, DBG_DMESG, "====>5G\n");
1042 		if (rtlhal->interfaceindex == 1)
1043 			_rtl92d_phy_config_bb_with_headerfile(hw,
1044 				BASEBAND_CONFIG_AGC_TAB);
1045 	}
1046 	rtl92d_update_bbrf_configuration(hw);
1047 	if (rtlhal->current_bandtype == BAND_ON_2_4G)
1048 		rtl_set_bbreg(hw, RFPGA0_RFMOD, BCCKEN, 0x1);
1049 	rtl_set_bbreg(hw, RFPGA0_RFMOD, BOFDMEN, 0x1);
1050 
1051 	/* 20M BW. */
1052 	/* rtl_set_bbreg(hw, RFPGA0_ANALOGPARAMETER2, BIT(10), 1); */
1053 	rtlhal->reloadtxpowerindex = true;
1054 	/* notice fw know band status  0x81[1]/0x53[1] = 0: 5G, 1: 2G */
1055 	if (rtlhal->current_bandtype == BAND_ON_2_4G) {
1056 		value8 = rtl_read_byte(rtlpriv,	(rtlhal->interfaceindex ==
1057 			0 ? REG_MAC0 : REG_MAC1));
1058 		value8 |= BIT(1);
1059 		rtl_write_byte(rtlpriv, (rtlhal->interfaceindex ==
1060 			0 ? REG_MAC0 : REG_MAC1), value8);
1061 	} else {
1062 		value8 = rtl_read_byte(rtlpriv, (rtlhal->interfaceindex ==
1063 			0 ? REG_MAC0 : REG_MAC1));
1064 		value8 &= (~BIT(1));
1065 		rtl_write_byte(rtlpriv, (rtlhal->interfaceindex ==
1066 			0 ? REG_MAC0 : REG_MAC1), value8);
1067 	}
1068 	mdelay(1);
1069 	rtl_dbg(rtlpriv, COMP_INIT, DBG_LOUD, "<==Switch Band OK\n");
1070 }
1071 
1072 static void _rtl92d_phy_reload_imr_setting(struct ieee80211_hw *hw,
1073 	u8 channel, u8 rfpath)
1074 {
1075 	struct rtl_priv *rtlpriv = rtl_priv(hw);
1076 	u32 imr_num = MAX_RF_IMR_INDEX;
1077 	u32 rfmask = RFREG_OFFSET_MASK;
1078 	u8 group, i;
1079 	unsigned long flag = 0;
1080 
1081 	rtl_dbg(rtlpriv, COMP_CMD, DBG_LOUD, "====>path %d\n", rfpath);
1082 	if (rtlpriv->rtlhal.current_bandtype == BAND_ON_5G) {
1083 		rtl_dbg(rtlpriv, COMP_CMD, DBG_LOUD, "====>5G\n");
1084 		rtl_set_bbreg(hw, RFPGA0_RFMOD, BIT(25) | BIT(24), 0);
1085 		rtl_set_bbreg(hw, RFPGA0_ANALOGPARAMETER4, 0x00f00000, 0xf);
1086 		/* fc area 0xd2c */
1087 		if (channel > 99)
1088 			rtl_set_bbreg(hw, ROFDM1_CFOTRACKING, BIT(13) |
1089 				      BIT(14), 2);
1090 		else
1091 			rtl_set_bbreg(hw, ROFDM1_CFOTRACKING, BIT(13) |
1092 				      BIT(14), 1);
1093 		/* leave 0 for channel1-14. */
1094 		group = channel <= 64 ? 1 : 2;
1095 		imr_num = MAX_RF_IMR_INDEX_NORMAL;
1096 		for (i = 0; i < imr_num; i++)
1097 			rtl_set_rfreg(hw, (enum radio_path)rfpath,
1098 				      rf_reg_for_5g_swchnl_normal[i], rfmask,
1099 				      rf_imr_param_normal[0][group][i]);
1100 		rtl_set_bbreg(hw, RFPGA0_ANALOGPARAMETER4, 0x00f00000, 0);
1101 		rtl_set_bbreg(hw, RFPGA0_RFMOD, BOFDMEN, 1);
1102 	} else {
1103 		/* G band. */
1104 		rtl_dbg(rtlpriv, COMP_SCAN, DBG_LOUD,
1105 			"Load RF IMR parameters for G band. IMR already setting %d\n",
1106 			rtlpriv->rtlhal.load_imrandiqk_setting_for2g);
1107 		rtl_dbg(rtlpriv, COMP_CMD, DBG_LOUD, "====>2.4G\n");
1108 		if (!rtlpriv->rtlhal.load_imrandiqk_setting_for2g) {
1109 			rtl_dbg(rtlpriv, COMP_SCAN, DBG_LOUD,
1110 				"Load RF IMR parameters for G band. %d\n",
1111 				rfpath);
1112 			rtl92d_acquire_cckandrw_pagea_ctl(hw, &flag);
1113 			rtl_set_bbreg(hw, RFPGA0_RFMOD, BIT(25) | BIT(24), 0);
1114 			rtl_set_bbreg(hw, RFPGA0_ANALOGPARAMETER4,
1115 				      0x00f00000, 0xf);
1116 			imr_num = MAX_RF_IMR_INDEX_NORMAL;
1117 			for (i = 0; i < imr_num; i++) {
1118 				rtl_set_rfreg(hw, (enum radio_path)rfpath,
1119 					      rf_reg_for_5g_swchnl_normal[i],
1120 					      RFREG_OFFSET_MASK,
1121 					      rf_imr_param_normal[0][0][i]);
1122 			}
1123 			rtl_set_bbreg(hw, RFPGA0_ANALOGPARAMETER4,
1124 				      0x00f00000, 0);
1125 			rtl_set_bbreg(hw, RFPGA0_RFMOD, BOFDMEN | BCCKEN, 3);
1126 			rtl92d_release_cckandrw_pagea_ctl(hw, &flag);
1127 		}
1128 	}
1129 	rtl_dbg(rtlpriv, COMP_CMD, DBG_LOUD, "<====\n");
1130 }
1131 
1132 static void _rtl92d_phy_enable_rf_env(struct ieee80211_hw *hw,
1133 	u8 rfpath, u32 *pu4_regval)
1134 {
1135 	struct rtl_priv *rtlpriv = rtl_priv(hw);
1136 	struct rtl_phy *rtlphy = &(rtlpriv->phy);
1137 	struct bb_reg_def *pphyreg = &rtlphy->phyreg_def[rfpath];
1138 
1139 	rtl_dbg(rtlpriv, COMP_RF, DBG_LOUD, "====>\n");
1140 	/*----Store original RFENV control type----*/
1141 	switch (rfpath) {
1142 	case RF90_PATH_A:
1143 	case RF90_PATH_C:
1144 		*pu4_regval = rtl_get_bbreg(hw, pphyreg->rfintfs, BRFSI_RFENV);
1145 		break;
1146 	case RF90_PATH_B:
1147 	case RF90_PATH_D:
1148 		*pu4_regval =
1149 		    rtl_get_bbreg(hw, pphyreg->rfintfs, BRFSI_RFENV << 16);
1150 		break;
1151 	}
1152 	/*----Set RF_ENV enable----*/
1153 	rtl_set_bbreg(hw, pphyreg->rfintfe, BRFSI_RFENV << 16, 0x1);
1154 	udelay(1);
1155 	/*----Set RF_ENV output high----*/
1156 	rtl_set_bbreg(hw, pphyreg->rfintfo, BRFSI_RFENV, 0x1);
1157 	udelay(1);
1158 	/* Set bit number of Address and Data for RF register */
1159 	/* Set 1 to 4 bits for 8255 */
1160 	rtl_set_bbreg(hw, pphyreg->rfhssi_para2, B3WIREADDRESSLENGTH, 0x0);
1161 	udelay(1);
1162 	/*Set 0 to 12 bits for 8255 */
1163 	rtl_set_bbreg(hw, pphyreg->rfhssi_para2, B3WIREDATALENGTH, 0x0);
1164 	udelay(1);
1165 	rtl_dbg(rtlpriv, COMP_RF, DBG_LOUD, "<====\n");
1166 }
1167 
1168 static void _rtl92d_phy_restore_rf_env(struct ieee80211_hw *hw, u8 rfpath,
1169 				       u32 *pu4_regval)
1170 {
1171 	struct rtl_priv *rtlpriv = rtl_priv(hw);
1172 	struct rtl_phy *rtlphy = &(rtlpriv->phy);
1173 	struct bb_reg_def *pphyreg = &rtlphy->phyreg_def[rfpath];
1174 
1175 	rtl_dbg(rtlpriv, COMP_RF, DBG_LOUD, "=====>\n");
1176 	/*----Restore RFENV control type----*/
1177 	switch (rfpath) {
1178 	case RF90_PATH_A:
1179 	case RF90_PATH_C:
1180 		rtl_set_bbreg(hw, pphyreg->rfintfs, BRFSI_RFENV, *pu4_regval);
1181 		break;
1182 	case RF90_PATH_B:
1183 	case RF90_PATH_D:
1184 		rtl_set_bbreg(hw, pphyreg->rfintfs, BRFSI_RFENV << 16,
1185 			      *pu4_regval);
1186 		break;
1187 	}
1188 	rtl_dbg(rtlpriv, COMP_RF, DBG_LOUD, "<=====\n");
1189 }
1190 
1191 static void _rtl92d_phy_switch_rf_setting(struct ieee80211_hw *hw, u8 channel)
1192 {
1193 	struct rtl_priv *rtlpriv = rtl_priv(hw);
1194 	struct rtl_phy *rtlphy = &(rtlpriv->phy);
1195 	struct rtl_hal *rtlhal = &(rtlpriv->rtlhal);
1196 	u8 path = rtlhal->current_bandtype ==
1197 	    BAND_ON_5G ? RF90_PATH_A : RF90_PATH_B;
1198 	u8 index = 0, i = 0, rfpath = RF90_PATH_A;
1199 	bool need_pwr_down = false, internal_pa = false;
1200 	u32 u4regvalue, mask = 0x1C000, value = 0, u4tmp, u4tmp2;
1201 
1202 	rtl_dbg(rtlpriv, COMP_CMD, DBG_LOUD, "====>\n");
1203 	/* config path A for 5G */
1204 	if (rtlhal->current_bandtype == BAND_ON_5G) {
1205 		rtl_dbg(rtlpriv, COMP_CMD, DBG_LOUD, "====>5G\n");
1206 		u4tmp = curveindex_5g[channel - 1];
1207 		RTPRINT(rtlpriv, FINIT, INIT_IQK,
1208 			"ver 1 set RF-A, 5G, 0x28 = 0x%x !!\n", u4tmp);
1209 		for (i = 0; i < RF_CHNL_NUM_5G; i++) {
1210 			if (channel == rf_chnl_5g[i] && channel <= 140)
1211 				index = 0;
1212 		}
1213 		for (i = 0; i < RF_CHNL_NUM_5G_40M; i++) {
1214 			if (channel == rf_chnl_5g_40m[i] && channel <= 140)
1215 				index = 1;
1216 		}
1217 		if (channel == 149 || channel == 155 || channel == 161)
1218 			index = 2;
1219 		else if (channel == 151 || channel == 153 || channel == 163
1220 			 || channel == 165)
1221 			index = 3;
1222 		else if (channel == 157 || channel == 159)
1223 			index = 4;
1224 
1225 		if (rtlhal->macphymode == DUALMAC_DUALPHY
1226 		    && rtlhal->interfaceindex == 1) {
1227 			need_pwr_down = rtl92d_phy_enable_anotherphy(hw, false);
1228 			rtlhal->during_mac1init_radioa = true;
1229 			/* asume no this case */
1230 			if (need_pwr_down)
1231 				_rtl92d_phy_enable_rf_env(hw, path,
1232 							  &u4regvalue);
1233 		}
1234 		for (i = 0; i < RF_REG_NUM_FOR_C_CUT_5G; i++) {
1235 			if (i == 0 && (rtlhal->macphymode == DUALMAC_DUALPHY)) {
1236 				rtl_set_rfreg(hw, (enum radio_path)path,
1237 					      rf_reg_for_c_cut_5g[i],
1238 					      RFREG_OFFSET_MASK, 0xE439D);
1239 			} else if (rf_reg_for_c_cut_5g[i] == RF_SYN_G4) {
1240 				u4tmp2 = (rf_reg_pram_c_5g[index][i] &
1241 				     0x7FF) | (u4tmp << 11);
1242 				if (channel == 36)
1243 					u4tmp2 &= ~(BIT(7) | BIT(6));
1244 				rtl_set_rfreg(hw, (enum radio_path)path,
1245 					      rf_reg_for_c_cut_5g[i],
1246 					      RFREG_OFFSET_MASK, u4tmp2);
1247 			} else {
1248 				rtl_set_rfreg(hw, (enum radio_path)path,
1249 					      rf_reg_for_c_cut_5g[i],
1250 					      RFREG_OFFSET_MASK,
1251 					      rf_reg_pram_c_5g[index][i]);
1252 			}
1253 			rtl_dbg(rtlpriv, COMP_RF, DBG_TRACE,
1254 				"offset 0x%x value 0x%x path %d index %d readback 0x%x\n",
1255 				rf_reg_for_c_cut_5g[i],
1256 				rf_reg_pram_c_5g[index][i],
1257 				path, index,
1258 				rtl_get_rfreg(hw, (enum radio_path)path,
1259 					      rf_reg_for_c_cut_5g[i],
1260 					      RFREG_OFFSET_MASK));
1261 		}
1262 		if (need_pwr_down)
1263 			_rtl92d_phy_restore_rf_env(hw, path, &u4regvalue);
1264 		if (rtlhal->during_mac1init_radioa)
1265 			rtl92d_phy_powerdown_anotherphy(hw, false);
1266 		if (channel < 149)
1267 			value = 0x07;
1268 		else if (channel >= 149)
1269 			value = 0x02;
1270 		if (channel >= 36 && channel <= 64)
1271 			index = 0;
1272 		else if (channel >= 100 && channel <= 140)
1273 			index = 1;
1274 		else
1275 			index = 2;
1276 		for (rfpath = RF90_PATH_A; rfpath < rtlphy->num_total_rfpath;
1277 			rfpath++) {
1278 			if (rtlhal->macphymode == DUALMAC_DUALPHY &&
1279 				rtlhal->interfaceindex == 1)	/* MAC 1 5G */
1280 				internal_pa = rtlpriv->efuse.internal_pa_5g[1];
1281 			else
1282 				internal_pa =
1283 					 rtlpriv->efuse.internal_pa_5g[rfpath];
1284 			if (internal_pa) {
1285 				for (i = 0;
1286 				     i < RF_REG_NUM_FOR_C_CUT_5G_INTERNALPA;
1287 				     i++) {
1288 					rtl_set_rfreg(hw, rfpath,
1289 						rf_for_c_cut_5g_internal_pa[i],
1290 						RFREG_OFFSET_MASK,
1291 						rf_pram_c_5g_int_pa[index][i]);
1292 					rtl_dbg(rtlpriv, COMP_RF, DBG_LOUD,
1293 						"offset 0x%x value 0x%x path %d index %d\n",
1294 						rf_for_c_cut_5g_internal_pa[i],
1295 						rf_pram_c_5g_int_pa[index][i],
1296 						rfpath, index);
1297 				}
1298 			} else {
1299 				rtl_set_rfreg(hw, (enum radio_path)rfpath, 0x0B,
1300 					      mask, value);
1301 			}
1302 		}
1303 	} else if (rtlhal->current_bandtype == BAND_ON_2_4G) {
1304 		rtl_dbg(rtlpriv, COMP_CMD, DBG_LOUD, "====>2.4G\n");
1305 		u4tmp = curveindex_2g[channel - 1];
1306 		RTPRINT(rtlpriv, FINIT, INIT_IQK,
1307 			"ver 3 set RF-B, 2G, 0x28 = 0x%x !!\n", u4tmp);
1308 		if (channel == 1 || channel == 2 || channel == 4 || channel == 9
1309 		    || channel == 10 || channel == 11 || channel == 12)
1310 			index = 0;
1311 		else if (channel == 3 || channel == 13 || channel == 14)
1312 			index = 1;
1313 		else if (channel >= 5 && channel <= 8)
1314 			index = 2;
1315 		if (rtlhal->macphymode == DUALMAC_DUALPHY) {
1316 			path = RF90_PATH_A;
1317 			if (rtlhal->interfaceindex == 0) {
1318 				need_pwr_down =
1319 					 rtl92d_phy_enable_anotherphy(hw, true);
1320 				rtlhal->during_mac0init_radiob = true;
1321 
1322 				if (need_pwr_down)
1323 					_rtl92d_phy_enable_rf_env(hw, path,
1324 								  &u4regvalue);
1325 			}
1326 		}
1327 		for (i = 0; i < RF_REG_NUM_FOR_C_CUT_2G; i++) {
1328 			if (rf_reg_for_c_cut_2g[i] == RF_SYN_G7)
1329 				rtl_set_rfreg(hw, (enum radio_path)path,
1330 					rf_reg_for_c_cut_2g[i],
1331 					RFREG_OFFSET_MASK,
1332 					(rf_reg_param_for_c_cut_2g[index][i] |
1333 					BIT(17)));
1334 			else
1335 				rtl_set_rfreg(hw, (enum radio_path)path,
1336 					      rf_reg_for_c_cut_2g[i],
1337 					      RFREG_OFFSET_MASK,
1338 					      rf_reg_param_for_c_cut_2g
1339 					      [index][i]);
1340 			rtl_dbg(rtlpriv, COMP_RF, DBG_TRACE,
1341 				"offset 0x%x value 0x%x mak 0x%x path %d index %d readback 0x%x\n",
1342 				rf_reg_for_c_cut_2g[i],
1343 				rf_reg_param_for_c_cut_2g[index][i],
1344 				rf_reg_mask_for_c_cut_2g[i], path, index,
1345 				rtl_get_rfreg(hw, (enum radio_path)path,
1346 					      rf_reg_for_c_cut_2g[i],
1347 					      RFREG_OFFSET_MASK));
1348 		}
1349 		RTPRINT(rtlpriv, FINIT, INIT_IQK,
1350 			"cosa ver 3 set RF-B, 2G, 0x28 = 0x%x !!\n",
1351 			rf_syn_g4_for_c_cut_2g | (u4tmp << 11));
1352 
1353 		rtl_set_rfreg(hw, (enum radio_path)path, RF_SYN_G4,
1354 			      RFREG_OFFSET_MASK,
1355 			      rf_syn_g4_for_c_cut_2g | (u4tmp << 11));
1356 		if (need_pwr_down)
1357 			_rtl92d_phy_restore_rf_env(hw, path, &u4regvalue);
1358 		if (rtlhal->during_mac0init_radiob)
1359 			rtl92d_phy_powerdown_anotherphy(hw, true);
1360 	}
1361 	rtl_dbg(rtlpriv, COMP_CMD, DBG_LOUD, "<====\n");
1362 }
1363 
1364 u8 rtl92d_get_rightchnlplace_for_iqk(u8 chnl)
1365 {
1366 	u8 place;
1367 
1368 	if (chnl > 14) {
1369 		for (place = 14; place < ARRAY_SIZE(channel_all); place++) {
1370 			if (channel_all[place] == chnl)
1371 				return place - 13;
1372 		}
1373 	}
1374 
1375 	return 0;
1376 }
1377 
1378 #define MAX_TOLERANCE		5
1379 #define IQK_DELAY_TIME		1	/* ms */
1380 #define MAX_TOLERANCE_92D	3
1381 
1382 /* bit0 = 1 => Tx OK, bit1 = 1 => Rx OK */
1383 static u8 _rtl92d_phy_patha_iqk(struct ieee80211_hw *hw, bool configpathb)
1384 {
1385 	struct rtl_priv *rtlpriv = rtl_priv(hw);
1386 	struct rtl_hal *rtlhal = rtl_hal(rtl_priv(hw));
1387 	u32 regeac, rege94, rege9c, regea4;
1388 	u8 result = 0;
1389 
1390 	RTPRINT(rtlpriv, FINIT, INIT_IQK,  "Path A IQK!\n");
1391 	/* path-A IQK setting */
1392 	RTPRINT(rtlpriv, FINIT, INIT_IQK,  "Path-A IQK setting!\n");
1393 	if (rtlhal->interfaceindex == 0) {
1394 		rtl_set_bbreg(hw, 0xe30, MASKDWORD, 0x10008c1f);
1395 		rtl_set_bbreg(hw, 0xe34, MASKDWORD, 0x10008c1f);
1396 	} else {
1397 		rtl_set_bbreg(hw, 0xe30, MASKDWORD, 0x10008c22);
1398 		rtl_set_bbreg(hw, 0xe34, MASKDWORD, 0x10008c22);
1399 	}
1400 	rtl_set_bbreg(hw, 0xe38, MASKDWORD, 0x82140102);
1401 	rtl_set_bbreg(hw, 0xe3c, MASKDWORD, 0x28160206);
1402 	/* path-B IQK setting */
1403 	if (configpathb) {
1404 		rtl_set_bbreg(hw, 0xe50, MASKDWORD, 0x10008c22);
1405 		rtl_set_bbreg(hw, 0xe54, MASKDWORD, 0x10008c22);
1406 		rtl_set_bbreg(hw, 0xe58, MASKDWORD, 0x82140102);
1407 		rtl_set_bbreg(hw, 0xe5c, MASKDWORD, 0x28160206);
1408 	}
1409 	/* LO calibration setting */
1410 	RTPRINT(rtlpriv, FINIT, INIT_IQK,  "LO calibration setting!\n");
1411 	rtl_set_bbreg(hw, 0xe4c, MASKDWORD, 0x00462911);
1412 	/* One shot, path A LOK & IQK */
1413 	RTPRINT(rtlpriv, FINIT, INIT_IQK,  "One shot, path A LOK & IQK!\n");
1414 	rtl_set_bbreg(hw, 0xe48, MASKDWORD, 0xf9000000);
1415 	rtl_set_bbreg(hw, 0xe48, MASKDWORD, 0xf8000000);
1416 	/* delay x ms */
1417 	RTPRINT(rtlpriv, FINIT, INIT_IQK,
1418 		"Delay %d ms for One shot, path A LOK & IQK\n",
1419 		IQK_DELAY_TIME);
1420 	mdelay(IQK_DELAY_TIME);
1421 	/* Check failed */
1422 	regeac = rtl_get_bbreg(hw, 0xeac, MASKDWORD);
1423 	RTPRINT(rtlpriv, FINIT, INIT_IQK,  "0xeac = 0x%x\n", regeac);
1424 	rege94 = rtl_get_bbreg(hw, 0xe94, MASKDWORD);
1425 	RTPRINT(rtlpriv, FINIT, INIT_IQK,  "0xe94 = 0x%x\n", rege94);
1426 	rege9c = rtl_get_bbreg(hw, 0xe9c, MASKDWORD);
1427 	RTPRINT(rtlpriv, FINIT, INIT_IQK,  "0xe9c = 0x%x\n", rege9c);
1428 	regea4 = rtl_get_bbreg(hw, 0xea4, MASKDWORD);
1429 	RTPRINT(rtlpriv, FINIT, INIT_IQK,  "0xea4 = 0x%x\n", regea4);
1430 	if (!(regeac & BIT(28)) && (((rege94 & 0x03FF0000) >> 16) != 0x142) &&
1431 	    (((rege9c & 0x03FF0000) >> 16) != 0x42))
1432 		result |= 0x01;
1433 	else			/* if Tx not OK, ignore Rx */
1434 		return result;
1435 	/* if Tx is OK, check whether Rx is OK */
1436 	if (!(regeac & BIT(27)) && (((regea4 & 0x03FF0000) >> 16) != 0x132) &&
1437 	    (((regeac & 0x03FF0000) >> 16) != 0x36))
1438 		result |= 0x02;
1439 	else
1440 		RTPRINT(rtlpriv, FINIT, INIT_IQK,  "Path A Rx IQK fail!!\n");
1441 	return result;
1442 }
1443 
1444 /* bit0 = 1 => Tx OK, bit1 = 1 => Rx OK */
1445 static u8 _rtl92d_phy_patha_iqk_5g_normal(struct ieee80211_hw *hw,
1446 					  bool configpathb)
1447 {
1448 	struct rtl_priv *rtlpriv = rtl_priv(hw);
1449 	struct rtl_hal *rtlhal = rtl_hal(rtl_priv(hw));
1450 	struct rtl_phy *rtlphy = &(rtlpriv->phy);
1451 	u32 regeac, rege94, rege9c, regea4;
1452 	u8 result = 0;
1453 	u8 i;
1454 	u8 retrycount = 2;
1455 	u32 TXOKBIT = BIT(28), RXOKBIT = BIT(27);
1456 
1457 	if (rtlhal->interfaceindex == 1) {	/* PHY1 */
1458 		TXOKBIT = BIT(31);
1459 		RXOKBIT = BIT(30);
1460 	}
1461 	RTPRINT(rtlpriv, FINIT, INIT_IQK,  "Path A IQK!\n");
1462 	/* path-A IQK setting */
1463 	RTPRINT(rtlpriv, FINIT, INIT_IQK,  "Path-A IQK setting!\n");
1464 	rtl_set_bbreg(hw, 0xe30, MASKDWORD, 0x18008c1f);
1465 	rtl_set_bbreg(hw, 0xe34, MASKDWORD, 0x18008c1f);
1466 	rtl_set_bbreg(hw, 0xe38, MASKDWORD, 0x82140307);
1467 	rtl_set_bbreg(hw, 0xe3c, MASKDWORD, 0x68160960);
1468 	/* path-B IQK setting */
1469 	if (configpathb) {
1470 		rtl_set_bbreg(hw, 0xe50, MASKDWORD, 0x18008c2f);
1471 		rtl_set_bbreg(hw, 0xe54, MASKDWORD, 0x18008c2f);
1472 		rtl_set_bbreg(hw, 0xe58, MASKDWORD, 0x82110000);
1473 		rtl_set_bbreg(hw, 0xe5c, MASKDWORD, 0x68110000);
1474 	}
1475 	/* LO calibration setting */
1476 	RTPRINT(rtlpriv, FINIT, INIT_IQK,  "LO calibration setting!\n");
1477 	rtl_set_bbreg(hw, 0xe4c, MASKDWORD, 0x00462911);
1478 	/* path-A PA on */
1479 	rtl_set_bbreg(hw, RFPGA0_XAB_RFINTERFACESW, MASKDWORD, 0x07000f60);
1480 	rtl_set_bbreg(hw, RFPGA0_XA_RFINTERFACEOE, MASKDWORD, 0x66e60e30);
1481 	for (i = 0; i < retrycount; i++) {
1482 		/* One shot, path A LOK & IQK */
1483 		RTPRINT(rtlpriv, FINIT, INIT_IQK,
1484 			"One shot, path A LOK & IQK!\n");
1485 		rtl_set_bbreg(hw, 0xe48, MASKDWORD, 0xf9000000);
1486 		rtl_set_bbreg(hw, 0xe48, MASKDWORD, 0xf8000000);
1487 		/* delay x ms */
1488 		RTPRINT(rtlpriv, FINIT, INIT_IQK,
1489 			"Delay %d ms for One shot, path A LOK & IQK.\n",
1490 			IQK_DELAY_TIME);
1491 		mdelay(IQK_DELAY_TIME * 10);
1492 		/* Check failed */
1493 		regeac = rtl_get_bbreg(hw, 0xeac, MASKDWORD);
1494 		RTPRINT(rtlpriv, FINIT, INIT_IQK,  "0xeac = 0x%x\n", regeac);
1495 		rege94 = rtl_get_bbreg(hw, 0xe94, MASKDWORD);
1496 		RTPRINT(rtlpriv, FINIT, INIT_IQK,  "0xe94 = 0x%x\n", rege94);
1497 		rege9c = rtl_get_bbreg(hw, 0xe9c, MASKDWORD);
1498 		RTPRINT(rtlpriv, FINIT, INIT_IQK,  "0xe9c = 0x%x\n", rege9c);
1499 		regea4 = rtl_get_bbreg(hw, 0xea4, MASKDWORD);
1500 		RTPRINT(rtlpriv, FINIT, INIT_IQK,  "0xea4 = 0x%x\n", regea4);
1501 		if (!(regeac & TXOKBIT) &&
1502 		     (((rege94 & 0x03FF0000) >> 16) != 0x142)) {
1503 			result |= 0x01;
1504 		} else { /* if Tx not OK, ignore Rx */
1505 			RTPRINT(rtlpriv, FINIT, INIT_IQK,
1506 				"Path A Tx IQK fail!!\n");
1507 			continue;
1508 		}
1509 
1510 		/* if Tx is OK, check whether Rx is OK */
1511 		if (!(regeac & RXOKBIT) &&
1512 		    (((regea4 & 0x03FF0000) >> 16) != 0x132)) {
1513 			result |= 0x02;
1514 			break;
1515 		} else {
1516 			RTPRINT(rtlpriv, FINIT, INIT_IQK,
1517 				"Path A Rx IQK fail!!\n");
1518 		}
1519 	}
1520 	/* path A PA off */
1521 	rtl_set_bbreg(hw, RFPGA0_XAB_RFINTERFACESW, MASKDWORD,
1522 		      rtlphy->iqk_bb_backup[0]);
1523 	rtl_set_bbreg(hw, RFPGA0_XA_RFINTERFACEOE, MASKDWORD,
1524 		      rtlphy->iqk_bb_backup[1]);
1525 	return result;
1526 }
1527 
1528 /* bit0 = 1 => Tx OK, bit1 = 1 => Rx OK */
1529 static u8 _rtl92d_phy_pathb_iqk(struct ieee80211_hw *hw)
1530 {
1531 	struct rtl_priv *rtlpriv = rtl_priv(hw);
1532 	u32 regeac, regeb4, regebc, regec4, regecc;
1533 	u8 result = 0;
1534 
1535 	RTPRINT(rtlpriv, FINIT, INIT_IQK,  "Path B IQK!\n");
1536 	/* One shot, path B LOK & IQK */
1537 	RTPRINT(rtlpriv, FINIT, INIT_IQK,  "One shot, path A LOK & IQK!\n");
1538 	rtl_set_bbreg(hw, 0xe60, MASKDWORD, 0x00000002);
1539 	rtl_set_bbreg(hw, 0xe60, MASKDWORD, 0x00000000);
1540 	/* delay x ms  */
1541 	RTPRINT(rtlpriv, FINIT, INIT_IQK,
1542 		"Delay %d ms for One shot, path B LOK & IQK\n", IQK_DELAY_TIME);
1543 	mdelay(IQK_DELAY_TIME);
1544 	/* Check failed */
1545 	regeac = rtl_get_bbreg(hw, 0xeac, MASKDWORD);
1546 	RTPRINT(rtlpriv, FINIT, INIT_IQK,  "0xeac = 0x%x\n", regeac);
1547 	regeb4 = rtl_get_bbreg(hw, 0xeb4, MASKDWORD);
1548 	RTPRINT(rtlpriv, FINIT, INIT_IQK,  "0xeb4 = 0x%x\n", regeb4);
1549 	regebc = rtl_get_bbreg(hw, 0xebc, MASKDWORD);
1550 	RTPRINT(rtlpriv, FINIT, INIT_IQK,  "0xebc = 0x%x\n", regebc);
1551 	regec4 = rtl_get_bbreg(hw, 0xec4, MASKDWORD);
1552 	RTPRINT(rtlpriv, FINIT, INIT_IQK,  "0xec4 = 0x%x\n", regec4);
1553 	regecc = rtl_get_bbreg(hw, 0xecc, MASKDWORD);
1554 	RTPRINT(rtlpriv, FINIT, INIT_IQK,  "0xecc = 0x%x\n", regecc);
1555 	if (!(regeac & BIT(31)) && (((regeb4 & 0x03FF0000) >> 16) != 0x142) &&
1556 	    (((regebc & 0x03FF0000) >> 16) != 0x42))
1557 		result |= 0x01;
1558 	else
1559 		return result;
1560 	if (!(regeac & BIT(30)) && (((regec4 & 0x03FF0000) >> 16) != 0x132) &&
1561 	    (((regecc & 0x03FF0000) >> 16) != 0x36))
1562 		result |= 0x02;
1563 	else
1564 		RTPRINT(rtlpriv, FINIT, INIT_IQK,  "Path B Rx IQK fail!!\n");
1565 	return result;
1566 }
1567 
1568 /* bit0 = 1 => Tx OK, bit1 = 1 => Rx OK */
1569 static u8 _rtl92d_phy_pathb_iqk_5g_normal(struct ieee80211_hw *hw)
1570 {
1571 	struct rtl_priv *rtlpriv = rtl_priv(hw);
1572 	struct rtl_phy *rtlphy = &(rtlpriv->phy);
1573 	u32 regeac, regeb4, regebc, regec4, regecc;
1574 	u8 result = 0;
1575 	u8 i;
1576 	u8 retrycount = 2;
1577 
1578 	RTPRINT(rtlpriv, FINIT, INIT_IQK,  "Path B IQK!\n");
1579 	/* path-A IQK setting */
1580 	RTPRINT(rtlpriv, FINIT, INIT_IQK,  "Path-A IQK setting!\n");
1581 	rtl_set_bbreg(hw, 0xe30, MASKDWORD, 0x18008c1f);
1582 	rtl_set_bbreg(hw, 0xe34, MASKDWORD, 0x18008c1f);
1583 	rtl_set_bbreg(hw, 0xe38, MASKDWORD, 0x82110000);
1584 	rtl_set_bbreg(hw, 0xe3c, MASKDWORD, 0x68110000);
1585 
1586 	/* path-B IQK setting */
1587 	rtl_set_bbreg(hw, 0xe50, MASKDWORD, 0x18008c2f);
1588 	rtl_set_bbreg(hw, 0xe54, MASKDWORD, 0x18008c2f);
1589 	rtl_set_bbreg(hw, 0xe58, MASKDWORD, 0x82140307);
1590 	rtl_set_bbreg(hw, 0xe5c, MASKDWORD, 0x68160960);
1591 
1592 	/* LO calibration setting */
1593 	RTPRINT(rtlpriv, FINIT, INIT_IQK,  "LO calibration setting!\n");
1594 	rtl_set_bbreg(hw, 0xe4c, MASKDWORD, 0x00462911);
1595 
1596 	/* path-B PA on */
1597 	rtl_set_bbreg(hw, RFPGA0_XAB_RFINTERFACESW, MASKDWORD, 0x0f600700);
1598 	rtl_set_bbreg(hw, RFPGA0_XB_RFINTERFACEOE, MASKDWORD, 0x061f0d30);
1599 
1600 	for (i = 0; i < retrycount; i++) {
1601 		/* One shot, path B LOK & IQK */
1602 		RTPRINT(rtlpriv, FINIT, INIT_IQK,
1603 			"One shot, path A LOK & IQK!\n");
1604 		rtl_set_bbreg(hw, 0xe48, MASKDWORD, 0xfa000000);
1605 		rtl_set_bbreg(hw, 0xe48, MASKDWORD, 0xf8000000);
1606 
1607 		/* delay x ms */
1608 		RTPRINT(rtlpriv, FINIT, INIT_IQK,
1609 			"Delay %d ms for One shot, path B LOK & IQK.\n", 10);
1610 		mdelay(IQK_DELAY_TIME * 10);
1611 
1612 		/* Check failed */
1613 		regeac = rtl_get_bbreg(hw, 0xeac, MASKDWORD);
1614 		RTPRINT(rtlpriv, FINIT, INIT_IQK,  "0xeac = 0x%x\n", regeac);
1615 		regeb4 = rtl_get_bbreg(hw, 0xeb4, MASKDWORD);
1616 		RTPRINT(rtlpriv, FINIT, INIT_IQK,  "0xeb4 = 0x%x\n", regeb4);
1617 		regebc = rtl_get_bbreg(hw, 0xebc, MASKDWORD);
1618 		RTPRINT(rtlpriv, FINIT, INIT_IQK,  "0xebc = 0x%x\n", regebc);
1619 		regec4 = rtl_get_bbreg(hw, 0xec4, MASKDWORD);
1620 		RTPRINT(rtlpriv, FINIT, INIT_IQK,  "0xec4 = 0x%x\n", regec4);
1621 		regecc = rtl_get_bbreg(hw, 0xecc, MASKDWORD);
1622 		RTPRINT(rtlpriv, FINIT, INIT_IQK,  "0xecc = 0x%x\n", regecc);
1623 		if (!(regeac & BIT(31)) &&
1624 		    (((regeb4 & 0x03FF0000) >> 16) != 0x142))
1625 			result |= 0x01;
1626 		else
1627 			continue;
1628 		if (!(regeac & BIT(30)) &&
1629 		    (((regec4 & 0x03FF0000) >> 16) != 0x132)) {
1630 			result |= 0x02;
1631 			break;
1632 		} else {
1633 			RTPRINT(rtlpriv, FINIT, INIT_IQK,
1634 				"Path B Rx IQK fail!!\n");
1635 		}
1636 	}
1637 
1638 	/* path B PA off */
1639 	rtl_set_bbreg(hw, RFPGA0_XAB_RFINTERFACESW, MASKDWORD,
1640 		      rtlphy->iqk_bb_backup[0]);
1641 	rtl_set_bbreg(hw, RFPGA0_XB_RFINTERFACEOE, MASKDWORD,
1642 		      rtlphy->iqk_bb_backup[2]);
1643 	return result;
1644 }
1645 
1646 static void _rtl92d_phy_save_adda_registers(struct ieee80211_hw *hw,
1647 					    u32 *adda_reg, u32 *adda_backup,
1648 					    u32 regnum)
1649 {
1650 	struct rtl_priv *rtlpriv = rtl_priv(hw);
1651 	u32 i;
1652 
1653 	RTPRINT(rtlpriv, FINIT, INIT_IQK,  "Save ADDA parameters.\n");
1654 	for (i = 0; i < regnum; i++)
1655 		adda_backup[i] = rtl_get_bbreg(hw, adda_reg[i], MASKDWORD);
1656 }
1657 
1658 static void _rtl92d_phy_save_mac_registers(struct ieee80211_hw *hw,
1659 	u32 *macreg, u32 *macbackup)
1660 {
1661 	struct rtl_priv *rtlpriv = rtl_priv(hw);
1662 	u32 i;
1663 
1664 	RTPRINT(rtlpriv, FINIT, INIT_IQK,  "Save MAC parameters.\n");
1665 	for (i = 0; i < (IQK_MAC_REG_NUM - 1); i++)
1666 		macbackup[i] = rtl_read_byte(rtlpriv, macreg[i]);
1667 	macbackup[i] = rtl_read_dword(rtlpriv, macreg[i]);
1668 }
1669 
1670 static void _rtl92d_phy_reload_adda_registers(struct ieee80211_hw *hw,
1671 					      u32 *adda_reg, u32 *adda_backup,
1672 					      u32 regnum)
1673 {
1674 	struct rtl_priv *rtlpriv = rtl_priv(hw);
1675 	u32 i;
1676 
1677 	RTPRINT(rtlpriv, FINIT, INIT_IQK,
1678 		"Reload ADDA power saving parameters !\n");
1679 	for (i = 0; i < regnum; i++)
1680 		rtl_set_bbreg(hw, adda_reg[i], MASKDWORD, adda_backup[i]);
1681 }
1682 
1683 static void _rtl92d_phy_reload_mac_registers(struct ieee80211_hw *hw,
1684 					     u32 *macreg, u32 *macbackup)
1685 {
1686 	struct rtl_priv *rtlpriv = rtl_priv(hw);
1687 	u32 i;
1688 
1689 	RTPRINT(rtlpriv, FINIT, INIT_IQK,  "Reload MAC parameters !\n");
1690 	for (i = 0; i < (IQK_MAC_REG_NUM - 1); i++)
1691 		rtl_write_byte(rtlpriv, macreg[i], (u8) macbackup[i]);
1692 	rtl_write_byte(rtlpriv, macreg[i], macbackup[i]);
1693 }
1694 
1695 static void _rtl92d_phy_path_adda_on(struct ieee80211_hw *hw,
1696 		u32 *adda_reg, bool patha_on, bool is2t)
1697 {
1698 	struct rtl_priv *rtlpriv = rtl_priv(hw);
1699 	u32 pathon;
1700 	u32 i;
1701 
1702 	RTPRINT(rtlpriv, FINIT, INIT_IQK,  "ADDA ON.\n");
1703 	pathon = patha_on ? 0x04db25a4 : 0x0b1b25a4;
1704 	if (patha_on)
1705 		pathon = rtlpriv->rtlhal.interfaceindex == 0 ?
1706 		    0x04db25a4 : 0x0b1b25a4;
1707 	for (i = 0; i < IQK_ADDA_REG_NUM; i++)
1708 		rtl_set_bbreg(hw, adda_reg[i], MASKDWORD, pathon);
1709 }
1710 
1711 static void _rtl92d_phy_mac_setting_calibration(struct ieee80211_hw *hw,
1712 						u32 *macreg, u32 *macbackup)
1713 {
1714 	struct rtl_priv *rtlpriv = rtl_priv(hw);
1715 	u32 i;
1716 
1717 	RTPRINT(rtlpriv, FINIT, INIT_IQK,  "MAC settings for Calibration.\n");
1718 	rtl_write_byte(rtlpriv, macreg[0], 0x3F);
1719 
1720 	for (i = 1; i < (IQK_MAC_REG_NUM - 1); i++)
1721 		rtl_write_byte(rtlpriv, macreg[i], (u8)(macbackup[i] &
1722 			       (~BIT(3))));
1723 	rtl_write_byte(rtlpriv, macreg[i], (u8) (macbackup[i] & (~BIT(5))));
1724 }
1725 
1726 static void _rtl92d_phy_patha_standby(struct ieee80211_hw *hw)
1727 {
1728 	struct rtl_priv *rtlpriv = rtl_priv(hw);
1729 	RTPRINT(rtlpriv, FINIT, INIT_IQK,  "Path-A standby mode!\n");
1730 
1731 	rtl_set_bbreg(hw, 0xe28, MASKDWORD, 0x0);
1732 	rtl_set_bbreg(hw, RFPGA0_XA_LSSIPARAMETER, MASKDWORD, 0x00010000);
1733 	rtl_set_bbreg(hw, 0xe28, MASKDWORD, 0x80800000);
1734 }
1735 
1736 static void _rtl92d_phy_pimode_switch(struct ieee80211_hw *hw, bool pi_mode)
1737 {
1738 	struct rtl_priv *rtlpriv = rtl_priv(hw);
1739 	u32 mode;
1740 
1741 	RTPRINT(rtlpriv, FINIT, INIT_IQK,
1742 		"BB Switch to %s mode!\n", pi_mode ? "PI" : "SI");
1743 	mode = pi_mode ? 0x01000100 : 0x01000000;
1744 	rtl_set_bbreg(hw, 0x820, MASKDWORD, mode);
1745 	rtl_set_bbreg(hw, 0x828, MASKDWORD, mode);
1746 }
1747 
1748 static void _rtl92d_phy_iq_calibrate(struct ieee80211_hw *hw, long result[][8],
1749 				     u8 t, bool is2t)
1750 {
1751 	struct rtl_priv *rtlpriv = rtl_priv(hw);
1752 	struct rtl_phy *rtlphy = &(rtlpriv->phy);
1753 	u32 i;
1754 	u8 patha_ok, pathb_ok;
1755 	static u32 adda_reg[IQK_ADDA_REG_NUM] = {
1756 		RFPGA0_XCD_SWITCHCONTROL, 0xe6c, 0xe70, 0xe74,
1757 		0xe78, 0xe7c, 0xe80, 0xe84,
1758 		0xe88, 0xe8c, 0xed0, 0xed4,
1759 		0xed8, 0xedc, 0xee0, 0xeec
1760 	};
1761 	static u32 iqk_mac_reg[IQK_MAC_REG_NUM] = {
1762 		0x522, 0x550, 0x551, 0x040
1763 	};
1764 	static u32 iqk_bb_reg[IQK_BB_REG_NUM] = {
1765 		RFPGA0_XAB_RFINTERFACESW, RFPGA0_XA_RFINTERFACEOE,
1766 		RFPGA0_XB_RFINTERFACEOE, ROFDM0_TRMUXPAR,
1767 		RFPGA0_XCD_RFINTERFACESW, ROFDM0_TRXPATHENABLE,
1768 		RFPGA0_RFMOD, RFPGA0_ANALOGPARAMETER4,
1769 		ROFDM0_XAAGCCORE1, ROFDM0_XBAGCCORE1
1770 	};
1771 	const u32 retrycount = 2;
1772 	u32 bbvalue;
1773 
1774 	RTPRINT(rtlpriv, FINIT, INIT_IQK,  "IQK for 2.4G :Start!!!\n");
1775 	if (t == 0) {
1776 		bbvalue = rtl_get_bbreg(hw, RFPGA0_RFMOD, MASKDWORD);
1777 		RTPRINT(rtlpriv, FINIT, INIT_IQK,  "==>0x%08x\n", bbvalue);
1778 		RTPRINT(rtlpriv, FINIT, INIT_IQK, "IQ Calibration for %s\n",
1779 			is2t ? "2T2R" : "1T1R");
1780 
1781 		/*  Save ADDA parameters, turn Path A ADDA on */
1782 		_rtl92d_phy_save_adda_registers(hw, adda_reg,
1783 			rtlphy->adda_backup, IQK_ADDA_REG_NUM);
1784 		_rtl92d_phy_save_mac_registers(hw, iqk_mac_reg,
1785 			rtlphy->iqk_mac_backup);
1786 		_rtl92d_phy_save_adda_registers(hw, iqk_bb_reg,
1787 			rtlphy->iqk_bb_backup, IQK_BB_REG_NUM);
1788 	}
1789 	_rtl92d_phy_path_adda_on(hw, adda_reg, true, is2t);
1790 	if (t == 0)
1791 		rtlphy->rfpi_enable = (u8) rtl_get_bbreg(hw,
1792 				RFPGA0_XA_HSSIPARAMETER1, BIT(8));
1793 
1794 	/*  Switch BB to PI mode to do IQ Calibration. */
1795 	if (!rtlphy->rfpi_enable)
1796 		_rtl92d_phy_pimode_switch(hw, true);
1797 
1798 	rtl_set_bbreg(hw, RFPGA0_RFMOD, BIT(24), 0x00);
1799 	rtl_set_bbreg(hw, ROFDM0_TRXPATHENABLE, MASKDWORD, 0x03a05600);
1800 	rtl_set_bbreg(hw, ROFDM0_TRMUXPAR, MASKDWORD, 0x000800e4);
1801 	rtl_set_bbreg(hw, RFPGA0_XCD_RFINTERFACESW, MASKDWORD, 0x22204000);
1802 	rtl_set_bbreg(hw, RFPGA0_ANALOGPARAMETER4, 0xf00000, 0x0f);
1803 	if (is2t) {
1804 		rtl_set_bbreg(hw, RFPGA0_XA_LSSIPARAMETER, MASKDWORD,
1805 			      0x00010000);
1806 		rtl_set_bbreg(hw, RFPGA0_XB_LSSIPARAMETER, MASKDWORD,
1807 			      0x00010000);
1808 	}
1809 	/* MAC settings */
1810 	_rtl92d_phy_mac_setting_calibration(hw, iqk_mac_reg,
1811 					    rtlphy->iqk_mac_backup);
1812 	/* Page B init */
1813 	rtl_set_bbreg(hw, 0xb68, MASKDWORD, 0x0f600000);
1814 	if (is2t)
1815 		rtl_set_bbreg(hw, 0xb6c, MASKDWORD, 0x0f600000);
1816 	/* IQ calibration setting */
1817 	RTPRINT(rtlpriv, FINIT, INIT_IQK,  "IQK setting!\n");
1818 	rtl_set_bbreg(hw, 0xe28, MASKDWORD, 0x80800000);
1819 	rtl_set_bbreg(hw, 0xe40, MASKDWORD, 0x01007c00);
1820 	rtl_set_bbreg(hw, 0xe44, MASKDWORD, 0x01004800);
1821 	for (i = 0; i < retrycount; i++) {
1822 		patha_ok = _rtl92d_phy_patha_iqk(hw, is2t);
1823 		if (patha_ok == 0x03) {
1824 			RTPRINT(rtlpriv, FINIT, INIT_IQK,
1825 				"Path A IQK Success!!\n");
1826 			result[t][0] = (rtl_get_bbreg(hw, 0xe94, MASKDWORD) &
1827 					0x3FF0000) >> 16;
1828 			result[t][1] = (rtl_get_bbreg(hw, 0xe9c, MASKDWORD) &
1829 					0x3FF0000) >> 16;
1830 			result[t][2] = (rtl_get_bbreg(hw, 0xea4, MASKDWORD) &
1831 					0x3FF0000) >> 16;
1832 			result[t][3] = (rtl_get_bbreg(hw, 0xeac, MASKDWORD) &
1833 					0x3FF0000) >> 16;
1834 			break;
1835 		} else if (i == (retrycount - 1) && patha_ok == 0x01) {
1836 			/* Tx IQK OK */
1837 			RTPRINT(rtlpriv, FINIT, INIT_IQK,
1838 				"Path A IQK Only  Tx Success!!\n");
1839 
1840 			result[t][0] = (rtl_get_bbreg(hw, 0xe94, MASKDWORD) &
1841 					0x3FF0000) >> 16;
1842 			result[t][1] = (rtl_get_bbreg(hw, 0xe9c, MASKDWORD) &
1843 					0x3FF0000) >> 16;
1844 		}
1845 	}
1846 	if (0x00 == patha_ok)
1847 		RTPRINT(rtlpriv, FINIT, INIT_IQK,  "Path A IQK failed!!\n");
1848 	if (is2t) {
1849 		_rtl92d_phy_patha_standby(hw);
1850 		/* Turn Path B ADDA on */
1851 		_rtl92d_phy_path_adda_on(hw, adda_reg, false, is2t);
1852 		for (i = 0; i < retrycount; i++) {
1853 			pathb_ok = _rtl92d_phy_pathb_iqk(hw);
1854 			if (pathb_ok == 0x03) {
1855 				RTPRINT(rtlpriv, FINIT, INIT_IQK,
1856 					"Path B IQK Success!!\n");
1857 				result[t][4] = (rtl_get_bbreg(hw, 0xeb4,
1858 					       MASKDWORD) & 0x3FF0000) >> 16;
1859 				result[t][5] = (rtl_get_bbreg(hw, 0xebc,
1860 					       MASKDWORD) & 0x3FF0000) >> 16;
1861 				result[t][6] = (rtl_get_bbreg(hw, 0xec4,
1862 					       MASKDWORD) & 0x3FF0000) >> 16;
1863 				result[t][7] = (rtl_get_bbreg(hw, 0xecc,
1864 					       MASKDWORD) & 0x3FF0000) >> 16;
1865 				break;
1866 			} else if (i == (retrycount - 1) && pathb_ok == 0x01) {
1867 				/* Tx IQK OK */
1868 				RTPRINT(rtlpriv, FINIT, INIT_IQK,
1869 					"Path B Only Tx IQK Success!!\n");
1870 				result[t][4] = (rtl_get_bbreg(hw, 0xeb4,
1871 					       MASKDWORD) & 0x3FF0000) >> 16;
1872 				result[t][5] = (rtl_get_bbreg(hw, 0xebc,
1873 					       MASKDWORD) & 0x3FF0000) >> 16;
1874 			}
1875 		}
1876 		if (0x00 == pathb_ok)
1877 			RTPRINT(rtlpriv, FINIT, INIT_IQK,
1878 				"Path B IQK failed!!\n");
1879 	}
1880 
1881 	/* Back to BB mode, load original value */
1882 	RTPRINT(rtlpriv, FINIT, INIT_IQK,
1883 		"IQK:Back to BB mode, load original value!\n");
1884 
1885 	rtl_set_bbreg(hw, 0xe28, MASKDWORD, 0);
1886 	if (t != 0) {
1887 		/* Switch back BB to SI mode after finish IQ Calibration. */
1888 		if (!rtlphy->rfpi_enable)
1889 			_rtl92d_phy_pimode_switch(hw, false);
1890 		/* Reload ADDA power saving parameters */
1891 		_rtl92d_phy_reload_adda_registers(hw, adda_reg,
1892 				rtlphy->adda_backup, IQK_ADDA_REG_NUM);
1893 		/* Reload MAC parameters */
1894 		_rtl92d_phy_reload_mac_registers(hw, iqk_mac_reg,
1895 					rtlphy->iqk_mac_backup);
1896 		if (is2t)
1897 			_rtl92d_phy_reload_adda_registers(hw, iqk_bb_reg,
1898 							  rtlphy->iqk_bb_backup,
1899 							  IQK_BB_REG_NUM);
1900 		else
1901 			_rtl92d_phy_reload_adda_registers(hw, iqk_bb_reg,
1902 							  rtlphy->iqk_bb_backup,
1903 							  IQK_BB_REG_NUM - 1);
1904 		/* load 0xe30 IQC default value */
1905 		rtl_set_bbreg(hw, 0xe30, MASKDWORD, 0x01008c00);
1906 		rtl_set_bbreg(hw, 0xe34, MASKDWORD, 0x01008c00);
1907 	}
1908 	RTPRINT(rtlpriv, FINIT, INIT_IQK,  "<==\n");
1909 }
1910 
1911 static void _rtl92d_phy_iq_calibrate_5g_normal(struct ieee80211_hw *hw,
1912 					       long result[][8], u8 t)
1913 {
1914 	struct rtl_priv *rtlpriv = rtl_priv(hw);
1915 	struct rtl_phy *rtlphy = &(rtlpriv->phy);
1916 	struct rtl_hal *rtlhal = &(rtlpriv->rtlhal);
1917 	u8 patha_ok, pathb_ok;
1918 	static u32 adda_reg[IQK_ADDA_REG_NUM] = {
1919 		RFPGA0_XCD_SWITCHCONTROL, 0xe6c, 0xe70, 0xe74,
1920 		0xe78, 0xe7c, 0xe80, 0xe84,
1921 		0xe88, 0xe8c, 0xed0, 0xed4,
1922 		0xed8, 0xedc, 0xee0, 0xeec
1923 	};
1924 	static u32 iqk_mac_reg[IQK_MAC_REG_NUM] = {
1925 		0x522, 0x550, 0x551, 0x040
1926 	};
1927 	static u32 iqk_bb_reg[IQK_BB_REG_NUM] = {
1928 		RFPGA0_XAB_RFINTERFACESW, RFPGA0_XA_RFINTERFACEOE,
1929 		RFPGA0_XB_RFINTERFACEOE, ROFDM0_TRMUXPAR,
1930 		RFPGA0_XCD_RFINTERFACESW, ROFDM0_TRXPATHENABLE,
1931 		RFPGA0_RFMOD, RFPGA0_ANALOGPARAMETER4,
1932 		ROFDM0_XAAGCCORE1, ROFDM0_XBAGCCORE1
1933 	};
1934 	u32 bbvalue;
1935 	bool is2t = IS_92D_SINGLEPHY(rtlhal->version);
1936 
1937 	/* Note: IQ calibration must be performed after loading
1938 	 * PHY_REG.txt , and radio_a, radio_b.txt */
1939 
1940 	RTPRINT(rtlpriv, FINIT, INIT_IQK,  "IQK for 5G NORMAL:Start!!!\n");
1941 	mdelay(IQK_DELAY_TIME * 20);
1942 	if (t == 0) {
1943 		bbvalue = rtl_get_bbreg(hw, RFPGA0_RFMOD, MASKDWORD);
1944 		RTPRINT(rtlpriv, FINIT, INIT_IQK,  "==>0x%08x\n", bbvalue);
1945 		RTPRINT(rtlpriv, FINIT, INIT_IQK, "IQ Calibration for %s\n",
1946 			is2t ? "2T2R" : "1T1R");
1947 		/* Save ADDA parameters, turn Path A ADDA on */
1948 		_rtl92d_phy_save_adda_registers(hw, adda_reg,
1949 						rtlphy->adda_backup,
1950 						IQK_ADDA_REG_NUM);
1951 		_rtl92d_phy_save_mac_registers(hw, iqk_mac_reg,
1952 					       rtlphy->iqk_mac_backup);
1953 		if (is2t)
1954 			_rtl92d_phy_save_adda_registers(hw, iqk_bb_reg,
1955 							rtlphy->iqk_bb_backup,
1956 							IQK_BB_REG_NUM);
1957 		else
1958 			_rtl92d_phy_save_adda_registers(hw, iqk_bb_reg,
1959 							rtlphy->iqk_bb_backup,
1960 							IQK_BB_REG_NUM - 1);
1961 	}
1962 	_rtl92d_phy_path_adda_on(hw, adda_reg, true, is2t);
1963 	/* MAC settings */
1964 	_rtl92d_phy_mac_setting_calibration(hw, iqk_mac_reg,
1965 			rtlphy->iqk_mac_backup);
1966 	if (t == 0)
1967 		rtlphy->rfpi_enable = (u8) rtl_get_bbreg(hw,
1968 			RFPGA0_XA_HSSIPARAMETER1, BIT(8));
1969 	/*  Switch BB to PI mode to do IQ Calibration. */
1970 	if (!rtlphy->rfpi_enable)
1971 		_rtl92d_phy_pimode_switch(hw, true);
1972 	rtl_set_bbreg(hw, RFPGA0_RFMOD, BIT(24), 0x00);
1973 	rtl_set_bbreg(hw, ROFDM0_TRXPATHENABLE, MASKDWORD, 0x03a05600);
1974 	rtl_set_bbreg(hw, ROFDM0_TRMUXPAR, MASKDWORD, 0x000800e4);
1975 	rtl_set_bbreg(hw, RFPGA0_XCD_RFINTERFACESW, MASKDWORD, 0x22208000);
1976 	rtl_set_bbreg(hw, RFPGA0_ANALOGPARAMETER4, 0xf00000, 0x0f);
1977 
1978 	/* Page B init */
1979 	rtl_set_bbreg(hw, 0xb68, MASKDWORD, 0x0f600000);
1980 	if (is2t)
1981 		rtl_set_bbreg(hw, 0xb6c, MASKDWORD, 0x0f600000);
1982 	/* IQ calibration setting  */
1983 	RTPRINT(rtlpriv, FINIT, INIT_IQK,  "IQK setting!\n");
1984 	rtl_set_bbreg(hw, 0xe28, MASKDWORD, 0x80800000);
1985 	rtl_set_bbreg(hw, 0xe40, MASKDWORD, 0x10007c00);
1986 	rtl_set_bbreg(hw, 0xe44, MASKDWORD, 0x01004800);
1987 	patha_ok = _rtl92d_phy_patha_iqk_5g_normal(hw, is2t);
1988 	if (patha_ok == 0x03) {
1989 		RTPRINT(rtlpriv, FINIT, INIT_IQK,  "Path A IQK Success!!\n");
1990 		result[t][0] = (rtl_get_bbreg(hw, 0xe94, MASKDWORD) &
1991 				0x3FF0000) >> 16;
1992 		result[t][1] = (rtl_get_bbreg(hw, 0xe9c, MASKDWORD) &
1993 				0x3FF0000) >> 16;
1994 		result[t][2] = (rtl_get_bbreg(hw, 0xea4, MASKDWORD) &
1995 				0x3FF0000) >> 16;
1996 		result[t][3] = (rtl_get_bbreg(hw, 0xeac, MASKDWORD) &
1997 				0x3FF0000) >> 16;
1998 	} else if (patha_ok == 0x01) {	/* Tx IQK OK */
1999 		RTPRINT(rtlpriv, FINIT, INIT_IQK,
2000 			"Path A IQK Only  Tx Success!!\n");
2001 
2002 		result[t][0] = (rtl_get_bbreg(hw, 0xe94, MASKDWORD) &
2003 				0x3FF0000) >> 16;
2004 		result[t][1] = (rtl_get_bbreg(hw, 0xe9c, MASKDWORD) &
2005 				0x3FF0000) >> 16;
2006 	} else {
2007 		RTPRINT(rtlpriv, FINIT, INIT_IQK,  "Path A IQK Fail!!\n");
2008 	}
2009 	if (is2t) {
2010 		/* _rtl92d_phy_patha_standby(hw); */
2011 		/* Turn Path B ADDA on  */
2012 		_rtl92d_phy_path_adda_on(hw, adda_reg, false, is2t);
2013 		pathb_ok = _rtl92d_phy_pathb_iqk_5g_normal(hw);
2014 		if (pathb_ok == 0x03) {
2015 			RTPRINT(rtlpriv, FINIT, INIT_IQK,
2016 				"Path B IQK Success!!\n");
2017 			result[t][4] = (rtl_get_bbreg(hw, 0xeb4, MASKDWORD) &
2018 			     0x3FF0000) >> 16;
2019 			result[t][5] = (rtl_get_bbreg(hw, 0xebc, MASKDWORD) &
2020 			     0x3FF0000) >> 16;
2021 			result[t][6] = (rtl_get_bbreg(hw, 0xec4, MASKDWORD) &
2022 			     0x3FF0000) >> 16;
2023 			result[t][7] = (rtl_get_bbreg(hw, 0xecc, MASKDWORD) &
2024 			     0x3FF0000) >> 16;
2025 		} else if (pathb_ok == 0x01) { /* Tx IQK OK */
2026 			RTPRINT(rtlpriv, FINIT, INIT_IQK,
2027 				"Path B Only Tx IQK Success!!\n");
2028 			result[t][4] = (rtl_get_bbreg(hw, 0xeb4, MASKDWORD) &
2029 			     0x3FF0000) >> 16;
2030 			result[t][5] = (rtl_get_bbreg(hw, 0xebc, MASKDWORD) &
2031 			     0x3FF0000) >> 16;
2032 		} else {
2033 			RTPRINT(rtlpriv, FINIT, INIT_IQK,
2034 				"Path B IQK failed!!\n");
2035 		}
2036 	}
2037 
2038 	/* Back to BB mode, load original value */
2039 	RTPRINT(rtlpriv, FINIT, INIT_IQK,
2040 		"IQK:Back to BB mode, load original value!\n");
2041 	rtl_set_bbreg(hw, 0xe28, MASKDWORD, 0);
2042 	if (t != 0) {
2043 		if (is2t)
2044 			_rtl92d_phy_reload_adda_registers(hw, iqk_bb_reg,
2045 							  rtlphy->iqk_bb_backup,
2046 							  IQK_BB_REG_NUM);
2047 		else
2048 			_rtl92d_phy_reload_adda_registers(hw, iqk_bb_reg,
2049 							  rtlphy->iqk_bb_backup,
2050 							  IQK_BB_REG_NUM - 1);
2051 		/* Reload MAC parameters */
2052 		_rtl92d_phy_reload_mac_registers(hw, iqk_mac_reg,
2053 				rtlphy->iqk_mac_backup);
2054 		/*  Switch back BB to SI mode after finish IQ Calibration. */
2055 		if (!rtlphy->rfpi_enable)
2056 			_rtl92d_phy_pimode_switch(hw, false);
2057 		/* Reload ADDA power saving parameters */
2058 		_rtl92d_phy_reload_adda_registers(hw, adda_reg,
2059 						  rtlphy->adda_backup,
2060 						  IQK_ADDA_REG_NUM);
2061 	}
2062 	RTPRINT(rtlpriv, FINIT, INIT_IQK,  "<==\n");
2063 }
2064 
2065 static bool _rtl92d_phy_simularity_compare(struct ieee80211_hw *hw,
2066 	long result[][8], u8 c1, u8 c2)
2067 {
2068 	struct rtl_priv *rtlpriv = rtl_priv(hw);
2069 	struct rtl_hal *rtlhal = &(rtlpriv->rtlhal);
2070 	u32 i, j, diff, sim_bitmap, bound;
2071 	u8 final_candidate[2] = {0xFF, 0xFF};	/* for path A and path B */
2072 	bool bresult = true;
2073 	bool is2t = IS_92D_SINGLEPHY(rtlhal->version);
2074 
2075 	if (is2t)
2076 		bound = 8;
2077 	else
2078 		bound = 4;
2079 	sim_bitmap = 0;
2080 	for (i = 0; i < bound; i++) {
2081 		diff = (result[c1][i] > result[c2][i]) ? (result[c1][i] -
2082 		       result[c2][i]) : (result[c2][i] - result[c1][i]);
2083 		if (diff > MAX_TOLERANCE_92D) {
2084 			if ((i == 2 || i == 6) && !sim_bitmap) {
2085 				if (result[c1][i] + result[c1][i + 1] == 0)
2086 					final_candidate[(i / 4)] = c2;
2087 				else if (result[c2][i] + result[c2][i + 1] == 0)
2088 					final_candidate[(i / 4)] = c1;
2089 				else
2090 					sim_bitmap = sim_bitmap | (1 << i);
2091 			} else {
2092 				sim_bitmap = sim_bitmap | (1 << i);
2093 			}
2094 		}
2095 	}
2096 	if (sim_bitmap == 0) {
2097 		for (i = 0; i < (bound / 4); i++) {
2098 			if (final_candidate[i] != 0xFF) {
2099 				for (j = i * 4; j < (i + 1) * 4 - 2; j++)
2100 					result[3][j] =
2101 						 result[final_candidate[i]][j];
2102 				bresult = false;
2103 			}
2104 		}
2105 		return bresult;
2106 	}
2107 	if (!(sim_bitmap & 0x0F)) { /* path A OK */
2108 		for (i = 0; i < 4; i++)
2109 			result[3][i] = result[c1][i];
2110 	} else if (!(sim_bitmap & 0x03)) { /* path A, Tx OK */
2111 		for (i = 0; i < 2; i++)
2112 			result[3][i] = result[c1][i];
2113 	}
2114 	if (!(sim_bitmap & 0xF0) && is2t) { /* path B OK */
2115 		for (i = 4; i < 8; i++)
2116 			result[3][i] = result[c1][i];
2117 	} else if (!(sim_bitmap & 0x30)) { /* path B, Tx OK */
2118 		for (i = 4; i < 6; i++)
2119 			result[3][i] = result[c1][i];
2120 	}
2121 	return false;
2122 }
2123 
2124 static void _rtl92d_phy_patha_fill_iqk_matrix(struct ieee80211_hw *hw,
2125 					      bool iqk_ok, long result[][8],
2126 					      u8 final_candidate, bool txonly)
2127 {
2128 	struct rtl_priv *rtlpriv = rtl_priv(hw);
2129 	struct rtl_hal *rtlhal = &(rtlpriv->rtlhal);
2130 	u32 oldval_0, val_x, tx0_a, reg;
2131 	long val_y, tx0_c;
2132 	bool is2t = IS_92D_SINGLEPHY(rtlhal->version) ||
2133 	    rtlhal->macphymode == DUALMAC_DUALPHY;
2134 
2135 	RTPRINT(rtlpriv, FINIT, INIT_IQK,
2136 		"Path A IQ Calibration %s !\n", iqk_ok ? "Success" : "Failed");
2137 	if (final_candidate == 0xFF) {
2138 		return;
2139 	} else if (iqk_ok) {
2140 		oldval_0 = (rtl_get_bbreg(hw, ROFDM0_XATXIQIMBALANCE,
2141 			MASKDWORD) >> 22) & 0x3FF;	/* OFDM0_D */
2142 		val_x = result[final_candidate][0];
2143 		if ((val_x & 0x00000200) != 0)
2144 			val_x = val_x | 0xFFFFFC00;
2145 		tx0_a = (val_x * oldval_0) >> 8;
2146 		RTPRINT(rtlpriv, FINIT, INIT_IQK,
2147 			"X = 0x%x, tx0_a = 0x%x, oldval_0 0x%x\n",
2148 			val_x, tx0_a, oldval_0);
2149 		rtl_set_bbreg(hw, ROFDM0_XATXIQIMBALANCE, 0x3FF, tx0_a);
2150 		rtl_set_bbreg(hw, ROFDM0_ECCATHRESHOLD, BIT(24),
2151 			      ((val_x * oldval_0 >> 7) & 0x1));
2152 		val_y = result[final_candidate][1];
2153 		if ((val_y & 0x00000200) != 0)
2154 			val_y = val_y | 0xFFFFFC00;
2155 		/* path B IQK result + 3 */
2156 		if (rtlhal->interfaceindex == 1 &&
2157 			rtlhal->current_bandtype == BAND_ON_5G)
2158 			val_y += 3;
2159 		tx0_c = (val_y * oldval_0) >> 8;
2160 		RTPRINT(rtlpriv, FINIT, INIT_IQK,
2161 			"Y = 0x%lx, tx0_c = 0x%lx\n",
2162 			val_y, tx0_c);
2163 		rtl_set_bbreg(hw, ROFDM0_XCTXAFE, 0xF0000000,
2164 			      ((tx0_c & 0x3C0) >> 6));
2165 		rtl_set_bbreg(hw, ROFDM0_XATXIQIMBALANCE, 0x003F0000,
2166 			      (tx0_c & 0x3F));
2167 		if (is2t)
2168 			rtl_set_bbreg(hw, ROFDM0_ECCATHRESHOLD, BIT(26),
2169 				      ((val_y * oldval_0 >> 7) & 0x1));
2170 		RTPRINT(rtlpriv, FINIT, INIT_IQK, "0xC80 = 0x%x\n",
2171 			rtl_get_bbreg(hw, ROFDM0_XATXIQIMBALANCE,
2172 				      MASKDWORD));
2173 		if (txonly) {
2174 			RTPRINT(rtlpriv, FINIT, INIT_IQK,  "only Tx OK\n");
2175 			return;
2176 		}
2177 		reg = result[final_candidate][2];
2178 		rtl_set_bbreg(hw, ROFDM0_XARXIQIMBALANCE, 0x3FF, reg);
2179 		reg = result[final_candidate][3] & 0x3F;
2180 		rtl_set_bbreg(hw, ROFDM0_XARXIQIMBALANCE, 0xFC00, reg);
2181 		reg = (result[final_candidate][3] >> 6) & 0xF;
2182 		rtl_set_bbreg(hw, 0xca0, 0xF0000000, reg);
2183 	}
2184 }
2185 
2186 static void _rtl92d_phy_pathb_fill_iqk_matrix(struct ieee80211_hw *hw,
2187 	bool iqk_ok, long result[][8], u8 final_candidate, bool txonly)
2188 {
2189 	struct rtl_priv *rtlpriv = rtl_priv(hw);
2190 	struct rtl_hal *rtlhal = &(rtlpriv->rtlhal);
2191 	u32 oldval_1, val_x, tx1_a, reg;
2192 	long val_y, tx1_c;
2193 
2194 	RTPRINT(rtlpriv, FINIT, INIT_IQK, "Path B IQ Calibration %s !\n",
2195 		iqk_ok ? "Success" : "Failed");
2196 	if (final_candidate == 0xFF) {
2197 		return;
2198 	} else if (iqk_ok) {
2199 		oldval_1 = (rtl_get_bbreg(hw, ROFDM0_XBTXIQIMBALANCE,
2200 					  MASKDWORD) >> 22) & 0x3FF;
2201 		val_x = result[final_candidate][4];
2202 		if ((val_x & 0x00000200) != 0)
2203 			val_x = val_x | 0xFFFFFC00;
2204 		tx1_a = (val_x * oldval_1) >> 8;
2205 		RTPRINT(rtlpriv, FINIT, INIT_IQK, "X = 0x%x, tx1_a = 0x%x\n",
2206 			val_x, tx1_a);
2207 		rtl_set_bbreg(hw, ROFDM0_XBTXIQIMBALANCE, 0x3FF, tx1_a);
2208 		rtl_set_bbreg(hw, ROFDM0_ECCATHRESHOLD, BIT(28),
2209 			      ((val_x * oldval_1 >> 7) & 0x1));
2210 		val_y = result[final_candidate][5];
2211 		if ((val_y & 0x00000200) != 0)
2212 			val_y = val_y | 0xFFFFFC00;
2213 		if (rtlhal->current_bandtype == BAND_ON_5G)
2214 			val_y += 3;
2215 		tx1_c = (val_y * oldval_1) >> 8;
2216 		RTPRINT(rtlpriv, FINIT, INIT_IQK, "Y = 0x%lx, tx1_c = 0x%lx\n",
2217 			val_y, tx1_c);
2218 		rtl_set_bbreg(hw, ROFDM0_XDTXAFE, 0xF0000000,
2219 			      ((tx1_c & 0x3C0) >> 6));
2220 		rtl_set_bbreg(hw, ROFDM0_XBTXIQIMBALANCE, 0x003F0000,
2221 			      (tx1_c & 0x3F));
2222 		rtl_set_bbreg(hw, ROFDM0_ECCATHRESHOLD, BIT(30),
2223 			      ((val_y * oldval_1 >> 7) & 0x1));
2224 		if (txonly)
2225 			return;
2226 		reg = result[final_candidate][6];
2227 		rtl_set_bbreg(hw, ROFDM0_XBRXIQIMBALANCE, 0x3FF, reg);
2228 		reg = result[final_candidate][7] & 0x3F;
2229 		rtl_set_bbreg(hw, ROFDM0_XBRXIQIMBALANCE, 0xFC00, reg);
2230 		reg = (result[final_candidate][7] >> 6) & 0xF;
2231 		rtl_set_bbreg(hw, ROFDM0_AGCRSSITABLE, 0x0000F000, reg);
2232 	}
2233 }
2234 
2235 void rtl92d_phy_iq_calibrate(struct ieee80211_hw *hw)
2236 {
2237 	struct rtl_priv *rtlpriv = rtl_priv(hw);
2238 	struct rtl_phy *rtlphy = &(rtlpriv->phy);
2239 	struct rtl_hal *rtlhal = &(rtlpriv->rtlhal);
2240 	long result[4][8];
2241 	u8 i, final_candidate, indexforchannel;
2242 	bool patha_ok, pathb_ok;
2243 	long rege94, rege9c, regea4, regeac, regeb4;
2244 	long regebc, regec4, regecc, regtmp = 0;
2245 	bool is12simular, is13simular, is23simular;
2246 	unsigned long flag = 0;
2247 
2248 	RTPRINT(rtlpriv, FINIT, INIT_IQK,
2249 		"IQK:Start!!!channel %d\n", rtlphy->current_channel);
2250 	for (i = 0; i < 8; i++) {
2251 		result[0][i] = 0;
2252 		result[1][i] = 0;
2253 		result[2][i] = 0;
2254 		result[3][i] = 0;
2255 	}
2256 	final_candidate = 0xff;
2257 	patha_ok = false;
2258 	pathb_ok = false;
2259 	is12simular = false;
2260 	is23simular = false;
2261 	is13simular = false;
2262 	RTPRINT(rtlpriv, FINIT, INIT_IQK,
2263 		"IQK !!!currentband %d\n", rtlhal->current_bandtype);
2264 	rtl92d_acquire_cckandrw_pagea_ctl(hw, &flag);
2265 	for (i = 0; i < 3; i++) {
2266 		if (rtlhal->current_bandtype == BAND_ON_5G) {
2267 			_rtl92d_phy_iq_calibrate_5g_normal(hw, result, i);
2268 		} else if (rtlhal->current_bandtype == BAND_ON_2_4G) {
2269 			if (IS_92D_SINGLEPHY(rtlhal->version))
2270 				_rtl92d_phy_iq_calibrate(hw, result, i, true);
2271 			else
2272 				_rtl92d_phy_iq_calibrate(hw, result, i, false);
2273 		}
2274 		if (i == 1) {
2275 			is12simular = _rtl92d_phy_simularity_compare(hw, result,
2276 								     0, 1);
2277 			if (is12simular) {
2278 				final_candidate = 0;
2279 				break;
2280 			}
2281 		}
2282 		if (i == 2) {
2283 			is13simular = _rtl92d_phy_simularity_compare(hw, result,
2284 								     0, 2);
2285 			if (is13simular) {
2286 				final_candidate = 0;
2287 				break;
2288 			}
2289 			is23simular = _rtl92d_phy_simularity_compare(hw, result,
2290 								     1, 2);
2291 			if (is23simular) {
2292 				final_candidate = 1;
2293 			} else {
2294 				for (i = 0; i < 8; i++)
2295 					regtmp += result[3][i];
2296 
2297 				if (regtmp != 0)
2298 					final_candidate = 3;
2299 				else
2300 					final_candidate = 0xFF;
2301 			}
2302 		}
2303 	}
2304 	rtl92d_release_cckandrw_pagea_ctl(hw, &flag);
2305 	for (i = 0; i < 4; i++) {
2306 		rege94 = result[i][0];
2307 		rege9c = result[i][1];
2308 		regea4 = result[i][2];
2309 		regeac = result[i][3];
2310 		regeb4 = result[i][4];
2311 		regebc = result[i][5];
2312 		regec4 = result[i][6];
2313 		regecc = result[i][7];
2314 		RTPRINT(rtlpriv, FINIT, INIT_IQK,
2315 			"IQK: rege94=%lx rege9c=%lx regea4=%lx regeac=%lx regeb4=%lx regebc=%lx regec4=%lx regecc=%lx\n",
2316 			rege94, rege9c, regea4, regeac, regeb4, regebc, regec4,
2317 			regecc);
2318 	}
2319 	if (final_candidate != 0xff) {
2320 		rtlphy->reg_e94 = rege94 = result[final_candidate][0];
2321 		rtlphy->reg_e9c = rege9c = result[final_candidate][1];
2322 		regea4 = result[final_candidate][2];
2323 		regeac = result[final_candidate][3];
2324 		rtlphy->reg_eb4 = regeb4 = result[final_candidate][4];
2325 		rtlphy->reg_ebc = regebc = result[final_candidate][5];
2326 		regec4 = result[final_candidate][6];
2327 		regecc = result[final_candidate][7];
2328 		RTPRINT(rtlpriv, FINIT, INIT_IQK,
2329 			"IQK: final_candidate is %x\n", final_candidate);
2330 		RTPRINT(rtlpriv, FINIT, INIT_IQK,
2331 			"IQK: rege94=%lx rege9c=%lx regea4=%lx regeac=%lx regeb4=%lx regebc=%lx regec4=%lx regecc=%lx\n",
2332 			rege94, rege9c, regea4, regeac, regeb4, regebc, regec4,
2333 			regecc);
2334 		patha_ok = pathb_ok = true;
2335 	} else {
2336 		rtlphy->reg_e94 = rtlphy->reg_eb4 = 0x100; /* X default value */
2337 		rtlphy->reg_e9c = rtlphy->reg_ebc = 0x0;   /* Y default value */
2338 	}
2339 	if ((rege94 != 0) /*&&(regea4 != 0) */)
2340 		_rtl92d_phy_patha_fill_iqk_matrix(hw, patha_ok, result,
2341 				final_candidate, (regea4 == 0));
2342 	if (IS_92D_SINGLEPHY(rtlhal->version)) {
2343 		if ((regeb4 != 0) /*&&(regec4 != 0) */)
2344 			_rtl92d_phy_pathb_fill_iqk_matrix(hw, pathb_ok, result,
2345 						final_candidate, (regec4 == 0));
2346 	}
2347 	if (final_candidate != 0xFF) {
2348 		indexforchannel = rtl92d_get_rightchnlplace_for_iqk(
2349 				  rtlphy->current_channel);
2350 
2351 		for (i = 0; i < IQK_MATRIX_REG_NUM; i++)
2352 			rtlphy->iqk_matrix[indexforchannel].
2353 				value[0][i] = result[final_candidate][i];
2354 		rtlphy->iqk_matrix[indexforchannel].iqk_done =
2355 			true;
2356 
2357 		rtl_dbg(rtlpriv, COMP_SCAN | COMP_MLME, DBG_LOUD,
2358 			"IQK OK indexforchannel %d\n", indexforchannel);
2359 	}
2360 }
2361 
2362 void rtl92d_phy_reload_iqk_setting(struct ieee80211_hw *hw, u8 channel)
2363 {
2364 	struct rtl_priv *rtlpriv = rtl_priv(hw);
2365 	struct rtl_phy *rtlphy = &(rtlpriv->phy);
2366 	struct rtl_hal *rtlhal = &(rtlpriv->rtlhal);
2367 	u8 indexforchannel;
2368 
2369 	rtl_dbg(rtlpriv, COMP_CMD, DBG_LOUD, "channel %d\n", channel);
2370 	/*------Do IQK for normal chip and test chip 5G band------- */
2371 	indexforchannel = rtl92d_get_rightchnlplace_for_iqk(channel);
2372 	rtl_dbg(rtlpriv, COMP_CMD, DBG_LOUD, "indexforchannel %d done %d\n",
2373 		indexforchannel,
2374 		 rtlphy->iqk_matrix[indexforchannel].iqk_done);
2375 	if (0 && !rtlphy->iqk_matrix[indexforchannel].iqk_done &&
2376 		rtlphy->need_iqk) {
2377 		/* Re Do IQK. */
2378 		rtl_dbg(rtlpriv, COMP_SCAN | COMP_INIT, DBG_LOUD,
2379 			"Do IQK Matrix reg for channel:%d....\n", channel);
2380 		rtl92d_phy_iq_calibrate(hw);
2381 	} else {
2382 		/* Just load the value. */
2383 		/* 2G band just load once. */
2384 		if (((!rtlhal->load_imrandiqk_setting_for2g) &&
2385 		    indexforchannel == 0) || indexforchannel > 0) {
2386 			rtl_dbg(rtlpriv, COMP_SCAN, DBG_LOUD,
2387 				"Just Read IQK Matrix reg for channel:%d....\n",
2388 				channel);
2389 			if (rtlphy->iqk_matrix[indexforchannel].value[0][0] != 0)
2390 				_rtl92d_phy_patha_fill_iqk_matrix(hw, true,
2391 					rtlphy->iqk_matrix[indexforchannel].value, 0,
2392 					rtlphy->iqk_matrix[indexforchannel].value[0][2] == 0);
2393 			if (IS_92D_SINGLEPHY(rtlhal->version)) {
2394 				if ((rtlphy->iqk_matrix[
2395 					indexforchannel].value[0][4] != 0)
2396 					/*&&(regec4 != 0) */)
2397 					_rtl92d_phy_pathb_fill_iqk_matrix(hw,
2398 						true,
2399 						rtlphy->iqk_matrix[
2400 						indexforchannel].value, 0,
2401 						(rtlphy->iqk_matrix[
2402 						indexforchannel].value[0][6]
2403 						== 0));
2404 			}
2405 		}
2406 	}
2407 	rtlphy->need_iqk = false;
2408 	rtl_dbg(rtlpriv, COMP_CMD, DBG_LOUD, "<====\n");
2409 }
2410 
2411 static u32 _rtl92d_phy_get_abs(u32 val1, u32 val2)
2412 {
2413 	u32 ret;
2414 
2415 	if (val1 >= val2)
2416 		ret = val1 - val2;
2417 	else
2418 		ret = val2 - val1;
2419 	return ret;
2420 }
2421 
2422 static bool _rtl92d_is_legal_5g_channel(struct ieee80211_hw *hw, u8 channel)
2423 {
2424 
2425 	int i;
2426 
2427 	for (i = 0; i < ARRAY_SIZE(channel5g); i++)
2428 		if (channel == channel5g[i])
2429 			return true;
2430 	return false;
2431 }
2432 
2433 static void _rtl92d_phy_calc_curvindex(struct ieee80211_hw *hw,
2434 				       u32 *targetchnl, u32 * curvecount_val,
2435 				       bool is5g, u32 *curveindex)
2436 {
2437 	struct rtl_priv *rtlpriv = rtl_priv(hw);
2438 	u32 smallest_abs_val = 0xffffffff, u4tmp;
2439 	u8 i, j;
2440 	u8 chnl_num = is5g ? TARGET_CHNL_NUM_5G : TARGET_CHNL_NUM_2G;
2441 
2442 	for (i = 0; i < chnl_num; i++) {
2443 		if (is5g && !_rtl92d_is_legal_5g_channel(hw, i + 1))
2444 			continue;
2445 		curveindex[i] = 0;
2446 		for (j = 0; j < (CV_CURVE_CNT * 2); j++) {
2447 			u4tmp = _rtl92d_phy_get_abs(targetchnl[i],
2448 				curvecount_val[j]);
2449 
2450 			if (u4tmp < smallest_abs_val) {
2451 				curveindex[i] = j;
2452 				smallest_abs_val = u4tmp;
2453 			}
2454 		}
2455 		smallest_abs_val = 0xffffffff;
2456 		RTPRINT(rtlpriv, FINIT, INIT_IQK, "curveindex[%d] = %x\n",
2457 			i, curveindex[i]);
2458 	}
2459 }
2460 
2461 static void _rtl92d_phy_reload_lck_setting(struct ieee80211_hw *hw,
2462 		u8 channel)
2463 {
2464 	struct rtl_priv *rtlpriv = rtl_priv(hw);
2465 	u8 erfpath = rtlpriv->rtlhal.current_bandtype ==
2466 		BAND_ON_5G ? RF90_PATH_A :
2467 		IS_92D_SINGLEPHY(rtlpriv->rtlhal.version) ?
2468 		RF90_PATH_B : RF90_PATH_A;
2469 	u32 u4tmp = 0, u4regvalue = 0;
2470 	bool bneed_powerdown_radio = false;
2471 
2472 	rtl_dbg(rtlpriv, COMP_CMD, DBG_LOUD, "path %d\n", erfpath);
2473 	RTPRINT(rtlpriv, FINIT, INIT_IQK, "band type = %d\n",
2474 		rtlpriv->rtlhal.current_bandtype);
2475 	RTPRINT(rtlpriv, FINIT, INIT_IQK,  "channel = %d\n", channel);
2476 	if (rtlpriv->rtlhal.current_bandtype == BAND_ON_5G) {/* Path-A for 5G */
2477 		u4tmp = curveindex_5g[channel-1];
2478 		RTPRINT(rtlpriv, FINIT, INIT_IQK,
2479 			"ver 1 set RF-A, 5G,	0x28 = 0x%x !!\n", u4tmp);
2480 		if (rtlpriv->rtlhal.macphymode == DUALMAC_DUALPHY &&
2481 			rtlpriv->rtlhal.interfaceindex == 1) {
2482 			bneed_powerdown_radio =
2483 				rtl92d_phy_enable_anotherphy(hw, false);
2484 			rtlpriv->rtlhal.during_mac1init_radioa = true;
2485 			/* asume no this case */
2486 			if (bneed_powerdown_radio)
2487 				_rtl92d_phy_enable_rf_env(hw, erfpath,
2488 							  &u4regvalue);
2489 		}
2490 		rtl_set_rfreg(hw, erfpath, RF_SYN_G4, 0x3f800, u4tmp);
2491 		if (bneed_powerdown_radio)
2492 			_rtl92d_phy_restore_rf_env(hw, erfpath, &u4regvalue);
2493 		if (rtlpriv->rtlhal.during_mac1init_radioa)
2494 			rtl92d_phy_powerdown_anotherphy(hw, false);
2495 	} else if (rtlpriv->rtlhal.current_bandtype == BAND_ON_2_4G) {
2496 		u4tmp = curveindex_2g[channel-1];
2497 		RTPRINT(rtlpriv, FINIT, INIT_IQK,
2498 			"ver 3 set RF-B, 2G, 0x28 = 0x%x !!\n", u4tmp);
2499 		if (rtlpriv->rtlhal.macphymode == DUALMAC_DUALPHY &&
2500 			rtlpriv->rtlhal.interfaceindex == 0) {
2501 			bneed_powerdown_radio =
2502 				rtl92d_phy_enable_anotherphy(hw, true);
2503 			rtlpriv->rtlhal.during_mac0init_radiob = true;
2504 			if (bneed_powerdown_radio)
2505 				_rtl92d_phy_enable_rf_env(hw, erfpath,
2506 							  &u4regvalue);
2507 		}
2508 		rtl_set_rfreg(hw, erfpath, RF_SYN_G4, 0x3f800, u4tmp);
2509 		RTPRINT(rtlpriv, FINIT, INIT_IQK,
2510 			"ver 3 set RF-B, 2G, 0x28 = 0x%x !!\n",
2511 			rtl_get_rfreg(hw,  erfpath, RF_SYN_G4, 0x3f800));
2512 		if (bneed_powerdown_radio)
2513 			_rtl92d_phy_restore_rf_env(hw, erfpath, &u4regvalue);
2514 		if (rtlpriv->rtlhal.during_mac0init_radiob)
2515 			rtl92d_phy_powerdown_anotherphy(hw, true);
2516 	}
2517 	rtl_dbg(rtlpriv, COMP_CMD, DBG_LOUD, "<====\n");
2518 }
2519 
2520 static void _rtl92d_phy_lc_calibrate_sw(struct ieee80211_hw *hw, bool is2t)
2521 {
2522 	struct rtl_priv *rtlpriv = rtl_priv(hw);
2523 	struct rtl_hal *rtlhal = &(rtlpriv->rtlhal);
2524 	struct rtl_pci *rtlpci = rtl_pcidev(rtl_pcipriv(hw));
2525 	u8 tmpreg, index, rf_mode[2];
2526 	u8 path = is2t ? 2 : 1;
2527 	u8 i;
2528 	u32 u4tmp, offset;
2529 	u32 curvecount_val[CV_CURVE_CNT * 2] = {0};
2530 	u16 timeout = 800, timecount = 0;
2531 
2532 	/* Check continuous TX and Packet TX */
2533 	tmpreg = rtl_read_byte(rtlpriv, 0xd03);
2534 	/* if Deal with contisuous TX case, disable all continuous TX */
2535 	/* if Deal with Packet TX case, block all queues */
2536 	if ((tmpreg & 0x70) != 0)
2537 		rtl_write_byte(rtlpriv, 0xd03, tmpreg & 0x8F);
2538 	else
2539 		rtl_write_byte(rtlpriv, REG_TXPAUSE, 0xFF);
2540 	rtl_set_bbreg(hw, RFPGA0_ANALOGPARAMETER4, 0xF00000, 0x0F);
2541 	for (index = 0; index < path; index++) {
2542 		/* 1. Read original RF mode */
2543 		offset = index == 0 ? ROFDM0_XAAGCCORE1 : ROFDM0_XBAGCCORE1;
2544 		rf_mode[index] = rtl_read_byte(rtlpriv, offset);
2545 		/* 2. Set RF mode = standby mode */
2546 		rtl_set_rfreg(hw, (enum radio_path)index, RF_AC,
2547 			      RFREG_OFFSET_MASK, 0x010000);
2548 		if (rtlpci->init_ready) {
2549 			/* switch CV-curve control by LC-calibration */
2550 			rtl_set_rfreg(hw, (enum radio_path)index, RF_SYN_G7,
2551 				      BIT(17), 0x0);
2552 			/* 4. Set LC calibration begin */
2553 			rtl_set_rfreg(hw, (enum radio_path)index, RF_CHNLBW,
2554 				      0x08000, 0x01);
2555 		}
2556 		u4tmp = rtl_get_rfreg(hw, (enum radio_path)index, RF_SYN_G6,
2557 				  RFREG_OFFSET_MASK);
2558 		while ((!(u4tmp & BIT(11))) && timecount <= timeout) {
2559 			mdelay(50);
2560 			timecount += 50;
2561 			u4tmp = rtl_get_rfreg(hw, (enum radio_path)index,
2562 					      RF_SYN_G6, RFREG_OFFSET_MASK);
2563 		}
2564 		RTPRINT(rtlpriv, FINIT, INIT_IQK,
2565 			"PHY_LCK finish delay for %d ms=2\n", timecount);
2566 		rtl_get_rfreg(hw, index, RF_SYN_G4, RFREG_OFFSET_MASK);
2567 		if (index == 0 && rtlhal->interfaceindex == 0) {
2568 			RTPRINT(rtlpriv, FINIT, INIT_IQK,
2569 				"path-A / 5G LCK\n");
2570 		} else {
2571 			RTPRINT(rtlpriv, FINIT, INIT_IQK,
2572 				"path-B / 2.4G LCK\n");
2573 		}
2574 		memset(curvecount_val, 0, sizeof(curvecount_val));
2575 		/* Set LC calibration off */
2576 		rtl_set_rfreg(hw, (enum radio_path)index, RF_CHNLBW,
2577 			      0x08000, 0x0);
2578 		RTPRINT(rtlpriv, FINIT, INIT_IQK,  "set RF 0x18[15] = 0\n");
2579 		/* save Curve-counting number */
2580 		for (i = 0; i < CV_CURVE_CNT; i++) {
2581 			u32 readval = 0, readval2 = 0;
2582 			rtl_set_rfreg(hw, (enum radio_path)index, 0x3F,
2583 				      0x7f, i);
2584 
2585 			rtl_set_rfreg(hw, (enum radio_path)index, 0x4D,
2586 				RFREG_OFFSET_MASK, 0x0);
2587 			readval = rtl_get_rfreg(hw, (enum radio_path)index,
2588 					  0x4F, RFREG_OFFSET_MASK);
2589 			curvecount_val[2 * i + 1] = (readval & 0xfffe0) >> 5;
2590 			/* reg 0x4f [4:0] */
2591 			/* reg 0x50 [19:10] */
2592 			readval2 = rtl_get_rfreg(hw, (enum radio_path)index,
2593 						 0x50, 0xffc00);
2594 			curvecount_val[2 * i] = (((readval & 0x1F) << 10) |
2595 						 readval2);
2596 		}
2597 		if (index == 0 && rtlhal->interfaceindex == 0)
2598 			_rtl92d_phy_calc_curvindex(hw, targetchnl_5g,
2599 						   curvecount_val,
2600 						   true, curveindex_5g);
2601 		else
2602 			_rtl92d_phy_calc_curvindex(hw, targetchnl_2g,
2603 						   curvecount_val,
2604 						   false, curveindex_2g);
2605 		/* switch CV-curve control mode */
2606 		rtl_set_rfreg(hw, (enum radio_path)index, RF_SYN_G7,
2607 			      BIT(17), 0x1);
2608 	}
2609 
2610 	/* Restore original situation  */
2611 	for (index = 0; index < path; index++) {
2612 		offset = index == 0 ? ROFDM0_XAAGCCORE1 : ROFDM0_XBAGCCORE1;
2613 		rtl_write_byte(rtlpriv, offset, 0x50);
2614 		rtl_write_byte(rtlpriv, offset, rf_mode[index]);
2615 	}
2616 	if ((tmpreg & 0x70) != 0)
2617 		rtl_write_byte(rtlpriv, 0xd03, tmpreg);
2618 	else /*Deal with Packet TX case */
2619 		rtl_write_byte(rtlpriv, REG_TXPAUSE, 0x00);
2620 	rtl_set_bbreg(hw, RFPGA0_ANALOGPARAMETER4, 0xF00000, 0x00);
2621 	_rtl92d_phy_reload_lck_setting(hw, rtlpriv->phy.current_channel);
2622 }
2623 
2624 static void _rtl92d_phy_lc_calibrate(struct ieee80211_hw *hw, bool is2t)
2625 {
2626 	struct rtl_priv *rtlpriv = rtl_priv(hw);
2627 
2628 	RTPRINT(rtlpriv, FINIT, INIT_IQK,  "cosa PHY_LCK ver=2\n");
2629 	_rtl92d_phy_lc_calibrate_sw(hw, is2t);
2630 }
2631 
2632 void rtl92d_phy_lc_calibrate(struct ieee80211_hw *hw)
2633 {
2634 	struct rtl_priv *rtlpriv = rtl_priv(hw);
2635 	struct rtl_phy *rtlphy = &(rtlpriv->phy);
2636 	struct rtl_hal *rtlhal = &(rtlpriv->rtlhal);
2637 	u32 timeout = 2000, timecount = 0;
2638 
2639 	while (rtlpriv->mac80211.act_scanning && timecount < timeout) {
2640 		udelay(50);
2641 		timecount += 50;
2642 	}
2643 
2644 	rtlphy->lck_inprogress = true;
2645 	RTPRINT(rtlpriv, FINIT, INIT_IQK,
2646 		"LCK:Start!!! currentband %x delay %d ms\n",
2647 		rtlhal->current_bandtype, timecount);
2648 	if (IS_92D_SINGLEPHY(rtlhal->version)) {
2649 		_rtl92d_phy_lc_calibrate(hw, true);
2650 	} else {
2651 		/* For 1T1R */
2652 		_rtl92d_phy_lc_calibrate(hw, false);
2653 	}
2654 	rtlphy->lck_inprogress = false;
2655 	RTPRINT(rtlpriv, FINIT, INIT_IQK,  "LCK:Finish!!!\n");
2656 }
2657 
2658 void rtl92d_phy_ap_calibrate(struct ieee80211_hw *hw, s8 delta)
2659 {
2660 	return;
2661 }
2662 
2663 static bool _rtl92d_phy_set_sw_chnl_cmdarray(struct swchnlcmd *cmdtable,
2664 		u32 cmdtableidx, u32 cmdtablesz, enum swchnlcmd_id cmdid,
2665 		u32 para1, u32 para2, u32 msdelay)
2666 {
2667 	struct swchnlcmd *pcmd;
2668 
2669 	if (cmdtable == NULL) {
2670 		WARN_ONCE(true, "rtl8192de: cmdtable cannot be NULL\n");
2671 		return false;
2672 	}
2673 	if (cmdtableidx >= cmdtablesz)
2674 		return false;
2675 
2676 	pcmd = cmdtable + cmdtableidx;
2677 	pcmd->cmdid = cmdid;
2678 	pcmd->para1 = para1;
2679 	pcmd->para2 = para2;
2680 	pcmd->msdelay = msdelay;
2681 	return true;
2682 }
2683 
2684 void rtl92d_phy_reset_iqk_result(struct ieee80211_hw *hw)
2685 {
2686 	struct rtl_priv *rtlpriv = rtl_priv(hw);
2687 	struct rtl_phy *rtlphy = &(rtlpriv->phy);
2688 	u8 i;
2689 
2690 	rtl_dbg(rtlpriv, COMP_INIT, DBG_LOUD,
2691 		"settings regs %zu default regs %d\n",
2692 		ARRAY_SIZE(rtlphy->iqk_matrix),
2693 		IQK_MATRIX_REG_NUM);
2694 	/* 0xe94, 0xe9c, 0xea4, 0xeac, 0xeb4, 0xebc, 0xec4, 0xecc */
2695 	for (i = 0; i < IQK_MATRIX_SETTINGS_NUM; i++) {
2696 		rtlphy->iqk_matrix[i].value[0][0] = 0x100;
2697 		rtlphy->iqk_matrix[i].value[0][2] = 0x100;
2698 		rtlphy->iqk_matrix[i].value[0][4] = 0x100;
2699 		rtlphy->iqk_matrix[i].value[0][6] = 0x100;
2700 		rtlphy->iqk_matrix[i].value[0][1] = 0x0;
2701 		rtlphy->iqk_matrix[i].value[0][3] = 0x0;
2702 		rtlphy->iqk_matrix[i].value[0][5] = 0x0;
2703 		rtlphy->iqk_matrix[i].value[0][7] = 0x0;
2704 		rtlphy->iqk_matrix[i].iqk_done = false;
2705 	}
2706 }
2707 
2708 static bool _rtl92d_phy_sw_chnl_step_by_step(struct ieee80211_hw *hw,
2709 					     u8 channel, u8 *stage, u8 *step,
2710 					     u32 *delay)
2711 {
2712 	struct rtl_priv *rtlpriv = rtl_priv(hw);
2713 	struct rtl_phy *rtlphy = &(rtlpriv->phy);
2714 	struct swchnlcmd precommoncmd[MAX_PRECMD_CNT];
2715 	u32 precommoncmdcnt;
2716 	struct swchnlcmd postcommoncmd[MAX_POSTCMD_CNT];
2717 	u32 postcommoncmdcnt;
2718 	struct swchnlcmd rfdependcmd[MAX_RFDEPENDCMD_CNT];
2719 	u32 rfdependcmdcnt;
2720 	struct swchnlcmd *currentcmd = NULL;
2721 	u8 rfpath;
2722 	u8 num_total_rfpath = rtlphy->num_total_rfpath;
2723 
2724 	precommoncmdcnt = 0;
2725 	_rtl92d_phy_set_sw_chnl_cmdarray(precommoncmd, precommoncmdcnt++,
2726 					 MAX_PRECMD_CNT,
2727 					 CMDID_SET_TXPOWEROWER_LEVEL, 0, 0, 0);
2728 	_rtl92d_phy_set_sw_chnl_cmdarray(precommoncmd, precommoncmdcnt++,
2729 					 MAX_PRECMD_CNT, CMDID_END, 0, 0, 0);
2730 	postcommoncmdcnt = 0;
2731 	_rtl92d_phy_set_sw_chnl_cmdarray(postcommoncmd, postcommoncmdcnt++,
2732 					 MAX_POSTCMD_CNT, CMDID_END, 0, 0, 0);
2733 	rfdependcmdcnt = 0;
2734 	_rtl92d_phy_set_sw_chnl_cmdarray(rfdependcmd, rfdependcmdcnt++,
2735 					 MAX_RFDEPENDCMD_CNT, CMDID_RF_WRITEREG,
2736 					 RF_CHNLBW, channel, 0);
2737 	_rtl92d_phy_set_sw_chnl_cmdarray(rfdependcmd, rfdependcmdcnt++,
2738 					 MAX_RFDEPENDCMD_CNT, CMDID_END,
2739 					 0, 0, 0);
2740 
2741 	do {
2742 		switch (*stage) {
2743 		case 0:
2744 			currentcmd = &precommoncmd[*step];
2745 			break;
2746 		case 1:
2747 			currentcmd = &rfdependcmd[*step];
2748 			break;
2749 		case 2:
2750 			currentcmd = &postcommoncmd[*step];
2751 			break;
2752 		}
2753 		if (currentcmd->cmdid == CMDID_END) {
2754 			if ((*stage) == 2) {
2755 				return true;
2756 			} else {
2757 				(*stage)++;
2758 				(*step) = 0;
2759 				continue;
2760 			}
2761 		}
2762 		switch (currentcmd->cmdid) {
2763 		case CMDID_SET_TXPOWEROWER_LEVEL:
2764 			rtl92d_phy_set_txpower_level(hw, channel);
2765 			break;
2766 		case CMDID_WRITEPORT_ULONG:
2767 			rtl_write_dword(rtlpriv, currentcmd->para1,
2768 					currentcmd->para2);
2769 			break;
2770 		case CMDID_WRITEPORT_USHORT:
2771 			rtl_write_word(rtlpriv, currentcmd->para1,
2772 				       (u16)currentcmd->para2);
2773 			break;
2774 		case CMDID_WRITEPORT_UCHAR:
2775 			rtl_write_byte(rtlpriv, currentcmd->para1,
2776 				       (u8)currentcmd->para2);
2777 			break;
2778 		case CMDID_RF_WRITEREG:
2779 			for (rfpath = 0; rfpath < num_total_rfpath; rfpath++) {
2780 				rtlphy->rfreg_chnlval[rfpath] =
2781 					((rtlphy->rfreg_chnlval[rfpath] &
2782 					0xffffff00) | currentcmd->para2);
2783 				if (rtlpriv->rtlhal.current_bandtype ==
2784 				    BAND_ON_5G) {
2785 					if (currentcmd->para2 > 99)
2786 						rtlphy->rfreg_chnlval[rfpath] =
2787 						    rtlphy->rfreg_chnlval
2788 						    [rfpath] | (BIT(18));
2789 					else
2790 						rtlphy->rfreg_chnlval[rfpath] =
2791 						    rtlphy->rfreg_chnlval
2792 						    [rfpath] & (~BIT(18));
2793 					rtlphy->rfreg_chnlval[rfpath] |=
2794 						 (BIT(16) | BIT(8));
2795 				} else {
2796 					rtlphy->rfreg_chnlval[rfpath] &=
2797 						~(BIT(8) | BIT(16) | BIT(18));
2798 				}
2799 				rtl_set_rfreg(hw, (enum radio_path)rfpath,
2800 					      currentcmd->para1,
2801 					      RFREG_OFFSET_MASK,
2802 					      rtlphy->rfreg_chnlval[rfpath]);
2803 				_rtl92d_phy_reload_imr_setting(hw, channel,
2804 							       rfpath);
2805 			}
2806 			_rtl92d_phy_switch_rf_setting(hw, channel);
2807 			/* do IQK when all parameters are ready */
2808 			rtl92d_phy_reload_iqk_setting(hw, channel);
2809 			break;
2810 		default:
2811 			pr_err("switch case %#x not processed\n",
2812 			       currentcmd->cmdid);
2813 			break;
2814 		}
2815 		break;
2816 	} while (true);
2817 	(*delay) = currentcmd->msdelay;
2818 	(*step)++;
2819 	return false;
2820 }
2821 
2822 u8 rtl92d_phy_sw_chnl(struct ieee80211_hw *hw)
2823 {
2824 	struct rtl_priv *rtlpriv = rtl_priv(hw);
2825 	struct rtl_phy *rtlphy = &(rtlpriv->phy);
2826 	struct rtl_hal *rtlhal = rtl_hal(rtl_priv(hw));
2827 	u32 delay;
2828 	u32 timeout = 1000, timecount = 0;
2829 	u8 channel = rtlphy->current_channel;
2830 	u32 ret_value;
2831 
2832 	if (rtlphy->sw_chnl_inprogress)
2833 		return 0;
2834 	if (rtlphy->set_bwmode_inprogress)
2835 		return 0;
2836 
2837 	if ((is_hal_stop(rtlhal)) || (RT_CANNOT_IO(hw))) {
2838 		rtl_dbg(rtlpriv, COMP_CHAN, DBG_LOUD,
2839 			"sw_chnl_inprogress false driver sleep or unload\n");
2840 		return 0;
2841 	}
2842 	while (rtlphy->lck_inprogress && timecount < timeout) {
2843 		mdelay(50);
2844 		timecount += 50;
2845 	}
2846 	if (rtlhal->macphymode == SINGLEMAC_SINGLEPHY &&
2847 	    rtlhal->bandset == BAND_ON_BOTH) {
2848 		ret_value = rtl_get_bbreg(hw, RFPGA0_XAB_RFPARAMETER,
2849 					  MASKDWORD);
2850 		if (rtlphy->current_channel > 14 && !(ret_value & BIT(0)))
2851 			rtl92d_phy_switch_wirelessband(hw, BAND_ON_5G);
2852 		else if (rtlphy->current_channel <= 14 && (ret_value & BIT(0)))
2853 			rtl92d_phy_switch_wirelessband(hw, BAND_ON_2_4G);
2854 	}
2855 	switch (rtlhal->current_bandtype) {
2856 	case BAND_ON_5G:
2857 		/* Get first channel error when change between
2858 		 * 5G and 2.4G band. */
2859 		if (WARN_ONCE(channel <= 14, "rtl8192de: 5G but channel<=14\n"))
2860 			return 0;
2861 		break;
2862 	case BAND_ON_2_4G:
2863 		/* Get first channel error when change between
2864 		 * 5G and 2.4G band. */
2865 		if (WARN_ONCE(channel > 14, "rtl8192de: 2G but channel>14\n"))
2866 			return 0;
2867 		break;
2868 	default:
2869 		WARN_ONCE(true, "rtl8192de: Invalid WirelessMode(%#x)!!\n",
2870 			  rtlpriv->mac80211.mode);
2871 		break;
2872 	}
2873 	rtlphy->sw_chnl_inprogress = true;
2874 	if (channel == 0)
2875 		channel = 1;
2876 	rtlphy->sw_chnl_stage = 0;
2877 	rtlphy->sw_chnl_step = 0;
2878 	rtl_dbg(rtlpriv, COMP_SCAN, DBG_TRACE,
2879 		"switch to channel%d\n", rtlphy->current_channel);
2880 
2881 	do {
2882 		if (!rtlphy->sw_chnl_inprogress)
2883 			break;
2884 		if (!_rtl92d_phy_sw_chnl_step_by_step(hw,
2885 						      rtlphy->current_channel,
2886 		    &rtlphy->sw_chnl_stage, &rtlphy->sw_chnl_step, &delay)) {
2887 			if (delay > 0)
2888 				mdelay(delay);
2889 			else
2890 				continue;
2891 		} else {
2892 			rtlphy->sw_chnl_inprogress = false;
2893 		}
2894 		break;
2895 	} while (true);
2896 	rtl_dbg(rtlpriv, COMP_SCAN, DBG_TRACE, "<==\n");
2897 	rtlphy->sw_chnl_inprogress = false;
2898 	return 1;
2899 }
2900 
2901 static void rtl92d_phy_set_io(struct ieee80211_hw *hw)
2902 {
2903 	struct rtl_priv *rtlpriv = rtl_priv(hw);
2904 	struct dig_t *de_digtable = &rtlpriv->dm_digtable;
2905 	struct rtl_phy *rtlphy = &(rtlpriv->phy);
2906 
2907 	rtl_dbg(rtlpriv, COMP_CMD, DBG_TRACE,
2908 		"--->Cmd(%#x), set_io_inprogress(%d)\n",
2909 		rtlphy->current_io_type, rtlphy->set_io_inprogress);
2910 	switch (rtlphy->current_io_type) {
2911 	case IO_CMD_RESUME_DM_BY_SCAN:
2912 		de_digtable->cur_igvalue = rtlphy->initgain_backup.xaagccore1;
2913 		rtl92d_dm_write_dig(hw);
2914 		rtl92d_phy_set_txpower_level(hw, rtlphy->current_channel);
2915 		break;
2916 	case IO_CMD_PAUSE_DM_BY_SCAN:
2917 		rtlphy->initgain_backup.xaagccore1 = de_digtable->cur_igvalue;
2918 		de_digtable->cur_igvalue = 0x37;
2919 		rtl92d_dm_write_dig(hw);
2920 		break;
2921 	default:
2922 		pr_err("switch case %#x not processed\n",
2923 		       rtlphy->current_io_type);
2924 		break;
2925 	}
2926 	rtlphy->set_io_inprogress = false;
2927 	rtl_dbg(rtlpriv, COMP_CMD, DBG_TRACE, "<---(%#x)\n",
2928 		rtlphy->current_io_type);
2929 }
2930 
2931 bool rtl92d_phy_set_io_cmd(struct ieee80211_hw *hw, enum io_type iotype)
2932 {
2933 	struct rtl_priv *rtlpriv = rtl_priv(hw);
2934 	struct rtl_phy *rtlphy = &(rtlpriv->phy);
2935 	bool postprocessing = false;
2936 
2937 	rtl_dbg(rtlpriv, COMP_CMD, DBG_TRACE,
2938 		"-->IO Cmd(%#x), set_io_inprogress(%d)\n",
2939 		 iotype, rtlphy->set_io_inprogress);
2940 	do {
2941 		switch (iotype) {
2942 		case IO_CMD_RESUME_DM_BY_SCAN:
2943 			rtl_dbg(rtlpriv, COMP_CMD, DBG_TRACE,
2944 				"[IO CMD] Resume DM after scan\n");
2945 			postprocessing = true;
2946 			break;
2947 		case IO_CMD_PAUSE_DM_BY_SCAN:
2948 			rtl_dbg(rtlpriv, COMP_CMD, DBG_TRACE,
2949 				"[IO CMD] Pause DM before scan\n");
2950 			postprocessing = true;
2951 			break;
2952 		default:
2953 			pr_err("switch case %#x not processed\n",
2954 			       iotype);
2955 			break;
2956 		}
2957 	} while (false);
2958 	if (postprocessing && !rtlphy->set_io_inprogress) {
2959 		rtlphy->set_io_inprogress = true;
2960 		rtlphy->current_io_type = iotype;
2961 	} else {
2962 		return false;
2963 	}
2964 	rtl92d_phy_set_io(hw);
2965 	rtl_dbg(rtlpriv, COMP_CMD, DBG_TRACE, "<--IO Type(%#x)\n", iotype);
2966 	return true;
2967 }
2968 
2969 static void _rtl92d_phy_set_rfon(struct ieee80211_hw *hw)
2970 {
2971 	struct rtl_priv *rtlpriv = rtl_priv(hw);
2972 
2973 	/* a.  SYS_CLKR 0x08[11] = 1  restore MAC clock */
2974 	/* b.  SPS_CTRL 0x11[7:0] = 0x2b */
2975 	if (rtlpriv->rtlhal.macphymode == SINGLEMAC_SINGLEPHY)
2976 		rtl_write_byte(rtlpriv, REG_SPS0_CTRL, 0x2b);
2977 	/* c.  For PCIE: SYS_FUNC_EN 0x02[7:0] = 0xE3 enable BB TRX function */
2978 	rtl_write_byte(rtlpriv, REG_SYS_FUNC_EN, 0xE3);
2979 	/* RF_ON_EXCEP(d~g): */
2980 	/* d.  APSD_CTRL 0x600[7:0] = 0x00 */
2981 	rtl_write_byte(rtlpriv, REG_APSD_CTRL, 0x00);
2982 	/* e.  SYS_FUNC_EN 0x02[7:0] = 0xE2  reset BB TRX function again */
2983 	/* f.  SYS_FUNC_EN 0x02[7:0] = 0xE3  enable BB TRX function*/
2984 	rtl_write_byte(rtlpriv, REG_SYS_FUNC_EN, 0xE2);
2985 	rtl_write_byte(rtlpriv, REG_SYS_FUNC_EN, 0xE3);
2986 	/* g.   txpause 0x522[7:0] = 0x00  enable mac tx queue */
2987 	rtl_write_byte(rtlpriv, REG_TXPAUSE, 0x00);
2988 }
2989 
2990 static void _rtl92d_phy_set_rfsleep(struct ieee80211_hw *hw)
2991 {
2992 	struct rtl_priv *rtlpriv = rtl_priv(hw);
2993 	u32 u4btmp;
2994 	u8 delay = 5;
2995 
2996 	/* a.   TXPAUSE 0x522[7:0] = 0xFF  Pause MAC TX queue  */
2997 	rtl_write_byte(rtlpriv, REG_TXPAUSE, 0xFF);
2998 	/* b.   RF path 0 offset 0x00 = 0x00  disable RF  */
2999 	rtl_set_rfreg(hw, RF90_PATH_A, 0x00, RFREG_OFFSET_MASK, 0x00);
3000 	/* c.   APSD_CTRL 0x600[7:0] = 0x40 */
3001 	rtl_write_byte(rtlpriv, REG_APSD_CTRL, 0x40);
3002 	/* d. APSD_CTRL 0x600[7:0] = 0x00
3003 	 * APSD_CTRL 0x600[7:0] = 0x00
3004 	 * RF path 0 offset 0x00 = 0x00
3005 	 * APSD_CTRL 0x600[7:0] = 0x40
3006 	 * */
3007 	u4btmp = rtl_get_rfreg(hw, RF90_PATH_A, 0, RFREG_OFFSET_MASK);
3008 	while (u4btmp != 0 && delay > 0) {
3009 		rtl_write_byte(rtlpriv, REG_APSD_CTRL, 0x0);
3010 		rtl_set_rfreg(hw, RF90_PATH_A, 0x00, RFREG_OFFSET_MASK, 0x00);
3011 		rtl_write_byte(rtlpriv, REG_APSD_CTRL, 0x40);
3012 		u4btmp = rtl_get_rfreg(hw, RF90_PATH_A, 0, RFREG_OFFSET_MASK);
3013 		delay--;
3014 	}
3015 	if (delay == 0) {
3016 		/* Jump out the LPS turn off sequence to RF_ON_EXCEP */
3017 		rtl_write_byte(rtlpriv, REG_APSD_CTRL, 0x00);
3018 
3019 		rtl_write_byte(rtlpriv, REG_SYS_FUNC_EN, 0xE2);
3020 		rtl_write_byte(rtlpriv, REG_SYS_FUNC_EN, 0xE3);
3021 		rtl_write_byte(rtlpriv, REG_TXPAUSE, 0x00);
3022 		rtl_dbg(rtlpriv, COMP_POWER, DBG_LOUD,
3023 			"Fail !!! Switch RF timeout\n");
3024 		return;
3025 	}
3026 	/* e.   For PCIE: SYS_FUNC_EN 0x02[7:0] = 0xE2 reset BB TRX function */
3027 	rtl_write_byte(rtlpriv, REG_SYS_FUNC_EN, 0xE2);
3028 	/* f.   SPS_CTRL 0x11[7:0] = 0x22 */
3029 	if (rtlpriv->rtlhal.macphymode == SINGLEMAC_SINGLEPHY)
3030 		rtl_write_byte(rtlpriv, REG_SPS0_CTRL, 0x22);
3031 	/* g.    SYS_CLKR 0x08[11] = 0  gated MAC clock */
3032 }
3033 
3034 bool rtl92d_phy_set_rf_power_state(struct ieee80211_hw *hw,
3035 				   enum rf_pwrstate rfpwr_state)
3036 {
3037 
3038 	bool bresult = true;
3039 	struct rtl_priv *rtlpriv = rtl_priv(hw);
3040 	struct rtl_pci_priv *pcipriv = rtl_pcipriv(hw);
3041 	struct rtl_mac *mac = rtl_mac(rtl_priv(hw));
3042 	struct rtl_ps_ctl *ppsc = rtl_psc(rtl_priv(hw));
3043 	struct rtl_pci *rtlpci = rtl_pcidev(rtl_pcipriv(hw));
3044 	u8 i, queue_id;
3045 	struct rtl8192_tx_ring *ring = NULL;
3046 
3047 	if (rfpwr_state == ppsc->rfpwr_state)
3048 		return false;
3049 	switch (rfpwr_state) {
3050 	case ERFON:
3051 		if ((ppsc->rfpwr_state == ERFOFF) &&
3052 		    RT_IN_PS_LEVEL(ppsc, RT_RF_OFF_LEVL_HALT_NIC)) {
3053 			bool rtstatus;
3054 			u32 initializecount = 0;
3055 			do {
3056 				initializecount++;
3057 				rtl_dbg(rtlpriv, COMP_RF, DBG_DMESG,
3058 					"IPS Set eRf nic enable\n");
3059 				rtstatus = rtl_ps_enable_nic(hw);
3060 			} while (!rtstatus && (initializecount < 10));
3061 
3062 			RT_CLEAR_PS_LEVEL(ppsc,
3063 					  RT_RF_OFF_LEVL_HALT_NIC);
3064 		} else {
3065 			rtl_dbg(rtlpriv, COMP_POWER, DBG_DMESG,
3066 				"awake, slept:%d ms state_inap:%x\n",
3067 				jiffies_to_msecs(jiffies -
3068 						 ppsc->last_sleep_jiffies),
3069 				 rtlpriv->psc.state_inap);
3070 			ppsc->last_awake_jiffies = jiffies;
3071 			_rtl92d_phy_set_rfon(hw);
3072 		}
3073 
3074 		if (mac->link_state == MAC80211_LINKED)
3075 			rtlpriv->cfg->ops->led_control(hw,
3076 					 LED_CTL_LINK);
3077 		else
3078 			rtlpriv->cfg->ops->led_control(hw,
3079 					 LED_CTL_NO_LINK);
3080 		break;
3081 	case ERFOFF:
3082 		if (ppsc->reg_rfps_level & RT_RF_OFF_LEVL_HALT_NIC) {
3083 			rtl_dbg(rtlpriv, COMP_RF, DBG_DMESG,
3084 				"IPS Set eRf nic disable\n");
3085 			rtl_ps_disable_nic(hw);
3086 			RT_SET_PS_LEVEL(ppsc, RT_RF_OFF_LEVL_HALT_NIC);
3087 		} else {
3088 			if (ppsc->rfoff_reason == RF_CHANGE_BY_IPS)
3089 				rtlpriv->cfg->ops->led_control(hw,
3090 						 LED_CTL_NO_LINK);
3091 			else
3092 				rtlpriv->cfg->ops->led_control(hw,
3093 						 LED_CTL_POWER_OFF);
3094 		}
3095 		break;
3096 	case ERFSLEEP:
3097 		if (ppsc->rfpwr_state == ERFOFF)
3098 			return false;
3099 
3100 		for (queue_id = 0, i = 0;
3101 		     queue_id < RTL_PCI_MAX_TX_QUEUE_COUNT;) {
3102 			ring = &pcipriv->dev.tx_ring[queue_id];
3103 			if (skb_queue_len(&ring->queue) == 0 ||
3104 			    queue_id == BEACON_QUEUE) {
3105 				queue_id++;
3106 				continue;
3107 			} else if (rtlpci->pdev->current_state != PCI_D0) {
3108 				rtl_dbg(rtlpriv, COMP_POWER, DBG_LOUD,
3109 					"eRf Off/Sleep: %d times TcbBusyQueue[%d] !=0 but lower power state!\n",
3110 					i + 1, queue_id);
3111 				break;
3112 			} else {
3113 				rtl_dbg(rtlpriv, COMP_ERR, DBG_WARNING,
3114 					"eRf Off/Sleep: %d times TcbBusyQueue[%d] =%d before doze!\n",
3115 					i + 1, queue_id,
3116 					skb_queue_len(&ring->queue));
3117 				udelay(10);
3118 				i++;
3119 			}
3120 
3121 			if (i >= MAX_DOZE_WAITING_TIMES_9x) {
3122 				rtl_dbg(rtlpriv, COMP_ERR, DBG_WARNING,
3123 					"ERFOFF: %d times TcbBusyQueue[%d] = %d !\n",
3124 					MAX_DOZE_WAITING_TIMES_9x, queue_id,
3125 					skb_queue_len(&ring->queue));
3126 				break;
3127 			}
3128 		}
3129 		rtl_dbg(rtlpriv, COMP_POWER, DBG_DMESG,
3130 			"Set rfsleep awakened:%d ms\n",
3131 			 jiffies_to_msecs(jiffies - ppsc->last_awake_jiffies));
3132 		rtl_dbg(rtlpriv, COMP_POWER, DBG_DMESG,
3133 			"sleep awakened:%d ms state_inap:%x\n",
3134 			jiffies_to_msecs(jiffies -
3135 					 ppsc->last_awake_jiffies),
3136 			rtlpriv->psc.state_inap);
3137 		ppsc->last_sleep_jiffies = jiffies;
3138 		_rtl92d_phy_set_rfsleep(hw);
3139 		break;
3140 	default:
3141 		pr_err("switch case %#x not processed\n",
3142 		       rfpwr_state);
3143 		bresult = false;
3144 		break;
3145 	}
3146 	if (bresult)
3147 		ppsc->rfpwr_state = rfpwr_state;
3148 	return bresult;
3149 }
3150 
3151 void rtl92d_phy_config_macphymode(struct ieee80211_hw *hw)
3152 {
3153 	struct rtl_priv *rtlpriv = rtl_priv(hw);
3154 	struct rtl_hal *rtlhal = rtl_hal(rtl_priv(hw));
3155 	u8 offset = REG_MAC_PHY_CTRL_NORMAL;
3156 
3157 	switch (rtlhal->macphymode) {
3158 	case DUALMAC_DUALPHY:
3159 		rtl_dbg(rtlpriv, COMP_INIT, DBG_LOUD,
3160 			"MacPhyMode: DUALMAC_DUALPHY\n");
3161 		rtl_write_byte(rtlpriv, offset, 0xF3);
3162 		break;
3163 	case SINGLEMAC_SINGLEPHY:
3164 		rtl_dbg(rtlpriv, COMP_INIT, DBG_LOUD,
3165 			"MacPhyMode: SINGLEMAC_SINGLEPHY\n");
3166 		rtl_write_byte(rtlpriv, offset, 0xF4);
3167 		break;
3168 	case DUALMAC_SINGLEPHY:
3169 		rtl_dbg(rtlpriv, COMP_INIT, DBG_LOUD,
3170 			"MacPhyMode: DUALMAC_SINGLEPHY\n");
3171 		rtl_write_byte(rtlpriv, offset, 0xF1);
3172 		break;
3173 	}
3174 }
3175 
3176 void rtl92d_phy_config_macphymode_info(struct ieee80211_hw *hw)
3177 {
3178 	struct rtl_priv *rtlpriv = rtl_priv(hw);
3179 	struct rtl_hal *rtlhal = rtl_hal(rtl_priv(hw));
3180 	struct rtl_phy *rtlphy = &(rtlpriv->phy);
3181 
3182 	switch (rtlhal->macphymode) {
3183 	case DUALMAC_SINGLEPHY:
3184 		rtlphy->rf_type = RF_2T2R;
3185 		rtlhal->version |= RF_TYPE_2T2R;
3186 		rtlhal->bandset = BAND_ON_BOTH;
3187 		rtlhal->current_bandtype = BAND_ON_2_4G;
3188 		break;
3189 
3190 	case SINGLEMAC_SINGLEPHY:
3191 		rtlphy->rf_type = RF_2T2R;
3192 		rtlhal->version |= RF_TYPE_2T2R;
3193 		rtlhal->bandset = BAND_ON_BOTH;
3194 		rtlhal->current_bandtype = BAND_ON_2_4G;
3195 		break;
3196 
3197 	case DUALMAC_DUALPHY:
3198 		rtlphy->rf_type = RF_1T1R;
3199 		rtlhal->version &= RF_TYPE_1T1R;
3200 		/* Now we let MAC0 run on 5G band. */
3201 		if (rtlhal->interfaceindex == 0) {
3202 			rtlhal->bandset = BAND_ON_5G;
3203 			rtlhal->current_bandtype = BAND_ON_5G;
3204 		} else {
3205 			rtlhal->bandset = BAND_ON_2_4G;
3206 			rtlhal->current_bandtype = BAND_ON_2_4G;
3207 		}
3208 		break;
3209 	default:
3210 		break;
3211 	}
3212 }
3213 
3214 u8 rtl92d_get_chnlgroup_fromarray(u8 chnl)
3215 {
3216 	u8 group;
3217 
3218 	if (channel_all[chnl] <= 3)
3219 		group = 0;
3220 	else if (channel_all[chnl] <= 9)
3221 		group = 1;
3222 	else if (channel_all[chnl] <= 14)
3223 		group = 2;
3224 	else if (channel_all[chnl] <= 44)
3225 		group = 3;
3226 	else if (channel_all[chnl] <= 54)
3227 		group = 4;
3228 	else if (channel_all[chnl] <= 64)
3229 		group = 5;
3230 	else if (channel_all[chnl] <= 112)
3231 		group = 6;
3232 	else if (channel_all[chnl] <= 126)
3233 		group = 7;
3234 	else if (channel_all[chnl] <= 140)
3235 		group = 8;
3236 	else if (channel_all[chnl] <= 153)
3237 		group = 9;
3238 	else if (channel_all[chnl] <= 159)
3239 		group = 10;
3240 	else
3241 		group = 11;
3242 	return group;
3243 }
3244 
3245 void rtl92d_phy_set_poweron(struct ieee80211_hw *hw)
3246 {
3247 	struct rtl_priv *rtlpriv = rtl_priv(hw);
3248 	struct rtl_hal *rtlhal = rtl_hal(rtl_priv(hw));
3249 	unsigned long flags;
3250 	u8 value8;
3251 	u16 i;
3252 	u32 mac_reg = (rtlhal->interfaceindex == 0 ? REG_MAC0 : REG_MAC1);
3253 
3254 	/* notice fw know band status  0x81[1]/0x53[1] = 0: 5G, 1: 2G */
3255 	if (rtlhal->current_bandtype == BAND_ON_2_4G) {
3256 		value8 = rtl_read_byte(rtlpriv, mac_reg);
3257 		value8 |= BIT(1);
3258 		rtl_write_byte(rtlpriv, mac_reg, value8);
3259 	} else {
3260 		value8 = rtl_read_byte(rtlpriv, mac_reg);
3261 		value8 &= (~BIT(1));
3262 		rtl_write_byte(rtlpriv, mac_reg, value8);
3263 	}
3264 
3265 	if (rtlhal->macphymode == SINGLEMAC_SINGLEPHY) {
3266 		value8 = rtl_read_byte(rtlpriv, REG_MAC0);
3267 		rtl_write_byte(rtlpriv, REG_MAC0, value8 | MAC0_ON);
3268 	} else {
3269 		spin_lock_irqsave(&globalmutex_power, flags);
3270 		if (rtlhal->interfaceindex == 0) {
3271 			value8 = rtl_read_byte(rtlpriv, REG_MAC0);
3272 			rtl_write_byte(rtlpriv, REG_MAC0, value8 | MAC0_ON);
3273 		} else {
3274 			value8 = rtl_read_byte(rtlpriv, REG_MAC1);
3275 			rtl_write_byte(rtlpriv, REG_MAC1, value8 | MAC1_ON);
3276 		}
3277 		value8 = rtl_read_byte(rtlpriv, REG_POWER_OFF_IN_PROCESS);
3278 		spin_unlock_irqrestore(&globalmutex_power, flags);
3279 		for (i = 0; i < 200; i++) {
3280 			if ((value8 & BIT(7)) == 0) {
3281 				break;
3282 			} else {
3283 				udelay(500);
3284 				spin_lock_irqsave(&globalmutex_power, flags);
3285 				value8 = rtl_read_byte(rtlpriv,
3286 						    REG_POWER_OFF_IN_PROCESS);
3287 				spin_unlock_irqrestore(&globalmutex_power,
3288 						       flags);
3289 			}
3290 		}
3291 		if (i == 200)
3292 			WARN_ONCE(true, "rtl8192de: Another mac power off over time\n");
3293 	}
3294 }
3295 
3296 void rtl92d_phy_config_maccoexist_rfpage(struct ieee80211_hw *hw)
3297 {
3298 	struct rtl_priv *rtlpriv = rtl_priv(hw);
3299 
3300 	switch (rtlpriv->rtlhal.macphymode) {
3301 	case DUALMAC_DUALPHY:
3302 		rtl_write_byte(rtlpriv, REG_DMC, 0x0);
3303 		rtl_write_byte(rtlpriv, REG_RX_PKT_LIMIT, 0x08);
3304 		rtl_write_word(rtlpriv, REG_TRXFF_BNDY + 2, 0x13ff);
3305 		break;
3306 	case DUALMAC_SINGLEPHY:
3307 		rtl_write_byte(rtlpriv, REG_DMC, 0xf8);
3308 		rtl_write_byte(rtlpriv, REG_RX_PKT_LIMIT, 0x08);
3309 		rtl_write_word(rtlpriv, REG_TRXFF_BNDY + 2, 0x13ff);
3310 		break;
3311 	case SINGLEMAC_SINGLEPHY:
3312 		rtl_write_byte(rtlpriv, REG_DMC, 0x0);
3313 		rtl_write_byte(rtlpriv, REG_RX_PKT_LIMIT, 0x10);
3314 		rtl_write_word(rtlpriv, (REG_TRXFF_BNDY + 2), 0x27FF);
3315 		break;
3316 	default:
3317 		break;
3318 	}
3319 }
3320 
3321 void rtl92d_update_bbrf_configuration(struct ieee80211_hw *hw)
3322 {
3323 	struct rtl_priv *rtlpriv = rtl_priv(hw);
3324 	struct rtl_hal *rtlhal = rtl_hal(rtl_priv(hw));
3325 	struct rtl_phy *rtlphy = &(rtlpriv->phy);
3326 	struct rtl_efuse *rtlefuse = rtl_efuse(rtl_priv(hw));
3327 	u8 rfpath, i;
3328 
3329 	rtl_dbg(rtlpriv, COMP_INIT, DBG_LOUD, "==>\n");
3330 	/* r_select_5G for path_A/B 0 for 2.4G, 1 for 5G */
3331 	if (rtlhal->current_bandtype == BAND_ON_2_4G) {
3332 		/* r_select_5G for path_A/B,0x878 */
3333 		rtl_set_bbreg(hw, RFPGA0_XAB_RFPARAMETER, BIT(0), 0x0);
3334 		rtl_set_bbreg(hw, RFPGA0_XAB_RFPARAMETER, BIT(15), 0x0);
3335 		if (rtlhal->macphymode != DUALMAC_DUALPHY) {
3336 			rtl_set_bbreg(hw, RFPGA0_XAB_RFPARAMETER, BIT(16), 0x0);
3337 			rtl_set_bbreg(hw, RFPGA0_XAB_RFPARAMETER, BIT(31), 0x0);
3338 		}
3339 		/* rssi_table_select:index 0 for 2.4G.1~3 for 5G,0xc78 */
3340 		rtl_set_bbreg(hw, ROFDM0_AGCRSSITABLE, BIT(6) | BIT(7), 0x0);
3341 		/* fc_area  0xd2c */
3342 		rtl_set_bbreg(hw, ROFDM1_CFOTRACKING, BIT(14) | BIT(13), 0x0);
3343 		/* 5G LAN ON */
3344 		rtl_set_bbreg(hw, 0xB30, 0x00F00000, 0xa);
3345 		/* TX BB gain shift*1,Just for testchip,0xc80,0xc88 */
3346 		rtl_set_bbreg(hw, ROFDM0_XATXIQIMBALANCE, MASKDWORD,
3347 			      0x40000100);
3348 		rtl_set_bbreg(hw, ROFDM0_XBTXIQIMBALANCE, MASKDWORD,
3349 			      0x40000100);
3350 		if (rtlhal->macphymode == DUALMAC_DUALPHY) {
3351 			rtl_set_bbreg(hw, RFPGA0_XAB_RFINTERFACESW,
3352 				      BIT(10) | BIT(6) | BIT(5),
3353 				      ((rtlefuse->eeprom_c9 & BIT(3)) >> 3) |
3354 				      (rtlefuse->eeprom_c9 & BIT(1)) |
3355 				      ((rtlefuse->eeprom_cc & BIT(1)) << 4));
3356 			rtl_set_bbreg(hw, RFPGA0_XA_RFINTERFACEOE,
3357 				      BIT(10) | BIT(6) | BIT(5),
3358 				      ((rtlefuse->eeprom_c9 & BIT(2)) >> 2) |
3359 				      ((rtlefuse->eeprom_c9 & BIT(0)) << 1) |
3360 				      ((rtlefuse->eeprom_cc & BIT(0)) << 5));
3361 			rtl_set_bbreg(hw, RFPGA0_XAB_RFPARAMETER, BIT(15), 0);
3362 		} else {
3363 			rtl_set_bbreg(hw, RFPGA0_XAB_RFINTERFACESW,
3364 				      BIT(26) | BIT(22) | BIT(21) | BIT(10) |
3365 				      BIT(6) | BIT(5),
3366 				      ((rtlefuse->eeprom_c9 & BIT(3)) >> 3) |
3367 				      (rtlefuse->eeprom_c9 & BIT(1)) |
3368 				      ((rtlefuse->eeprom_cc & BIT(1)) << 4) |
3369 				      ((rtlefuse->eeprom_c9 & BIT(7)) << 9) |
3370 				      ((rtlefuse->eeprom_c9 & BIT(5)) << 12) |
3371 				      ((rtlefuse->eeprom_cc & BIT(3)) << 18));
3372 			rtl_set_bbreg(hw, RFPGA0_XA_RFINTERFACEOE,
3373 				      BIT(10) | BIT(6) | BIT(5),
3374 				      ((rtlefuse->eeprom_c9 & BIT(2)) >> 2) |
3375 				      ((rtlefuse->eeprom_c9 & BIT(0)) << 1) |
3376 				      ((rtlefuse->eeprom_cc & BIT(0)) << 5));
3377 			rtl_set_bbreg(hw, RFPGA0_XB_RFINTERFACEOE,
3378 				      BIT(10) | BIT(6) | BIT(5),
3379 				      ((rtlefuse->eeprom_c9 & BIT(6)) >> 6) |
3380 				      ((rtlefuse->eeprom_c9 & BIT(4)) >> 3) |
3381 				      ((rtlefuse->eeprom_cc & BIT(2)) << 3));
3382 			rtl_set_bbreg(hw, RFPGA0_XAB_RFPARAMETER,
3383 				      BIT(31) | BIT(15), 0);
3384 		}
3385 		/* 1.5V_LDO */
3386 	} else {
3387 		/* r_select_5G for path_A/B */
3388 		rtl_set_bbreg(hw, RFPGA0_XAB_RFPARAMETER, BIT(0), 0x1);
3389 		rtl_set_bbreg(hw, RFPGA0_XAB_RFPARAMETER, BIT(15), 0x1);
3390 		if (rtlhal->macphymode != DUALMAC_DUALPHY) {
3391 			rtl_set_bbreg(hw, RFPGA0_XAB_RFPARAMETER, BIT(16), 0x1);
3392 			rtl_set_bbreg(hw, RFPGA0_XAB_RFPARAMETER, BIT(31), 0x1);
3393 		}
3394 		/* rssi_table_select:index 0 for 2.4G.1~3 for 5G */
3395 		rtl_set_bbreg(hw, ROFDM0_AGCRSSITABLE, BIT(6) | BIT(7), 0x1);
3396 		/* fc_area */
3397 		rtl_set_bbreg(hw, ROFDM1_CFOTRACKING, BIT(14) | BIT(13), 0x1);
3398 		/* 5G LAN ON */
3399 		rtl_set_bbreg(hw, 0xB30, 0x00F00000, 0x0);
3400 		/* TX BB gain shift,Just for testchip,0xc80,0xc88 */
3401 		if (rtlefuse->internal_pa_5g[0])
3402 			rtl_set_bbreg(hw, ROFDM0_XATXIQIMBALANCE, MASKDWORD,
3403 				      0x2d4000b5);
3404 		else
3405 			rtl_set_bbreg(hw, ROFDM0_XATXIQIMBALANCE, MASKDWORD,
3406 				      0x20000080);
3407 		if (rtlefuse->internal_pa_5g[1])
3408 			rtl_set_bbreg(hw, ROFDM0_XBTXIQIMBALANCE, MASKDWORD,
3409 				      0x2d4000b5);
3410 		else
3411 			rtl_set_bbreg(hw, ROFDM0_XBTXIQIMBALANCE, MASKDWORD,
3412 				      0x20000080);
3413 		if (rtlhal->macphymode == DUALMAC_DUALPHY) {
3414 			rtl_set_bbreg(hw, RFPGA0_XAB_RFINTERFACESW,
3415 				      BIT(10) | BIT(6) | BIT(5),
3416 				      (rtlefuse->eeprom_cc & BIT(5)));
3417 			rtl_set_bbreg(hw, RFPGA0_XA_RFINTERFACEOE, BIT(10),
3418 				      ((rtlefuse->eeprom_cc & BIT(4)) >> 4));
3419 			rtl_set_bbreg(hw, RFPGA0_XAB_RFPARAMETER, BIT(15),
3420 				      (rtlefuse->eeprom_cc & BIT(4)) >> 4);
3421 		} else {
3422 			rtl_set_bbreg(hw, RFPGA0_XAB_RFINTERFACESW,
3423 				      BIT(26) | BIT(22) | BIT(21) | BIT(10) |
3424 				      BIT(6) | BIT(5),
3425 				      (rtlefuse->eeprom_cc & BIT(5)) |
3426 				      ((rtlefuse->eeprom_cc & BIT(7)) << 14));
3427 			rtl_set_bbreg(hw, RFPGA0_XA_RFINTERFACEOE, BIT(10),
3428 				      ((rtlefuse->eeprom_cc & BIT(4)) >> 4));
3429 			rtl_set_bbreg(hw, RFPGA0_XB_RFINTERFACEOE, BIT(10),
3430 				      ((rtlefuse->eeprom_cc & BIT(6)) >> 6));
3431 			rtl_set_bbreg(hw, RFPGA0_XAB_RFPARAMETER,
3432 				      BIT(31) | BIT(15),
3433 				      ((rtlefuse->eeprom_cc & BIT(4)) >> 4) |
3434 				      ((rtlefuse->eeprom_cc & BIT(6)) << 10));
3435 		}
3436 	}
3437 	/* update IQK related settings */
3438 	rtl_set_bbreg(hw, ROFDM0_XARXIQIMBALANCE, MASKDWORD, 0x40000100);
3439 	rtl_set_bbreg(hw, ROFDM0_XBRXIQIMBALANCE, MASKDWORD, 0x40000100);
3440 	rtl_set_bbreg(hw, ROFDM0_XCTXAFE, 0xF0000000, 0x00);
3441 	rtl_set_bbreg(hw, ROFDM0_ECCATHRESHOLD, BIT(30) | BIT(28) |
3442 		      BIT(26) | BIT(24), 0x00);
3443 	rtl_set_bbreg(hw, ROFDM0_XDTXAFE, 0xF0000000, 0x00);
3444 	rtl_set_bbreg(hw, 0xca0, 0xF0000000, 0x00);
3445 	rtl_set_bbreg(hw, ROFDM0_AGCRSSITABLE, 0x0000F000, 0x00);
3446 
3447 	/* Update RF */
3448 	for (rfpath = RF90_PATH_A; rfpath < rtlphy->num_total_rfpath;
3449 	     rfpath++) {
3450 		if (rtlhal->current_bandtype == BAND_ON_2_4G) {
3451 			/* MOD_AG for RF path_A 0x18 BIT8,BIT16 */
3452 			rtl_set_rfreg(hw, rfpath, RF_CHNLBW, BIT(8) | BIT(16) |
3453 				      BIT(18), 0);
3454 			/* RF0x0b[16:14] =3b'111 */
3455 			rtl_set_rfreg(hw, (enum radio_path)rfpath, 0x0B,
3456 				      0x1c000, 0x07);
3457 		} else {
3458 			/* MOD_AG for RF path_A 0x18 BIT8,BIT16 */
3459 			rtl_set_rfreg(hw, rfpath, RF_CHNLBW, BIT(8) |
3460 				      BIT(16) | BIT(18),
3461 				      (BIT(16) | BIT(8)) >> 8);
3462 		}
3463 	}
3464 	/* Update for all band. */
3465 	/* DMDP */
3466 	if (rtlphy->rf_type == RF_1T1R) {
3467 		/* Use antenna 0,0xc04,0xd04 */
3468 		rtl_set_bbreg(hw, ROFDM0_TRXPATHENABLE, MASKBYTE0, 0x11);
3469 		rtl_set_bbreg(hw, ROFDM1_TRXPATHENABLE, BDWORD, 0x1);
3470 
3471 		/* enable ad/da clock1 for dual-phy reg0x888 */
3472 		if (rtlhal->interfaceindex == 0) {
3473 			rtl_set_bbreg(hw, RFPGA0_ADDALLOCKEN, BIT(12) |
3474 				      BIT(13), 0x3);
3475 		} else {
3476 			rtl92d_phy_enable_anotherphy(hw, false);
3477 			rtl_dbg(rtlpriv, COMP_INIT, DBG_LOUD,
3478 				"MAC1 use DBI to update 0x888\n");
3479 			/* 0x888 */
3480 			rtl92de_write_dword_dbi(hw, RFPGA0_ADDALLOCKEN,
3481 						rtl92de_read_dword_dbi(hw,
3482 						RFPGA0_ADDALLOCKEN,
3483 						BIT(3)) | BIT(12) | BIT(13),
3484 						BIT(3));
3485 			rtl92d_phy_powerdown_anotherphy(hw, false);
3486 		}
3487 	} else {
3488 		/* Single PHY */
3489 		/* Use antenna 0 & 1,0xc04,0xd04 */
3490 		rtl_set_bbreg(hw, ROFDM0_TRXPATHENABLE, MASKBYTE0, 0x33);
3491 		rtl_set_bbreg(hw, ROFDM1_TRXPATHENABLE, BDWORD, 0x3);
3492 		/* disable ad/da clock1,0x888 */
3493 		rtl_set_bbreg(hw, RFPGA0_ADDALLOCKEN, BIT(12) | BIT(13), 0);
3494 	}
3495 	for (rfpath = RF90_PATH_A; rfpath < rtlphy->num_total_rfpath;
3496 	     rfpath++) {
3497 		rtlphy->rfreg_chnlval[rfpath] = rtl_get_rfreg(hw, rfpath,
3498 						RF_CHNLBW, RFREG_OFFSET_MASK);
3499 		rtlphy->reg_rf3c[rfpath] = rtl_get_rfreg(hw, rfpath, 0x3C,
3500 			RFREG_OFFSET_MASK);
3501 	}
3502 	for (i = 0; i < 2; i++)
3503 		rtl_dbg(rtlpriv, COMP_RF, DBG_LOUD, "RF 0x18 = 0x%x\n",
3504 			rtlphy->rfreg_chnlval[i]);
3505 	rtl_dbg(rtlpriv, COMP_INIT, DBG_LOUD, "<==\n");
3506 
3507 }
3508 
3509 bool rtl92d_phy_check_poweroff(struct ieee80211_hw *hw)
3510 {
3511 	struct rtl_priv *rtlpriv = rtl_priv(hw);
3512 	struct rtl_hal *rtlhal = rtl_hal(rtl_priv(hw));
3513 	u8 u1btmp;
3514 	unsigned long flags;
3515 
3516 	if (rtlhal->macphymode == SINGLEMAC_SINGLEPHY) {
3517 		u1btmp = rtl_read_byte(rtlpriv, REG_MAC0);
3518 		rtl_write_byte(rtlpriv, REG_MAC0, u1btmp & (~MAC0_ON));
3519 		return true;
3520 	}
3521 	spin_lock_irqsave(&globalmutex_power, flags);
3522 	if (rtlhal->interfaceindex == 0) {
3523 		u1btmp = rtl_read_byte(rtlpriv, REG_MAC0);
3524 		rtl_write_byte(rtlpriv, REG_MAC0, u1btmp & (~MAC0_ON));
3525 		u1btmp = rtl_read_byte(rtlpriv, REG_MAC1);
3526 		u1btmp &= MAC1_ON;
3527 	} else {
3528 		u1btmp = rtl_read_byte(rtlpriv, REG_MAC1);
3529 		rtl_write_byte(rtlpriv, REG_MAC1, u1btmp & (~MAC1_ON));
3530 		u1btmp = rtl_read_byte(rtlpriv, REG_MAC0);
3531 		u1btmp &= MAC0_ON;
3532 	}
3533 	if (u1btmp) {
3534 		spin_unlock_irqrestore(&globalmutex_power, flags);
3535 		return false;
3536 	}
3537 	u1btmp = rtl_read_byte(rtlpriv, REG_POWER_OFF_IN_PROCESS);
3538 	u1btmp |= BIT(7);
3539 	rtl_write_byte(rtlpriv, REG_POWER_OFF_IN_PROCESS, u1btmp);
3540 	spin_unlock_irqrestore(&globalmutex_power, flags);
3541 	return true;
3542 }
3543