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
_rtl92d_phy_calculate_bit_shift(u32 bitmask)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
rtl92d_phy_query_bb_reg(struct ieee80211_hw * hw,u32 regaddr,u32 bitmask)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
rtl92d_phy_set_bb_reg(struct ieee80211_hw * hw,u32 regaddr,u32 bitmask,u32 data)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
_rtl92d_phy_rf_serial_read(struct ieee80211_hw * hw,enum radio_path rfpath,u32 offset)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
_rtl92d_phy_rf_serial_write(struct ieee80211_hw * hw,enum radio_path rfpath,u32 offset,u32 data)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
rtl92d_phy_query_rf_reg(struct ieee80211_hw * hw,enum radio_path rfpath,u32 regaddr,u32 bitmask)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
rtl92d_phy_set_rf_reg(struct ieee80211_hw * hw,enum radio_path rfpath,u32 regaddr,u32 bitmask,u32 data)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
rtl92d_phy_mac_config(struct ieee80211_hw * hw)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
_rtl92d_phy_init_bb_rf_register_definition(struct ieee80211_hw * hw)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
_rtl92d_phy_config_bb_with_headerfile(struct ieee80211_hw * hw,u8 configtype)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
_rtl92d_store_pwrindex_diffrate_offset(struct ieee80211_hw * hw,u32 regaddr,u32 bitmask,u32 data)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
_rtl92d_phy_config_bb_with_pgheaderfile(struct ieee80211_hw * hw,u8 configtype)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
_rtl92d_phy_bb_config(struct ieee80211_hw * hw)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
rtl92d_phy_bb_config(struct ieee80211_hw * hw)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
rtl92d_phy_rf_config(struct ieee80211_hw * hw)757 bool rtl92d_phy_rf_config(struct ieee80211_hw *hw)
758 {
759 return rtl92d_phy_rf6052_config(hw);
760 }
761
rtl92d_phy_config_rf_with_headerfile(struct ieee80211_hw * hw,enum rf_content content,enum radio_path rfpath)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
rtl92d_phy_get_hw_reg_originalvalue(struct ieee80211_hw * hw)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
_rtl92d_get_txpower_index(struct ieee80211_hw * hw,u8 channel,u8 * cckpowerlevel,u8 * ofdmpowerlevel)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
_rtl92d_ccxpower_index_check(struct ieee80211_hw * hw,u8 channel,u8 * cckpowerlevel,u8 * ofdmpowerlevel)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
_rtl92c_phy_get_rightchnlplace(u8 chnl)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
rtl92d_phy_set_txpower_level(struct ieee80211_hw * hw,u8 channel)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
rtl92d_phy_set_bw_mode(struct ieee80211_hw * hw,enum nl80211_channel_type ch_type)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
_rtl92d_phy_stop_trx_before_changeband(struct ieee80211_hw * hw)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
rtl92d_phy_switch_wirelessband(struct ieee80211_hw * hw,u8 band)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
_rtl92d_phy_reload_imr_setting(struct ieee80211_hw * hw,u8 channel,u8 rfpath)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
_rtl92d_phy_enable_rf_env(struct ieee80211_hw * hw,u8 rfpath,u32 * pu4_regval)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
_rtl92d_phy_restore_rf_env(struct ieee80211_hw * hw,u8 rfpath,u32 * pu4_regval)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
_rtl92d_phy_switch_rf_setting(struct ieee80211_hw * hw,u8 channel)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
rtl92d_get_rightchnlplace_for_iqk(u8 chnl)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 */
_rtl92d_phy_patha_iqk(struct ieee80211_hw * hw,bool configpathb)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 */
_rtl92d_phy_patha_iqk_5g_normal(struct ieee80211_hw * hw,bool configpathb)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 */
_rtl92d_phy_pathb_iqk(struct ieee80211_hw * hw)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 */
_rtl92d_phy_pathb_iqk_5g_normal(struct ieee80211_hw * hw)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
_rtl92d_phy_save_adda_registers(struct ieee80211_hw * hw,u32 * adda_reg,u32 * adda_backup,u32 regnum)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
_rtl92d_phy_save_mac_registers(struct ieee80211_hw * hw,u32 * macreg,u32 * macbackup)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
_rtl92d_phy_reload_adda_registers(struct ieee80211_hw * hw,u32 * adda_reg,u32 * adda_backup,u32 regnum)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
_rtl92d_phy_reload_mac_registers(struct ieee80211_hw * hw,u32 * macreg,u32 * macbackup)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
_rtl92d_phy_path_adda_on(struct ieee80211_hw * hw,u32 * adda_reg,bool patha_on,bool is2t)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
_rtl92d_phy_mac_setting_calibration(struct ieee80211_hw * hw,u32 * macreg,u32 * macbackup)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
_rtl92d_phy_patha_standby(struct ieee80211_hw * hw)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
_rtl92d_phy_pimode_switch(struct ieee80211_hw * hw,bool pi_mode)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
_rtl92d_phy_iq_calibrate(struct ieee80211_hw * hw,long result[][8],u8 t,bool is2t)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
_rtl92d_phy_iq_calibrate_5g_normal(struct ieee80211_hw * hw,long result[][8],u8 t)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
_rtl92d_phy_simularity_compare(struct ieee80211_hw * hw,long result[][8],u8 c1,u8 c2)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
_rtl92d_phy_patha_fill_iqk_matrix(struct ieee80211_hw * hw,bool iqk_ok,long result[][8],u8 final_candidate,bool txonly)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
_rtl92d_phy_pathb_fill_iqk_matrix(struct ieee80211_hw * hw,bool iqk_ok,long result[][8],u8 final_candidate,bool txonly)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
rtl92d_phy_iq_calibrate(struct ieee80211_hw * hw)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
rtl92d_phy_reload_iqk_setting(struct ieee80211_hw * hw,u8 channel)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
_rtl92d_phy_get_abs(u32 val1,u32 val2)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
_rtl92d_is_legal_5g_channel(struct ieee80211_hw * hw,u8 channel)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
_rtl92d_phy_calc_curvindex(struct ieee80211_hw * hw,u32 * targetchnl,u32 * curvecount_val,bool is5g,u32 * curveindex)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
_rtl92d_phy_reload_lck_setting(struct ieee80211_hw * hw,u8 channel)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
_rtl92d_phy_lc_calibrate_sw(struct ieee80211_hw * hw,bool is2t)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
_rtl92d_phy_lc_calibrate(struct ieee80211_hw * hw,bool is2t)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
rtl92d_phy_lc_calibrate(struct ieee80211_hw * hw)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
rtl92d_phy_ap_calibrate(struct ieee80211_hw * hw,s8 delta)2658 void rtl92d_phy_ap_calibrate(struct ieee80211_hw *hw, s8 delta)
2659 {
2660 return;
2661 }
2662
_rtl92d_phy_set_sw_chnl_cmdarray(struct swchnlcmd * cmdtable,u32 cmdtableidx,u32 cmdtablesz,enum swchnlcmd_id cmdid,u32 para1,u32 para2,u32 msdelay)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
rtl92d_phy_reset_iqk_result(struct ieee80211_hw * hw)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
_rtl92d_phy_sw_chnl_step_by_step(struct ieee80211_hw * hw,u8 channel,u8 * stage,u8 * step,u32 * delay)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
rtl92d_phy_sw_chnl(struct ieee80211_hw * hw)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
rtl92d_phy_set_io(struct ieee80211_hw * hw)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
rtl92d_phy_set_io_cmd(struct ieee80211_hw * hw,enum io_type iotype)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
_rtl92d_phy_set_rfon(struct ieee80211_hw * hw)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
_rtl92d_phy_set_rfsleep(struct ieee80211_hw * hw)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
rtl92d_phy_set_rf_power_state(struct ieee80211_hw * hw,enum rf_pwrstate rfpwr_state)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
rtl92d_phy_config_macphymode(struct ieee80211_hw * hw)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
rtl92d_phy_config_macphymode_info(struct ieee80211_hw * hw)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
rtl92d_get_chnlgroup_fromarray(u8 chnl)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
rtl92d_phy_set_poweron(struct ieee80211_hw * hw)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
rtl92d_phy_config_maccoexist_rfpage(struct ieee80211_hw * hw)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
rtl92d_update_bbrf_configuration(struct ieee80211_hw * hw)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
rtl92d_phy_check_poweroff(struct ieee80211_hw * hw)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