xref: /freebsd/sys/contrib/dev/rtw88/rtw8822c.c (revision a0ccc12f6882a886d89ae279c541b2c2b62c6aca)
1 // SPDX-License-Identifier: GPL-2.0 OR BSD-3-Clause
2 /* Copyright(c) 2018-2019  Realtek Corporation
3  */
4 
5 #include <linux/module.h>
6 #include "main.h"
7 #include "coex.h"
8 #include "fw.h"
9 #include "tx.h"
10 #include "rx.h"
11 #include "phy.h"
12 #include "rtw8822c.h"
13 #include "rtw8822c_table.h"
14 #include "mac.h"
15 #include "reg.h"
16 #include "debug.h"
17 #include "util.h"
18 #include "bf.h"
19 #include "efuse.h"
20 
21 #define IQK_DONE_8822C 0xaa
22 
23 static void rtw8822c_config_trx_mode(struct rtw_dev *rtwdev, u8 tx_path,
24 				     u8 rx_path, bool is_tx2_path);
25 
26 static void rtw8822ce_efuse_parsing(struct rtw_efuse *efuse,
27 				    struct rtw8822c_efuse *map)
28 {
29 	ether_addr_copy(efuse->addr, map->e.mac_addr);
30 }
31 
32 static void rtw8822cu_efuse_parsing(struct rtw_efuse *efuse,
33 				    struct rtw8822c_efuse *map)
34 {
35 	ether_addr_copy(efuse->addr, map->u.mac_addr);
36 }
37 
38 static void rtw8822cs_efuse_parsing(struct rtw_efuse *efuse,
39 				    struct rtw8822c_efuse *map)
40 {
41 	ether_addr_copy(efuse->addr, map->s.mac_addr);
42 }
43 
44 static int rtw8822c_read_efuse(struct rtw_dev *rtwdev, u8 *log_map)
45 {
46 	struct rtw_efuse *efuse = &rtwdev->efuse;
47 	struct rtw8822c_efuse *map;
48 	int i;
49 
50 	map = (struct rtw8822c_efuse *)log_map;
51 
52 	efuse->usb_mode_switch = u8_get_bits(map->usb_mode, BIT(7));
53 	efuse->rfe_option = map->rfe_option;
54 	efuse->rf_board_option = map->rf_board_option;
55 	efuse->crystal_cap = map->xtal_k & XCAP_MASK;
56 	efuse->channel_plan = map->channel_plan;
57 	efuse->country_code[0] = map->country_code[0];
58 	efuse->country_code[1] = map->country_code[1];
59 	efuse->bt_setting = map->rf_bt_setting;
60 	efuse->regd = map->rf_board_option & 0x7;
61 	efuse->thermal_meter[RF_PATH_A] = map->path_a_thermal;
62 	efuse->thermal_meter[RF_PATH_B] = map->path_b_thermal;
63 	efuse->thermal_meter_k =
64 			(map->path_a_thermal + map->path_b_thermal) >> 1;
65 	efuse->power_track_type = (map->tx_pwr_calibrate_rate >> 4) & 0xf;
66 
67 	for (i = 0; i < 4; i++)
68 		efuse->txpwr_idx_table[i] = map->txpwr_idx_table[i];
69 
70 	switch (rtw_hci_type(rtwdev)) {
71 	case RTW_HCI_TYPE_PCIE:
72 		rtw8822ce_efuse_parsing(efuse, map);
73 		break;
74 	case RTW_HCI_TYPE_USB:
75 		rtw8822cu_efuse_parsing(efuse, map);
76 		break;
77 	case RTW_HCI_TYPE_SDIO:
78 		rtw8822cs_efuse_parsing(efuse, map);
79 		break;
80 	default:
81 		/* unsupported now */
82 		return -ENOTSUPP;
83 	}
84 
85 	return 0;
86 }
87 
88 static void rtw8822c_header_file_init(struct rtw_dev *rtwdev, bool pre)
89 {
90 	rtw_write32_set(rtwdev, REG_3WIRE, BIT_3WIRE_TX_EN | BIT_3WIRE_RX_EN);
91 	rtw_write32_set(rtwdev, REG_3WIRE, BIT_3WIRE_PI_ON);
92 	rtw_write32_set(rtwdev, REG_3WIRE2, BIT_3WIRE_TX_EN | BIT_3WIRE_RX_EN);
93 	rtw_write32_set(rtwdev, REG_3WIRE2, BIT_3WIRE_PI_ON);
94 
95 	if (pre)
96 		rtw_write32_clr(rtwdev, REG_ENCCK, BIT_CCK_OFDM_BLK_EN);
97 	else
98 		rtw_write32_set(rtwdev, REG_ENCCK, BIT_CCK_OFDM_BLK_EN);
99 }
100 
101 static void rtw8822c_bb_reset(struct rtw_dev *rtwdev)
102 {
103 	rtw_write16_set(rtwdev, REG_SYS_FUNC_EN, BIT_FEN_BB_RSTB);
104 	rtw_write16_clr(rtwdev, REG_SYS_FUNC_EN, BIT_FEN_BB_RSTB);
105 	rtw_write16_set(rtwdev, REG_SYS_FUNC_EN, BIT_FEN_BB_RSTB);
106 }
107 
108 static void rtw8822c_dac_backup_reg(struct rtw_dev *rtwdev,
109 				    struct rtw_backup_info *backup,
110 				    struct rtw_backup_info *backup_rf)
111 {
112 	u32 path, i;
113 	u32 val;
114 	u32 reg;
115 	u32 rf_addr[DACK_RF_8822C] = {0x8f};
116 	u32 addrs[DACK_REG_8822C] = {0x180c, 0x1810, 0x410c, 0x4110,
117 				     0x1c3c, 0x1c24, 0x1d70, 0x9b4,
118 				     0x1a00, 0x1a14, 0x1d58, 0x1c38,
119 				     0x1e24, 0x1e28, 0x1860, 0x4160};
120 
121 	for (i = 0; i < DACK_REG_8822C; i++) {
122 		backup[i].len = 4;
123 		backup[i].reg = addrs[i];
124 		backup[i].val = rtw_read32(rtwdev, addrs[i]);
125 	}
126 
127 	for (path = 0; path < DACK_PATH_8822C; path++) {
128 		for (i = 0; i < DACK_RF_8822C; i++) {
129 			reg = rf_addr[i];
130 			val = rtw_read_rf(rtwdev, path, reg, RFREG_MASK);
131 			backup_rf[path * i + i].reg = reg;
132 			backup_rf[path * i + i].val = val;
133 		}
134 	}
135 }
136 
137 static void rtw8822c_dac_restore_reg(struct rtw_dev *rtwdev,
138 				     struct rtw_backup_info *backup,
139 				     struct rtw_backup_info *backup_rf)
140 {
141 	u32 path, i;
142 	u32 val;
143 	u32 reg;
144 
145 	rtw_restore_reg(rtwdev, backup, DACK_REG_8822C);
146 
147 	for (path = 0; path < DACK_PATH_8822C; path++) {
148 		for (i = 0; i < DACK_RF_8822C; i++) {
149 			val = backup_rf[path * i + i].val;
150 			reg = backup_rf[path * i + i].reg;
151 			rtw_write_rf(rtwdev, path, reg, RFREG_MASK, val);
152 		}
153 	}
154 }
155 
156 static void rtw8822c_rf_minmax_cmp(struct rtw_dev *rtwdev, u32 value,
157 				   u32 *min, u32 *max)
158 {
159 	if (value >= 0x200) {
160 		if (*min >= 0x200) {
161 			if (*min > value)
162 				*min = value;
163 		} else {
164 			*min = value;
165 		}
166 		if (*max >= 0x200) {
167 			if (*max < value)
168 				*max = value;
169 		}
170 	} else {
171 		if (*min < 0x200) {
172 			if (*min > value)
173 				*min = value;
174 		}
175 
176 		if (*max  >= 0x200) {
177 			*max = value;
178 		} else {
179 			if (*max < value)
180 				*max = value;
181 		}
182 	}
183 }
184 
185 static void __rtw8822c_dac_iq_sort(struct rtw_dev *rtwdev, u32 *v1, u32 *v2)
186 {
187 	if (*v1 >= 0x200 && *v2 >= 0x200) {
188 		if (*v1 > *v2)
189 			swap(*v1, *v2);
190 	} else if (*v1 < 0x200 && *v2 < 0x200) {
191 		if (*v1 > *v2)
192 			swap(*v1, *v2);
193 	} else if (*v1 < 0x200 && *v2 >= 0x200) {
194 		swap(*v1, *v2);
195 	}
196 }
197 
198 static void rtw8822c_dac_iq_sort(struct rtw_dev *rtwdev, u32 *iv, u32 *qv)
199 {
200 	u32 i, j;
201 
202 	for (i = 0; i < DACK_SN_8822C - 1; i++) {
203 		for (j = 0; j < (DACK_SN_8822C - 1 - i) ; j++) {
204 			__rtw8822c_dac_iq_sort(rtwdev, &iv[j], &iv[j + 1]);
205 			__rtw8822c_dac_iq_sort(rtwdev, &qv[j], &qv[j + 1]);
206 		}
207 	}
208 }
209 
210 static void rtw8822c_dac_iq_offset(struct rtw_dev *rtwdev, u32 *vec, u32 *val)
211 {
212 	u32 p, m, t, i;
213 
214 	m = 0;
215 	p = 0;
216 	for (i = 10; i < DACK_SN_8822C - 10; i++) {
217 		if (vec[i] > 0x200)
218 			m = (0x400 - vec[i]) + m;
219 		else
220 			p = vec[i] + p;
221 	}
222 
223 	if (p > m) {
224 		t = p - m;
225 		t = t / (DACK_SN_8822C - 20);
226 	} else {
227 		t = m - p;
228 		t = t / (DACK_SN_8822C - 20);
229 		if (t != 0x0)
230 			t = 0x400 - t;
231 	}
232 
233 	*val = t;
234 }
235 
236 static u32 rtw8822c_get_path_write_addr(u8 path)
237 {
238 	u32 base_addr;
239 
240 	switch (path) {
241 	case RF_PATH_A:
242 		base_addr = 0x1800;
243 		break;
244 	case RF_PATH_B:
245 		base_addr = 0x4100;
246 		break;
247 	default:
248 		WARN_ON(1);
249 		return -1;
250 	}
251 
252 	return base_addr;
253 }
254 
255 static u32 rtw8822c_get_path_read_addr(u8 path)
256 {
257 	u32 base_addr;
258 
259 	switch (path) {
260 	case RF_PATH_A:
261 		base_addr = 0x2800;
262 		break;
263 	case RF_PATH_B:
264 		base_addr = 0x4500;
265 		break;
266 	default:
267 		WARN_ON(1);
268 		return -1;
269 	}
270 
271 	return base_addr;
272 }
273 
274 static bool rtw8822c_dac_iq_check(struct rtw_dev *rtwdev, u32 value)
275 {
276 	bool ret = true;
277 
278 	if ((value >= 0x200 && (0x400 - value) > 0x64) ||
279 	    (value < 0x200 && value > 0x64)) {
280 		ret = false;
281 		rtw_dbg(rtwdev, RTW_DBG_RFK, "[DACK] Error overflow\n");
282 	}
283 
284 	return ret;
285 }
286 
287 static void rtw8822c_dac_cal_iq_sample(struct rtw_dev *rtwdev, u32 *iv, u32 *qv)
288 {
289 	u32 temp;
290 	int i = 0, cnt = 0;
291 
292 	while (i < DACK_SN_8822C && cnt < 10000) {
293 		cnt++;
294 		temp = rtw_read32_mask(rtwdev, 0x2dbc, 0x3fffff);
295 		iv[i] = (temp & 0x3ff000) >> 12;
296 		qv[i] = temp & 0x3ff;
297 
298 		if (rtw8822c_dac_iq_check(rtwdev, iv[i]) &&
299 		    rtw8822c_dac_iq_check(rtwdev, qv[i]))
300 			i++;
301 	}
302 }
303 
304 static void rtw8822c_dac_cal_iq_search(struct rtw_dev *rtwdev,
305 				       u32 *iv, u32 *qv,
306 				       u32 *i_value, u32 *q_value)
307 {
308 	u32 i_max = 0, q_max = 0, i_min = 0, q_min = 0;
309 	u32 i_delta, q_delta;
310 	u32 temp;
311 	int i, cnt = 0;
312 
313 	do {
314 		i_min = iv[0];
315 		i_max = iv[0];
316 		q_min = qv[0];
317 		q_max = qv[0];
318 		for (i = 0; i < DACK_SN_8822C; i++) {
319 			rtw8822c_rf_minmax_cmp(rtwdev, iv[i], &i_min, &i_max);
320 			rtw8822c_rf_minmax_cmp(rtwdev, qv[i], &q_min, &q_max);
321 		}
322 
323 		if (i_max < 0x200 && i_min < 0x200)
324 			i_delta = i_max - i_min;
325 		else if (i_max >= 0x200 && i_min >= 0x200)
326 			i_delta = i_max - i_min;
327 		else
328 			i_delta = i_max + (0x400 - i_min);
329 
330 		if (q_max < 0x200 && q_min < 0x200)
331 			q_delta = q_max - q_min;
332 		else if (q_max >= 0x200 && q_min >= 0x200)
333 			q_delta = q_max - q_min;
334 		else
335 			q_delta = q_max + (0x400 - q_min);
336 
337 		rtw_dbg(rtwdev, RTW_DBG_RFK,
338 			"[DACK] i: min=0x%08x, max=0x%08x, delta=0x%08x\n",
339 			i_min, i_max, i_delta);
340 		rtw_dbg(rtwdev, RTW_DBG_RFK,
341 			"[DACK] q: min=0x%08x, max=0x%08x, delta=0x%08x\n",
342 			q_min, q_max, q_delta);
343 
344 		rtw8822c_dac_iq_sort(rtwdev, iv, qv);
345 
346 		if (i_delta > 5 || q_delta > 5) {
347 			temp = rtw_read32_mask(rtwdev, 0x2dbc, 0x3fffff);
348 			iv[0] = (temp & 0x3ff000) >> 12;
349 			qv[0] = temp & 0x3ff;
350 			temp = rtw_read32_mask(rtwdev, 0x2dbc, 0x3fffff);
351 			iv[DACK_SN_8822C - 1] = (temp & 0x3ff000) >> 12;
352 			qv[DACK_SN_8822C - 1] = temp & 0x3ff;
353 		} else {
354 			break;
355 		}
356 	} while (cnt++ < 100);
357 
358 	rtw8822c_dac_iq_offset(rtwdev, iv, i_value);
359 	rtw8822c_dac_iq_offset(rtwdev, qv, q_value);
360 }
361 
362 static void rtw8822c_dac_cal_rf_mode(struct rtw_dev *rtwdev,
363 				     u32 *i_value, u32 *q_value)
364 {
365 	u32 iv[DACK_SN_8822C], qv[DACK_SN_8822C];
366 	u32 rf_a, rf_b;
367 
368 	rf_a = rtw_read_rf(rtwdev, RF_PATH_A, 0x0, RFREG_MASK);
369 	rf_b = rtw_read_rf(rtwdev, RF_PATH_B, 0x0, RFREG_MASK);
370 
371 	rtw_dbg(rtwdev, RTW_DBG_RFK, "[DACK] RF path-A=0x%05x\n", rf_a);
372 	rtw_dbg(rtwdev, RTW_DBG_RFK, "[DACK] RF path-B=0x%05x\n", rf_b);
373 
374 	rtw8822c_dac_cal_iq_sample(rtwdev, iv, qv);
375 	rtw8822c_dac_cal_iq_search(rtwdev, iv, qv, i_value, q_value);
376 }
377 
378 static void rtw8822c_dac_bb_setting(struct rtw_dev *rtwdev)
379 {
380 	rtw_write32_mask(rtwdev, 0x1d58, 0xff8, 0x1ff);
381 	rtw_write32_mask(rtwdev, 0x1a00, 0x3, 0x2);
382 	rtw_write32_mask(rtwdev, 0x1a14, 0x300, 0x3);
383 	rtw_write32(rtwdev, 0x1d70, 0x7e7e7e7e);
384 	rtw_write32_mask(rtwdev, 0x180c, 0x3, 0x0);
385 	rtw_write32_mask(rtwdev, 0x410c, 0x3, 0x0);
386 	rtw_write32(rtwdev, 0x1b00, 0x00000008);
387 	rtw_write8(rtwdev, 0x1bcc, 0x3f);
388 	rtw_write32(rtwdev, 0x1b00, 0x0000000a);
389 	rtw_write8(rtwdev, 0x1bcc, 0x3f);
390 	rtw_write32_mask(rtwdev, 0x1e24, BIT(31), 0x0);
391 	rtw_write32_mask(rtwdev, 0x1e28, 0xf, 0x3);
392 }
393 
394 static void rtw8822c_dac_cal_adc(struct rtw_dev *rtwdev,
395 				 u8 path, u32 *adc_ic, u32 *adc_qc)
396 {
397 	struct rtw_dm_info *dm_info = &rtwdev->dm_info;
398 	u32 ic = 0, qc = 0, temp = 0;
399 	u32 base_addr;
400 	u32 path_sel;
401 	int i;
402 
403 	rtw_dbg(rtwdev, RTW_DBG_RFK, "[DACK] ADCK path(%d)\n", path);
404 
405 	base_addr = rtw8822c_get_path_write_addr(path);
406 	switch (path) {
407 	case RF_PATH_A:
408 		path_sel = 0xa0000;
409 		break;
410 	case RF_PATH_B:
411 		path_sel = 0x80000;
412 		break;
413 	default:
414 		WARN_ON(1);
415 		return;
416 	}
417 
418 	/* ADCK step1 */
419 	rtw_write32_mask(rtwdev, base_addr + 0x30, BIT(30), 0x0);
420 	if (path == RF_PATH_B)
421 		rtw_write32(rtwdev, base_addr + 0x30, 0x30db8041);
422 	rtw_write32(rtwdev, base_addr + 0x60, 0xf0040ff0);
423 	rtw_write32(rtwdev, base_addr + 0x0c, 0xdff00220);
424 	rtw_write32(rtwdev, base_addr + 0x10, 0x02dd08c4);
425 	rtw_write32(rtwdev, base_addr + 0x0c, 0x10000260);
426 	rtw_write_rf(rtwdev, RF_PATH_A, 0x0, RFREG_MASK, 0x10000);
427 	rtw_write_rf(rtwdev, RF_PATH_B, 0x0, RFREG_MASK, 0x10000);
428 	for (i = 0; i < 10; i++) {
429 		rtw_dbg(rtwdev, RTW_DBG_RFK, "[DACK] ADCK count=%d\n", i);
430 		rtw_write32(rtwdev, 0x1c3c, path_sel + 0x8003);
431 		rtw_write32(rtwdev, 0x1c24, 0x00010002);
432 		rtw8822c_dac_cal_rf_mode(rtwdev, &ic, &qc);
433 		rtw_dbg(rtwdev, RTW_DBG_RFK,
434 			"[DACK] before: i=0x%x, q=0x%x\n", ic, qc);
435 
436 		/* compensation value */
437 		if (ic != 0x0) {
438 			ic = 0x400 - ic;
439 			*adc_ic = ic;
440 		}
441 		if (qc != 0x0) {
442 			qc = 0x400 - qc;
443 			*adc_qc = qc;
444 		}
445 		temp = (ic & 0x3ff) | ((qc & 0x3ff) << 10);
446 		rtw_write32(rtwdev, base_addr + 0x68, temp);
447 		dm_info->dack_adck[path] = temp;
448 		rtw_dbg(rtwdev, RTW_DBG_RFK, "[DACK] ADCK 0x%08x=0x08%x\n",
449 			base_addr + 0x68, temp);
450 		/* check ADC DC offset */
451 		rtw_write32(rtwdev, 0x1c3c, path_sel + 0x8103);
452 		rtw8822c_dac_cal_rf_mode(rtwdev, &ic, &qc);
453 		rtw_dbg(rtwdev, RTW_DBG_RFK,
454 			"[DACK] after:  i=0x%08x, q=0x%08x\n", ic, qc);
455 		if (ic >= 0x200)
456 			ic = 0x400 - ic;
457 		if (qc >= 0x200)
458 			qc = 0x400 - qc;
459 		if (ic < 5 && qc < 5)
460 			break;
461 	}
462 
463 	/* ADCK step2 */
464 	rtw_write32(rtwdev, 0x1c3c, 0x00000003);
465 	rtw_write32(rtwdev, base_addr + 0x0c, 0x10000260);
466 	rtw_write32(rtwdev, base_addr + 0x10, 0x02d508c4);
467 
468 	/* release pull low switch on IQ path */
469 	rtw_write_rf(rtwdev, path, 0x8f, BIT(13), 0x1);
470 }
471 
472 static void rtw8822c_dac_cal_step1(struct rtw_dev *rtwdev, u8 path)
473 {
474 	struct rtw_dm_info *dm_info = &rtwdev->dm_info;
475 	u32 base_addr;
476 	u32 read_addr;
477 
478 	base_addr = rtw8822c_get_path_write_addr(path);
479 	read_addr = rtw8822c_get_path_read_addr(path);
480 
481 	rtw_write32(rtwdev, base_addr + 0x68, dm_info->dack_adck[path]);
482 	rtw_write32(rtwdev, base_addr + 0x0c, 0xdff00220);
483 	if (path == RF_PATH_A) {
484 		rtw_write32(rtwdev, base_addr + 0x60, 0xf0040ff0);
485 		rtw_write32(rtwdev, 0x1c38, 0xffffffff);
486 	}
487 	rtw_write32(rtwdev, base_addr + 0x10, 0x02d508c5);
488 	rtw_write32(rtwdev, 0x9b4, 0xdb66db00);
489 	rtw_write32(rtwdev, base_addr + 0xb0, 0x0a11fb88);
490 	rtw_write32(rtwdev, base_addr + 0xbc, 0x0008ff81);
491 	rtw_write32(rtwdev, base_addr + 0xc0, 0x0003d208);
492 	rtw_write32(rtwdev, base_addr + 0xcc, 0x0a11fb88);
493 	rtw_write32(rtwdev, base_addr + 0xd8, 0x0008ff81);
494 	rtw_write32(rtwdev, base_addr + 0xdc, 0x0003d208);
495 	rtw_write32(rtwdev, base_addr + 0xb8, 0x60000000);
496 	mdelay(2);
497 	rtw_write32(rtwdev, base_addr + 0xbc, 0x000aff8d);
498 	mdelay(2);
499 	rtw_write32(rtwdev, base_addr + 0xb0, 0x0a11fb89);
500 	rtw_write32(rtwdev, base_addr + 0xcc, 0x0a11fb89);
501 	mdelay(1);
502 	rtw_write32(rtwdev, base_addr + 0xb8, 0x62000000);
503 	rtw_write32(rtwdev, base_addr + 0xd4, 0x62000000);
504 	mdelay(20);
505 	if (!check_hw_ready(rtwdev, read_addr + 0x08, 0x7fff80, 0xffff) ||
506 	    !check_hw_ready(rtwdev, read_addr + 0x34, 0x7fff80, 0xffff))
507 		rtw_err(rtwdev, "failed to wait for dack ready\n");
508 	rtw_write32(rtwdev, base_addr + 0xb8, 0x02000000);
509 	mdelay(1);
510 	rtw_write32(rtwdev, base_addr + 0xbc, 0x0008ff87);
511 	rtw_write32(rtwdev, 0x9b4, 0xdb6db600);
512 	rtw_write32(rtwdev, base_addr + 0x10, 0x02d508c5);
513 	rtw_write32(rtwdev, base_addr + 0xbc, 0x0008ff87);
514 	rtw_write32(rtwdev, base_addr + 0x60, 0xf0000000);
515 }
516 
517 static void rtw8822c_dac_cal_step2(struct rtw_dev *rtwdev,
518 				   u8 path, u32 *ic_out, u32 *qc_out)
519 {
520 	u32 base_addr;
521 	u32 ic, qc, ic_in, qc_in;
522 
523 	base_addr = rtw8822c_get_path_write_addr(path);
524 	rtw_write32_mask(rtwdev, base_addr + 0xbc, 0xf0000000, 0x0);
525 	rtw_write32_mask(rtwdev, base_addr + 0xc0, 0xf, 0x8);
526 	rtw_write32_mask(rtwdev, base_addr + 0xd8, 0xf0000000, 0x0);
527 	rtw_write32_mask(rtwdev, base_addr + 0xdc, 0xf, 0x8);
528 
529 	rtw_write32(rtwdev, 0x1b00, 0x00000008);
530 	rtw_write8(rtwdev, 0x1bcc, 0x03f);
531 	rtw_write32(rtwdev, base_addr + 0x0c, 0xdff00220);
532 	rtw_write32(rtwdev, base_addr + 0x10, 0x02d508c5);
533 	rtw_write32(rtwdev, 0x1c3c, 0x00088103);
534 
535 	rtw8822c_dac_cal_rf_mode(rtwdev, &ic_in, &qc_in);
536 	ic = ic_in;
537 	qc = qc_in;
538 
539 	/* compensation value */
540 	if (ic != 0x0)
541 		ic = 0x400 - ic;
542 	if (qc != 0x0)
543 		qc = 0x400 - qc;
544 	if (ic < 0x300) {
545 		ic = ic * 2 * 6 / 5;
546 		ic = ic + 0x80;
547 	} else {
548 		ic = (0x400 - ic) * 2 * 6 / 5;
549 		ic = 0x7f - ic;
550 	}
551 	if (qc < 0x300) {
552 		qc = qc * 2 * 6 / 5;
553 		qc = qc + 0x80;
554 	} else {
555 		qc = (0x400 - qc) * 2 * 6 / 5;
556 		qc = 0x7f - qc;
557 	}
558 
559 	*ic_out = ic;
560 	*qc_out = qc;
561 
562 	rtw_dbg(rtwdev, RTW_DBG_RFK, "[DACK] before i=0x%x, q=0x%x\n", ic_in, qc_in);
563 	rtw_dbg(rtwdev, RTW_DBG_RFK, "[DACK] after  i=0x%x, q=0x%x\n", ic, qc);
564 }
565 
566 static void rtw8822c_dac_cal_step3(struct rtw_dev *rtwdev, u8 path,
567 				   u32 adc_ic, u32 adc_qc,
568 				   u32 *ic_in, u32 *qc_in,
569 				   u32 *i_out, u32 *q_out)
570 {
571 	u32 base_addr;
572 	u32 read_addr;
573 	u32 ic, qc;
574 	u32 temp;
575 
576 	base_addr = rtw8822c_get_path_write_addr(path);
577 	read_addr = rtw8822c_get_path_read_addr(path);
578 	ic = *ic_in;
579 	qc = *qc_in;
580 
581 	rtw_write32(rtwdev, base_addr + 0x0c, 0xdff00220);
582 	rtw_write32(rtwdev, base_addr + 0x10, 0x02d508c5);
583 	rtw_write32(rtwdev, 0x9b4, 0xdb66db00);
584 	rtw_write32(rtwdev, base_addr + 0xb0, 0x0a11fb88);
585 	rtw_write32(rtwdev, base_addr + 0xbc, 0xc008ff81);
586 	rtw_write32(rtwdev, base_addr + 0xc0, 0x0003d208);
587 	rtw_write32_mask(rtwdev, base_addr + 0xbc, 0xf0000000, ic & 0xf);
588 	rtw_write32_mask(rtwdev, base_addr + 0xc0, 0xf, (ic & 0xf0) >> 4);
589 	rtw_write32(rtwdev, base_addr + 0xcc, 0x0a11fb88);
590 	rtw_write32(rtwdev, base_addr + 0xd8, 0xe008ff81);
591 	rtw_write32(rtwdev, base_addr + 0xdc, 0x0003d208);
592 	rtw_write32_mask(rtwdev, base_addr + 0xd8, 0xf0000000, qc & 0xf);
593 	rtw_write32_mask(rtwdev, base_addr + 0xdc, 0xf, (qc & 0xf0) >> 4);
594 	rtw_write32(rtwdev, base_addr + 0xb8, 0x60000000);
595 	mdelay(2);
596 	rtw_write32_mask(rtwdev, base_addr + 0xbc, 0xe, 0x6);
597 	mdelay(2);
598 	rtw_write32(rtwdev, base_addr + 0xb0, 0x0a11fb89);
599 	rtw_write32(rtwdev, base_addr + 0xcc, 0x0a11fb89);
600 	mdelay(1);
601 	rtw_write32(rtwdev, base_addr + 0xb8, 0x62000000);
602 	rtw_write32(rtwdev, base_addr + 0xd4, 0x62000000);
603 	mdelay(20);
604 	if (!check_hw_ready(rtwdev, read_addr + 0x24, 0x07f80000, ic) ||
605 	    !check_hw_ready(rtwdev, read_addr + 0x50, 0x07f80000, qc))
606 		rtw_err(rtwdev, "failed to write IQ vector to hardware\n");
607 	rtw_write32(rtwdev, base_addr + 0xb8, 0x02000000);
608 	mdelay(1);
609 	rtw_write32_mask(rtwdev, base_addr + 0xbc, 0xe, 0x3);
610 	rtw_write32(rtwdev, 0x9b4, 0xdb6db600);
611 
612 	/* check DAC DC offset */
613 	temp = ((adc_ic + 0x10) & 0x3ff) | (((adc_qc + 0x10) & 0x3ff) << 10);
614 	rtw_write32(rtwdev, base_addr + 0x68, temp);
615 	rtw_write32(rtwdev, base_addr + 0x10, 0x02d508c5);
616 	rtw_write32(rtwdev, base_addr + 0x60, 0xf0000000);
617 	rtw8822c_dac_cal_rf_mode(rtwdev, &ic, &qc);
618 	if (ic >= 0x10)
619 		ic = ic - 0x10;
620 	else
621 		ic = 0x400 - (0x10 - ic);
622 
623 	if (qc >= 0x10)
624 		qc = qc - 0x10;
625 	else
626 		qc = 0x400 - (0x10 - qc);
627 
628 	*i_out = ic;
629 	*q_out = qc;
630 
631 	if (ic >= 0x200)
632 		ic = 0x400 - ic;
633 	if (qc >= 0x200)
634 		qc = 0x400 - qc;
635 
636 	*ic_in = ic;
637 	*qc_in = qc;
638 
639 	rtw_dbg(rtwdev, RTW_DBG_RFK,
640 		"[DACK] after  DACK i=0x%x, q=0x%x\n", *i_out, *q_out);
641 }
642 
643 static void rtw8822c_dac_cal_step4(struct rtw_dev *rtwdev, u8 path)
644 {
645 	u32 base_addr = rtw8822c_get_path_write_addr(path);
646 
647 	rtw_write32(rtwdev, base_addr + 0x68, 0x0);
648 	rtw_write32(rtwdev, base_addr + 0x10, 0x02d508c4);
649 	rtw_write32_mask(rtwdev, base_addr + 0xbc, 0x1, 0x0);
650 	rtw_write32_mask(rtwdev, base_addr + 0x30, BIT(30), 0x1);
651 }
652 
653 static void rtw8822c_dac_cal_backup_vec(struct rtw_dev *rtwdev,
654 					u8 path, u8 vec, u32 w_addr, u32 r_addr)
655 {
656 	struct rtw_dm_info *dm_info = &rtwdev->dm_info;
657 	u16 val;
658 	u32 i;
659 
660 	if (WARN_ON(vec >= 2))
661 		return;
662 
663 	for (i = 0; i < DACK_MSBK_BACKUP_NUM; i++) {
664 		rtw_write32_mask(rtwdev, w_addr, 0xf0000000, i);
665 		val = (u16)rtw_read32_mask(rtwdev, r_addr, 0x7fc0000);
666 		dm_info->dack_msbk[path][vec][i] = val;
667 	}
668 }
669 
670 static void rtw8822c_dac_cal_backup_path(struct rtw_dev *rtwdev, u8 path)
671 {
672 	u32 w_off = 0x1c;
673 	u32 r_off = 0x2c;
674 	u32 w_addr, r_addr;
675 
676 	if (WARN_ON(path >= 2))
677 		return;
678 
679 	/* backup I vector */
680 	w_addr = rtw8822c_get_path_write_addr(path) + 0xb0;
681 	r_addr = rtw8822c_get_path_read_addr(path) + 0x10;
682 	rtw8822c_dac_cal_backup_vec(rtwdev, path, 0, w_addr, r_addr);
683 
684 	/* backup Q vector */
685 	w_addr = rtw8822c_get_path_write_addr(path) + 0xb0 + w_off;
686 	r_addr = rtw8822c_get_path_read_addr(path) + 0x10 + r_off;
687 	rtw8822c_dac_cal_backup_vec(rtwdev, path, 1, w_addr, r_addr);
688 }
689 
690 static void rtw8822c_dac_cal_backup_dck(struct rtw_dev *rtwdev)
691 {
692 	struct rtw_dm_info *dm_info = &rtwdev->dm_info;
693 	u8 val;
694 
695 	val = (u8)rtw_read32_mask(rtwdev, REG_DCKA_I_0, 0xf0000000);
696 	dm_info->dack_dck[RF_PATH_A][0][0] = val;
697 	val = (u8)rtw_read32_mask(rtwdev, REG_DCKA_I_1, 0xf);
698 	dm_info->dack_dck[RF_PATH_A][0][1] = val;
699 	val = (u8)rtw_read32_mask(rtwdev, REG_DCKA_Q_0, 0xf0000000);
700 	dm_info->dack_dck[RF_PATH_A][1][0] = val;
701 	val = (u8)rtw_read32_mask(rtwdev, REG_DCKA_Q_1, 0xf);
702 	dm_info->dack_dck[RF_PATH_A][1][1] = val;
703 
704 	val = (u8)rtw_read32_mask(rtwdev, REG_DCKB_I_0, 0xf0000000);
705 	dm_info->dack_dck[RF_PATH_B][0][0] = val;
706 	val = (u8)rtw_read32_mask(rtwdev, REG_DCKB_I_1, 0xf);
707 	dm_info->dack_dck[RF_PATH_B][1][0] = val;
708 	val = (u8)rtw_read32_mask(rtwdev, REG_DCKB_Q_0, 0xf0000000);
709 	dm_info->dack_dck[RF_PATH_B][0][1] = val;
710 	val = (u8)rtw_read32_mask(rtwdev, REG_DCKB_Q_1, 0xf);
711 	dm_info->dack_dck[RF_PATH_B][1][1] = val;
712 }
713 
714 static void rtw8822c_dac_cal_backup(struct rtw_dev *rtwdev)
715 {
716 	u32 temp[3];
717 
718 	temp[0] = rtw_read32(rtwdev, 0x1860);
719 	temp[1] = rtw_read32(rtwdev, 0x4160);
720 	temp[2] = rtw_read32(rtwdev, 0x9b4);
721 
722 	/* set clock */
723 	rtw_write32(rtwdev, 0x9b4, 0xdb66db00);
724 
725 	/* backup path-A I/Q */
726 	rtw_write32_clr(rtwdev, 0x1830, BIT(30));
727 	rtw_write32_mask(rtwdev, 0x1860, 0xfc000000, 0x3c);
728 	rtw8822c_dac_cal_backup_path(rtwdev, RF_PATH_A);
729 
730 	/* backup path-B I/Q */
731 	rtw_write32_clr(rtwdev, 0x4130, BIT(30));
732 	rtw_write32_mask(rtwdev, 0x4160, 0xfc000000, 0x3c);
733 	rtw8822c_dac_cal_backup_path(rtwdev, RF_PATH_B);
734 
735 	rtw8822c_dac_cal_backup_dck(rtwdev);
736 	rtw_write32_set(rtwdev, 0x1830, BIT(30));
737 	rtw_write32_set(rtwdev, 0x4130, BIT(30));
738 
739 	rtw_write32(rtwdev, 0x1860, temp[0]);
740 	rtw_write32(rtwdev, 0x4160, temp[1]);
741 	rtw_write32(rtwdev, 0x9b4, temp[2]);
742 }
743 
744 static void rtw8822c_dac_cal_restore_dck(struct rtw_dev *rtwdev)
745 {
746 	struct rtw_dm_info *dm_info = &rtwdev->dm_info;
747 	u8 val;
748 
749 	rtw_write32_set(rtwdev, REG_DCKA_I_0, BIT(19));
750 	val = dm_info->dack_dck[RF_PATH_A][0][0];
751 	rtw_write32_mask(rtwdev, REG_DCKA_I_0, 0xf0000000, val);
752 	val = dm_info->dack_dck[RF_PATH_A][0][1];
753 	rtw_write32_mask(rtwdev, REG_DCKA_I_1, 0xf, val);
754 
755 	rtw_write32_set(rtwdev, REG_DCKA_Q_0, BIT(19));
756 	val = dm_info->dack_dck[RF_PATH_A][1][0];
757 	rtw_write32_mask(rtwdev, REG_DCKA_Q_0, 0xf0000000, val);
758 	val = dm_info->dack_dck[RF_PATH_A][1][1];
759 	rtw_write32_mask(rtwdev, REG_DCKA_Q_1, 0xf, val);
760 
761 	rtw_write32_set(rtwdev, REG_DCKB_I_0, BIT(19));
762 	val = dm_info->dack_dck[RF_PATH_B][0][0];
763 	rtw_write32_mask(rtwdev, REG_DCKB_I_0, 0xf0000000, val);
764 	val = dm_info->dack_dck[RF_PATH_B][0][1];
765 	rtw_write32_mask(rtwdev, REG_DCKB_I_1, 0xf, val);
766 
767 	rtw_write32_set(rtwdev, REG_DCKB_Q_0, BIT(19));
768 	val = dm_info->dack_dck[RF_PATH_B][1][0];
769 	rtw_write32_mask(rtwdev, REG_DCKB_Q_0, 0xf0000000, val);
770 	val = dm_info->dack_dck[RF_PATH_B][1][1];
771 	rtw_write32_mask(rtwdev, REG_DCKB_Q_1, 0xf, val);
772 }
773 
774 static void rtw8822c_dac_cal_restore_prepare(struct rtw_dev *rtwdev)
775 {
776 	rtw_write32(rtwdev, 0x9b4, 0xdb66db00);
777 
778 	rtw_write32_mask(rtwdev, 0x18b0, BIT(27), 0x0);
779 	rtw_write32_mask(rtwdev, 0x18cc, BIT(27), 0x0);
780 	rtw_write32_mask(rtwdev, 0x41b0, BIT(27), 0x0);
781 	rtw_write32_mask(rtwdev, 0x41cc, BIT(27), 0x0);
782 
783 	rtw_write32_mask(rtwdev, 0x1830, BIT(30), 0x0);
784 	rtw_write32_mask(rtwdev, 0x1860, 0xfc000000, 0x3c);
785 	rtw_write32_mask(rtwdev, 0x18b4, BIT(0), 0x1);
786 	rtw_write32_mask(rtwdev, 0x18d0, BIT(0), 0x1);
787 
788 	rtw_write32_mask(rtwdev, 0x4130, BIT(30), 0x0);
789 	rtw_write32_mask(rtwdev, 0x4160, 0xfc000000, 0x3c);
790 	rtw_write32_mask(rtwdev, 0x41b4, BIT(0), 0x1);
791 	rtw_write32_mask(rtwdev, 0x41d0, BIT(0), 0x1);
792 
793 	rtw_write32_mask(rtwdev, 0x18b0, 0xf00, 0x0);
794 	rtw_write32_mask(rtwdev, 0x18c0, BIT(14), 0x0);
795 	rtw_write32_mask(rtwdev, 0x18cc, 0xf00, 0x0);
796 	rtw_write32_mask(rtwdev, 0x18dc, BIT(14), 0x0);
797 
798 	rtw_write32_mask(rtwdev, 0x18b0, BIT(0), 0x0);
799 	rtw_write32_mask(rtwdev, 0x18cc, BIT(0), 0x0);
800 	rtw_write32_mask(rtwdev, 0x18b0, BIT(0), 0x1);
801 	rtw_write32_mask(rtwdev, 0x18cc, BIT(0), 0x1);
802 
803 	rtw8822c_dac_cal_restore_dck(rtwdev);
804 
805 	rtw_write32_mask(rtwdev, 0x18c0, 0x38000, 0x7);
806 	rtw_write32_mask(rtwdev, 0x18dc, 0x38000, 0x7);
807 	rtw_write32_mask(rtwdev, 0x41c0, 0x38000, 0x7);
808 	rtw_write32_mask(rtwdev, 0x41dc, 0x38000, 0x7);
809 
810 	rtw_write32_mask(rtwdev, 0x18b8, BIT(26) | BIT(25), 0x1);
811 	rtw_write32_mask(rtwdev, 0x18d4, BIT(26) | BIT(25), 0x1);
812 
813 	rtw_write32_mask(rtwdev, 0x41b0, 0xf00, 0x0);
814 	rtw_write32_mask(rtwdev, 0x41c0, BIT(14), 0x0);
815 	rtw_write32_mask(rtwdev, 0x41cc, 0xf00, 0x0);
816 	rtw_write32_mask(rtwdev, 0x41dc, BIT(14), 0x0);
817 
818 	rtw_write32_mask(rtwdev, 0x41b0, BIT(0), 0x0);
819 	rtw_write32_mask(rtwdev, 0x41cc, BIT(0), 0x0);
820 	rtw_write32_mask(rtwdev, 0x41b0, BIT(0), 0x1);
821 	rtw_write32_mask(rtwdev, 0x41cc, BIT(0), 0x1);
822 
823 	rtw_write32_mask(rtwdev, 0x41b8, BIT(26) | BIT(25), 0x1);
824 	rtw_write32_mask(rtwdev, 0x41d4, BIT(26) | BIT(25), 0x1);
825 }
826 
827 static bool rtw8822c_dac_cal_restore_wait(struct rtw_dev *rtwdev,
828 					  u32 target_addr, u32 toggle_addr)
829 {
830 	u32 cnt = 0;
831 
832 	do {
833 		rtw_write32_mask(rtwdev, toggle_addr, BIT(26) | BIT(25), 0x0);
834 		rtw_write32_mask(rtwdev, toggle_addr, BIT(26) | BIT(25), 0x2);
835 
836 		if (rtw_read32_mask(rtwdev, target_addr, 0xf) == 0x6)
837 			return true;
838 
839 	} while (cnt++ < 100);
840 
841 	return false;
842 }
843 
844 static bool rtw8822c_dac_cal_restore_path(struct rtw_dev *rtwdev, u8 path)
845 {
846 	struct rtw_dm_info *dm_info = &rtwdev->dm_info;
847 	u32 w_off = 0x1c;
848 	u32 r_off = 0x2c;
849 	u32 w_i, r_i, w_q, r_q;
850 	u32 value;
851 	u32 i;
852 
853 	w_i = rtw8822c_get_path_write_addr(path) + 0xb0;
854 	r_i = rtw8822c_get_path_read_addr(path) + 0x08;
855 	w_q = rtw8822c_get_path_write_addr(path) + 0xb0 + w_off;
856 	r_q = rtw8822c_get_path_read_addr(path) + 0x08 + r_off;
857 
858 	if (!rtw8822c_dac_cal_restore_wait(rtwdev, r_i, w_i + 0x8))
859 		return false;
860 
861 	for (i = 0; i < DACK_MSBK_BACKUP_NUM; i++) {
862 		rtw_write32_mask(rtwdev, w_i + 0x4, BIT(2), 0x0);
863 		value = dm_info->dack_msbk[path][0][i];
864 		rtw_write32_mask(rtwdev, w_i + 0x4, 0xff8, value);
865 		rtw_write32_mask(rtwdev, w_i, 0xf0000000, i);
866 		rtw_write32_mask(rtwdev, w_i + 0x4, BIT(2), 0x1);
867 	}
868 
869 	rtw_write32_mask(rtwdev, w_i + 0x4, BIT(2), 0x0);
870 
871 	if (!rtw8822c_dac_cal_restore_wait(rtwdev, r_q, w_q + 0x8))
872 		return false;
873 
874 	for (i = 0; i < DACK_MSBK_BACKUP_NUM; i++) {
875 		rtw_write32_mask(rtwdev, w_q + 0x4, BIT(2), 0x0);
876 		value = dm_info->dack_msbk[path][1][i];
877 		rtw_write32_mask(rtwdev, w_q + 0x4, 0xff8, value);
878 		rtw_write32_mask(rtwdev, w_q, 0xf0000000, i);
879 		rtw_write32_mask(rtwdev, w_q + 0x4, BIT(2), 0x1);
880 	}
881 	rtw_write32_mask(rtwdev, w_q + 0x4, BIT(2), 0x0);
882 
883 	rtw_write32_mask(rtwdev, w_i + 0x8, BIT(26) | BIT(25), 0x0);
884 	rtw_write32_mask(rtwdev, w_q + 0x8, BIT(26) | BIT(25), 0x0);
885 	rtw_write32_mask(rtwdev, w_i + 0x4, BIT(0), 0x0);
886 	rtw_write32_mask(rtwdev, w_q + 0x4, BIT(0), 0x0);
887 
888 	return true;
889 }
890 
891 static bool __rtw8822c_dac_cal_restore(struct rtw_dev *rtwdev)
892 {
893 	if (!rtw8822c_dac_cal_restore_path(rtwdev, RF_PATH_A))
894 		return false;
895 
896 	if (!rtw8822c_dac_cal_restore_path(rtwdev, RF_PATH_B))
897 		return false;
898 
899 	return true;
900 }
901 
902 static bool rtw8822c_dac_cal_restore(struct rtw_dev *rtwdev)
903 {
904 	struct rtw_dm_info *dm_info = &rtwdev->dm_info;
905 	u32 temp[3];
906 
907 	/* sample the first element for both path's IQ vector */
908 	if (dm_info->dack_msbk[RF_PATH_A][0][0] == 0 &&
909 	    dm_info->dack_msbk[RF_PATH_A][1][0] == 0 &&
910 	    dm_info->dack_msbk[RF_PATH_B][0][0] == 0 &&
911 	    dm_info->dack_msbk[RF_PATH_B][1][0] == 0)
912 		return false;
913 
914 	temp[0] = rtw_read32(rtwdev, 0x1860);
915 	temp[1] = rtw_read32(rtwdev, 0x4160);
916 	temp[2] = rtw_read32(rtwdev, 0x9b4);
917 
918 	rtw8822c_dac_cal_restore_prepare(rtwdev);
919 	if (!check_hw_ready(rtwdev, 0x2808, 0x7fff80, 0xffff) ||
920 	    !check_hw_ready(rtwdev, 0x2834, 0x7fff80, 0xffff) ||
921 	    !check_hw_ready(rtwdev, 0x4508, 0x7fff80, 0xffff) ||
922 	    !check_hw_ready(rtwdev, 0x4534, 0x7fff80, 0xffff))
923 		return false;
924 
925 	if (!__rtw8822c_dac_cal_restore(rtwdev)) {
926 		rtw_err(rtwdev, "failed to restore dack vectors\n");
927 		return false;
928 	}
929 
930 	rtw_write32_mask(rtwdev, 0x1830, BIT(30), 0x1);
931 	rtw_write32_mask(rtwdev, 0x4130, BIT(30), 0x1);
932 	rtw_write32(rtwdev, 0x1860, temp[0]);
933 	rtw_write32(rtwdev, 0x4160, temp[1]);
934 	rtw_write32_mask(rtwdev, 0x18b0, BIT(27), 0x1);
935 	rtw_write32_mask(rtwdev, 0x18cc, BIT(27), 0x1);
936 	rtw_write32_mask(rtwdev, 0x41b0, BIT(27), 0x1);
937 	rtw_write32_mask(rtwdev, 0x41cc, BIT(27), 0x1);
938 	rtw_write32(rtwdev, 0x9b4, temp[2]);
939 
940 	return true;
941 }
942 
943 static void rtw8822c_rf_dac_cal(struct rtw_dev *rtwdev)
944 {
945 	struct rtw_backup_info backup_rf[DACK_RF_8822C * DACK_PATH_8822C];
946 	struct rtw_backup_info backup[DACK_REG_8822C];
947 	u32 ic = 0, qc = 0, i;
948 	u32 i_a = 0x0, q_a = 0x0, i_b = 0x0, q_b = 0x0;
949 	u32 ic_a = 0x0, qc_a = 0x0, ic_b = 0x0, qc_b = 0x0;
950 	u32 adc_ic_a = 0x0, adc_qc_a = 0x0, adc_ic_b = 0x0, adc_qc_b = 0x0;
951 
952 	if (rtw8822c_dac_cal_restore(rtwdev))
953 		return;
954 
955 	/* not able to restore, do it */
956 
957 	rtw8822c_dac_backup_reg(rtwdev, backup, backup_rf);
958 
959 	rtw8822c_dac_bb_setting(rtwdev);
960 
961 	/* path-A */
962 	rtw8822c_dac_cal_adc(rtwdev, RF_PATH_A, &adc_ic_a, &adc_qc_a);
963 	for (i = 0; i < 10; i++) {
964 		rtw8822c_dac_cal_step1(rtwdev, RF_PATH_A);
965 		rtw8822c_dac_cal_step2(rtwdev, RF_PATH_A, &ic, &qc);
966 		ic_a = ic;
967 		qc_a = qc;
968 
969 		rtw8822c_dac_cal_step3(rtwdev, RF_PATH_A, adc_ic_a, adc_qc_a,
970 				       &ic, &qc, &i_a, &q_a);
971 
972 		if (ic < 5 && qc < 5)
973 			break;
974 	}
975 	rtw8822c_dac_cal_step4(rtwdev, RF_PATH_A);
976 
977 	/* path-B */
978 	rtw8822c_dac_cal_adc(rtwdev, RF_PATH_B, &adc_ic_b, &adc_qc_b);
979 	for (i = 0; i < 10; i++) {
980 		rtw8822c_dac_cal_step1(rtwdev, RF_PATH_B);
981 		rtw8822c_dac_cal_step2(rtwdev, RF_PATH_B, &ic, &qc);
982 		ic_b = ic;
983 		qc_b = qc;
984 
985 		rtw8822c_dac_cal_step3(rtwdev, RF_PATH_B, adc_ic_b, adc_qc_b,
986 				       &ic, &qc, &i_b, &q_b);
987 
988 		if (ic < 5 && qc < 5)
989 			break;
990 	}
991 	rtw8822c_dac_cal_step4(rtwdev, RF_PATH_B);
992 
993 	rtw_write32(rtwdev, 0x1b00, 0x00000008);
994 	rtw_write32_mask(rtwdev, 0x4130, BIT(30), 0x1);
995 	rtw_write8(rtwdev, 0x1bcc, 0x0);
996 	rtw_write32(rtwdev, 0x1b00, 0x0000000a);
997 	rtw_write8(rtwdev, 0x1bcc, 0x0);
998 
999 	rtw8822c_dac_restore_reg(rtwdev, backup, backup_rf);
1000 
1001 	/* backup results to restore, saving a lot of time */
1002 	rtw8822c_dac_cal_backup(rtwdev);
1003 
1004 	rtw_dbg(rtwdev, RTW_DBG_RFK, "[DACK] path A: ic=0x%x, qc=0x%x\n", ic_a, qc_a);
1005 	rtw_dbg(rtwdev, RTW_DBG_RFK, "[DACK] path B: ic=0x%x, qc=0x%x\n", ic_b, qc_b);
1006 	rtw_dbg(rtwdev, RTW_DBG_RFK, "[DACK] path A: i=0x%x, q=0x%x\n", i_a, q_a);
1007 	rtw_dbg(rtwdev, RTW_DBG_RFK, "[DACK] path B: i=0x%x, q=0x%x\n", i_b, q_b);
1008 }
1009 
1010 static void rtw8822c_rf_x2_check(struct rtw_dev *rtwdev)
1011 {
1012 	u8 x2k_busy;
1013 
1014 	mdelay(1);
1015 	x2k_busy = rtw_read_rf(rtwdev, RF_PATH_A, 0xb8, BIT(15));
1016 	if (x2k_busy == 1) {
1017 		rtw_write_rf(rtwdev, RF_PATH_A, 0xb8, RFREG_MASK, 0xC4440);
1018 		rtw_write_rf(rtwdev, RF_PATH_A, 0xba, RFREG_MASK, 0x6840D);
1019 		rtw_write_rf(rtwdev, RF_PATH_A, 0xb8, RFREG_MASK, 0x80440);
1020 		mdelay(1);
1021 	}
1022 }
1023 
1024 static void rtw8822c_set_power_trim(struct rtw_dev *rtwdev, s8 bb_gain[2][8])
1025 {
1026 #define RF_SET_POWER_TRIM(_path, _seq, _idx)					\
1027 		do {								\
1028 			rtw_write_rf(rtwdev, _path, 0x33, RFREG_MASK, _seq);	\
1029 			rtw_write_rf(rtwdev, _path, 0x3f, RFREG_MASK,		\
1030 				     bb_gain[_path][_idx]);			\
1031 		} while (0)
1032 	u8 path;
1033 
1034 	for (path = 0; path < rtwdev->hal.rf_path_num; path++) {
1035 		rtw_write_rf(rtwdev, path, 0xee, BIT(19), 1);
1036 		RF_SET_POWER_TRIM(path, 0x0, 0);
1037 		RF_SET_POWER_TRIM(path, 0x1, 1);
1038 		RF_SET_POWER_TRIM(path, 0x2, 2);
1039 		RF_SET_POWER_TRIM(path, 0x3, 2);
1040 		RF_SET_POWER_TRIM(path, 0x4, 3);
1041 		RF_SET_POWER_TRIM(path, 0x5, 4);
1042 		RF_SET_POWER_TRIM(path, 0x6, 5);
1043 		RF_SET_POWER_TRIM(path, 0x7, 6);
1044 		RF_SET_POWER_TRIM(path, 0x8, 7);
1045 		RF_SET_POWER_TRIM(path, 0x9, 3);
1046 		RF_SET_POWER_TRIM(path, 0xa, 4);
1047 		RF_SET_POWER_TRIM(path, 0xb, 5);
1048 		RF_SET_POWER_TRIM(path, 0xc, 6);
1049 		RF_SET_POWER_TRIM(path, 0xd, 7);
1050 		RF_SET_POWER_TRIM(path, 0xe, 7);
1051 		rtw_write_rf(rtwdev, path, 0xee, BIT(19), 0);
1052 	}
1053 #undef RF_SET_POWER_TRIM
1054 }
1055 
1056 static void rtw8822c_power_trim(struct rtw_dev *rtwdev)
1057 {
1058 	u8 pg_pwr = 0xff, i, path, idx;
1059 	s8 bb_gain[2][8] = {};
1060 	u16 rf_efuse_2g[3] = {PPG_2GL_TXAB, PPG_2GM_TXAB, PPG_2GH_TXAB};
1061 	u16 rf_efuse_5g[2][5] = {{PPG_5GL1_TXA, PPG_5GL2_TXA, PPG_5GM1_TXA,
1062 				  PPG_5GM2_TXA, PPG_5GH1_TXA},
1063 				 {PPG_5GL1_TXB, PPG_5GL2_TXB, PPG_5GM1_TXB,
1064 				  PPG_5GM2_TXB, PPG_5GH1_TXB} };
1065 	bool set = false;
1066 
1067 	for (i = 0; i < ARRAY_SIZE(rf_efuse_2g); i++) {
1068 		rtw_read8_physical_efuse(rtwdev, rf_efuse_2g[i], &pg_pwr);
1069 		if (pg_pwr == EFUSE_READ_FAIL)
1070 			continue;
1071 		set = true;
1072 		bb_gain[RF_PATH_A][i] = FIELD_GET(PPG_2G_A_MASK, pg_pwr);
1073 		bb_gain[RF_PATH_B][i] = FIELD_GET(PPG_2G_B_MASK, pg_pwr);
1074 	}
1075 
1076 	for (i = 0; i < ARRAY_SIZE(rf_efuse_5g[0]); i++) {
1077 		for (path = 0; path < rtwdev->hal.rf_path_num; path++) {
1078 			rtw_read8_physical_efuse(rtwdev, rf_efuse_5g[path][i],
1079 						 &pg_pwr);
1080 			if (pg_pwr == EFUSE_READ_FAIL)
1081 				continue;
1082 			set = true;
1083 			idx = i + ARRAY_SIZE(rf_efuse_2g);
1084 			bb_gain[path][idx] = FIELD_GET(PPG_5G_MASK, pg_pwr);
1085 		}
1086 	}
1087 	if (set)
1088 		rtw8822c_set_power_trim(rtwdev, bb_gain);
1089 
1090 	rtw_write32_mask(rtwdev, REG_DIS_DPD, DIS_DPD_MASK, DIS_DPD_RATEALL);
1091 }
1092 
1093 static void rtw8822c_thermal_trim(struct rtw_dev *rtwdev)
1094 {
1095 	u16 rf_efuse[2] = {PPG_THERMAL_A, PPG_THERMAL_B};
1096 	u8 pg_therm = 0xff, thermal[2] = {0}, path;
1097 
1098 	for (path = 0; path < rtwdev->hal.rf_path_num; path++) {
1099 		rtw_read8_physical_efuse(rtwdev, rf_efuse[path], &pg_therm);
1100 		if (pg_therm == EFUSE_READ_FAIL)
1101 			return;
1102 		/* Efuse value of BIT(0) shall be move to BIT(3), and the value
1103 		 * of BIT(1) to BIT(3) should be right shifted 1 bit.
1104 		 */
1105 		thermal[path] = FIELD_GET(GENMASK(3, 1), pg_therm);
1106 		thermal[path] |= FIELD_PREP(BIT(3), pg_therm & BIT(0));
1107 		rtw_write_rf(rtwdev, path, 0x43, RF_THEMAL_MASK, thermal[path]);
1108 	}
1109 }
1110 
1111 static void rtw8822c_pa_bias(struct rtw_dev *rtwdev)
1112 {
1113 	u16 rf_efuse_2g[2] = {PPG_PABIAS_2GA, PPG_PABIAS_2GB};
1114 	u16 rf_efuse_5g[2] = {PPG_PABIAS_5GA, PPG_PABIAS_5GB};
1115 	u8 pg_pa_bias = 0xff, path;
1116 
1117 	for (path = 0; path < rtwdev->hal.rf_path_num; path++) {
1118 		rtw_read8_physical_efuse(rtwdev, rf_efuse_2g[path],
1119 					 &pg_pa_bias);
1120 		if (pg_pa_bias == EFUSE_READ_FAIL)
1121 			return;
1122 		pg_pa_bias = FIELD_GET(PPG_PABIAS_MASK, pg_pa_bias);
1123 		rtw_write_rf(rtwdev, path, RF_PA, RF_PABIAS_2G_MASK, pg_pa_bias);
1124 	}
1125 	for (path = 0; path < rtwdev->hal.rf_path_num; path++) {
1126 		rtw_read8_physical_efuse(rtwdev, rf_efuse_5g[path],
1127 					 &pg_pa_bias);
1128 		pg_pa_bias = FIELD_GET(PPG_PABIAS_MASK, pg_pa_bias);
1129 		rtw_write_rf(rtwdev, path, RF_PA, RF_PABIAS_5G_MASK, pg_pa_bias);
1130 	}
1131 }
1132 
1133 static void rtw8822c_rfk_handshake(struct rtw_dev *rtwdev, bool is_before_k)
1134 {
1135 	struct rtw_dm_info *dm = &rtwdev->dm_info;
1136 	u8 u1b_tmp;
1137 	u8 u4b_tmp;
1138 	int ret;
1139 
1140 	if (is_before_k) {
1141 		rtw_dbg(rtwdev, RTW_DBG_RFK,
1142 			"[RFK] WiFi / BT RFK handshake start!!\n");
1143 
1144 		if (!dm->is_bt_iqk_timeout) {
1145 			ret = read_poll_timeout(rtw_read32_mask, u4b_tmp,
1146 						u4b_tmp == 0, 20, 600000, false,
1147 						rtwdev, REG_PMC_DBG_CTRL1,
1148 						BITS_PMC_BT_IQK_STS);
1149 			if (ret) {
1150 				rtw_dbg(rtwdev, RTW_DBG_RFK,
1151 					"[RFK] Wait BT IQK finish timeout!!\n");
1152 				dm->is_bt_iqk_timeout = true;
1153 			}
1154 		}
1155 
1156 		rtw_fw_inform_rfk_status(rtwdev, true);
1157 
1158 		ret = read_poll_timeout(rtw_read8_mask, u1b_tmp,
1159 					u1b_tmp == 1, 20, 100000, false,
1160 					rtwdev, REG_ARFR4, BIT_WL_RFK);
1161 		if (ret)
1162 			rtw_dbg(rtwdev, RTW_DBG_RFK,
1163 				"[RFK] Send WiFi RFK start H2C cmd FAIL!!\n");
1164 	} else {
1165 		rtw_fw_inform_rfk_status(rtwdev, false);
1166 		ret = read_poll_timeout(rtw_read8_mask, u1b_tmp,
1167 					u1b_tmp == 1, 20, 100000, false,
1168 					rtwdev, REG_ARFR4,
1169 					BIT_WL_RFK);
1170 		if (ret)
1171 			rtw_dbg(rtwdev, RTW_DBG_RFK,
1172 				"[RFK] Send WiFi RFK finish H2C cmd FAIL!!\n");
1173 
1174 		rtw_dbg(rtwdev, RTW_DBG_RFK,
1175 			"[RFK] WiFi / BT RFK handshake finish!!\n");
1176 	}
1177 }
1178 
1179 static void rtw8822c_rfk_power_save(struct rtw_dev *rtwdev,
1180 				    bool is_power_save)
1181 {
1182 	u8 path;
1183 
1184 	for (path = 0; path < rtwdev->hal.rf_path_num; path++) {
1185 		rtw_write32_mask(rtwdev, REG_NCTL0, BIT_SEL_PATH, path);
1186 		rtw_write32_mask(rtwdev, REG_DPD_CTL1_S0, BIT_PS_EN,
1187 				 is_power_save ? 0 : 1);
1188 	}
1189 }
1190 
1191 static void rtw8822c_txgapk_backup_bb_reg(struct rtw_dev *rtwdev, const u32 reg[],
1192 					  u32 reg_backup[], u32 reg_num)
1193 {
1194 	u32 i;
1195 
1196 	for (i = 0; i < reg_num; i++) {
1197 		reg_backup[i] = rtw_read32(rtwdev, reg[i]);
1198 
1199 		rtw_dbg(rtwdev, RTW_DBG_RFK, "[TXGAPK] Backup BB 0x%x = 0x%x\n",
1200 			reg[i], reg_backup[i]);
1201 	}
1202 }
1203 
1204 static void rtw8822c_txgapk_reload_bb_reg(struct rtw_dev *rtwdev,
1205 					  const u32 reg[], u32 reg_backup[],
1206 					  u32 reg_num)
1207 {
1208 	u32 i;
1209 
1210 	for (i = 0; i < reg_num; i++) {
1211 		rtw_write32(rtwdev, reg[i], reg_backup[i]);
1212 		rtw_dbg(rtwdev, RTW_DBG_RFK, "[TXGAPK] Reload BB 0x%x = 0x%x\n",
1213 			reg[i], reg_backup[i]);
1214 	}
1215 }
1216 
1217 static bool check_rf_status(struct rtw_dev *rtwdev, u8 status)
1218 {
1219 	u8 reg_rf0_a, reg_rf0_b;
1220 
1221 	reg_rf0_a = (u8)rtw_read_rf(rtwdev, RF_PATH_A,
1222 				    RF_MODE_TRXAGC, BIT_RF_MODE);
1223 	reg_rf0_b = (u8)rtw_read_rf(rtwdev, RF_PATH_B,
1224 				    RF_MODE_TRXAGC, BIT_RF_MODE);
1225 
1226 	if (reg_rf0_a == status || reg_rf0_b == status)
1227 		return false;
1228 
1229 	return true;
1230 }
1231 
1232 static void rtw8822c_txgapk_tx_pause(struct rtw_dev *rtwdev)
1233 {
1234 	bool status;
1235 	int ret;
1236 
1237 	rtw_write8(rtwdev, REG_TXPAUSE, BIT_AC_QUEUE);
1238 	rtw_write32_mask(rtwdev, REG_TX_FIFO, BIT_STOP_TX, 0x2);
1239 
1240 	ret = read_poll_timeout_atomic(check_rf_status, status, status,
1241 				       2, 5000, false, rtwdev, 2);
1242 	if (ret)
1243 		rtw_warn(rtwdev, "failed to pause TX\n");
1244 
1245 	rtw_dbg(rtwdev, RTW_DBG_RFK, "[TXGAPK] Tx pause!!\n");
1246 }
1247 
1248 static void rtw8822c_txgapk_bb_dpk(struct rtw_dev *rtwdev, u8 path)
1249 {
1250 	rtw_dbg(rtwdev, RTW_DBG_RFK, "[TXGAPK] ======>%s\n", __func__);
1251 
1252 	rtw_write32_mask(rtwdev, REG_ENFN, BIT_IQK_DPK_EN, 0x1);
1253 	rtw_write32_mask(rtwdev, REG_CH_DELAY_EXTR2,
1254 			 BIT_IQK_DPK_CLOCK_SRC, 0x1);
1255 	rtw_write32_mask(rtwdev, REG_CH_DELAY_EXTR2,
1256 			 BIT_IQK_DPK_RESET_SRC, 0x1);
1257 	rtw_write32_mask(rtwdev, REG_CH_DELAY_EXTR2, BIT_EN_IOQ_IQK_DPK, 0x1);
1258 	rtw_write32_mask(rtwdev, REG_CH_DELAY_EXTR2, BIT_TST_IQK2SET_SRC, 0x0);
1259 	rtw_write32_mask(rtwdev, REG_CCA_OFF, BIT_CCA_ON_BY_PW, 0x1ff);
1260 
1261 	if (path == RF_PATH_A) {
1262 		rtw_write32_mask(rtwdev, REG_RFTXEN_GCK_A,
1263 				 BIT_RFTXEN_GCK_FORCE_ON, 0x1);
1264 		rtw_write32_mask(rtwdev, REG_3WIRE, BIT_DIS_SHARERX_TXGAT, 0x1);
1265 		rtw_write32_mask(rtwdev, REG_DIS_SHARE_RX_A,
1266 				 BIT_TX_SCALE_0DB, 0x1);
1267 		rtw_write32_mask(rtwdev, REG_3WIRE, BIT_3WIRE_EN, 0x0);
1268 	} else if (path == RF_PATH_B) {
1269 		rtw_write32_mask(rtwdev, REG_RFTXEN_GCK_B,
1270 				 BIT_RFTXEN_GCK_FORCE_ON, 0x1);
1271 		rtw_write32_mask(rtwdev, REG_3WIRE2,
1272 				 BIT_DIS_SHARERX_TXGAT, 0x1);
1273 		rtw_write32_mask(rtwdev, REG_DIS_SHARE_RX_B,
1274 				 BIT_TX_SCALE_0DB, 0x1);
1275 		rtw_write32_mask(rtwdev, REG_3WIRE2, BIT_3WIRE_EN, 0x0);
1276 	}
1277 	rtw_write32_mask(rtwdev, REG_CCKSB, BIT_BBMODE, 0x2);
1278 }
1279 
1280 static void rtw8822c_txgapk_afe_dpk(struct rtw_dev *rtwdev, u8 path)
1281 {
1282 	u32 reg;
1283 
1284 	rtw_dbg(rtwdev, RTW_DBG_RFK, "[TXGAPK] ======>%s\n", __func__);
1285 
1286 	if (path == RF_PATH_A) {
1287 		reg = REG_ANAPAR_A;
1288 	} else if (path == RF_PATH_B) {
1289 		reg = REG_ANAPAR_B;
1290 	} else {
1291 		rtw_err(rtwdev, "[TXGAPK] unknown path %d!!\n", path);
1292 		return;
1293 	}
1294 
1295 	rtw_write32_mask(rtwdev, REG_IQK_CTRL, MASKDWORD, MASKDWORD);
1296 	rtw_write32_mask(rtwdev, reg, MASKDWORD, 0x700f0001);
1297 	rtw_write32_mask(rtwdev, reg, MASKDWORD, 0x700f0001);
1298 	rtw_write32_mask(rtwdev, reg, MASKDWORD, 0x701f0001);
1299 	rtw_write32_mask(rtwdev, reg, MASKDWORD, 0x702f0001);
1300 	rtw_write32_mask(rtwdev, reg, MASKDWORD, 0x703f0001);
1301 	rtw_write32_mask(rtwdev, reg, MASKDWORD, 0x704f0001);
1302 	rtw_write32_mask(rtwdev, reg, MASKDWORD, 0x705f0001);
1303 	rtw_write32_mask(rtwdev, reg, MASKDWORD, 0x706f0001);
1304 	rtw_write32_mask(rtwdev, reg, MASKDWORD, 0x707f0001);
1305 	rtw_write32_mask(rtwdev, reg, MASKDWORD, 0x708f0001);
1306 	rtw_write32_mask(rtwdev, reg, MASKDWORD, 0x709f0001);
1307 	rtw_write32_mask(rtwdev, reg, MASKDWORD, 0x70af0001);
1308 	rtw_write32_mask(rtwdev, reg, MASKDWORD, 0x70bf0001);
1309 	rtw_write32_mask(rtwdev, reg, MASKDWORD, 0x70cf0001);
1310 	rtw_write32_mask(rtwdev, reg, MASKDWORD, 0x70df0001);
1311 	rtw_write32_mask(rtwdev, reg, MASKDWORD, 0x70ef0001);
1312 	rtw_write32_mask(rtwdev, reg, MASKDWORD, 0x70ff0001);
1313 	rtw_write32_mask(rtwdev, reg, MASKDWORD, 0x70ff0001);
1314 }
1315 
1316 static void rtw8822c_txgapk_afe_dpk_restore(struct rtw_dev *rtwdev, u8 path)
1317 {
1318 	u32 reg;
1319 
1320 	rtw_dbg(rtwdev, RTW_DBG_RFK, "[TXGAPK] ======>%s\n", __func__);
1321 
1322 	if (path == RF_PATH_A) {
1323 		reg = REG_ANAPAR_A;
1324 	} else if (path == RF_PATH_B) {
1325 		reg = REG_ANAPAR_B;
1326 	} else {
1327 		rtw_err(rtwdev, "[TXGAPK] unknown path %d!!\n", path);
1328 		return;
1329 	}
1330 	rtw_write32_mask(rtwdev, REG_IQK_CTRL, MASKDWORD, 0xffa1005e);
1331 	rtw_write32_mask(rtwdev, reg, MASKDWORD, 0x700b8041);
1332 	rtw_write32_mask(rtwdev, reg, MASKDWORD, 0x70144041);
1333 	rtw_write32_mask(rtwdev, reg, MASKDWORD, 0x70244041);
1334 	rtw_write32_mask(rtwdev, reg, MASKDWORD, 0x70344041);
1335 	rtw_write32_mask(rtwdev, reg, MASKDWORD, 0x70444041);
1336 	rtw_write32_mask(rtwdev, reg, MASKDWORD, 0x705b8041);
1337 	rtw_write32_mask(rtwdev, reg, MASKDWORD, 0x70644041);
1338 	rtw_write32_mask(rtwdev, reg, MASKDWORD, 0x707b8041);
1339 	rtw_write32_mask(rtwdev, reg, MASKDWORD, 0x708b8041);
1340 	rtw_write32_mask(rtwdev, reg, MASKDWORD, 0x709b8041);
1341 	rtw_write32_mask(rtwdev, reg, MASKDWORD, 0x70ab8041);
1342 	rtw_write32_mask(rtwdev, reg, MASKDWORD, 0x70bb8041);
1343 	rtw_write32_mask(rtwdev, reg, MASKDWORD, 0x70cb8041);
1344 	rtw_write32_mask(rtwdev, reg, MASKDWORD, 0x70db8041);
1345 	rtw_write32_mask(rtwdev, reg, MASKDWORD, 0x70eb8041);
1346 	rtw_write32_mask(rtwdev, reg, MASKDWORD, 0x70fb8041);
1347 }
1348 
1349 static void rtw8822c_txgapk_bb_dpk_restore(struct rtw_dev *rtwdev, u8 path)
1350 {
1351 	rtw_dbg(rtwdev, RTW_DBG_RFK, "[TXGAPK] ======>%s\n", __func__);
1352 
1353 	rtw_write_rf(rtwdev, path, RF_DEBUG, BIT_DE_TX_GAIN, 0x0);
1354 	rtw_write_rf(rtwdev, path, RF_DIS_BYPASS_TXBB, BIT_TIA_BYPASS, 0x0);
1355 	rtw_write_rf(rtwdev, path, RF_DIS_BYPASS_TXBB, BIT_TXBB, 0x0);
1356 
1357 	rtw_write32_mask(rtwdev, REG_NCTL0, BIT_SEL_PATH, 0x0);
1358 	rtw_write32_mask(rtwdev, REG_IQK_CTL1, BIT_TX_CFIR, 0x0);
1359 	rtw_write32_mask(rtwdev, REG_SINGLE_TONE_SW, BIT_IRQ_TEST_MODE, 0x0);
1360 	rtw_write32_mask(rtwdev, REG_R_CONFIG, MASKBYTE0, 0x00);
1361 	rtw_write32_mask(rtwdev, REG_NCTL0, BIT_SEL_PATH, 0x1);
1362 	rtw_write32_mask(rtwdev, REG_IQK_CTL1, BIT_TX_CFIR, 0x0);
1363 	rtw_write32_mask(rtwdev, REG_SINGLE_TONE_SW, BIT_IRQ_TEST_MODE, 0x0);
1364 	rtw_write32_mask(rtwdev, REG_R_CONFIG, MASKBYTE0, 0x00);
1365 	rtw_write32_mask(rtwdev, REG_NCTL0, BIT_SEL_PATH, 0x0);
1366 	rtw_write32_mask(rtwdev, REG_CCA_OFF, BIT_CCA_ON_BY_PW, 0x0);
1367 
1368 	if (path == RF_PATH_A) {
1369 		rtw_write32_mask(rtwdev, REG_RFTXEN_GCK_A,
1370 				 BIT_RFTXEN_GCK_FORCE_ON, 0x0);
1371 		rtw_write32_mask(rtwdev, REG_3WIRE, BIT_DIS_SHARERX_TXGAT, 0x0);
1372 		rtw_write32_mask(rtwdev, REG_DIS_SHARE_RX_A,
1373 				 BIT_TX_SCALE_0DB, 0x0);
1374 		rtw_write32_mask(rtwdev, REG_3WIRE, BIT_3WIRE_EN, 0x3);
1375 	} else if (path == RF_PATH_B) {
1376 		rtw_write32_mask(rtwdev, REG_RFTXEN_GCK_B,
1377 				 BIT_RFTXEN_GCK_FORCE_ON, 0x0);
1378 		rtw_write32_mask(rtwdev, REG_3WIRE2,
1379 				 BIT_DIS_SHARERX_TXGAT, 0x0);
1380 		rtw_write32_mask(rtwdev, REG_DIS_SHARE_RX_B,
1381 				 BIT_TX_SCALE_0DB, 0x0);
1382 		rtw_write32_mask(rtwdev, REG_3WIRE2, BIT_3WIRE_EN, 0x3);
1383 	}
1384 
1385 	rtw_write32_mask(rtwdev, REG_CCKSB, BIT_BBMODE, 0x0);
1386 	rtw_write32_mask(rtwdev, REG_IQK_CTL1, BIT_CFIR_EN, 0x5);
1387 }
1388 
1389 static bool _rtw8822c_txgapk_gain_valid(struct rtw_dev *rtwdev, u32 gain)
1390 {
1391 	if ((FIELD_GET(BIT_GAIN_TX_PAD_H, gain) >= 0xc) &&
1392 	    (FIELD_GET(BIT_GAIN_TX_PAD_L, gain) >= 0xe))
1393 		return true;
1394 
1395 	return false;
1396 }
1397 
1398 static void _rtw8822c_txgapk_write_gain_bb_table(struct rtw_dev *rtwdev,
1399 						 u8 band, u8 path)
1400 {
1401 	struct rtw_gapk_info *txgapk = &rtwdev->dm_info.gapk;
1402 	u32 v, tmp_3f = 0;
1403 	u8 gain, check_txgain;
1404 
1405 	rtw_write32_mask(rtwdev, REG_NCTL0, BIT_SEL_PATH, path);
1406 
1407 	switch (band) {
1408 	case RF_BAND_2G_OFDM:
1409 		rtw_write32_mask(rtwdev, REG_TABLE_SEL, BIT_Q_GAIN_SEL, 0x0);
1410 		break;
1411 	case RF_BAND_5G_L:
1412 		rtw_write32_mask(rtwdev, REG_TABLE_SEL, BIT_Q_GAIN_SEL, 0x2);
1413 		break;
1414 	case RF_BAND_5G_M:
1415 		rtw_write32_mask(rtwdev, REG_TABLE_SEL, BIT_Q_GAIN_SEL, 0x3);
1416 		break;
1417 	case RF_BAND_5G_H:
1418 		rtw_write32_mask(rtwdev, REG_TABLE_SEL, BIT_Q_GAIN_SEL, 0x4);
1419 		break;
1420 	default:
1421 		break;
1422 	}
1423 
1424 	rtw_write32_mask(rtwdev, REG_TX_GAIN_SET, MASKBYTE0, 0x88);
1425 
1426 	check_txgain = 0;
1427 	for (gain = 0; gain < RF_GAIN_NUM; gain++) {
1428 		v = txgapk->rf3f_bp[band][gain][path];
1429 		if (_rtw8822c_txgapk_gain_valid(rtwdev, v)) {
1430 			if (!check_txgain) {
1431 				tmp_3f = txgapk->rf3f_bp[band][gain][path];
1432 				check_txgain = 1;
1433 			}
1434 			rtw_dbg(rtwdev, RTW_DBG_RFK,
1435 				"[TXGAPK] tx_gain=0x%03X >= 0xCEX\n",
1436 				txgapk->rf3f_bp[band][gain][path]);
1437 		} else {
1438 			tmp_3f = txgapk->rf3f_bp[band][gain][path];
1439 		}
1440 
1441 		rtw_write32_mask(rtwdev, REG_TABLE_SEL, BIT_Q_GAIN, tmp_3f);
1442 		rtw_write32_mask(rtwdev, REG_TABLE_SEL, BIT_I_GAIN, gain);
1443 		rtw_write32_mask(rtwdev, REG_TABLE_SEL, BIT_GAIN_RST, 0x1);
1444 		rtw_write32_mask(rtwdev, REG_TABLE_SEL, BIT_GAIN_RST, 0x0);
1445 
1446 		rtw_dbg(rtwdev, RTW_DBG_RFK,
1447 			"[TXGAPK] Band=%d 0x1b98[11:0]=0x%03X path=%d\n",
1448 			band, tmp_3f, path);
1449 	}
1450 }
1451 
1452 static void rtw8822c_txgapk_write_gain_bb_table(struct rtw_dev *rtwdev)
1453 {
1454 	u8 path, band;
1455 
1456 	rtw_dbg(rtwdev, RTW_DBG_RFK, "[TXGAPK] ======>%s channel=%d\n",
1457 		__func__, rtwdev->dm_info.gapk.channel);
1458 
1459 	for (band = 0; band < RF_BAND_MAX; band++) {
1460 		for (path = 0; path < rtwdev->hal.rf_path_num; path++) {
1461 			_rtw8822c_txgapk_write_gain_bb_table(rtwdev,
1462 							     band, path);
1463 		}
1464 	}
1465 }
1466 
1467 static void rtw8822c_txgapk_read_offset(struct rtw_dev *rtwdev, u8 path)
1468 {
1469 	static const u32 cfg1_1b00[2] = {0x00000d18, 0x00000d2a};
1470 	static const u32 cfg2_1b00[2] = {0x00000d19, 0x00000d2b};
1471 	static const u32 set_pi[2] = {REG_RSV_CTRL, REG_WLRF1};
1472 	static const u32 path_setting[2] = {REG_ORITXCODE, REG_ORITXCODE2};
1473 	struct rtw_gapk_info *txgapk = &rtwdev->dm_info.gapk;
1474 	u8 channel = txgapk->channel;
1475 	u32 val;
1476 	int i;
1477 
1478 	if (path >= ARRAY_SIZE(cfg1_1b00) ||
1479 	    path >= ARRAY_SIZE(cfg2_1b00) ||
1480 	    path >= ARRAY_SIZE(set_pi) ||
1481 	    path >= ARRAY_SIZE(path_setting)) {
1482 		rtw_warn(rtwdev, "[TXGAPK] wrong path %d\n", path);
1483 		return;
1484 	}
1485 
1486 	rtw_write32_mask(rtwdev, REG_ANTMAP0, BIT_ANT_PATH, path + 1);
1487 	rtw_write32_mask(rtwdev, REG_TXLGMAP, MASKDWORD, 0xe4e40000);
1488 	rtw_write32_mask(rtwdev, REG_TXANTSEG, BIT_ANTSEG, 0x3);
1489 	rtw_write32_mask(rtwdev, path_setting[path], MASK20BITS, 0x33312);
1490 	rtw_write32_mask(rtwdev, path_setting[path], BIT_PATH_EN, 0x1);
1491 	rtw_write32_mask(rtwdev, set_pi[path], BITS_RFC_DIRECT, 0x0);
1492 	rtw_write_rf(rtwdev, path, RF_LUTDBG, BIT_TXA_TANK, 0x1);
1493 	rtw_write_rf(rtwdev, path, RF_IDAC, BIT_TX_MODE, 0x820);
1494 	rtw_write32_mask(rtwdev, REG_NCTL0, BIT_SEL_PATH, path);
1495 	rtw_write32_mask(rtwdev, REG_IQKSTAT, MASKBYTE0, 0x0);
1496 
1497 	rtw_write32_mask(rtwdev, REG_TX_TONE_IDX, MASKBYTE0, 0x018);
1498 	fsleep(1000);
1499 	if (channel >= 1 && channel <= 14)
1500 		rtw_write32_mask(rtwdev, REG_R_CONFIG, MASKBYTE0, BIT_2G_SWING);
1501 	else
1502 		rtw_write32_mask(rtwdev, REG_R_CONFIG, MASKBYTE0, BIT_5G_SWING);
1503 	fsleep(1000);
1504 
1505 	rtw_write32_mask(rtwdev, REG_NCTL0, MASKDWORD, cfg1_1b00[path]);
1506 	rtw_write32_mask(rtwdev, REG_NCTL0, MASKDWORD, cfg2_1b00[path]);
1507 
1508 	read_poll_timeout(rtw_read32_mask, val,
1509 			  val == 0x55, 1000, 100000, false,
1510 			  rtwdev, REG_RPT_CIP, BIT_RPT_CIP_STATUS);
1511 
1512 	rtw_write32_mask(rtwdev, set_pi[path], BITS_RFC_DIRECT, 0x2);
1513 	rtw_write32_mask(rtwdev, REG_NCTL0, BIT_SEL_PATH, path);
1514 	rtw_write32_mask(rtwdev, REG_RXSRAM_CTL, BIT_RPT_EN, 0x1);
1515 	rtw_write32_mask(rtwdev, REG_RXSRAM_CTL, BIT_RPT_SEL, 0x12);
1516 	rtw_write32_mask(rtwdev, REG_TX_GAIN_SET, BIT_GAPK_RPT_IDX, 0x3);
1517 	val = rtw_read32(rtwdev, REG_STAT_RPT);
1518 
1519 	txgapk->offset[0][path] = (s8)FIELD_GET(BIT_GAPK_RPT0, val);
1520 	txgapk->offset[1][path] = (s8)FIELD_GET(BIT_GAPK_RPT1, val);
1521 	txgapk->offset[2][path] = (s8)FIELD_GET(BIT_GAPK_RPT2, val);
1522 	txgapk->offset[3][path] = (s8)FIELD_GET(BIT_GAPK_RPT3, val);
1523 	txgapk->offset[4][path] = (s8)FIELD_GET(BIT_GAPK_RPT4, val);
1524 	txgapk->offset[5][path] = (s8)FIELD_GET(BIT_GAPK_RPT5, val);
1525 	txgapk->offset[6][path] = (s8)FIELD_GET(BIT_GAPK_RPT6, val);
1526 	txgapk->offset[7][path] = (s8)FIELD_GET(BIT_GAPK_RPT7, val);
1527 
1528 	rtw_write32_mask(rtwdev, REG_TX_GAIN_SET, BIT_GAPK_RPT_IDX, 0x4);
1529 	val = rtw_read32(rtwdev, REG_STAT_RPT);
1530 
1531 	txgapk->offset[8][path] = (s8)FIELD_GET(BIT_GAPK_RPT0, val);
1532 	txgapk->offset[9][path] = (s8)FIELD_GET(BIT_GAPK_RPT1, val);
1533 
1534 	for (i = 0; i < RF_HW_OFFSET_NUM; i++)
1535 		if (txgapk->offset[i][path] & BIT(3))
1536 			txgapk->offset[i][path] = txgapk->offset[i][path] |
1537 						  0xf0;
1538 	for (i = 0; i < RF_HW_OFFSET_NUM; i++)
1539 		rtw_dbg(rtwdev, RTW_DBG_RFK,
1540 			"[TXGAPK] offset %d %d path=%d\n",
1541 			txgapk->offset[i][path], i, path);
1542 }
1543 
1544 static void rtw8822c_txgapk_calculate_offset(struct rtw_dev *rtwdev, u8 path)
1545 {
1546 	static const u32 bb_reg[] = {REG_ANTMAP0, REG_TXLGMAP, REG_TXANTSEG,
1547 				     REG_ORITXCODE, REG_ORITXCODE2};
1548 	struct rtw_gapk_info *txgapk = &rtwdev->dm_info.gapk;
1549 	u8 channel = txgapk->channel;
1550 	u32 reg_backup[ARRAY_SIZE(bb_reg)] = {0};
1551 
1552 	rtw_dbg(rtwdev, RTW_DBG_RFK, "[TXGAPK] ======>%s channel=%d\n",
1553 		__func__, channel);
1554 
1555 	rtw8822c_txgapk_backup_bb_reg(rtwdev, bb_reg,
1556 				      reg_backup, ARRAY_SIZE(bb_reg));
1557 
1558 	if (channel >= 1 && channel <= 14) {
1559 		rtw_write32_mask(rtwdev,
1560 				 REG_SINGLE_TONE_SW, BIT_IRQ_TEST_MODE, 0x0);
1561 		rtw_write32_mask(rtwdev, REG_NCTL0, BIT_SEL_PATH, path);
1562 		rtw_write32_mask(rtwdev, REG_R_CONFIG, BIT_IQ_SWITCH, 0x3f);
1563 		rtw_write32_mask(rtwdev, REG_IQK_CTL1, BIT_TX_CFIR, 0x0);
1564 		rtw_write_rf(rtwdev, path, RF_DEBUG, BIT_DE_TX_GAIN, 0x1);
1565 		rtw_write_rf(rtwdev, path, RF_MODE_TRXAGC, RFREG_MASK, 0x5000f);
1566 		rtw_write_rf(rtwdev, path, RF_TX_GAIN_OFFSET, BIT_RF_GAIN, 0x0);
1567 		rtw_write_rf(rtwdev, path, RF_RXG_GAIN, BIT_RXG_GAIN, 0x1);
1568 		rtw_write_rf(rtwdev, path, RF_MODE_TRXAGC, BIT_RXAGC, 0x0f);
1569 		rtw_write_rf(rtwdev, path, RF_DEBUG, BIT_DE_TRXBW, 0x1);
1570 		rtw_write_rf(rtwdev, path, RF_BW_TRXBB, BIT_BW_TXBB, 0x1);
1571 		rtw_write_rf(rtwdev, path, RF_BW_TRXBB, BIT_BW_RXBB, 0x0);
1572 		rtw_write_rf(rtwdev, path, RF_EXT_TIA_BW, BIT_PW_EXT_TIA, 0x1);
1573 
1574 		rtw_write32_mask(rtwdev, REG_IQKSTAT, MASKBYTE0, 0x00);
1575 		rtw_write32_mask(rtwdev, REG_TABLE_SEL, BIT_Q_GAIN_SEL, 0x0);
1576 
1577 		rtw8822c_txgapk_read_offset(rtwdev, path);
1578 		rtw_dbg(rtwdev, RTW_DBG_RFK, "=============================\n");
1579 
1580 	} else {
1581 		rtw_write32_mask(rtwdev,
1582 				 REG_SINGLE_TONE_SW, BIT_IRQ_TEST_MODE, 0x0);
1583 		rtw_write32_mask(rtwdev, REG_NCTL0, BIT_SEL_PATH, path);
1584 		rtw_write32_mask(rtwdev, REG_R_CONFIG, BIT_IQ_SWITCH, 0x3f);
1585 		rtw_write32_mask(rtwdev, REG_IQK_CTL1, BIT_TX_CFIR, 0x0);
1586 		rtw_write_rf(rtwdev, path, RF_DEBUG, BIT_DE_TX_GAIN, 0x1);
1587 		rtw_write_rf(rtwdev, path, RF_MODE_TRXAGC, RFREG_MASK, 0x50011);
1588 		rtw_write_rf(rtwdev, path, RF_TXA_LB_SW, BIT_TXA_LB_ATT, 0x3);
1589 		rtw_write_rf(rtwdev, path, RF_TXA_LB_SW, BIT_LB_ATT, 0x3);
1590 		rtw_write_rf(rtwdev, path, RF_TXA_LB_SW, BIT_LB_SW, 0x1);
1591 		rtw_write_rf(rtwdev, path,
1592 			     RF_RXA_MIX_GAIN, BIT_RXA_MIX_GAIN, 0x2);
1593 		rtw_write_rf(rtwdev, path, RF_MODE_TRXAGC, BIT_RXAGC, 0x12);
1594 		rtw_write_rf(rtwdev, path, RF_DEBUG, BIT_DE_TRXBW, 0x1);
1595 		rtw_write_rf(rtwdev, path, RF_BW_TRXBB, BIT_BW_RXBB, 0x0);
1596 		rtw_write_rf(rtwdev, path, RF_EXT_TIA_BW, BIT_PW_EXT_TIA, 0x1);
1597 		rtw_write_rf(rtwdev, path, RF_MODE_TRXAGC, BIT_RF_MODE, 0x5);
1598 
1599 		rtw_write32_mask(rtwdev, REG_IQKSTAT, MASKBYTE0, 0x0);
1600 
1601 		if (channel >= 36 && channel <= 64)
1602 			rtw_write32_mask(rtwdev,
1603 					 REG_TABLE_SEL, BIT_Q_GAIN_SEL, 0x2);
1604 		else if (channel >= 100 && channel <= 144)
1605 			rtw_write32_mask(rtwdev,
1606 					 REG_TABLE_SEL, BIT_Q_GAIN_SEL, 0x3);
1607 		else if (channel >= 149 && channel <= 177)
1608 			rtw_write32_mask(rtwdev,
1609 					 REG_TABLE_SEL, BIT_Q_GAIN_SEL, 0x4);
1610 
1611 		rtw8822c_txgapk_read_offset(rtwdev, path);
1612 		rtw_dbg(rtwdev, RTW_DBG_RFK, "=============================\n");
1613 	}
1614 	rtw8822c_txgapk_reload_bb_reg(rtwdev, bb_reg,
1615 				      reg_backup, ARRAY_SIZE(bb_reg));
1616 }
1617 
1618 static void rtw8822c_txgapk_rf_restore(struct rtw_dev *rtwdev, u8 path)
1619 {
1620 	rtw_dbg(rtwdev, RTW_DBG_RFK, "[TXGAPK] ======>%s\n", __func__);
1621 
1622 	if (path >= rtwdev->hal.rf_path_num)
1623 		return;
1624 
1625 	rtw_write_rf(rtwdev, path, RF_MODE_TRXAGC, BIT_RF_MODE, 0x3);
1626 	rtw_write_rf(rtwdev, path, RF_DEBUG, BIT_DE_TRXBW, 0x0);
1627 	rtw_write_rf(rtwdev, path, RF_EXT_TIA_BW, BIT_PW_EXT_TIA, 0x0);
1628 }
1629 
1630 static u32 rtw8822c_txgapk_cal_gain(struct rtw_dev *rtwdev, u32 gain, s8 offset)
1631 {
1632 	u32 gain_x2, new_gain;
1633 
1634 	rtw_dbg(rtwdev, RTW_DBG_RFK, "[TXGAPK] ======>%s\n", __func__);
1635 
1636 	if (_rtw8822c_txgapk_gain_valid(rtwdev, gain)) {
1637 		new_gain = gain;
1638 		rtw_dbg(rtwdev, RTW_DBG_RFK,
1639 			"[TXGAPK] gain=0x%03X(>=0xCEX) offset=%d new_gain=0x%03X\n",
1640 			gain, offset, new_gain);
1641 		return new_gain;
1642 	}
1643 
1644 	gain_x2 = (gain << 1) + offset;
1645 	new_gain = (gain_x2 >> 1) | (gain_x2 & BIT(0) ? BIT_GAIN_EXT : 0);
1646 
1647 	rtw_dbg(rtwdev, RTW_DBG_RFK,
1648 		"[TXGAPK] gain=0x%X offset=%d new_gain=0x%X\n",
1649 		gain, offset, new_gain);
1650 
1651 	return new_gain;
1652 }
1653 
1654 static void rtw8822c_txgapk_write_tx_gain(struct rtw_dev *rtwdev)
1655 {
1656 	struct rtw_gapk_info *txgapk = &rtwdev->dm_info.gapk;
1657 	u32 i, j, tmp = 0x20, tmp_3f, v;
1658 	s8 offset_tmp[RF_GAIN_NUM] = {0};
1659 	u8 path, band = RF_BAND_2G_OFDM, channel = txgapk->channel;
1660 
1661 	rtw_dbg(rtwdev, RTW_DBG_RFK, "[TXGAPK] ======>%s\n", __func__);
1662 
1663 	if (channel >= 1 && channel <= 14) {
1664 		tmp = 0x20;
1665 		band = RF_BAND_2G_OFDM;
1666 	} else if (channel >= 36 && channel <= 64) {
1667 		tmp = 0x200;
1668 		band = RF_BAND_5G_L;
1669 	} else if (channel >= 100 && channel <= 144) {
1670 		tmp = 0x280;
1671 		band = RF_BAND_5G_M;
1672 	} else if (channel >= 149 && channel <= 177) {
1673 		tmp = 0x300;
1674 		band = RF_BAND_5G_H;
1675 	} else {
1676 		rtw_err(rtwdev, "[TXGAPK] unknown channel %d!!\n", channel);
1677 		return;
1678 	}
1679 
1680 	for (path = 0; path < rtwdev->hal.rf_path_num; path++) {
1681 		for (i = 0; i < RF_GAIN_NUM; i++) {
1682 			offset_tmp[i] = 0;
1683 			for (j = i; j < RF_GAIN_NUM; j++) {
1684 				v = txgapk->rf3f_bp[band][j][path];
1685 				if (_rtw8822c_txgapk_gain_valid(rtwdev, v))
1686 					continue;
1687 
1688 				offset_tmp[i] += txgapk->offset[j][path];
1689 				txgapk->fianl_offset[i][path] = offset_tmp[i];
1690 			}
1691 
1692 			v = txgapk->rf3f_bp[band][i][path];
1693 			if (_rtw8822c_txgapk_gain_valid(rtwdev, v)) {
1694 				rtw_dbg(rtwdev, RTW_DBG_RFK,
1695 					"[TXGAPK] tx_gain=0x%03X >= 0xCEX\n",
1696 					txgapk->rf3f_bp[band][i][path]);
1697 			} else {
1698 				txgapk->rf3f_fs[path][i] = offset_tmp[i];
1699 				rtw_dbg(rtwdev, RTW_DBG_RFK,
1700 					"[TXGAPK] offset %d %d\n",
1701 					offset_tmp[i], i);
1702 			}
1703 		}
1704 
1705 		rtw_write_rf(rtwdev, path, RF_LUTWE2, RFREG_MASK, 0x10000);
1706 		for (i = 0; i < RF_GAIN_NUM; i++) {
1707 			rtw_write_rf(rtwdev, path,
1708 				     RF_LUTWA, RFREG_MASK, tmp + i);
1709 
1710 			tmp_3f = rtw8822c_txgapk_cal_gain(rtwdev,
1711 							  txgapk->rf3f_bp[band][i][path],
1712 							  offset_tmp[i]);
1713 			rtw_write_rf(rtwdev, path, RF_LUTWD0,
1714 				     BIT_GAIN_EXT | BIT_DATA_L, tmp_3f);
1715 
1716 			rtw_dbg(rtwdev, RTW_DBG_RFK,
1717 				"[TXGAPK] 0x33=0x%05X 0x3f=0x%04X\n",
1718 				tmp + i, tmp_3f);
1719 		}
1720 		rtw_write_rf(rtwdev, path, RF_LUTWE2, RFREG_MASK, 0x0);
1721 	}
1722 }
1723 
1724 static void rtw8822c_txgapk_save_all_tx_gain_table(struct rtw_dev *rtwdev)
1725 {
1726 	struct rtw_gapk_info *txgapk = &rtwdev->dm_info.gapk;
1727 	static const u32 three_wire[2] = {REG_3WIRE, REG_3WIRE2};
1728 	static const u8 ch_num[RF_BAND_MAX] = {1, 1, 36, 100, 149};
1729 	static const u8 band_num[RF_BAND_MAX] = {0x0, 0x0, 0x1, 0x3, 0x5};
1730 	static const u8 cck[RF_BAND_MAX] = {0x1, 0x0, 0x0, 0x0, 0x0};
1731 	u8 path, band, gain, rf0_idx;
1732 	u32 rf18, v;
1733 
1734 	if (rtwdev->dm_info.dm_flags & BIT(RTW_DM_CAP_TXGAPK))
1735 		return;
1736 
1737 	rtw_dbg(rtwdev, RTW_DBG_RFK, "[TXGAPK] ======>%s\n", __func__);
1738 
1739 	if (txgapk->read_txgain == 1) {
1740 		rtw_dbg(rtwdev, RTW_DBG_RFK,
1741 			"[TXGAPK] Already Read txgapk->read_txgain return!!!\n");
1742 		rtw8822c_txgapk_write_gain_bb_table(rtwdev);
1743 		return;
1744 	}
1745 
1746 	for (band = 0; band < RF_BAND_MAX; band++) {
1747 		for (path = 0; path < rtwdev->hal.rf_path_num; path++) {
1748 			rf18 = rtw_read_rf(rtwdev, path, RF_CFGCH, RFREG_MASK);
1749 
1750 			rtw_write32_mask(rtwdev,
1751 					 three_wire[path], BIT_3WIRE_EN, 0x0);
1752 			rtw_write_rf(rtwdev, path,
1753 				     RF_CFGCH, MASKBYTE0, ch_num[band]);
1754 			rtw_write_rf(rtwdev, path,
1755 				     RF_CFGCH, BIT_BAND, band_num[band]);
1756 			rtw_write_rf(rtwdev, path,
1757 				     RF_BW_TRXBB, BIT_DBG_CCK_CCA, cck[band]);
1758 			rtw_write_rf(rtwdev, path,
1759 				     RF_BW_TRXBB, BIT_TX_CCK_IND, cck[band]);
1760 			gain = 0;
1761 			for (rf0_idx = 1; rf0_idx < 32; rf0_idx += 3) {
1762 				rtw_write_rf(rtwdev, path, RF_MODE_TRXAGC,
1763 					     MASKBYTE0, rf0_idx);
1764 				v = rtw_read_rf(rtwdev, path,
1765 						RF_TX_RESULT, RFREG_MASK);
1766 				txgapk->rf3f_bp[band][gain][path] = v & BIT_DATA_L;
1767 
1768 				rtw_dbg(rtwdev, RTW_DBG_RFK,
1769 					"[TXGAPK] 0x5f=0x%03X band=%d path=%d\n",
1770 					txgapk->rf3f_bp[band][gain][path],
1771 					band, path);
1772 				gain++;
1773 			}
1774 			rtw_write_rf(rtwdev, path, RF_CFGCH, RFREG_MASK, rf18);
1775 			rtw_write32_mask(rtwdev,
1776 					 three_wire[path], BIT_3WIRE_EN, 0x3);
1777 		}
1778 	}
1779 	rtw8822c_txgapk_write_gain_bb_table(rtwdev);
1780 	txgapk->read_txgain = 1;
1781 }
1782 
1783 static void rtw8822c_txgapk(struct rtw_dev *rtwdev)
1784 {
1785 	static const u32 bb_reg[2] = {REG_TX_PTCL_CTRL, REG_TX_FIFO};
1786 	struct rtw_gapk_info *txgapk = &rtwdev->dm_info.gapk;
1787 	u32 bb_reg_backup[2];
1788 	u8 path;
1789 
1790 	rtw_dbg(rtwdev, RTW_DBG_RFK, "[TXGAPK] ======>%s\n", __func__);
1791 
1792 	rtw8822c_txgapk_save_all_tx_gain_table(rtwdev);
1793 
1794 	if (txgapk->read_txgain == 0) {
1795 		rtw_dbg(rtwdev, RTW_DBG_RFK,
1796 			"[TXGAPK] txgapk->read_txgain == 0 return!!!\n");
1797 		return;
1798 	}
1799 
1800 	if (rtwdev->efuse.power_track_type >= 4 &&
1801 	    rtwdev->efuse.power_track_type <= 7) {
1802 		rtw_dbg(rtwdev, RTW_DBG_RFK,
1803 			"[TXGAPK] Normal Mode in TSSI mode. return!!!\n");
1804 		return;
1805 	}
1806 
1807 	rtw8822c_txgapk_backup_bb_reg(rtwdev, bb_reg,
1808 				      bb_reg_backup, ARRAY_SIZE(bb_reg));
1809 	rtw8822c_txgapk_tx_pause(rtwdev);
1810 	for (path = 0; path < rtwdev->hal.rf_path_num; path++) {
1811 		txgapk->channel = rtw_read_rf(rtwdev, path,
1812 					      RF_CFGCH, RFREG_MASK) & MASKBYTE0;
1813 		rtw8822c_txgapk_bb_dpk(rtwdev, path);
1814 		rtw8822c_txgapk_afe_dpk(rtwdev, path);
1815 		rtw8822c_txgapk_calculate_offset(rtwdev, path);
1816 		rtw8822c_txgapk_rf_restore(rtwdev, path);
1817 		rtw8822c_txgapk_afe_dpk_restore(rtwdev, path);
1818 		rtw8822c_txgapk_bb_dpk_restore(rtwdev, path);
1819 	}
1820 	rtw8822c_txgapk_write_tx_gain(rtwdev);
1821 	rtw8822c_txgapk_reload_bb_reg(rtwdev, bb_reg,
1822 				      bb_reg_backup, ARRAY_SIZE(bb_reg));
1823 }
1824 
1825 static void rtw8822c_do_gapk(struct rtw_dev *rtwdev)
1826 {
1827 	struct rtw_dm_info *dm = &rtwdev->dm_info;
1828 
1829 	if (dm->dm_flags & BIT(RTW_DM_CAP_TXGAPK)) {
1830 		rtw_dbg(rtwdev, RTW_DBG_RFK, "[TXGAPK] feature disable!!!\n");
1831 		return;
1832 	}
1833 	rtw8822c_rfk_handshake(rtwdev, true);
1834 	rtw8822c_txgapk(rtwdev);
1835 	rtw8822c_rfk_handshake(rtwdev, false);
1836 }
1837 
1838 static void rtw8822c_rf_init(struct rtw_dev *rtwdev)
1839 {
1840 	rtw8822c_rf_dac_cal(rtwdev);
1841 	rtw8822c_rf_x2_check(rtwdev);
1842 	rtw8822c_thermal_trim(rtwdev);
1843 	rtw8822c_power_trim(rtwdev);
1844 	rtw8822c_pa_bias(rtwdev);
1845 }
1846 
1847 static void rtw8822c_pwrtrack_init(struct rtw_dev *rtwdev)
1848 {
1849 	struct rtw_dm_info *dm_info = &rtwdev->dm_info;
1850 	u8 path;
1851 
1852 	for (path = RF_PATH_A; path < RTW_RF_PATH_MAX; path++) {
1853 		dm_info->delta_power_index[path] = 0;
1854 		ewma_thermal_init(&dm_info->avg_thermal[path]);
1855 		dm_info->thermal_avg[path] = 0xff;
1856 	}
1857 
1858 	dm_info->pwr_trk_triggered = false;
1859 	dm_info->thermal_meter_k = rtwdev->efuse.thermal_meter_k;
1860 	dm_info->thermal_meter_lck = rtwdev->efuse.thermal_meter_k;
1861 }
1862 
1863 static void rtw8822c_phy_set_param(struct rtw_dev *rtwdev)
1864 {
1865 	struct rtw_dm_info *dm_info = &rtwdev->dm_info;
1866 	struct rtw_hal *hal = &rtwdev->hal;
1867 	u8 crystal_cap;
1868 	u8 cck_gi_u_bnd_msb = 0;
1869 	u8 cck_gi_u_bnd_lsb = 0;
1870 	u8 cck_gi_l_bnd_msb = 0;
1871 	u8 cck_gi_l_bnd_lsb = 0;
1872 	bool is_tx2_path;
1873 
1874 	/* power on BB/RF domain */
1875 	rtw_write8_set(rtwdev, REG_SYS_FUNC_EN,
1876 		       BIT_FEN_BB_GLB_RST | BIT_FEN_BB_RSTB);
1877 	rtw_write8_set(rtwdev, REG_RF_CTRL,
1878 		       BIT_RF_EN | BIT_RF_RSTB | BIT_RF_SDM_RSTB);
1879 	rtw_write32_set(rtwdev, REG_WLRF1, BIT_WLRF1_BBRF_EN);
1880 
1881 	/* disable low rate DPD */
1882 	rtw_write32_mask(rtwdev, REG_DIS_DPD, DIS_DPD_MASK, DIS_DPD_RATEALL);
1883 
1884 	/* pre init before header files config */
1885 	rtw8822c_header_file_init(rtwdev, true);
1886 
1887 	rtw_phy_load_tables(rtwdev);
1888 
1889 	crystal_cap = rtwdev->efuse.crystal_cap & 0x7f;
1890 	rtw_write32_mask(rtwdev, REG_ANAPAR_XTAL_0, 0xfffc00,
1891 			 crystal_cap | (crystal_cap << 7));
1892 
1893 	/* post init after header files config */
1894 	rtw8822c_header_file_init(rtwdev, false);
1895 
1896 	is_tx2_path = false;
1897 	rtw8822c_config_trx_mode(rtwdev, hal->antenna_tx, hal->antenna_rx,
1898 				 is_tx2_path);
1899 	rtw_phy_init(rtwdev);
1900 
1901 	cck_gi_u_bnd_msb = (u8)rtw_read32_mask(rtwdev, 0x1a98, 0xc000);
1902 	cck_gi_u_bnd_lsb = (u8)rtw_read32_mask(rtwdev, 0x1aa8, 0xf0000);
1903 	cck_gi_l_bnd_msb = (u8)rtw_read32_mask(rtwdev, 0x1a98, 0xc0);
1904 	cck_gi_l_bnd_lsb = (u8)rtw_read32_mask(rtwdev, 0x1a70, 0x0f000000);
1905 
1906 	dm_info->cck_gi_u_bnd = ((cck_gi_u_bnd_msb << 4) | (cck_gi_u_bnd_lsb));
1907 	dm_info->cck_gi_l_bnd = ((cck_gi_l_bnd_msb << 4) | (cck_gi_l_bnd_lsb));
1908 
1909 	rtw8822c_rf_init(rtwdev);
1910 	rtw8822c_pwrtrack_init(rtwdev);
1911 
1912 	rtw_bf_phy_init(rtwdev);
1913 }
1914 
1915 #define WLAN_TXQ_RPT_EN		0x1F
1916 #define WLAN_SLOT_TIME		0x09
1917 #define WLAN_PIFS_TIME		0x1C
1918 #define WLAN_SIFS_CCK_CONT_TX	0x0A
1919 #define WLAN_SIFS_OFDM_CONT_TX	0x0E
1920 #define WLAN_SIFS_CCK_TRX	0x0A
1921 #define WLAN_SIFS_OFDM_TRX	0x10
1922 #define WLAN_NAV_MAX		0xC8
1923 #define WLAN_RDG_NAV		0x05
1924 #define WLAN_TXOP_NAV		0x1B
1925 #define WLAN_CCK_RX_TSF		0x30
1926 #define WLAN_OFDM_RX_TSF	0x30
1927 #define WLAN_TBTT_PROHIBIT	0x04 /* unit : 32us */
1928 #define WLAN_TBTT_HOLD_TIME	0x064 /* unit : 32us */
1929 #define WLAN_DRV_EARLY_INT	0x04
1930 #define WLAN_BCN_CTRL_CLT0	0x10
1931 #define WLAN_BCN_DMA_TIME	0x02
1932 #define WLAN_BCN_MAX_ERR	0xFF
1933 #define WLAN_SIFS_CCK_DUR_TUNE	0x0A
1934 #define WLAN_SIFS_OFDM_DUR_TUNE	0x10
1935 #define WLAN_SIFS_CCK_CTX	0x0A
1936 #define WLAN_SIFS_CCK_IRX	0x0A
1937 #define WLAN_SIFS_OFDM_CTX	0x0E
1938 #define WLAN_SIFS_OFDM_IRX	0x0E
1939 #define WLAN_EIFS_DUR_TUNE	0x40
1940 #define WLAN_EDCA_VO_PARAM	0x002FA226
1941 #define WLAN_EDCA_VI_PARAM	0x005EA328
1942 #define WLAN_EDCA_BE_PARAM	0x005EA42B
1943 #define WLAN_EDCA_BK_PARAM	0x0000A44F
1944 
1945 #define WLAN_RX_FILTER0		0xFFFFFFFF
1946 #define WLAN_RX_FILTER2		0xFFFF
1947 #define WLAN_RCR_CFG		0xE400220E
1948 #define WLAN_RXPKT_MAX_SZ	12288
1949 #define WLAN_RXPKT_MAX_SZ_512	(WLAN_RXPKT_MAX_SZ >> 9)
1950 
1951 #define WLAN_AMPDU_MAX_TIME		0x70
1952 #define WLAN_RTS_LEN_TH			0xFF
1953 #define WLAN_RTS_TX_TIME_TH		0x08
1954 #define WLAN_MAX_AGG_PKT_LIMIT		0x3f
1955 #define WLAN_RTS_MAX_AGG_PKT_LIMIT	0x3f
1956 #define WLAN_PRE_TXCNT_TIME_TH		0x1E0
1957 #define FAST_EDCA_VO_TH		0x06
1958 #define FAST_EDCA_VI_TH		0x06
1959 #define FAST_EDCA_BE_TH		0x06
1960 #define FAST_EDCA_BK_TH		0x06
1961 #define WLAN_BAR_RETRY_LIMIT		0x01
1962 #define WLAN_BAR_ACK_TYPE		0x05
1963 #define WLAN_RA_TRY_RATE_AGG_LIMIT	0x08
1964 #define WLAN_RESP_TXRATE		0x84
1965 #define WLAN_ACK_TO			0x21
1966 #define WLAN_ACK_TO_CCK			0x6A
1967 #define WLAN_DATA_RATE_FB_CNT_1_4	0x01000000
1968 #define WLAN_DATA_RATE_FB_CNT_5_8	0x08070504
1969 #define WLAN_RTS_RATE_FB_CNT_5_8	0x08070504
1970 #define WLAN_DATA_RATE_FB_RATE0		0xFE01F010
1971 #define WLAN_DATA_RATE_FB_RATE0_H	0x40000000
1972 #define WLAN_RTS_RATE_FB_RATE1		0x003FF010
1973 #define WLAN_RTS_RATE_FB_RATE1_H	0x40000000
1974 #define WLAN_RTS_RATE_FB_RATE4		0x0600F010
1975 #define WLAN_RTS_RATE_FB_RATE4_H	0x400003E0
1976 #define WLAN_RTS_RATE_FB_RATE5		0x0600F015
1977 #define WLAN_RTS_RATE_FB_RATE5_H	0x000000E0
1978 #define WLAN_MULTI_ADDR			0xFFFFFFFF
1979 
1980 #define WLAN_TX_FUNC_CFG1		0x30
1981 #define WLAN_TX_FUNC_CFG2		0x30
1982 #define WLAN_MAC_OPT_NORM_FUNC1		0x98
1983 #define WLAN_MAC_OPT_LB_FUNC1		0x80
1984 #define WLAN_MAC_OPT_FUNC2		0xb0810041
1985 #define WLAN_MAC_INT_MIG_CFG		0x33330000
1986 
1987 #define WLAN_SIFS_CFG	(WLAN_SIFS_CCK_CONT_TX | \
1988 			(WLAN_SIFS_OFDM_CONT_TX << BIT_SHIFT_SIFS_OFDM_CTX) | \
1989 			(WLAN_SIFS_CCK_TRX << BIT_SHIFT_SIFS_CCK_TRX) | \
1990 			(WLAN_SIFS_OFDM_TRX << BIT_SHIFT_SIFS_OFDM_TRX))
1991 
1992 #define WLAN_SIFS_DUR_TUNE	(WLAN_SIFS_CCK_DUR_TUNE | \
1993 				(WLAN_SIFS_OFDM_DUR_TUNE << 8))
1994 
1995 #define WLAN_TBTT_TIME	(WLAN_TBTT_PROHIBIT |\
1996 			(WLAN_TBTT_HOLD_TIME << BIT_SHIFT_TBTT_HOLD_TIME_AP))
1997 
1998 #define WLAN_NAV_CFG		(WLAN_RDG_NAV | (WLAN_TXOP_NAV << 16))
1999 #define WLAN_RX_TSF_CFG		(WLAN_CCK_RX_TSF | (WLAN_OFDM_RX_TSF) << 8)
2000 
2001 #define MAC_CLK_SPEED	80 /* 80M */
2002 #define EFUSE_PCB_INFO_OFFSET	0xCA
2003 
2004 static int rtw8822c_mac_init(struct rtw_dev *rtwdev)
2005 {
2006 	u8 value8;
2007 	u16 value16;
2008 	u32 value32;
2009 	u16 pre_txcnt;
2010 
2011 	/* txq control */
2012 	value8 = rtw_read8(rtwdev, REG_FWHW_TXQ_CTRL);
2013 	value8 |= (BIT(7) & ~BIT(1) & ~BIT(2));
2014 	rtw_write8(rtwdev, REG_FWHW_TXQ_CTRL, value8);
2015 	rtw_write8(rtwdev, REG_FWHW_TXQ_CTRL + 1, WLAN_TXQ_RPT_EN);
2016 	/* sifs control */
2017 	rtw_write16(rtwdev, REG_SPEC_SIFS, WLAN_SIFS_DUR_TUNE);
2018 	rtw_write32(rtwdev, REG_SIFS, WLAN_SIFS_CFG);
2019 	rtw_write16(rtwdev, REG_RESP_SIFS_CCK,
2020 		    WLAN_SIFS_CCK_CTX | WLAN_SIFS_CCK_IRX << 8);
2021 	rtw_write16(rtwdev, REG_RESP_SIFS_OFDM,
2022 		    WLAN_SIFS_OFDM_CTX | WLAN_SIFS_OFDM_IRX << 8);
2023 	/* rate fallback control */
2024 	rtw_write32(rtwdev, REG_DARFRC, WLAN_DATA_RATE_FB_CNT_1_4);
2025 	rtw_write32(rtwdev, REG_DARFRCH, WLAN_DATA_RATE_FB_CNT_5_8);
2026 	rtw_write32(rtwdev, REG_RARFRCH, WLAN_RTS_RATE_FB_CNT_5_8);
2027 	rtw_write32(rtwdev, REG_ARFR0, WLAN_DATA_RATE_FB_RATE0);
2028 	rtw_write32(rtwdev, REG_ARFRH0, WLAN_DATA_RATE_FB_RATE0_H);
2029 	rtw_write32(rtwdev, REG_ARFR1_V1, WLAN_RTS_RATE_FB_RATE1);
2030 	rtw_write32(rtwdev, REG_ARFRH1_V1, WLAN_RTS_RATE_FB_RATE1_H);
2031 	rtw_write32(rtwdev, REG_ARFR4, WLAN_RTS_RATE_FB_RATE4);
2032 	rtw_write32(rtwdev, REG_ARFRH4, WLAN_RTS_RATE_FB_RATE4_H);
2033 	rtw_write32(rtwdev, REG_ARFR5, WLAN_RTS_RATE_FB_RATE5);
2034 	rtw_write32(rtwdev, REG_ARFRH5, WLAN_RTS_RATE_FB_RATE5_H);
2035 	/* protocol configuration */
2036 	rtw_write8(rtwdev, REG_AMPDU_MAX_TIME_V1, WLAN_AMPDU_MAX_TIME);
2037 	rtw_write8_set(rtwdev, REG_TX_HANG_CTRL, BIT_EN_EOF_V1);
2038 	pre_txcnt = WLAN_PRE_TXCNT_TIME_TH | BIT_EN_PRECNT;
2039 	rtw_write8(rtwdev, REG_PRECNT_CTRL, (u8)(pre_txcnt & 0xFF));
2040 	rtw_write8(rtwdev, REG_PRECNT_CTRL + 1, (u8)(pre_txcnt >> 8));
2041 	value32 = WLAN_RTS_LEN_TH | (WLAN_RTS_TX_TIME_TH << 8) |
2042 		  (WLAN_MAX_AGG_PKT_LIMIT << 16) |
2043 		  (WLAN_RTS_MAX_AGG_PKT_LIMIT << 24);
2044 	rtw_write32(rtwdev, REG_PROT_MODE_CTRL, value32);
2045 	rtw_write16(rtwdev, REG_BAR_MODE_CTRL + 2,
2046 		    WLAN_BAR_RETRY_LIMIT | WLAN_RA_TRY_RATE_AGG_LIMIT << 8);
2047 	rtw_write8(rtwdev, REG_FAST_EDCA_VOVI_SETTING, FAST_EDCA_VO_TH);
2048 	rtw_write8(rtwdev, REG_FAST_EDCA_VOVI_SETTING + 2, FAST_EDCA_VI_TH);
2049 	rtw_write8(rtwdev, REG_FAST_EDCA_BEBK_SETTING, FAST_EDCA_BE_TH);
2050 	rtw_write8(rtwdev, REG_FAST_EDCA_BEBK_SETTING + 2, FAST_EDCA_BK_TH);
2051 	/* close BA parser */
2052 	rtw_write8_clr(rtwdev, REG_LIFETIME_EN, BIT_BA_PARSER_EN);
2053 	rtw_write32_clr(rtwdev, REG_RRSR, BITS_RRSR_RSC);
2054 
2055 	/* EDCA configuration */
2056 	rtw_write32(rtwdev, REG_EDCA_VO_PARAM, WLAN_EDCA_VO_PARAM);
2057 	rtw_write32(rtwdev, REG_EDCA_VI_PARAM, WLAN_EDCA_VI_PARAM);
2058 	rtw_write32(rtwdev, REG_EDCA_BE_PARAM, WLAN_EDCA_BE_PARAM);
2059 	rtw_write32(rtwdev, REG_EDCA_BK_PARAM, WLAN_EDCA_BK_PARAM);
2060 	rtw_write8(rtwdev, REG_PIFS, WLAN_PIFS_TIME);
2061 	rtw_write8_clr(rtwdev, REG_TX_PTCL_CTRL + 1, BIT_SIFS_BK_EN >> 8);
2062 	rtw_write8_set(rtwdev, REG_RD_CTRL + 1,
2063 		       (BIT_DIS_TXOP_CFE | BIT_DIS_LSIG_CFE |
2064 			BIT_DIS_STBC_CFE) >> 8);
2065 
2066 	/* MAC clock configuration */
2067 	rtw_write32_clr(rtwdev, REG_AFE_CTRL1, BIT_MAC_CLK_SEL);
2068 	rtw_write8(rtwdev, REG_USTIME_TSF, MAC_CLK_SPEED);
2069 	rtw_write8(rtwdev, REG_USTIME_EDCA, MAC_CLK_SPEED);
2070 
2071 	rtw_write8_set(rtwdev, REG_MISC_CTRL,
2072 		       BIT_EN_FREE_CNT | BIT_DIS_SECOND_CCA);
2073 	rtw_write8_clr(rtwdev, REG_TIMER0_SRC_SEL, BIT_TSFT_SEL_TIMER0);
2074 	rtw_write16(rtwdev, REG_TXPAUSE, 0x0000);
2075 	rtw_write8(rtwdev, REG_SLOT, WLAN_SLOT_TIME);
2076 	rtw_write32(rtwdev, REG_RD_NAV_NXT, WLAN_NAV_CFG);
2077 	rtw_write16(rtwdev, REG_RXTSF_OFFSET_CCK, WLAN_RX_TSF_CFG);
2078 	/* Set beacon cotnrol - enable TSF and other related functions */
2079 	rtw_write8_set(rtwdev, REG_BCN_CTRL, BIT_EN_BCN_FUNCTION);
2080 	/* Set send beacon related registers */
2081 	rtw_write32(rtwdev, REG_TBTT_PROHIBIT, WLAN_TBTT_TIME);
2082 	rtw_write8(rtwdev, REG_DRVERLYINT, WLAN_DRV_EARLY_INT);
2083 	rtw_write8(rtwdev, REG_BCN_CTRL_CLINT0, WLAN_BCN_CTRL_CLT0);
2084 	rtw_write8(rtwdev, REG_BCNDMATIM, WLAN_BCN_DMA_TIME);
2085 	rtw_write8(rtwdev, REG_BCN_MAX_ERR, WLAN_BCN_MAX_ERR);
2086 
2087 	/* WMAC configuration */
2088 	rtw_write32(rtwdev, REG_MAR, WLAN_MULTI_ADDR);
2089 	rtw_write32(rtwdev, REG_MAR + 4, WLAN_MULTI_ADDR);
2090 	rtw_write8(rtwdev, REG_BBPSF_CTRL + 2, WLAN_RESP_TXRATE);
2091 	rtw_write8(rtwdev, REG_ACKTO, WLAN_ACK_TO);
2092 	rtw_write8(rtwdev, REG_ACKTO_CCK, WLAN_ACK_TO_CCK);
2093 	rtw_write16(rtwdev, REG_EIFS, WLAN_EIFS_DUR_TUNE);
2094 	rtw_write8(rtwdev, REG_NAV_CTRL + 2, WLAN_NAV_MAX);
2095 	rtw_write8(rtwdev, REG_WMAC_TRXPTCL_CTL_H  + 2, WLAN_BAR_ACK_TYPE);
2096 	rtw_write32(rtwdev, REG_RXFLTMAP0, WLAN_RX_FILTER0);
2097 	rtw_write16(rtwdev, REG_RXFLTMAP2, WLAN_RX_FILTER2);
2098 	rtw_write32(rtwdev, REG_RCR, WLAN_RCR_CFG);
2099 	rtw_write8(rtwdev, REG_RX_PKT_LIMIT, WLAN_RXPKT_MAX_SZ_512);
2100 	rtw_write8(rtwdev, REG_TCR + 2, WLAN_TX_FUNC_CFG2);
2101 	rtw_write8(rtwdev, REG_TCR + 1, WLAN_TX_FUNC_CFG1);
2102 	rtw_write32_set(rtwdev, REG_GENERAL_OPTION, BIT_DUMMY_FCS_READY_MASK_EN);
2103 	rtw_write32(rtwdev, REG_WMAC_OPTION_FUNCTION + 8, WLAN_MAC_OPT_FUNC2);
2104 	rtw_write8(rtwdev, REG_WMAC_OPTION_FUNCTION_1, WLAN_MAC_OPT_NORM_FUNC1);
2105 
2106 	/* init low power */
2107 	value16 = rtw_read16(rtwdev, REG_RXPSF_CTRL + 2) & 0xF00F;
2108 	value16 |= (BIT_RXGCK_VHT_FIFOTHR(1) | BIT_RXGCK_HT_FIFOTHR(1) |
2109 		    BIT_RXGCK_OFDM_FIFOTHR(1) | BIT_RXGCK_CCK_FIFOTHR(1)) >> 16;
2110 	rtw_write16(rtwdev, REG_RXPSF_CTRL + 2, value16);
2111 	value16 = 0;
2112 	value16 = BIT_SET_RXPSF_PKTLENTHR(value16, 1);
2113 	value16 |= BIT_RXPSF_CTRLEN | BIT_RXPSF_VHTCHKEN | BIT_RXPSF_HTCHKEN
2114 		| BIT_RXPSF_OFDMCHKEN | BIT_RXPSF_CCKCHKEN
2115 		| BIT_RXPSF_OFDMRST;
2116 	rtw_write16(rtwdev, REG_RXPSF_CTRL, value16);
2117 	rtw_write32(rtwdev, REG_RXPSF_TYPE_CTRL, 0xFFFFFFFF);
2118 	/* rx ignore configuration */
2119 	value16 = rtw_read16(rtwdev, REG_RXPSF_CTRL);
2120 	value16 &= ~(BIT_RXPSF_MHCHKEN | BIT_RXPSF_CCKRST |
2121 		     BIT_RXPSF_CONT_ERRCHKEN);
2122 	value16 = BIT_SET_RXPSF_ERRTHR(value16, 0x07);
2123 	rtw_write16(rtwdev, REG_RXPSF_CTRL, value16);
2124 	rtw_write8_set(rtwdev, REG_SND_PTCL_CTRL,
2125 		       BIT_DIS_CHK_VHTSIGB_CRC);
2126 
2127 	/* Interrupt migration configuration */
2128 	rtw_write32(rtwdev, REG_INT_MIG, WLAN_MAC_INT_MIG_CFG);
2129 
2130 	return 0;
2131 }
2132 
2133 #define FWCD_SIZE_REG_8822C 0x2000
2134 #define FWCD_SIZE_DMEM_8822C 0x10000
2135 #define FWCD_SIZE_IMEM_8822C 0x10000
2136 #define FWCD_SIZE_EMEM_8822C 0x20000
2137 #define FWCD_SIZE_ROM_8822C 0x10000
2138 
2139 static const u32 __fwcd_segs_8822c[] = {
2140 	FWCD_SIZE_REG_8822C,
2141 	FWCD_SIZE_DMEM_8822C,
2142 	FWCD_SIZE_IMEM_8822C,
2143 	FWCD_SIZE_EMEM_8822C,
2144 	FWCD_SIZE_ROM_8822C,
2145 };
2146 
2147 static const struct rtw_fwcd_segs rtw8822c_fwcd_segs = {
2148 	.segs = __fwcd_segs_8822c,
2149 	.num = ARRAY_SIZE(__fwcd_segs_8822c),
2150 };
2151 
2152 static int rtw8822c_dump_fw_crash(struct rtw_dev *rtwdev)
2153 {
2154 #define __dump_fw_8822c(_dev, _mem) \
2155 	rtw_dump_fw(_dev, OCPBASE_ ## _mem ## _88XX, \
2156 		    FWCD_SIZE_ ## _mem ## _8822C, RTW_FWCD_ ## _mem)
2157 	int ret;
2158 
2159 	ret = rtw_dump_reg(rtwdev, 0x0, FWCD_SIZE_REG_8822C);
2160 	if (ret)
2161 		return ret;
2162 	ret = __dump_fw_8822c(rtwdev, DMEM);
2163 	if (ret)
2164 		return ret;
2165 	ret = __dump_fw_8822c(rtwdev, IMEM);
2166 	if (ret)
2167 		return ret;
2168 	ret = __dump_fw_8822c(rtwdev, EMEM);
2169 	if (ret)
2170 		return ret;
2171 	ret = __dump_fw_8822c(rtwdev, ROM);
2172 	if (ret)
2173 		return ret;
2174 
2175 	return 0;
2176 
2177 #undef __dump_fw_8822c
2178 }
2179 
2180 static void rtw8822c_rstb_3wire(struct rtw_dev *rtwdev, bool enable)
2181 {
2182 	if (enable) {
2183 		rtw_write32_mask(rtwdev, REG_RSTB, BIT_RSTB_3WIRE, 0x1);
2184 		rtw_write32_mask(rtwdev, REG_ANAPAR_A, BIT_ANAPAR_UPDATE, 0x1);
2185 		rtw_write32_mask(rtwdev, REG_ANAPAR_B, BIT_ANAPAR_UPDATE, 0x1);
2186 	} else {
2187 		rtw_write32_mask(rtwdev, REG_RSTB, BIT_RSTB_3WIRE, 0x0);
2188 	}
2189 }
2190 
2191 static void rtw8822c_set_channel_rf(struct rtw_dev *rtwdev, u8 channel, u8 bw)
2192 {
2193 #define RF18_BAND_MASK		(BIT(16) | BIT(9) | BIT(8))
2194 #define RF18_BAND_2G		(0)
2195 #define RF18_BAND_5G		(BIT(16) | BIT(8))
2196 #define RF18_CHANNEL_MASK	(MASKBYTE0)
2197 #define RF18_RFSI_MASK		(BIT(18) | BIT(17))
2198 #define RF18_RFSI_GE_CH80	(BIT(17))
2199 #define RF18_RFSI_GT_CH140	(BIT(18))
2200 #define RF18_BW_MASK		(BIT(13) | BIT(12))
2201 #define RF18_BW_20M		(BIT(13) | BIT(12))
2202 #define RF18_BW_40M		(BIT(13))
2203 #define RF18_BW_80M		(BIT(12))
2204 
2205 	u32 rf_reg18 = 0;
2206 	u32 rf_rxbb = 0;
2207 
2208 #if defined(__linux__)
2209 	rf_reg18 = rtw_read_rf(rtwdev, RF_PATH_A, 0x18, RFREG_MASK);
2210 #elif defined(__FreeBSD__)
2211 	rf_reg18 = rtw_read_rf(rtwdev, RF_PATH_A, RF_CFGCH, RFREG_MASK);
2212 #endif
2213 
2214 	rf_reg18 &= ~(RF18_BAND_MASK | RF18_CHANNEL_MASK | RF18_RFSI_MASK |
2215 		      RF18_BW_MASK);
2216 
2217 	rf_reg18 |= (IS_CH_2G_BAND(channel) ? RF18_BAND_2G : RF18_BAND_5G);
2218 	rf_reg18 |= (channel & RF18_CHANNEL_MASK);
2219 	if (IS_CH_5G_BAND_4(channel))
2220 		rf_reg18 |= RF18_RFSI_GT_CH140;
2221 	else if (IS_CH_5G_BAND_3(channel))
2222 		rf_reg18 |= RF18_RFSI_GE_CH80;
2223 
2224 	switch (bw) {
2225 	case RTW_CHANNEL_WIDTH_5:
2226 	case RTW_CHANNEL_WIDTH_10:
2227 	case RTW_CHANNEL_WIDTH_20:
2228 	default:
2229 		rf_reg18 |= RF18_BW_20M;
2230 		rf_rxbb = 0x18;
2231 		break;
2232 	case RTW_CHANNEL_WIDTH_40:
2233 		/* RF bandwidth */
2234 		rf_reg18 |= RF18_BW_40M;
2235 		rf_rxbb = 0x10;
2236 		break;
2237 	case RTW_CHANNEL_WIDTH_80:
2238 		rf_reg18 |= RF18_BW_80M;
2239 		rf_rxbb = 0x8;
2240 		break;
2241 	}
2242 
2243 	rtw8822c_rstb_3wire(rtwdev, false);
2244 
2245 	rtw_write_rf(rtwdev, RF_PATH_A, RF_LUTWE2, 0x04, 0x01);
2246 	rtw_write_rf(rtwdev, RF_PATH_A, RF_LUTWA, 0x1f, 0x12);
2247 	rtw_write_rf(rtwdev, RF_PATH_A, RF_LUTWD0, 0xfffff, rf_rxbb);
2248 	rtw_write_rf(rtwdev, RF_PATH_A, RF_LUTWE2, 0x04, 0x00);
2249 
2250 	rtw_write_rf(rtwdev, RF_PATH_B, RF_LUTWE2, 0x04, 0x01);
2251 	rtw_write_rf(rtwdev, RF_PATH_B, RF_LUTWA, 0x1f, 0x12);
2252 	rtw_write_rf(rtwdev, RF_PATH_B, RF_LUTWD0, 0xfffff, rf_rxbb);
2253 	rtw_write_rf(rtwdev, RF_PATH_B, RF_LUTWE2, 0x04, 0x00);
2254 
2255 	rtw_write_rf(rtwdev, RF_PATH_A, RF_CFGCH, RFREG_MASK, rf_reg18);
2256 	rtw_write_rf(rtwdev, RF_PATH_B, RF_CFGCH, RFREG_MASK, rf_reg18);
2257 
2258 	rtw8822c_rstb_3wire(rtwdev, true);
2259 }
2260 
2261 static void rtw8822c_toggle_igi(struct rtw_dev *rtwdev)
2262 {
2263 	u32 igi;
2264 
2265 	igi = rtw_read32_mask(rtwdev, REG_RXIGI, 0x7f);
2266 	rtw_write32_mask(rtwdev, REG_RXIGI, 0x7f, igi - 2);
2267 	rtw_write32_mask(rtwdev, REG_RXIGI, 0x7f00, igi - 2);
2268 	rtw_write32_mask(rtwdev, REG_RXIGI, 0x7f, igi);
2269 	rtw_write32_mask(rtwdev, REG_RXIGI, 0x7f00, igi);
2270 }
2271 
2272 static void rtw8822c_set_channel_bb(struct rtw_dev *rtwdev, u8 channel, u8 bw,
2273 				    u8 primary_ch_idx)
2274 {
2275 	if (IS_CH_2G_BAND(channel)) {
2276 		rtw_write32_clr(rtwdev, REG_BGCTRL, BITS_RX_IQ_WEIGHT);
2277 		rtw_write32_set(rtwdev, REG_TXF4, BIT(20));
2278 		rtw_write32_clr(rtwdev, REG_CCK_CHECK, BIT_CHECK_CCK_EN);
2279 		rtw_write32_clr(rtwdev, REG_CCKTXONLY, BIT_BB_CCK_CHECK_EN);
2280 		rtw_write32_mask(rtwdev, REG_CCAMSK, 0x3F000000, 0xF);
2281 
2282 		switch (bw) {
2283 		case RTW_CHANNEL_WIDTH_20:
2284 			rtw_write32_mask(rtwdev, REG_RXAGCCTL0, BITS_RXAGC_CCK,
2285 					 0x5);
2286 			rtw_write32_mask(rtwdev, REG_RXAGCCTL, BITS_RXAGC_CCK,
2287 					 0x5);
2288 			rtw_write32_mask(rtwdev, REG_RXAGCCTL0, BITS_RXAGC_OFDM,
2289 					 0x6);
2290 			rtw_write32_mask(rtwdev, REG_RXAGCCTL, BITS_RXAGC_OFDM,
2291 					 0x6);
2292 			break;
2293 		case RTW_CHANNEL_WIDTH_40:
2294 			rtw_write32_mask(rtwdev, REG_RXAGCCTL0, BITS_RXAGC_CCK,
2295 					 0x4);
2296 			rtw_write32_mask(rtwdev, REG_RXAGCCTL, BITS_RXAGC_CCK,
2297 					 0x4);
2298 			rtw_write32_mask(rtwdev, REG_RXAGCCTL0, BITS_RXAGC_OFDM,
2299 					 0x0);
2300 			rtw_write32_mask(rtwdev, REG_RXAGCCTL, BITS_RXAGC_OFDM,
2301 					 0x0);
2302 			break;
2303 		}
2304 		if (channel == 13 || channel == 14)
2305 			rtw_write32_mask(rtwdev, REG_SCOTRK, 0xfff, 0x969);
2306 		else if (channel == 11 || channel == 12)
2307 			rtw_write32_mask(rtwdev, REG_SCOTRK, 0xfff, 0x96a);
2308 		else
2309 			rtw_write32_mask(rtwdev, REG_SCOTRK, 0xfff, 0x9aa);
2310 		if (channel == 14) {
2311 			rtw_write32_mask(rtwdev, REG_TXF0, MASKHWORD, 0x3da0);
2312 			rtw_write32_mask(rtwdev, REG_TXF1, MASKDWORD,
2313 					 0x4962c931);
2314 			rtw_write32_mask(rtwdev, REG_TXF2, MASKLWORD, 0x6aa3);
2315 			rtw_write32_mask(rtwdev, REG_TXF3, MASKHWORD, 0xaa7b);
2316 			rtw_write32_mask(rtwdev, REG_TXF4, MASKLWORD, 0xf3d7);
2317 			rtw_write32_mask(rtwdev, REG_TXF5, MASKDWORD, 0x0);
2318 			rtw_write32_mask(rtwdev, REG_TXF6, MASKDWORD,
2319 					 0xff012455);
2320 			rtw_write32_mask(rtwdev, REG_TXF7, MASKDWORD, 0xffff);
2321 		} else {
2322 			rtw_write32_mask(rtwdev, REG_TXF0, MASKHWORD, 0x5284);
2323 			rtw_write32_mask(rtwdev, REG_TXF1, MASKDWORD,
2324 					 0x3e18fec8);
2325 			rtw_write32_mask(rtwdev, REG_TXF2, MASKLWORD, 0x0a88);
2326 			rtw_write32_mask(rtwdev, REG_TXF3, MASKHWORD, 0xacc4);
2327 			rtw_write32_mask(rtwdev, REG_TXF4, MASKLWORD, 0xc8b2);
2328 			rtw_write32_mask(rtwdev, REG_TXF5, MASKDWORD,
2329 					 0x00faf0de);
2330 			rtw_write32_mask(rtwdev, REG_TXF6, MASKDWORD,
2331 					 0x00122344);
2332 			rtw_write32_mask(rtwdev, REG_TXF7, MASKDWORD,
2333 					 0x0fffffff);
2334 		}
2335 		if (channel == 13)
2336 			rtw_write32_mask(rtwdev, REG_TXDFIR0, 0x70, 0x3);
2337 		else
2338 			rtw_write32_mask(rtwdev, REG_TXDFIR0, 0x70, 0x1);
2339 	} else if (IS_CH_5G_BAND(channel)) {
2340 		rtw_write32_set(rtwdev, REG_CCKTXONLY, BIT_BB_CCK_CHECK_EN);
2341 		rtw_write32_set(rtwdev, REG_CCK_CHECK, BIT_CHECK_CCK_EN);
2342 		rtw_write32_set(rtwdev, REG_BGCTRL, BITS_RX_IQ_WEIGHT);
2343 		rtw_write32_clr(rtwdev, REG_TXF4, BIT(20));
2344 		rtw_write32_mask(rtwdev, REG_CCAMSK, 0x3F000000, 0x22);
2345 		rtw_write32_mask(rtwdev, REG_TXDFIR0, 0x70, 0x3);
2346 		if (IS_CH_5G_BAND_1(channel) || IS_CH_5G_BAND_2(channel)) {
2347 			rtw_write32_mask(rtwdev, REG_RXAGCCTL0, BITS_RXAGC_OFDM,
2348 					 0x1);
2349 			rtw_write32_mask(rtwdev, REG_RXAGCCTL, BITS_RXAGC_OFDM,
2350 					 0x1);
2351 		} else if (IS_CH_5G_BAND_3(channel)) {
2352 			rtw_write32_mask(rtwdev, REG_RXAGCCTL0, BITS_RXAGC_OFDM,
2353 					 0x2);
2354 			rtw_write32_mask(rtwdev, REG_RXAGCCTL, BITS_RXAGC_OFDM,
2355 					 0x2);
2356 		} else if (IS_CH_5G_BAND_4(channel)) {
2357 			rtw_write32_mask(rtwdev, REG_RXAGCCTL0, BITS_RXAGC_OFDM,
2358 					 0x3);
2359 			rtw_write32_mask(rtwdev, REG_RXAGCCTL, BITS_RXAGC_OFDM,
2360 					 0x3);
2361 		}
2362 
2363 		if (channel >= 36 && channel <= 51)
2364 			rtw_write32_mask(rtwdev, REG_SCOTRK, 0xfff, 0x494);
2365 		else if (channel >= 52 && channel <= 55)
2366 			rtw_write32_mask(rtwdev, REG_SCOTRK, 0xfff, 0x493);
2367 		else if (channel >= 56 && channel <= 111)
2368 			rtw_write32_mask(rtwdev, REG_SCOTRK, 0xfff, 0x453);
2369 		else if (channel >= 112 && channel <= 119)
2370 			rtw_write32_mask(rtwdev, REG_SCOTRK, 0xfff, 0x452);
2371 		else if (channel >= 120 && channel <= 172)
2372 			rtw_write32_mask(rtwdev, REG_SCOTRK, 0xfff, 0x412);
2373 		else if (channel >= 173 && channel <= 177)
2374 			rtw_write32_mask(rtwdev, REG_SCOTRK, 0xfff, 0x411);
2375 	}
2376 
2377 	switch (bw) {
2378 	case RTW_CHANNEL_WIDTH_20:
2379 		rtw_write32_mask(rtwdev, REG_DFIRBW, 0x3FF0, 0x19B);
2380 		rtw_write32_mask(rtwdev, REG_TXBWCTL, 0xf, 0x0);
2381 		rtw_write32_mask(rtwdev, REG_TXBWCTL, 0xffc0, 0x0);
2382 		rtw_write32_mask(rtwdev, REG_TXCLK, 0x700, 0x7);
2383 		rtw_write32_mask(rtwdev, REG_TXCLK, 0x700000, 0x6);
2384 		rtw_write32_mask(rtwdev, REG_CCK_SOURCE, BIT_NBI_EN, 0x0);
2385 		rtw_write32_mask(rtwdev, REG_SBD, BITS_SUBTUNE, 0x1);
2386 		rtw_write32_mask(rtwdev, REG_PT_CHSMO, BIT_PT_OPT, 0x0);
2387 		break;
2388 	case RTW_CHANNEL_WIDTH_40:
2389 		rtw_write32_mask(rtwdev, REG_CCKSB, BIT(4),
2390 				 (primary_ch_idx == RTW_SC_20_UPPER ? 1 : 0));
2391 		rtw_write32_mask(rtwdev, REG_TXBWCTL, 0xf, 0x5);
2392 		rtw_write32_mask(rtwdev, REG_TXBWCTL, 0xc0, 0x0);
2393 		rtw_write32_mask(rtwdev, REG_TXBWCTL, 0xff00,
2394 				 (primary_ch_idx | (primary_ch_idx << 4)));
2395 		rtw_write32_mask(rtwdev, REG_CCK_SOURCE, BIT_NBI_EN, 0x1);
2396 		rtw_write32_mask(rtwdev, REG_SBD, BITS_SUBTUNE, 0x1);
2397 		rtw_write32_mask(rtwdev, REG_PT_CHSMO, BIT_PT_OPT, 0x1);
2398 		break;
2399 	case RTW_CHANNEL_WIDTH_80:
2400 		rtw_write32_mask(rtwdev, REG_TXBWCTL, 0xf, 0xa);
2401 		rtw_write32_mask(rtwdev, REG_TXBWCTL, 0xc0, 0x0);
2402 		rtw_write32_mask(rtwdev, REG_TXBWCTL, 0xff00,
2403 				 (primary_ch_idx | (primary_ch_idx << 4)));
2404 		rtw_write32_mask(rtwdev, REG_SBD, BITS_SUBTUNE, 0x6);
2405 		rtw_write32_mask(rtwdev, REG_PT_CHSMO, BIT_PT_OPT, 0x1);
2406 		break;
2407 	case RTW_CHANNEL_WIDTH_5:
2408 		rtw_write32_mask(rtwdev, REG_DFIRBW, 0x3FF0, 0x2AB);
2409 		rtw_write32_mask(rtwdev, REG_TXBWCTL, 0xf, 0x0);
2410 		rtw_write32_mask(rtwdev, REG_TXBWCTL, 0xffc0, 0x1);
2411 		rtw_write32_mask(rtwdev, REG_TXCLK, 0x700, 0x4);
2412 		rtw_write32_mask(rtwdev, REG_TXCLK, 0x700000, 0x4);
2413 		rtw_write32_mask(rtwdev, REG_CCK_SOURCE, BIT_NBI_EN, 0x0);
2414 		rtw_write32_mask(rtwdev, REG_SBD, BITS_SUBTUNE, 0x1);
2415 		rtw_write32_mask(rtwdev, REG_PT_CHSMO, BIT_PT_OPT, 0x0);
2416 		break;
2417 	case RTW_CHANNEL_WIDTH_10:
2418 		rtw_write32_mask(rtwdev, REG_DFIRBW, 0x3FF0, 0x2AB);
2419 		rtw_write32_mask(rtwdev, REG_TXBWCTL, 0xf, 0x0);
2420 		rtw_write32_mask(rtwdev, REG_TXBWCTL, 0xffc0, 0x2);
2421 		rtw_write32_mask(rtwdev, REG_TXCLK, 0x700, 0x6);
2422 		rtw_write32_mask(rtwdev, REG_TXCLK, 0x700000, 0x5);
2423 		rtw_write32_mask(rtwdev, REG_CCK_SOURCE, BIT_NBI_EN, 0x0);
2424 		rtw_write32_mask(rtwdev, REG_SBD, BITS_SUBTUNE, 0x1);
2425 		rtw_write32_mask(rtwdev, REG_PT_CHSMO, BIT_PT_OPT, 0x0);
2426 		break;
2427 	}
2428 }
2429 
2430 static void rtw8822c_set_channel(struct rtw_dev *rtwdev, u8 channel, u8 bw,
2431 				 u8 primary_chan_idx)
2432 {
2433 	rtw8822c_set_channel_bb(rtwdev, channel, bw, primary_chan_idx);
2434 	rtw_set_channel_mac(rtwdev, channel, bw, primary_chan_idx);
2435 	rtw8822c_set_channel_rf(rtwdev, channel, bw);
2436 	rtw8822c_toggle_igi(rtwdev);
2437 }
2438 
2439 static void rtw8822c_config_cck_rx_path(struct rtw_dev *rtwdev, u8 rx_path)
2440 {
2441 	if (rx_path == BB_PATH_A || rx_path == BB_PATH_B) {
2442 		rtw_write32_mask(rtwdev, REG_CCANRX, 0x00060000, 0x0);
2443 		rtw_write32_mask(rtwdev, REG_CCANRX, 0x00600000, 0x0);
2444 	} else if (rx_path == BB_PATH_AB) {
2445 		rtw_write32_mask(rtwdev, REG_CCANRX, 0x00600000, 0x1);
2446 		rtw_write32_mask(rtwdev, REG_CCANRX, 0x00060000, 0x1);
2447 	}
2448 
2449 	if (rx_path == BB_PATH_A)
2450 		rtw_write32_mask(rtwdev, REG_RXCCKSEL, 0x0f000000, 0x0);
2451 	else if (rx_path == BB_PATH_B)
2452 		rtw_write32_mask(rtwdev, REG_RXCCKSEL, 0x0f000000, 0x5);
2453 	else if (rx_path == BB_PATH_AB)
2454 		rtw_write32_mask(rtwdev, REG_RXCCKSEL, 0x0f000000, 0x1);
2455 }
2456 
2457 static void rtw8822c_config_ofdm_rx_path(struct rtw_dev *rtwdev, u8 rx_path)
2458 {
2459 	if (rx_path == BB_PATH_A || rx_path == BB_PATH_B) {
2460 		rtw_write32_mask(rtwdev, REG_RXFNCTL, 0x300, 0x0);
2461 		rtw_write32_mask(rtwdev, REG_RXFNCTL, 0x600000, 0x0);
2462 		rtw_write32_mask(rtwdev, REG_AGCSWSH, BIT(17), 0x0);
2463 		rtw_write32_mask(rtwdev, REG_ANTWTPD, BIT(20), 0x0);
2464 		rtw_write32_mask(rtwdev, REG_MRCM, BIT(24), 0x0);
2465 	} else if (rx_path == BB_PATH_AB) {
2466 		rtw_write32_mask(rtwdev, REG_RXFNCTL, 0x300, 0x1);
2467 		rtw_write32_mask(rtwdev, REG_RXFNCTL, 0x600000, 0x1);
2468 		rtw_write32_mask(rtwdev, REG_AGCSWSH, BIT(17), 0x1);
2469 		rtw_write32_mask(rtwdev, REG_ANTWTPD, BIT(20), 0x1);
2470 		rtw_write32_mask(rtwdev, REG_MRCM, BIT(24), 0x1);
2471 	}
2472 
2473 	rtw_write32_mask(rtwdev, 0x824, 0x0f000000, rx_path);
2474 	rtw_write32_mask(rtwdev, 0x824, 0x000f0000, rx_path);
2475 }
2476 
2477 static void rtw8822c_config_rx_path(struct rtw_dev *rtwdev, u8 rx_path)
2478 {
2479 	rtw8822c_config_cck_rx_path(rtwdev, rx_path);
2480 	rtw8822c_config_ofdm_rx_path(rtwdev, rx_path);
2481 }
2482 
2483 static void rtw8822c_config_cck_tx_path(struct rtw_dev *rtwdev, u8 tx_path,
2484 					bool is_tx2_path)
2485 {
2486 	if (tx_path == BB_PATH_A) {
2487 		rtw_write32_mask(rtwdev, REG_RXCCKSEL, 0xf0000000, 0x8);
2488 	} else if (tx_path == BB_PATH_B) {
2489 		rtw_write32_mask(rtwdev, REG_RXCCKSEL, 0xf0000000, 0x4);
2490 	} else {
2491 		if (is_tx2_path)
2492 			rtw_write32_mask(rtwdev, REG_RXCCKSEL, 0xf0000000, 0xc);
2493 		else
2494 			rtw_write32_mask(rtwdev, REG_RXCCKSEL, 0xf0000000, 0x8);
2495 	}
2496 	rtw8822c_bb_reset(rtwdev);
2497 }
2498 
2499 static void rtw8822c_config_ofdm_tx_path(struct rtw_dev *rtwdev, u8 tx_path,
2500 					 enum rtw_bb_path tx_path_sel_1ss)
2501 {
2502 	if (tx_path == BB_PATH_A) {
2503 		rtw_write32_mask(rtwdev, REG_ANTMAP0, 0xff, 0x11);
2504 		rtw_write32_mask(rtwdev, REG_TXLGMAP, 0xff, 0x0);
2505 	} else if (tx_path == BB_PATH_B) {
2506 		rtw_write32_mask(rtwdev, REG_ANTMAP0, 0xff, 0x12);
2507 		rtw_write32_mask(rtwdev, REG_TXLGMAP, 0xff, 0x0);
2508 	} else {
2509 		if (tx_path_sel_1ss == BB_PATH_AB) {
2510 			rtw_write32_mask(rtwdev, REG_ANTMAP0, 0xff, 0x33);
2511 			rtw_write32_mask(rtwdev, REG_TXLGMAP, 0xffff, 0x0404);
2512 		} else if (tx_path_sel_1ss == BB_PATH_B) {
2513 			rtw_write32_mask(rtwdev, REG_ANTMAP0, 0xff, 0x32);
2514 			rtw_write32_mask(rtwdev, REG_TXLGMAP, 0xffff, 0x0400);
2515 		} else if (tx_path_sel_1ss == BB_PATH_A) {
2516 			rtw_write32_mask(rtwdev, REG_ANTMAP0, 0xff, 0x31);
2517 			rtw_write32_mask(rtwdev, REG_TXLGMAP, 0xffff, 0x0400);
2518 		}
2519 	}
2520 	rtw8822c_bb_reset(rtwdev);
2521 }
2522 
2523 static void rtw8822c_config_tx_path(struct rtw_dev *rtwdev, u8 tx_path,
2524 				    enum rtw_bb_path tx_path_sel_1ss,
2525 				    enum rtw_bb_path tx_path_cck,
2526 				    bool is_tx2_path)
2527 {
2528 	rtw8822c_config_cck_tx_path(rtwdev, tx_path_cck, is_tx2_path);
2529 	rtw8822c_config_ofdm_tx_path(rtwdev, tx_path, tx_path_sel_1ss);
2530 	rtw8822c_bb_reset(rtwdev);
2531 }
2532 
2533 static void rtw8822c_config_trx_mode(struct rtw_dev *rtwdev, u8 tx_path,
2534 				     u8 rx_path, bool is_tx2_path)
2535 {
2536 	if ((tx_path | rx_path) & BB_PATH_A)
2537 		rtw_write32_mask(rtwdev, REG_ORITXCODE, MASK20BITS, 0x33312);
2538 	else
2539 		rtw_write32_mask(rtwdev, REG_ORITXCODE, MASK20BITS, 0x11111);
2540 	if ((tx_path | rx_path) & BB_PATH_B)
2541 		rtw_write32_mask(rtwdev, REG_ORITXCODE2, MASK20BITS, 0x33312);
2542 	else
2543 		rtw_write32_mask(rtwdev, REG_ORITXCODE2, MASK20BITS, 0x11111);
2544 
2545 	rtw8822c_config_rx_path(rtwdev, rx_path);
2546 	rtw8822c_config_tx_path(rtwdev, tx_path, BB_PATH_A, BB_PATH_A,
2547 				is_tx2_path);
2548 
2549 	rtw8822c_toggle_igi(rtwdev);
2550 }
2551 
2552 static void query_phy_status_page0(struct rtw_dev *rtwdev, u8 *phy_status,
2553 				   struct rtw_rx_pkt_stat *pkt_stat)
2554 {
2555 	struct rtw_dm_info *dm_info = &rtwdev->dm_info;
2556 	u8 l_bnd, u_bnd;
2557 	u8 gain_a, gain_b;
2558 	s8 rx_power[RTW_RF_PATH_MAX];
2559 	s8 min_rx_power = -120;
2560 	u8 rssi;
2561 	u8 channel;
2562 	int path;
2563 
2564 	rx_power[RF_PATH_A] = GET_PHY_STAT_P0_PWDB_A(phy_status);
2565 	rx_power[RF_PATH_B] = GET_PHY_STAT_P0_PWDB_B(phy_status);
2566 	l_bnd = dm_info->cck_gi_l_bnd;
2567 	u_bnd = dm_info->cck_gi_u_bnd;
2568 	gain_a = GET_PHY_STAT_P0_GAIN_A(phy_status);
2569 	gain_b = GET_PHY_STAT_P0_GAIN_B(phy_status);
2570 	if (gain_a < l_bnd)
2571 		rx_power[RF_PATH_A] += (l_bnd - gain_a) << 1;
2572 	else if (gain_a > u_bnd)
2573 		rx_power[RF_PATH_A] -= (gain_a - u_bnd) << 1;
2574 	if (gain_b < l_bnd)
2575 		rx_power[RF_PATH_B] += (l_bnd - gain_b) << 1;
2576 	else if (gain_b > u_bnd)
2577 		rx_power[RF_PATH_B] -= (gain_b - u_bnd) << 1;
2578 
2579 	rx_power[RF_PATH_A] -= 110;
2580 	rx_power[RF_PATH_B] -= 110;
2581 
2582 	channel = GET_PHY_STAT_P0_CHANNEL(phy_status);
2583 	if (channel != 0)
2584 		rtw_set_rx_freq_band(pkt_stat, channel);
2585 	else
2586 		pkt_stat->channel_invalid = true;
2587 
2588 	pkt_stat->rx_power[RF_PATH_A] = rx_power[RF_PATH_A];
2589 	pkt_stat->rx_power[RF_PATH_B] = rx_power[RF_PATH_B];
2590 
2591 	for (path = 0; path <= rtwdev->hal.rf_path_num; path++) {
2592 		rssi = rtw_phy_rf_power_2_rssi(&pkt_stat->rx_power[path], 1);
2593 		dm_info->rssi[path] = rssi;
2594 	}
2595 
2596 	pkt_stat->rssi = rtw_phy_rf_power_2_rssi(pkt_stat->rx_power, 1);
2597 	pkt_stat->bw = RTW_CHANNEL_WIDTH_20;
2598 	pkt_stat->signal_power = max(pkt_stat->rx_power[RF_PATH_A],
2599 				     min_rx_power);
2600 }
2601 
2602 static void query_phy_status_page1(struct rtw_dev *rtwdev, u8 *phy_status,
2603 				   struct rtw_rx_pkt_stat *pkt_stat)
2604 {
2605 	struct rtw_path_div *p_div = &rtwdev->dm_path_div;
2606 	struct rtw_dm_info *dm_info = &rtwdev->dm_info;
2607 	u8 rxsc, bw;
2608 	s8 min_rx_power = -120;
2609 	s8 rx_evm;
2610 	u8 evm_dbm = 0;
2611 	u8 rssi;
2612 	int path;
2613 	u8 channel;
2614 
2615 	if (pkt_stat->rate > DESC_RATE11M && pkt_stat->rate < DESC_RATEMCS0)
2616 		rxsc = GET_PHY_STAT_P1_L_RXSC(phy_status);
2617 	else
2618 		rxsc = GET_PHY_STAT_P1_HT_RXSC(phy_status);
2619 
2620 	if (rxsc == 0)
2621 		bw = rtwdev->hal.current_band_width;
2622 	else if (rxsc >= 1 && rxsc <= 8)
2623 		bw = RTW_CHANNEL_WIDTH_20;
2624 	else if (rxsc >= 9 && rxsc <= 12)
2625 		bw = RTW_CHANNEL_WIDTH_40;
2626 	else
2627 		bw = RTW_CHANNEL_WIDTH_80;
2628 
2629 	channel = GET_PHY_STAT_P1_CHANNEL(phy_status);
2630 	rtw_set_rx_freq_band(pkt_stat, channel);
2631 
2632 	pkt_stat->rx_power[RF_PATH_A] = GET_PHY_STAT_P1_PWDB_A(phy_status) - 110;
2633 	pkt_stat->rx_power[RF_PATH_B] = GET_PHY_STAT_P1_PWDB_B(phy_status) - 110;
2634 	pkt_stat->rssi = rtw_phy_rf_power_2_rssi(pkt_stat->rx_power, 2);
2635 	pkt_stat->bw = bw;
2636 	pkt_stat->signal_power = max3(pkt_stat->rx_power[RF_PATH_A],
2637 				      pkt_stat->rx_power[RF_PATH_B],
2638 				      min_rx_power);
2639 
2640 	dm_info->curr_rx_rate = pkt_stat->rate;
2641 
2642 	pkt_stat->rx_evm[RF_PATH_A] = GET_PHY_STAT_P1_RXEVM_A(phy_status);
2643 	pkt_stat->rx_evm[RF_PATH_B] = GET_PHY_STAT_P1_RXEVM_B(phy_status);
2644 
2645 	pkt_stat->rx_snr[RF_PATH_A] = GET_PHY_STAT_P1_RXSNR_A(phy_status);
2646 	pkt_stat->rx_snr[RF_PATH_B] = GET_PHY_STAT_P1_RXSNR_B(phy_status);
2647 
2648 	pkt_stat->cfo_tail[RF_PATH_A] = GET_PHY_STAT_P1_CFO_TAIL_A(phy_status);
2649 	pkt_stat->cfo_tail[RF_PATH_B] = GET_PHY_STAT_P1_CFO_TAIL_B(phy_status);
2650 
2651 	for (path = 0; path <= rtwdev->hal.rf_path_num; path++) {
2652 		rssi = rtw_phy_rf_power_2_rssi(&pkt_stat->rx_power[path], 1);
2653 		dm_info->rssi[path] = rssi;
2654 		if (path == RF_PATH_A) {
2655 			p_div->path_a_sum += rssi;
2656 			p_div->path_a_cnt++;
2657 		} else if (path == RF_PATH_B) {
2658 			p_div->path_b_sum += rssi;
2659 			p_div->path_b_cnt++;
2660 		}
2661 		dm_info->rx_snr[path] = pkt_stat->rx_snr[path] >> 1;
2662 		dm_info->cfo_tail[path] = (pkt_stat->cfo_tail[path] * 5) >> 1;
2663 
2664 		rx_evm = pkt_stat->rx_evm[path];
2665 
2666 		if (rx_evm < 0) {
2667 			if (rx_evm == S8_MIN)
2668 				evm_dbm = 0;
2669 			else
2670 				evm_dbm = ((u8)-rx_evm >> 1);
2671 		}
2672 		dm_info->rx_evm_dbm[path] = evm_dbm;
2673 	}
2674 	rtw_phy_parsing_cfo(rtwdev, pkt_stat);
2675 }
2676 
2677 static void query_phy_status(struct rtw_dev *rtwdev, u8 *phy_status,
2678 			     struct rtw_rx_pkt_stat *pkt_stat)
2679 {
2680 	u8 page;
2681 
2682 	page = *phy_status & 0xf;
2683 
2684 	switch (page) {
2685 	case 0:
2686 		query_phy_status_page0(rtwdev, phy_status, pkt_stat);
2687 		break;
2688 	case 1:
2689 		query_phy_status_page1(rtwdev, phy_status, pkt_stat);
2690 		break;
2691 	default:
2692 		rtw_warn(rtwdev, "unused phy status page (%d)\n", page);
2693 		return;
2694 	}
2695 }
2696 
2697 static void
2698 rtw8822c_set_write_tx_power_ref(struct rtw_dev *rtwdev, u8 *tx_pwr_ref_cck,
2699 				u8 *tx_pwr_ref_ofdm)
2700 {
2701 	struct rtw_hal *hal = &rtwdev->hal;
2702 	u32 txref_cck[2] = {0x18a0, 0x41a0};
2703 	u32 txref_ofdm[2] = {0x18e8, 0x41e8};
2704 	u8 path;
2705 
2706 	for (path = 0; path < hal->rf_path_num; path++) {
2707 		rtw_write32_mask(rtwdev, 0x1c90, BIT(15), 0);
2708 		rtw_write32_mask(rtwdev, txref_cck[path], 0x7f0000,
2709 				 tx_pwr_ref_cck[path]);
2710 	}
2711 	for (path = 0; path < hal->rf_path_num; path++) {
2712 		rtw_write32_mask(rtwdev, 0x1c90, BIT(15), 0);
2713 		rtw_write32_mask(rtwdev, txref_ofdm[path], 0x1fc00,
2714 				 tx_pwr_ref_ofdm[path]);
2715 	}
2716 }
2717 
2718 static void rtw8822c_set_tx_power_diff(struct rtw_dev *rtwdev, u8 rate,
2719 				       s8 *diff_idx)
2720 {
2721 	u32 offset_txagc = 0x3a00;
2722 	u8 rate_idx = rate & 0xfc;
2723 	u8 pwr_idx[4];
2724 	u32 phy_pwr_idx;
2725 	int i;
2726 
2727 	for (i = 0; i < 4; i++)
2728 		pwr_idx[i] = diff_idx[i] & 0x7f;
2729 
2730 	phy_pwr_idx = pwr_idx[0] |
2731 		      (pwr_idx[1] << 8) |
2732 		      (pwr_idx[2] << 16) |
2733 		      (pwr_idx[3] << 24);
2734 
2735 	rtw_write32_mask(rtwdev, 0x1c90, BIT(15), 0x0);
2736 	rtw_write32_mask(rtwdev, offset_txagc + rate_idx, MASKDWORD,
2737 			 phy_pwr_idx);
2738 }
2739 
2740 static void rtw8822c_set_tx_power_index(struct rtw_dev *rtwdev)
2741 {
2742 	struct rtw_hal *hal = &rtwdev->hal;
2743 	u8 rs, rate, j;
2744 	u8 pwr_ref_cck[2] = {hal->tx_pwr_tbl[RF_PATH_A][DESC_RATE11M],
2745 			     hal->tx_pwr_tbl[RF_PATH_B][DESC_RATE11M]};
2746 	u8 pwr_ref_ofdm[2] = {hal->tx_pwr_tbl[RF_PATH_A][DESC_RATEMCS7],
2747 			      hal->tx_pwr_tbl[RF_PATH_B][DESC_RATEMCS7]};
2748 	s8 diff_a, diff_b;
2749 	u8 pwr_a, pwr_b;
2750 	s8 diff_idx[4];
2751 
2752 	rtw8822c_set_write_tx_power_ref(rtwdev, pwr_ref_cck, pwr_ref_ofdm);
2753 	for (rs = 0; rs < RTW_RATE_SECTION_MAX; rs++) {
2754 		for (j = 0; j < rtw_rate_size[rs]; j++) {
2755 			rate = rtw_rate_section[rs][j];
2756 			pwr_a = hal->tx_pwr_tbl[RF_PATH_A][rate];
2757 			pwr_b = hal->tx_pwr_tbl[RF_PATH_B][rate];
2758 			if (rs == 0) {
2759 				diff_a = (s8)pwr_a - (s8)pwr_ref_cck[0];
2760 				diff_b = (s8)pwr_b - (s8)pwr_ref_cck[1];
2761 			} else {
2762 				diff_a = (s8)pwr_a - (s8)pwr_ref_ofdm[0];
2763 				diff_b = (s8)pwr_b - (s8)pwr_ref_ofdm[1];
2764 			}
2765 			diff_idx[rate % 4] = min(diff_a, diff_b);
2766 			if (rate % 4 == 3)
2767 				rtw8822c_set_tx_power_diff(rtwdev, rate - 3,
2768 							   diff_idx);
2769 		}
2770 	}
2771 }
2772 
2773 static int rtw8822c_set_antenna(struct rtw_dev *rtwdev,
2774 				u32 antenna_tx,
2775 				u32 antenna_rx)
2776 {
2777 	struct rtw_hal *hal = &rtwdev->hal;
2778 
2779 	switch (antenna_tx) {
2780 	case BB_PATH_A:
2781 	case BB_PATH_B:
2782 	case BB_PATH_AB:
2783 		break;
2784 	default:
2785 		rtw_warn(rtwdev, "unsupported tx path 0x%x\n", antenna_tx);
2786 		return -EINVAL;
2787 	}
2788 
2789 	/* path B only is not available for RX */
2790 	switch (antenna_rx) {
2791 	case BB_PATH_A:
2792 	case BB_PATH_AB:
2793 		break;
2794 	default:
2795 		rtw_warn(rtwdev, "unsupported rx path 0x%x\n", antenna_rx);
2796 		return -EINVAL;
2797 	}
2798 
2799 	hal->antenna_tx = antenna_tx;
2800 	hal->antenna_rx = antenna_rx;
2801 
2802 	rtw8822c_config_trx_mode(rtwdev, antenna_tx, antenna_rx, false);
2803 
2804 	return 0;
2805 }
2806 
2807 static void rtw8822c_cfg_ldo25(struct rtw_dev *rtwdev, bool enable)
2808 {
2809 	u8 ldo_pwr;
2810 
2811 	ldo_pwr = rtw_read8(rtwdev, REG_ANAPARLDO_POW_MAC);
2812 	ldo_pwr = enable ? ldo_pwr | BIT_LDOE25_PON : ldo_pwr & ~BIT_LDOE25_PON;
2813 	rtw_write8(rtwdev, REG_ANAPARLDO_POW_MAC, ldo_pwr);
2814 }
2815 
2816 static void rtw8822c_false_alarm_statistics(struct rtw_dev *rtwdev)
2817 {
2818 	struct rtw_dm_info *dm_info = &rtwdev->dm_info;
2819 	u32 cck_enable;
2820 	u32 cck_fa_cnt;
2821 	u32 crc32_cnt;
2822 	u32 cca32_cnt;
2823 	u32 ofdm_fa_cnt;
2824 	u32 ofdm_fa_cnt1, ofdm_fa_cnt2, ofdm_fa_cnt3, ofdm_fa_cnt4, ofdm_fa_cnt5;
2825 	u16 parity_fail, rate_illegal, crc8_fail, mcs_fail, sb_search_fail,
2826 	    fast_fsync, crc8_fail_vhta, mcs_fail_vht;
2827 
2828 	cck_enable = rtw_read32(rtwdev, REG_ENCCK) & BIT_CCK_BLK_EN;
2829 	cck_fa_cnt = rtw_read16(rtwdev, REG_CCK_FACNT);
2830 
2831 	ofdm_fa_cnt1 = rtw_read32(rtwdev, REG_OFDM_FACNT1);
2832 	ofdm_fa_cnt2 = rtw_read32(rtwdev, REG_OFDM_FACNT2);
2833 	ofdm_fa_cnt3 = rtw_read32(rtwdev, REG_OFDM_FACNT3);
2834 	ofdm_fa_cnt4 = rtw_read32(rtwdev, REG_OFDM_FACNT4);
2835 	ofdm_fa_cnt5 = rtw_read32(rtwdev, REG_OFDM_FACNT5);
2836 
2837 	parity_fail	= FIELD_GET(GENMASK(31, 16), ofdm_fa_cnt1);
2838 	rate_illegal	= FIELD_GET(GENMASK(15, 0), ofdm_fa_cnt2);
2839 	crc8_fail	= FIELD_GET(GENMASK(31, 16), ofdm_fa_cnt2);
2840 	crc8_fail_vhta	= FIELD_GET(GENMASK(15, 0), ofdm_fa_cnt3);
2841 	mcs_fail	= FIELD_GET(GENMASK(15, 0), ofdm_fa_cnt4);
2842 	mcs_fail_vht	= FIELD_GET(GENMASK(31, 16), ofdm_fa_cnt4);
2843 	fast_fsync	= FIELD_GET(GENMASK(15, 0), ofdm_fa_cnt5);
2844 	sb_search_fail	= FIELD_GET(GENMASK(31, 16), ofdm_fa_cnt5);
2845 
2846 	ofdm_fa_cnt = parity_fail + rate_illegal + crc8_fail + crc8_fail_vhta +
2847 		      mcs_fail + mcs_fail_vht + fast_fsync + sb_search_fail;
2848 
2849 	dm_info->cck_fa_cnt = cck_fa_cnt;
2850 	dm_info->ofdm_fa_cnt = ofdm_fa_cnt;
2851 	dm_info->total_fa_cnt = ofdm_fa_cnt;
2852 	dm_info->total_fa_cnt += cck_enable ? cck_fa_cnt : 0;
2853 
2854 	crc32_cnt = rtw_read32(rtwdev, 0x2c04);
2855 	dm_info->cck_ok_cnt = crc32_cnt & 0xffff;
2856 	dm_info->cck_err_cnt = (crc32_cnt & 0xffff0000) >> 16;
2857 	crc32_cnt = rtw_read32(rtwdev, 0x2c14);
2858 	dm_info->ofdm_ok_cnt = crc32_cnt & 0xffff;
2859 	dm_info->ofdm_err_cnt = (crc32_cnt & 0xffff0000) >> 16;
2860 	crc32_cnt = rtw_read32(rtwdev, 0x2c10);
2861 	dm_info->ht_ok_cnt = crc32_cnt & 0xffff;
2862 	dm_info->ht_err_cnt = (crc32_cnt & 0xffff0000) >> 16;
2863 	crc32_cnt = rtw_read32(rtwdev, 0x2c0c);
2864 	dm_info->vht_ok_cnt = crc32_cnt & 0xffff;
2865 	dm_info->vht_err_cnt = (crc32_cnt & 0xffff0000) >> 16;
2866 
2867 	cca32_cnt = rtw_read32(rtwdev, 0x2c08);
2868 	dm_info->ofdm_cca_cnt = ((cca32_cnt & 0xffff0000) >> 16);
2869 	dm_info->cck_cca_cnt = cca32_cnt & 0xffff;
2870 	dm_info->total_cca_cnt = dm_info->ofdm_cca_cnt;
2871 	if (cck_enable)
2872 		dm_info->total_cca_cnt += dm_info->cck_cca_cnt;
2873 
2874 	rtw_write32_mask(rtwdev, REG_CCANRX, BIT_CCK_FA_RST, 0);
2875 	rtw_write32_mask(rtwdev, REG_CCANRX, BIT_CCK_FA_RST, 2);
2876 	rtw_write32_mask(rtwdev, REG_CCANRX, BIT_OFDM_FA_RST, 0);
2877 	rtw_write32_mask(rtwdev, REG_CCANRX, BIT_OFDM_FA_RST, 2);
2878 
2879 	/* disable rx clk gating to reset counters */
2880 	rtw_write32_clr(rtwdev, REG_RX_BREAK, BIT_COM_RX_GCK_EN);
2881 	rtw_write32_set(rtwdev, REG_CNT_CTRL, BIT_ALL_CNT_RST);
2882 	rtw_write32_clr(rtwdev, REG_CNT_CTRL, BIT_ALL_CNT_RST);
2883 	rtw_write32_set(rtwdev, REG_RX_BREAK, BIT_COM_RX_GCK_EN);
2884 }
2885 
2886 static void rtw8822c_do_lck(struct rtw_dev *rtwdev)
2887 {
2888 	u32 val;
2889 
2890 	rtw_write_rf(rtwdev, RF_PATH_A, RF_SYN_CTRL, RFREG_MASK, 0x80010);
2891 	rtw_write_rf(rtwdev, RF_PATH_A, RF_SYN_PFD, RFREG_MASK, 0x1F0FA);
2892 	fsleep(1);
2893 	rtw_write_rf(rtwdev, RF_PATH_A, RF_AAC_CTRL, RFREG_MASK, 0x80000);
2894 	rtw_write_rf(rtwdev, RF_PATH_A, RF_SYN_AAC, RFREG_MASK, 0x80001);
2895 	read_poll_timeout(rtw_read_rf, val, val != 0x1, 1000, 100000,
2896 			  true, rtwdev, RF_PATH_A, RF_AAC_CTRL, 0x1000);
2897 	rtw_write_rf(rtwdev, RF_PATH_A, RF_SYN_PFD, RFREG_MASK, 0x1F0F8);
2898 	rtw_write_rf(rtwdev, RF_PATH_B, RF_SYN_CTRL, RFREG_MASK, 0x80010);
2899 
2900 	rtw_write_rf(rtwdev, RF_PATH_A, RF_FAST_LCK, RFREG_MASK, 0x0f000);
2901 	rtw_write_rf(rtwdev, RF_PATH_A, RF_FAST_LCK, RFREG_MASK, 0x4f000);
2902 	fsleep(1);
2903 	rtw_write_rf(rtwdev, RF_PATH_A, RF_FAST_LCK, RFREG_MASK, 0x0f000);
2904 }
2905 
2906 static void rtw8822c_do_iqk(struct rtw_dev *rtwdev)
2907 {
2908 	struct rtw_iqk_para para = {0};
2909 	u8 iqk_chk;
2910 	int ret;
2911 
2912 	para.clear = 1;
2913 	rtw_fw_do_iqk(rtwdev, &para);
2914 
2915 	ret = read_poll_timeout(rtw_read8, iqk_chk, iqk_chk == IQK_DONE_8822C,
2916 				20000, 300000, false, rtwdev, REG_RPT_CIP);
2917 	if (ret)
2918 		rtw_warn(rtwdev, "failed to poll iqk status bit\n");
2919 
2920 	rtw_write8(rtwdev, REG_IQKSTAT, 0x0);
2921 }
2922 
2923 /* for coex */
2924 static void rtw8822c_coex_cfg_init(struct rtw_dev *rtwdev)
2925 {
2926 	/* enable TBTT nterrupt */
2927 	rtw_write8_set(rtwdev, REG_BCN_CTRL, BIT_EN_BCN_FUNCTION);
2928 
2929 	/* BT report packet sample rate */
2930 	/* 0x790[5:0]=0x5 */
2931 	rtw_write8_mask(rtwdev, REG_BT_TDMA_TIME, BIT_MASK_SAMPLE_RATE, 0x5);
2932 
2933 	/* enable BT counter statistics */
2934 	rtw_write8(rtwdev, REG_BT_STAT_CTRL, 0x1);
2935 
2936 	/* enable PTA (3-wire function form BT side) */
2937 	rtw_write32_set(rtwdev, REG_GPIO_MUXCFG, BIT_BT_PTA_EN);
2938 	rtw_write32_set(rtwdev, REG_GPIO_MUXCFG, BIT_PO_BT_PTA_PINS);
2939 
2940 	/* enable PTA (tx/rx signal form WiFi side) */
2941 	rtw_write8_set(rtwdev, REG_QUEUE_CTRL, BIT_PTA_WL_TX_EN);
2942 	/* wl tx signal to PTA not case EDCCA */
2943 	rtw_write8_clr(rtwdev, REG_QUEUE_CTRL, BIT_PTA_EDCCA_EN);
2944 	/* GNT_BT=1 while select both */
2945 	rtw_write16_set(rtwdev, REG_BT_COEX_V2, BIT_GNT_BT_POLARITY);
2946 	/* BT_CCA = ~GNT_WL_BB, not or GNT_BT_BB, LTE_Rx */
2947 	rtw_write8_clr(rtwdev, REG_DUMMY_PAGE4_V1, BIT_BTCCA_CTRL);
2948 
2949 	/* to avoid RF parameter error */
2950 	rtw_write_rf(rtwdev, RF_PATH_B, RF_MODOPT, 0xfffff, 0x40000);
2951 }
2952 
2953 static void rtw8822c_coex_cfg_gnt_fix(struct rtw_dev *rtwdev)
2954 {
2955 	struct rtw_coex *coex = &rtwdev->coex;
2956 	struct rtw_coex_stat *coex_stat = &coex->stat;
2957 	struct rtw_efuse *efuse = &rtwdev->efuse;
2958 	u32 rf_0x1;
2959 
2960 	if (coex_stat->gnt_workaround_state == coex_stat->wl_coex_mode)
2961 		return;
2962 
2963 	coex_stat->gnt_workaround_state = coex_stat->wl_coex_mode;
2964 
2965 	if ((coex_stat->kt_ver == 0 && coex->under_5g) || coex->freerun)
2966 		rf_0x1 = 0x40021;
2967 	else
2968 		rf_0x1 = 0x40000;
2969 
2970 	/* BT at S1 for Shared-Ant */
2971 	if (efuse->share_ant)
2972 		rf_0x1 |= BIT(13);
2973 
2974 	rtw_write_rf(rtwdev, RF_PATH_B, 0x1, 0xfffff, rf_0x1);
2975 
2976 	/* WL-S0 2G RF TRX cannot be masked by GNT_BT
2977 	 * enable "WLS0 BB chage RF mode if GNT_BT = 1" for shared-antenna type
2978 	 * disable:0x1860[3] = 1, enable:0x1860[3] = 0
2979 	 *
2980 	 * enable "DAC off if GNT_WL = 0" for non-shared-antenna
2981 	 * disable 0x1c30[22] = 0,
2982 	 * enable: 0x1c30[22] = 1, 0x1c38[12] = 0, 0x1c38[28] = 1
2983 	 */
2984 	if (coex_stat->wl_coex_mode == COEX_WLINK_2GFREE) {
2985 		rtw_write8_mask(rtwdev, REG_ANAPAR + 2,
2986 				BIT_ANAPAR_BTPS >> 16, 0);
2987 	} else {
2988 		rtw_write8_mask(rtwdev, REG_ANAPAR + 2,
2989 				BIT_ANAPAR_BTPS >> 16, 1);
2990 		rtw_write8_mask(rtwdev, REG_RSTB_SEL + 1,
2991 				BIT_DAC_OFF_ENABLE, 0);
2992 		rtw_write8_mask(rtwdev, REG_RSTB_SEL + 3,
2993 				BIT_DAC_OFF_ENABLE, 1);
2994 	}
2995 
2996 	/* disable WL-S1 BB chage RF mode if GNT_BT
2997 	 * since RF TRx mask can do it
2998 	 */
2999 	rtw_write8_mask(rtwdev, REG_IGN_GNTBT4,
3000 			BIT_PI_IGNORE_GNT_BT, 1);
3001 
3002 	/* disable WL-S0 BB chage RF mode if wifi is at 5G,
3003 	 * or antenna path is separated
3004 	 */
3005 	if (coex_stat->wl_coex_mode == COEX_WLINK_2GFREE) {
3006 		rtw_write8_mask(rtwdev, REG_IGN_GNT_BT1,
3007 				BIT_PI_IGNORE_GNT_BT, 1);
3008 		rtw_write8_mask(rtwdev, REG_NOMASK_TXBT,
3009 				BIT_NOMASK_TXBT_ENABLE, 1);
3010 	} else if (coex_stat->wl_coex_mode == COEX_WLINK_5G ||
3011 	    coex->under_5g || !efuse->share_ant) {
3012 		if (coex_stat->kt_ver >= 3) {
3013 			rtw_write8_mask(rtwdev, REG_IGN_GNT_BT1,
3014 					BIT_PI_IGNORE_GNT_BT, 0);
3015 			rtw_write8_mask(rtwdev, REG_NOMASK_TXBT,
3016 					BIT_NOMASK_TXBT_ENABLE, 1);
3017 		} else {
3018 			rtw_write8_mask(rtwdev, REG_IGN_GNT_BT1,
3019 					BIT_PI_IGNORE_GNT_BT, 1);
3020 		}
3021 	} else {
3022 		/* shared-antenna */
3023 		rtw_write8_mask(rtwdev, REG_IGN_GNT_BT1,
3024 				BIT_PI_IGNORE_GNT_BT, 0);
3025 		if (coex_stat->kt_ver >= 3) {
3026 			rtw_write8_mask(rtwdev, REG_NOMASK_TXBT,
3027 					BIT_NOMASK_TXBT_ENABLE, 0);
3028 		}
3029 	}
3030 }
3031 
3032 static void rtw8822c_coex_cfg_gnt_debug(struct rtw_dev *rtwdev)
3033 {
3034 	rtw_write8_mask(rtwdev, REG_PAD_CTRL1 + 2, BIT_BTGP_SPI_EN >> 16, 0);
3035 	rtw_write8_mask(rtwdev, REG_PAD_CTRL1 + 3, BIT_BTGP_JTAG_EN >> 24, 0);
3036 	rtw_write8_mask(rtwdev, REG_GPIO_MUXCFG + 2, BIT_FSPI_EN >> 16, 0);
3037 	rtw_write8_mask(rtwdev, REG_PAD_CTRL1 + 1, BIT_LED1DIS >> 8, 0);
3038 	rtw_write8_mask(rtwdev, REG_SYS_SDIO_CTRL + 3, BIT_DBG_GNT_WL_BT >> 24, 0);
3039 }
3040 
3041 static void rtw8822c_coex_cfg_rfe_type(struct rtw_dev *rtwdev)
3042 {
3043 	struct rtw_coex *coex = &rtwdev->coex;
3044 	struct rtw_coex_rfe *coex_rfe = &coex->rfe;
3045 	struct rtw_efuse *efuse = &rtwdev->efuse;
3046 
3047 	coex_rfe->rfe_module_type = rtwdev->efuse.rfe_option;
3048 	coex_rfe->ant_switch_polarity = 0;
3049 	coex_rfe->ant_switch_exist = false;
3050 	coex_rfe->ant_switch_with_bt = false;
3051 	coex_rfe->ant_switch_diversity = false;
3052 
3053 	if (efuse->share_ant)
3054 		coex_rfe->wlg_at_btg = true;
3055 	else
3056 		coex_rfe->wlg_at_btg = false;
3057 
3058 	/* disable LTE coex in wifi side */
3059 	rtw_coex_write_indirect_reg(rtwdev, LTE_COEX_CTRL, BIT_LTE_COEX_EN, 0x0);
3060 	rtw_coex_write_indirect_reg(rtwdev, LTE_WL_TRX_CTRL, MASKLWORD, 0xffff);
3061 	rtw_coex_write_indirect_reg(rtwdev, LTE_BT_TRX_CTRL, MASKLWORD, 0xffff);
3062 }
3063 
3064 static void rtw8822c_coex_cfg_wl_tx_power(struct rtw_dev *rtwdev, u8 wl_pwr)
3065 {
3066 	struct rtw_coex *coex = &rtwdev->coex;
3067 	struct rtw_coex_dm *coex_dm = &coex->dm;
3068 
3069 	if (wl_pwr == coex_dm->cur_wl_pwr_lvl)
3070 		return;
3071 
3072 	coex_dm->cur_wl_pwr_lvl = wl_pwr;
3073 }
3074 
3075 static void rtw8822c_coex_cfg_wl_rx_gain(struct rtw_dev *rtwdev, bool low_gain)
3076 {
3077 	struct rtw_coex *coex = &rtwdev->coex;
3078 	struct rtw_coex_dm *coex_dm = &coex->dm;
3079 
3080 	if (low_gain == coex_dm->cur_wl_rx_low_gain_en)
3081 		return;
3082 
3083 	coex_dm->cur_wl_rx_low_gain_en = low_gain;
3084 
3085 	if (coex_dm->cur_wl_rx_low_gain_en) {
3086 		rtw_dbg(rtwdev, RTW_DBG_COEX, "[BTCoex], Hi-Li Table On!\n");
3087 
3088 		/* set Rx filter corner RCK offset */
3089 		rtw_write_rf(rtwdev, RF_PATH_A, RF_RCKD, RFREG_MASK, 0x22);
3090 		rtw_write_rf(rtwdev, RF_PATH_A, RF_RCK, RFREG_MASK, 0x36);
3091 		rtw_write_rf(rtwdev, RF_PATH_B, RF_RCKD, RFREG_MASK, 0x22);
3092 		rtw_write_rf(rtwdev, RF_PATH_B, RF_RCK, RFREG_MASK, 0x36);
3093 
3094 	} else {
3095 		rtw_dbg(rtwdev, RTW_DBG_COEX, "[BTCoex], Hi-Li Table Off!\n");
3096 
3097 		/* set Rx filter corner RCK offset */
3098 		rtw_write_rf(rtwdev, RF_PATH_A, RF_RCKD, RFREG_MASK, 0x20);
3099 		rtw_write_rf(rtwdev, RF_PATH_A, RF_RCK, RFREG_MASK, 0x0);
3100 		rtw_write_rf(rtwdev, RF_PATH_B, RF_RCKD, RFREG_MASK, 0x20);
3101 		rtw_write_rf(rtwdev, RF_PATH_B, RF_RCK, RFREG_MASK, 0x0);
3102 	}
3103 }
3104 
3105 static void rtw8822c_bf_enable_bfee_su(struct rtw_dev *rtwdev,
3106 				       struct rtw_vif *vif,
3107 				       struct rtw_bfee *bfee)
3108 {
3109 	u8 csi_rsc = 0;
3110 	u32 tmp6dc;
3111 
3112 	rtw_bf_enable_bfee_su(rtwdev, vif, bfee);
3113 
3114 	tmp6dc = rtw_read32(rtwdev, REG_BBPSF_CTRL) |
3115 			    BIT_WMAC_USE_NDPARATE |
3116 			    (csi_rsc << 13);
3117 	if (vif->net_type == RTW_NET_AP_MODE)
3118 		rtw_write32(rtwdev, REG_BBPSF_CTRL, tmp6dc | BIT(12));
3119 	else
3120 		rtw_write32(rtwdev, REG_BBPSF_CTRL, tmp6dc & ~BIT(12));
3121 
3122 	rtw_write32(rtwdev, REG_CSI_RRSR, 0x550);
3123 }
3124 
3125 static void rtw8822c_bf_config_bfee_su(struct rtw_dev *rtwdev,
3126 				       struct rtw_vif *vif,
3127 				       struct rtw_bfee *bfee, bool enable)
3128 {
3129 	if (enable)
3130 		rtw8822c_bf_enable_bfee_su(rtwdev, vif, bfee);
3131 	else
3132 		rtw_bf_remove_bfee_su(rtwdev, bfee);
3133 }
3134 
3135 static void rtw8822c_bf_config_bfee_mu(struct rtw_dev *rtwdev,
3136 				       struct rtw_vif *vif,
3137 				       struct rtw_bfee *bfee, bool enable)
3138 {
3139 	if (enable)
3140 		rtw_bf_enable_bfee_mu(rtwdev, vif, bfee);
3141 	else
3142 		rtw_bf_remove_bfee_mu(rtwdev, bfee);
3143 }
3144 
3145 static void rtw8822c_bf_config_bfee(struct rtw_dev *rtwdev, struct rtw_vif *vif,
3146 				    struct rtw_bfee *bfee, bool enable)
3147 {
3148 	if (bfee->role == RTW_BFEE_SU)
3149 		rtw8822c_bf_config_bfee_su(rtwdev, vif, bfee, enable);
3150 	else if (bfee->role == RTW_BFEE_MU)
3151 		rtw8822c_bf_config_bfee_mu(rtwdev, vif, bfee, enable);
3152 	else
3153 		rtw_warn(rtwdev, "wrong bfee role\n");
3154 }
3155 
3156 struct dpk_cfg_pair {
3157 	u32 addr;
3158 	u32 bitmask;
3159 	u32 data;
3160 };
3161 
3162 void rtw8822c_parse_tbl_dpk(struct rtw_dev *rtwdev,
3163 			    const struct rtw_table *tbl)
3164 {
3165 	const struct dpk_cfg_pair *p = tbl->data;
3166 	const struct dpk_cfg_pair *end = p + tbl->size / 3;
3167 
3168 	BUILD_BUG_ON(sizeof(struct dpk_cfg_pair) != sizeof(u32) * 3);
3169 
3170 	for (; p < end; p++)
3171 		rtw_write32_mask(rtwdev, p->addr, p->bitmask, p->data);
3172 }
3173 
3174 static void rtw8822c_dpk_set_gnt_wl(struct rtw_dev *rtwdev, bool is_before_k)
3175 {
3176 	struct rtw_dpk_info *dpk_info = &rtwdev->dm_info.dpk_info;
3177 
3178 	if (is_before_k) {
3179 		dpk_info->gnt_control = rtw_read32(rtwdev, 0x70);
3180 		dpk_info->gnt_value = rtw_coex_read_indirect_reg(rtwdev, 0x38);
3181 		rtw_write32_mask(rtwdev, 0x70, BIT(26), 0x1);
3182 		rtw_coex_write_indirect_reg(rtwdev, 0x38, MASKBYTE1, 0x77);
3183 	} else {
3184 		rtw_coex_write_indirect_reg(rtwdev, 0x38, MASKDWORD,
3185 					    dpk_info->gnt_value);
3186 		rtw_write32(rtwdev, 0x70, dpk_info->gnt_control);
3187 	}
3188 }
3189 
3190 static void
3191 rtw8822c_dpk_restore_registers(struct rtw_dev *rtwdev, u32 reg_num,
3192 			       struct rtw_backup_info *bckp)
3193 {
3194 	rtw_restore_reg(rtwdev, bckp, reg_num);
3195 	rtw_write32_mask(rtwdev, REG_NCTL0, BIT_SUBPAGE, 0xc);
3196 	rtw_write32_mask(rtwdev, REG_RXSRAM_CTL, BIT_DPD_CLK, 0x4);
3197 }
3198 
3199 static void
3200 rtw8822c_dpk_backup_registers(struct rtw_dev *rtwdev, u32 *reg,
3201 			      u32 reg_num, struct rtw_backup_info *bckp)
3202 {
3203 	u32 i;
3204 
3205 	for (i = 0; i < reg_num; i++) {
3206 		bckp[i].len = 4;
3207 		bckp[i].reg = reg[i];
3208 		bckp[i].val = rtw_read32(rtwdev, reg[i]);
3209 	}
3210 }
3211 
3212 static void rtw8822c_dpk_backup_rf_registers(struct rtw_dev *rtwdev,
3213 					     u32 *rf_reg,
3214 					     u32 rf_reg_bak[][2])
3215 {
3216 	u32 i;
3217 
3218 	for (i = 0; i < DPK_RF_REG_NUM; i++) {
3219 		rf_reg_bak[i][RF_PATH_A] = rtw_read_rf(rtwdev, RF_PATH_A,
3220 						       rf_reg[i], RFREG_MASK);
3221 		rf_reg_bak[i][RF_PATH_B] = rtw_read_rf(rtwdev, RF_PATH_B,
3222 						       rf_reg[i], RFREG_MASK);
3223 	}
3224 }
3225 
3226 static void rtw8822c_dpk_reload_rf_registers(struct rtw_dev *rtwdev,
3227 					     u32 *rf_reg,
3228 					     u32 rf_reg_bak[][2])
3229 {
3230 	u32 i;
3231 
3232 	for (i = 0; i < DPK_RF_REG_NUM; i++) {
3233 		rtw_write_rf(rtwdev, RF_PATH_A, rf_reg[i], RFREG_MASK,
3234 			     rf_reg_bak[i][RF_PATH_A]);
3235 		rtw_write_rf(rtwdev, RF_PATH_B, rf_reg[i], RFREG_MASK,
3236 			     rf_reg_bak[i][RF_PATH_B]);
3237 	}
3238 }
3239 
3240 static void rtw8822c_dpk_information(struct rtw_dev *rtwdev)
3241 {
3242 	struct rtw_dpk_info *dpk_info = &rtwdev->dm_info.dpk_info;
3243 	u32  reg;
3244 	u8 band_shift;
3245 
3246 #if defined(__linux__)
3247 	reg = rtw_read_rf(rtwdev, RF_PATH_A, 0x18, RFREG_MASK);
3248 #elif defined(__FreeBSD__)
3249 	reg = rtw_read_rf(rtwdev, RF_PATH_A, RF_CFGCH, RFREG_MASK);
3250 #endif
3251 
3252 	band_shift = FIELD_GET(BIT(16), reg);
3253 	dpk_info->dpk_band = 1 << band_shift;
3254 	dpk_info->dpk_ch = FIELD_GET(0xff, reg);
3255 	dpk_info->dpk_bw = FIELD_GET(0x3000, reg);
3256 }
3257 
3258 static void rtw8822c_dpk_rxbb_dc_cal(struct rtw_dev *rtwdev, u8 path)
3259 {
3260 	rtw_write_rf(rtwdev, path, 0x92, RFREG_MASK, 0x84800);
3261 	udelay(5);
3262 	rtw_write_rf(rtwdev, path, 0x92, RFREG_MASK, 0x84801);
3263 	usleep_range(600, 610);
3264 	rtw_write_rf(rtwdev, path, 0x92, RFREG_MASK, 0x84800);
3265 }
3266 
3267 static u8 rtw8822c_dpk_dc_corr_check(struct rtw_dev *rtwdev, u8 path)
3268 {
3269 	u16 dc_i, dc_q;
3270 	u8 corr_idx;
3271 
3272 	rtw_write32(rtwdev, REG_RXSRAM_CTL, 0x000900f0);
3273 	dc_i = (u16)rtw_read32_mask(rtwdev, REG_STAT_RPT, GENMASK(27, 16));
3274 	dc_q = (u16)rtw_read32_mask(rtwdev, REG_STAT_RPT, GENMASK(11, 0));
3275 
3276 	if (dc_i & BIT(11))
3277 		dc_i = 0x1000 - dc_i;
3278 	if (dc_q & BIT(11))
3279 		dc_q = 0x1000 - dc_q;
3280 
3281 	rtw_write32(rtwdev, REG_RXSRAM_CTL, 0x000000f0);
3282 	corr_idx = (u8)rtw_read32_mask(rtwdev, REG_STAT_RPT, GENMASK(7, 0));
3283 	rtw_read32_mask(rtwdev, REG_STAT_RPT, GENMASK(15, 8));
3284 
3285 	if (dc_i > 200 || dc_q > 200 || corr_idx < 40 || corr_idx > 65)
3286 		return 1;
3287 	else
3288 		return 0;
3289 
3290 }
3291 
3292 static void rtw8822c_dpk_tx_pause(struct rtw_dev *rtwdev)
3293 {
3294 	u8 reg_a, reg_b;
3295 	u16 count = 0;
3296 
3297 	rtw_write8(rtwdev, 0x522, 0xff);
3298 	rtw_write32_mask(rtwdev, 0x1e70, 0xf, 0x2);
3299 
3300 	do {
3301 		reg_a = (u8)rtw_read_rf(rtwdev, RF_PATH_A, 0x00, 0xf0000);
3302 		reg_b = (u8)rtw_read_rf(rtwdev, RF_PATH_B, 0x00, 0xf0000);
3303 		udelay(2);
3304 		count++;
3305 	} while ((reg_a == 2 || reg_b == 2) && count < 2500);
3306 }
3307 
3308 static void rtw8822c_dpk_mac_bb_setting(struct rtw_dev *rtwdev)
3309 {
3310 	rtw8822c_dpk_tx_pause(rtwdev);
3311 	rtw_load_table(rtwdev, &rtw8822c_dpk_mac_bb_tbl);
3312 }
3313 
3314 static void rtw8822c_dpk_afe_setting(struct rtw_dev *rtwdev, bool is_do_dpk)
3315 {
3316 	if (is_do_dpk)
3317 		rtw_load_table(rtwdev, &rtw8822c_dpk_afe_is_dpk_tbl);
3318 	else
3319 		rtw_load_table(rtwdev, &rtw8822c_dpk_afe_no_dpk_tbl);
3320 }
3321 
3322 static void rtw8822c_dpk_pre_setting(struct rtw_dev *rtwdev)
3323 {
3324 	u8 path;
3325 
3326 	for (path = 0; path < rtwdev->hal.rf_path_num; path++) {
3327 		rtw_write_rf(rtwdev, path, RF_RXAGC_OFFSET, RFREG_MASK, 0x0);
3328 		rtw_write32(rtwdev, REG_NCTL0, 0x8 | (path << 1));
3329 		if (rtwdev->dm_info.dpk_info.dpk_band == RTW_BAND_2G)
3330 			rtw_write32(rtwdev, REG_DPD_CTL1_S1, 0x1f100000);
3331 		else
3332 			rtw_write32(rtwdev, REG_DPD_CTL1_S1, 0x1f0d0000);
3333 		rtw_write32_mask(rtwdev, REG_DPD_LUT0, BIT_GLOSS_DB, 0x4);
3334 		rtw_write32_mask(rtwdev, REG_IQK_CTL1, BIT_TX_CFIR, 0x3);
3335 	}
3336 	rtw_write32_mask(rtwdev, REG_NCTL0, BIT_SUBPAGE, 0xc);
3337 	rtw_write32(rtwdev, REG_DPD_CTL11, 0x3b23170b);
3338 	rtw_write32(rtwdev, REG_DPD_CTL12, 0x775f5347);
3339 }
3340 
3341 static u32 rtw8822c_dpk_rf_setting(struct rtw_dev *rtwdev, u8 path)
3342 {
3343 	u32 ori_txbb;
3344 
3345 	rtw_write_rf(rtwdev, path, RF_MODE_TRXAGC, RFREG_MASK, 0x50017);
3346 	ori_txbb = rtw_read_rf(rtwdev, path, RF_TX_GAIN, RFREG_MASK);
3347 
3348 	rtw_write_rf(rtwdev, path, RF_DEBUG, BIT_DE_TX_GAIN, 0x1);
3349 	rtw_write_rf(rtwdev, path, RF_DEBUG, BIT_DE_PWR_TRIM, 0x1);
3350 	rtw_write_rf(rtwdev, path, RF_TX_GAIN_OFFSET, BIT_BB_GAIN, 0x0);
3351 	rtw_write_rf(rtwdev, path, RF_TX_GAIN, RFREG_MASK, ori_txbb);
3352 
3353 	if (rtwdev->dm_info.dpk_info.dpk_band == RTW_BAND_2G) {
3354 		rtw_write_rf(rtwdev, path, RF_TX_GAIN_OFFSET, BIT_RF_GAIN, 0x1);
3355 		rtw_write_rf(rtwdev, path, RF_RXG_GAIN, BIT_RXG_GAIN, 0x0);
3356 	} else {
3357 		rtw_write_rf(rtwdev, path, RF_TXA_LB_SW, BIT_TXA_LB_ATT, 0x0);
3358 		rtw_write_rf(rtwdev, path, RF_TXA_LB_SW, BIT_LB_ATT, 0x6);
3359 		rtw_write_rf(rtwdev, path, RF_TXA_LB_SW, BIT_LB_SW, 0x1);
3360 		rtw_write_rf(rtwdev, path, RF_RXA_MIX_GAIN, BIT_RXA_MIX_GAIN, 0);
3361 	}
3362 
3363 	rtw_write_rf(rtwdev, path, RF_MODE_TRXAGC, BIT_RXAGC, 0xf);
3364 	rtw_write_rf(rtwdev, path, RF_DEBUG, BIT_DE_TRXBW, 0x1);
3365 	rtw_write_rf(rtwdev, path, RF_BW_TRXBB, BIT_BW_RXBB, 0x0);
3366 
3367 	if (rtwdev->dm_info.dpk_info.dpk_bw == DPK_CHANNEL_WIDTH_80)
3368 		rtw_write_rf(rtwdev, path, RF_BW_TRXBB, BIT_BW_TXBB, 0x2);
3369 	else
3370 		rtw_write_rf(rtwdev, path, RF_BW_TRXBB, BIT_BW_TXBB, 0x1);
3371 
3372 	rtw_write_rf(rtwdev, path, RF_EXT_TIA_BW, BIT(1), 0x1);
3373 
3374 	usleep_range(100, 110);
3375 
3376 	return ori_txbb & 0x1f;
3377 }
3378 
3379 static u16 rtw8822c_dpk_get_cmd(struct rtw_dev *rtwdev, u8 action, u8 path)
3380 {
3381 	u16 cmd;
3382 	u8 bw = rtwdev->dm_info.dpk_info.dpk_bw == DPK_CHANNEL_WIDTH_80 ? 2 : 0;
3383 
3384 	switch (action) {
3385 	case RTW_DPK_GAIN_LOSS:
3386 		cmd = 0x14 + path;
3387 		break;
3388 	case RTW_DPK_DO_DPK:
3389 		cmd = 0x16 + path + bw;
3390 		break;
3391 	case RTW_DPK_DPK_ON:
3392 		cmd = 0x1a + path;
3393 		break;
3394 	case RTW_DPK_DAGC:
3395 		cmd = 0x1c + path + bw;
3396 		break;
3397 	default:
3398 		return 0;
3399 	}
3400 
3401 	return (cmd << 8) | 0x48;
3402 }
3403 
3404 static u8 rtw8822c_dpk_one_shot(struct rtw_dev *rtwdev, u8 path, u8 action)
3405 {
3406 	u16 dpk_cmd;
3407 	u8 result = 0;
3408 
3409 	rtw8822c_dpk_set_gnt_wl(rtwdev, true);
3410 
3411 	if (action == RTW_DPK_CAL_PWR) {
3412 		rtw_write32_mask(rtwdev, REG_DPD_CTL0, BIT(12), 0x1);
3413 		rtw_write32_mask(rtwdev, REG_DPD_CTL0, BIT(12), 0x0);
3414 		rtw_write32_mask(rtwdev, REG_RXSRAM_CTL, BIT_RPT_SEL, 0x0);
3415 		msleep(10);
3416 		if (!check_hw_ready(rtwdev, REG_STAT_RPT, BIT(31), 0x1)) {
3417 			result = 1;
3418 			rtw_dbg(rtwdev, RTW_DBG_RFK, "[DPK] one-shot over 20ms\n");
3419 		}
3420 	} else {
3421 		rtw_write32_mask(rtwdev, REG_NCTL0, BIT_SUBPAGE,
3422 				 0x8 | (path << 1));
3423 		rtw_write32_mask(rtwdev, REG_R_CONFIG, BIT_IQ_SWITCH, 0x9);
3424 
3425 		dpk_cmd = rtw8822c_dpk_get_cmd(rtwdev, action, path);
3426 		rtw_write32(rtwdev, REG_NCTL0, dpk_cmd);
3427 		rtw_write32(rtwdev, REG_NCTL0, dpk_cmd + 1);
3428 		msleep(10);
3429 		if (!check_hw_ready(rtwdev, 0x2d9c, 0xff, 0x55)) {
3430 			result = 1;
3431 			rtw_dbg(rtwdev, RTW_DBG_RFK, "[DPK] one-shot over 20ms\n");
3432 		}
3433 		rtw_write32_mask(rtwdev, REG_NCTL0, BIT_SUBPAGE,
3434 				 0x8 | (path << 1));
3435 		rtw_write32_mask(rtwdev, REG_R_CONFIG, BIT_IQ_SWITCH, 0x0);
3436 	}
3437 
3438 	rtw8822c_dpk_set_gnt_wl(rtwdev, false);
3439 
3440 	rtw_write8(rtwdev, 0x1b10, 0x0);
3441 
3442 	return result;
3443 }
3444 
3445 static u16 rtw8822c_dpk_dgain_read(struct rtw_dev *rtwdev, u8 path)
3446 {
3447 	u16 dgain;
3448 
3449 	rtw_write32_mask(rtwdev, REG_NCTL0, BIT_SUBPAGE, 0xc);
3450 	rtw_write32_mask(rtwdev, REG_RXSRAM_CTL, 0x00ff0000, 0x0);
3451 
3452 	dgain = (u16)rtw_read32_mask(rtwdev, REG_STAT_RPT, GENMASK(27, 16));
3453 
3454 	return dgain;
3455 }
3456 
3457 static u8 rtw8822c_dpk_thermal_read(struct rtw_dev *rtwdev, u8 path)
3458 {
3459 	rtw_write_rf(rtwdev, path, RF_T_METER, BIT(19), 0x1);
3460 	rtw_write_rf(rtwdev, path, RF_T_METER, BIT(19), 0x0);
3461 	rtw_write_rf(rtwdev, path, RF_T_METER, BIT(19), 0x1);
3462 	udelay(15);
3463 
3464 	return (u8)rtw_read_rf(rtwdev, path, RF_T_METER, 0x0007e);
3465 }
3466 
3467 static u32 rtw8822c_dpk_pas_read(struct rtw_dev *rtwdev, u8 path)
3468 {
3469 	u32 i_val, q_val;
3470 
3471 	rtw_write32(rtwdev, REG_NCTL0, 0x8 | (path << 1));
3472 	rtw_write32_mask(rtwdev, 0x1b48, BIT(14), 0x0);
3473 	rtw_write32(rtwdev, REG_RXSRAM_CTL, 0x00060001);
3474 	rtw_write32(rtwdev, 0x1b4c, 0x00000000);
3475 	rtw_write32(rtwdev, 0x1b4c, 0x00080000);
3476 
3477 	q_val = rtw_read32_mask(rtwdev, REG_STAT_RPT, MASKHWORD);
3478 	i_val = rtw_read32_mask(rtwdev, REG_STAT_RPT, MASKLWORD);
3479 
3480 	if (i_val & BIT(15))
3481 		i_val = 0x10000 - i_val;
3482 	if (q_val & BIT(15))
3483 		q_val = 0x10000 - q_val;
3484 
3485 	rtw_write32(rtwdev, 0x1b4c, 0x00000000);
3486 
3487 	return i_val * i_val + q_val * q_val;
3488 }
3489 
3490 static u32 rtw8822c_psd_log2base(u32 val)
3491 {
3492 	u32 tmp, val_integerd_b, tindex;
3493 	u32 result, val_fractiond_b;
3494 	u32 table_fraction[21] = {0, 432, 332, 274, 232, 200, 174,
3495 				  151, 132, 115, 100, 86, 74, 62, 51,
3496 				  42, 32, 23, 15, 7, 0};
3497 
3498 	if (val == 0)
3499 		return 0;
3500 
3501 	val_integerd_b = __fls(val) + 1;
3502 
3503 	tmp = (val * 100) / (1 << val_integerd_b);
3504 	tindex = tmp / 5;
3505 
3506 	if (tindex >= ARRAY_SIZE(table_fraction))
3507 		tindex = ARRAY_SIZE(table_fraction) - 1;
3508 
3509 	val_fractiond_b = table_fraction[tindex];
3510 
3511 	result = val_integerd_b * 100 - val_fractiond_b;
3512 
3513 	return result;
3514 }
3515 
3516 static u8 rtw8822c_dpk_gainloss_result(struct rtw_dev *rtwdev, u8 path)
3517 {
3518 	u8 result;
3519 
3520 	rtw_write32_mask(rtwdev, REG_NCTL0, BIT_SUBPAGE, 0x8 | (path << 1));
3521 	rtw_write32_mask(rtwdev, 0x1b48, BIT(14), 0x1);
3522 	rtw_write32(rtwdev, REG_RXSRAM_CTL, 0x00060000);
3523 
3524 	result = (u8)rtw_read32_mask(rtwdev, REG_STAT_RPT, 0x000000f0);
3525 
3526 	rtw_write32_mask(rtwdev, 0x1b48, BIT(14), 0x0);
3527 
3528 	return result;
3529 }
3530 
3531 static u8 rtw8822c_dpk_agc_gain_chk(struct rtw_dev *rtwdev, u8 path,
3532 				    u8 limited_pga)
3533 {
3534 	u8 result = 0;
3535 	u16 dgain;
3536 
3537 	rtw8822c_dpk_one_shot(rtwdev, path, RTW_DPK_DAGC);
3538 	dgain = rtw8822c_dpk_dgain_read(rtwdev, path);
3539 
3540 	if (dgain > 1535 && !limited_pga)
3541 		return RTW_DPK_GAIN_LESS;
3542 	else if (dgain < 768 && !limited_pga)
3543 		return RTW_DPK_GAIN_LARGE;
3544 	else
3545 		return result;
3546 }
3547 
3548 static u8 rtw8822c_dpk_agc_loss_chk(struct rtw_dev *rtwdev, u8 path)
3549 {
3550 	u32 loss, loss_db;
3551 
3552 	loss = rtw8822c_dpk_pas_read(rtwdev, path);
3553 	if (loss < 0x4000000)
3554 		return RTW_DPK_GL_LESS;
3555 	loss_db = 3 * rtw8822c_psd_log2base(loss >> 13) - 3870;
3556 
3557 	if (loss_db > 1000)
3558 		return RTW_DPK_GL_LARGE;
3559 	else if (loss_db < 250)
3560 		return RTW_DPK_GL_LESS;
3561 	else
3562 		return RTW_DPK_AGC_OUT;
3563 }
3564 
3565 struct rtw8822c_dpk_data {
3566 	u8 txbb;
3567 	u8 pga;
3568 	u8 limited_pga;
3569 	u8 agc_cnt;
3570 	bool loss_only;
3571 	bool gain_only;
3572 	u8 path;
3573 };
3574 
3575 static u8 rtw8822c_gain_check_state(struct rtw_dev *rtwdev,
3576 				    struct rtw8822c_dpk_data *data)
3577 {
3578 	u8 state;
3579 
3580 	data->txbb = (u8)rtw_read_rf(rtwdev, data->path, RF_TX_GAIN,
3581 				     BIT_GAIN_TXBB);
3582 	data->pga = (u8)rtw_read_rf(rtwdev, data->path, RF_MODE_TRXAGC,
3583 				    BIT_RXAGC);
3584 
3585 	if (data->loss_only) {
3586 		state = RTW_DPK_LOSS_CHECK;
3587 		goto check_end;
3588 	}
3589 
3590 	state = rtw8822c_dpk_agc_gain_chk(rtwdev, data->path,
3591 					  data->limited_pga);
3592 	if (state == RTW_DPK_GAIN_CHECK && data->gain_only)
3593 		state = RTW_DPK_AGC_OUT;
3594 	else if (state == RTW_DPK_GAIN_CHECK)
3595 		state = RTW_DPK_LOSS_CHECK;
3596 
3597 check_end:
3598 	data->agc_cnt++;
3599 	if (data->agc_cnt >= 6)
3600 		state = RTW_DPK_AGC_OUT;
3601 
3602 	return state;
3603 }
3604 
3605 static u8 rtw8822c_gain_large_state(struct rtw_dev *rtwdev,
3606 				    struct rtw8822c_dpk_data *data)
3607 {
3608 	u8 pga = data->pga;
3609 
3610 	if (pga > 0xe)
3611 		rtw_write_rf(rtwdev, data->path, RF_MODE_TRXAGC, BIT_RXAGC, 0xc);
3612 	else if (pga > 0xb && pga < 0xf)
3613 		rtw_write_rf(rtwdev, data->path, RF_MODE_TRXAGC, BIT_RXAGC, 0x0);
3614 	else if (pga < 0xc)
3615 		data->limited_pga = 1;
3616 
3617 	return RTW_DPK_GAIN_CHECK;
3618 }
3619 
3620 static u8 rtw8822c_gain_less_state(struct rtw_dev *rtwdev,
3621 				   struct rtw8822c_dpk_data *data)
3622 {
3623 	u8 pga = data->pga;
3624 
3625 	if (pga < 0xc)
3626 		rtw_write_rf(rtwdev, data->path, RF_MODE_TRXAGC, BIT_RXAGC, 0xc);
3627 	else if (pga > 0xb && pga < 0xf)
3628 		rtw_write_rf(rtwdev, data->path, RF_MODE_TRXAGC, BIT_RXAGC, 0xf);
3629 	else if (pga > 0xe)
3630 		data->limited_pga = 1;
3631 
3632 	return RTW_DPK_GAIN_CHECK;
3633 }
3634 
3635 static u8 rtw8822c_gl_state(struct rtw_dev *rtwdev,
3636 			    struct rtw8822c_dpk_data *data, u8 is_large)
3637 {
3638 	u8 txbb_bound[] = {0x1f, 0};
3639 
3640 	if (data->txbb == txbb_bound[is_large])
3641 		return RTW_DPK_AGC_OUT;
3642 
3643 	if (is_large == 1)
3644 		data->txbb -= 2;
3645 	else
3646 		data->txbb += 3;
3647 
3648 	rtw_write_rf(rtwdev, data->path, RF_TX_GAIN, BIT_GAIN_TXBB, data->txbb);
3649 	data->limited_pga = 0;
3650 
3651 	return RTW_DPK_GAIN_CHECK;
3652 }
3653 
3654 static u8 rtw8822c_gl_large_state(struct rtw_dev *rtwdev,
3655 				  struct rtw8822c_dpk_data *data)
3656 {
3657 	return rtw8822c_gl_state(rtwdev, data, 1);
3658 }
3659 
3660 static u8 rtw8822c_gl_less_state(struct rtw_dev *rtwdev,
3661 				 struct rtw8822c_dpk_data *data)
3662 {
3663 	return rtw8822c_gl_state(rtwdev, data, 0);
3664 }
3665 
3666 static u8 rtw8822c_loss_check_state(struct rtw_dev *rtwdev,
3667 				    struct rtw8822c_dpk_data *data)
3668 {
3669 	u8 path = data->path;
3670 	u8 state;
3671 
3672 	rtw8822c_dpk_one_shot(rtwdev, path, RTW_DPK_GAIN_LOSS);
3673 	state = rtw8822c_dpk_agc_loss_chk(rtwdev, path);
3674 
3675 	return state;
3676 }
3677 
3678 static u8 (*dpk_state[])(struct rtw_dev *rtwdev,
3679 			  struct rtw8822c_dpk_data *data) = {
3680 	rtw8822c_gain_check_state, rtw8822c_gain_large_state,
3681 	rtw8822c_gain_less_state, rtw8822c_gl_large_state,
3682 	rtw8822c_gl_less_state, rtw8822c_loss_check_state };
3683 
3684 static u8 rtw8822c_dpk_pas_agc(struct rtw_dev *rtwdev, u8 path,
3685 			       bool gain_only, bool loss_only)
3686 {
3687 	struct rtw8822c_dpk_data data = {0};
3688 	u8 (*func)(struct rtw_dev *rtwdev, struct rtw8822c_dpk_data *data);
3689 	u8 state = RTW_DPK_GAIN_CHECK;
3690 
3691 	data.loss_only = loss_only;
3692 	data.gain_only = gain_only;
3693 	data.path = path;
3694 
3695 	for (;;) {
3696 		func = dpk_state[state];
3697 		state = func(rtwdev, &data);
3698 		if (state == RTW_DPK_AGC_OUT)
3699 			break;
3700 	}
3701 
3702 	return data.txbb;
3703 }
3704 
3705 static bool rtw8822c_dpk_coef_iq_check(struct rtw_dev *rtwdev,
3706 				       u16 coef_i, u16 coef_q)
3707 {
3708 	if (coef_i == 0x1000 || coef_i == 0x0fff ||
3709 	    coef_q == 0x1000 || coef_q == 0x0fff)
3710 		return true;
3711 
3712 	return false;
3713 }
3714 
3715 static u32 rtw8822c_dpk_coef_transfer(struct rtw_dev *rtwdev)
3716 {
3717 	u32 reg = 0;
3718 	u16 coef_i = 0, coef_q = 0;
3719 
3720 	reg = rtw_read32(rtwdev, REG_STAT_RPT);
3721 
3722 	coef_i = (u16)rtw_read32_mask(rtwdev, REG_STAT_RPT, MASKHWORD) & 0x1fff;
3723 	coef_q = (u16)rtw_read32_mask(rtwdev, REG_STAT_RPT, MASKLWORD) & 0x1fff;
3724 
3725 	coef_q = ((0x2000 - coef_q) & 0x1fff) - 1;
3726 
3727 	reg = (coef_i << 16) | coef_q;
3728 
3729 	return reg;
3730 }
3731 
3732 static const u32 rtw8822c_dpk_get_coef_tbl[] = {
3733 	0x000400f0, 0x040400f0, 0x080400f0, 0x010400f0, 0x050400f0,
3734 	0x090400f0, 0x020400f0, 0x060400f0, 0x0a0400f0, 0x030400f0,
3735 	0x070400f0, 0x0b0400f0, 0x0c0400f0, 0x100400f0, 0x0d0400f0,
3736 	0x110400f0, 0x0e0400f0, 0x120400f0, 0x0f0400f0, 0x130400f0,
3737 };
3738 
3739 static void rtw8822c_dpk_coef_tbl_apply(struct rtw_dev *rtwdev, u8 path)
3740 {
3741 	struct rtw_dpk_info *dpk_info = &rtwdev->dm_info.dpk_info;
3742 	int i;
3743 
3744 	for (i = 0; i < 20; i++) {
3745 		rtw_write32(rtwdev, REG_RXSRAM_CTL,
3746 			    rtw8822c_dpk_get_coef_tbl[i]);
3747 		dpk_info->coef[path][i] = rtw8822c_dpk_coef_transfer(rtwdev);
3748 	}
3749 }
3750 
3751 static void rtw8822c_dpk_get_coef(struct rtw_dev *rtwdev, u8 path)
3752 {
3753 	rtw_write32(rtwdev, REG_NCTL0, 0x0000000c);
3754 
3755 	if (path == RF_PATH_A) {
3756 		rtw_write32_mask(rtwdev, REG_DPD_CTL0, BIT(24), 0x0);
3757 		rtw_write32(rtwdev, REG_DPD_CTL0_S0, 0x30000080);
3758 	} else if (path == RF_PATH_B) {
3759 		rtw_write32_mask(rtwdev, REG_DPD_CTL0, BIT(24), 0x1);
3760 		rtw_write32(rtwdev, REG_DPD_CTL0_S1, 0x30000080);
3761 	}
3762 
3763 	rtw8822c_dpk_coef_tbl_apply(rtwdev, path);
3764 }
3765 
3766 static u8 rtw8822c_dpk_coef_read(struct rtw_dev *rtwdev, u8 path)
3767 {
3768 	struct rtw_dpk_info *dpk_info = &rtwdev->dm_info.dpk_info;
3769 	u8 addr, result = 1;
3770 	u16 coef_i, coef_q;
3771 
3772 	for (addr = 0; addr < 20; addr++) {
3773 		coef_i = FIELD_GET(0x1fff0000, dpk_info->coef[path][addr]);
3774 		coef_q = FIELD_GET(0x1fff, dpk_info->coef[path][addr]);
3775 
3776 		if (rtw8822c_dpk_coef_iq_check(rtwdev, coef_i, coef_q)) {
3777 			result = 0;
3778 			break;
3779 		}
3780 	}
3781 	return result;
3782 }
3783 
3784 static void rtw8822c_dpk_coef_write(struct rtw_dev *rtwdev, u8 path, u8 result)
3785 {
3786 	struct rtw_dpk_info *dpk_info = &rtwdev->dm_info.dpk_info;
3787 	u16 reg[DPK_RF_PATH_NUM] = {0x1b0c, 0x1b64};
3788 	u32 coef;
3789 	u8 addr;
3790 
3791 	rtw_write32(rtwdev, REG_NCTL0, 0x0000000c);
3792 	rtw_write32(rtwdev, REG_RXSRAM_CTL, 0x000000f0);
3793 
3794 	for (addr = 0; addr < 20; addr++) {
3795 		if (result == 0) {
3796 			if (addr == 3)
3797 				coef = 0x04001fff;
3798 			else
3799 				coef = 0x00001fff;
3800 		} else {
3801 			coef = dpk_info->coef[path][addr];
3802 		}
3803 		rtw_write32(rtwdev, reg[path] + addr * 4, coef);
3804 	}
3805 }
3806 
3807 static void rtw8822c_dpk_fill_result(struct rtw_dev *rtwdev, u32 dpk_txagc,
3808 				     u8 path, u8 result)
3809 {
3810 	struct rtw_dpk_info *dpk_info = &rtwdev->dm_info.dpk_info;
3811 
3812 	rtw_write32_mask(rtwdev, REG_NCTL0, BIT_SUBPAGE, 0x8 | (path << 1));
3813 
3814 	if (result)
3815 		rtw_write8(rtwdev, REG_DPD_AGC, (u8)(dpk_txagc - 6));
3816 	else
3817 		rtw_write8(rtwdev, REG_DPD_AGC, 0x00);
3818 
3819 	dpk_info->result[path] = result;
3820 	dpk_info->dpk_txagc[path] = rtw_read8(rtwdev, REG_DPD_AGC);
3821 
3822 	rtw8822c_dpk_coef_write(rtwdev, path, result);
3823 }
3824 
3825 static u32 rtw8822c_dpk_gainloss(struct rtw_dev *rtwdev, u8 path)
3826 {
3827 	struct rtw_dpk_info *dpk_info = &rtwdev->dm_info.dpk_info;
3828 	u8 tx_agc, tx_bb, ori_txbb, ori_txagc, tx_agc_search, t1, t2;
3829 
3830 	ori_txbb = rtw8822c_dpk_rf_setting(rtwdev, path);
3831 	ori_txagc = (u8)rtw_read_rf(rtwdev, path, RF_MODE_TRXAGC, BIT_TXAGC);
3832 
3833 	rtw8822c_dpk_rxbb_dc_cal(rtwdev, path);
3834 	rtw8822c_dpk_one_shot(rtwdev, path, RTW_DPK_DAGC);
3835 	rtw8822c_dpk_dgain_read(rtwdev, path);
3836 
3837 	if (rtw8822c_dpk_dc_corr_check(rtwdev, path)) {
3838 		rtw8822c_dpk_rxbb_dc_cal(rtwdev, path);
3839 		rtw8822c_dpk_one_shot(rtwdev, path, RTW_DPK_DAGC);
3840 		rtw8822c_dpk_dc_corr_check(rtwdev, path);
3841 	}
3842 
3843 	t1 = rtw8822c_dpk_thermal_read(rtwdev, path);
3844 	tx_bb = rtw8822c_dpk_pas_agc(rtwdev, path, false, true);
3845 	tx_agc_search = rtw8822c_dpk_gainloss_result(rtwdev, path);
3846 
3847 	if (tx_bb < tx_agc_search)
3848 		tx_bb = 0;
3849 	else
3850 		tx_bb = tx_bb - tx_agc_search;
3851 
3852 	rtw_write_rf(rtwdev, path, RF_TX_GAIN, BIT_GAIN_TXBB, tx_bb);
3853 
3854 	tx_agc = ori_txagc - (ori_txbb - tx_bb);
3855 
3856 	t2 = rtw8822c_dpk_thermal_read(rtwdev, path);
3857 
3858 	dpk_info->thermal_dpk_delta[path] = abs(t2 - t1);
3859 
3860 	return tx_agc;
3861 }
3862 
3863 static u8 rtw8822c_dpk_by_path(struct rtw_dev *rtwdev, u32 tx_agc, u8 path)
3864 {
3865 	u8 result;
3866 
3867 	result = rtw8822c_dpk_one_shot(rtwdev, path, RTW_DPK_DO_DPK);
3868 
3869 	rtw_write32_mask(rtwdev, REG_NCTL0, BIT_SUBPAGE, 0x8 | (path << 1));
3870 
3871 	result = result | (u8)rtw_read32_mask(rtwdev, REG_DPD_CTL1_S0, BIT(26));
3872 
3873 	rtw_write_rf(rtwdev, path, RF_MODE_TRXAGC, RFREG_MASK, 0x33e14);
3874 
3875 	rtw8822c_dpk_get_coef(rtwdev, path);
3876 
3877 	return result;
3878 }
3879 
3880 static void rtw8822c_dpk_cal_gs(struct rtw_dev *rtwdev, u8 path)
3881 {
3882 	struct rtw_dpk_info *dpk_info = &rtwdev->dm_info.dpk_info;
3883 	u32 tmp_gs = 0;
3884 
3885 	rtw_write32_mask(rtwdev, REG_NCTL0, BIT_SUBPAGE, 0x8 | (path << 1));
3886 	rtw_write32_mask(rtwdev, REG_IQK_CTL1, BIT_BYPASS_DPD, 0x0);
3887 	rtw_write32_mask(rtwdev, REG_IQK_CTL1, BIT_TX_CFIR, 0x0);
3888 	rtw_write32_mask(rtwdev, REG_R_CONFIG, BIT_IQ_SWITCH, 0x9);
3889 	rtw_write32_mask(rtwdev, REG_R_CONFIG, BIT_INNER_LB, 0x1);
3890 	rtw_write32_mask(rtwdev, REG_NCTL0, BIT_SUBPAGE, 0xc);
3891 	rtw_write32_mask(rtwdev, REG_RXSRAM_CTL, BIT_DPD_CLK, 0xf);
3892 
3893 	if (path == RF_PATH_A) {
3894 		rtw_write32_mask(rtwdev, REG_DPD_CTL0_S0, BIT_GS_PWSF,
3895 				 0x1066680);
3896 		rtw_write32_mask(rtwdev, REG_DPD_CTL1_S0, BIT_DPD_EN, 0x1);
3897 	} else {
3898 		rtw_write32_mask(rtwdev, REG_DPD_CTL0_S1, BIT_GS_PWSF,
3899 				 0x1066680);
3900 		rtw_write32_mask(rtwdev, REG_DPD_CTL1_S1, BIT_DPD_EN, 0x1);
3901 	}
3902 
3903 	if (dpk_info->dpk_bw == DPK_CHANNEL_WIDTH_80) {
3904 		rtw_write32(rtwdev, REG_DPD_CTL16, 0x80001310);
3905 		rtw_write32(rtwdev, REG_DPD_CTL16, 0x00001310);
3906 		rtw_write32(rtwdev, REG_DPD_CTL16, 0x810000db);
3907 		rtw_write32(rtwdev, REG_DPD_CTL16, 0x010000db);
3908 		rtw_write32(rtwdev, REG_DPD_CTL16, 0x0000b428);
3909 		rtw_write32(rtwdev, REG_DPD_CTL15,
3910 			    0x05020000 | (BIT(path) << 28));
3911 	} else {
3912 		rtw_write32(rtwdev, REG_DPD_CTL16, 0x8200190c);
3913 		rtw_write32(rtwdev, REG_DPD_CTL16, 0x0200190c);
3914 		rtw_write32(rtwdev, REG_DPD_CTL16, 0x8301ee14);
3915 		rtw_write32(rtwdev, REG_DPD_CTL16, 0x0301ee14);
3916 		rtw_write32(rtwdev, REG_DPD_CTL16, 0x0000b428);
3917 		rtw_write32(rtwdev, REG_DPD_CTL15,
3918 			    0x05020008 | (BIT(path) << 28));
3919 	}
3920 
3921 	rtw_write32_mask(rtwdev, REG_DPD_CTL0, MASKBYTE3, 0x8 | path);
3922 
3923 	rtw8822c_dpk_one_shot(rtwdev, path, RTW_DPK_CAL_PWR);
3924 
3925 	rtw_write32_mask(rtwdev, REG_DPD_CTL15, MASKBYTE3, 0x0);
3926 	rtw_write32_mask(rtwdev, REG_NCTL0, BIT_SUBPAGE, 0x8 | (path << 1));
3927 	rtw_write32_mask(rtwdev, REG_R_CONFIG, BIT_IQ_SWITCH, 0x0);
3928 	rtw_write32_mask(rtwdev, REG_R_CONFIG, BIT_INNER_LB, 0x0);
3929 	rtw_write32_mask(rtwdev, REG_NCTL0, BIT_SUBPAGE, 0xc);
3930 
3931 	if (path == RF_PATH_A)
3932 		rtw_write32_mask(rtwdev, REG_DPD_CTL0_S0, BIT_GS_PWSF, 0x5b);
3933 	else
3934 		rtw_write32_mask(rtwdev, REG_DPD_CTL0_S1, BIT_GS_PWSF, 0x5b);
3935 
3936 	rtw_write32_mask(rtwdev, REG_RXSRAM_CTL, BIT_RPT_SEL, 0x0);
3937 
3938 	tmp_gs = (u16)rtw_read32_mask(rtwdev, REG_STAT_RPT, BIT_RPT_DGAIN);
3939 	tmp_gs = (tmp_gs * 910) >> 10;
3940 	tmp_gs = DIV_ROUND_CLOSEST(tmp_gs, 10);
3941 
3942 	if (path == RF_PATH_A)
3943 		rtw_write32_mask(rtwdev, REG_DPD_CTL0_S0, BIT_GS_PWSF, tmp_gs);
3944 	else
3945 		rtw_write32_mask(rtwdev, REG_DPD_CTL0_S1, BIT_GS_PWSF, tmp_gs);
3946 
3947 	dpk_info->dpk_gs[path] = tmp_gs;
3948 }
3949 
3950 static void rtw8822c_dpk_cal_coef1(struct rtw_dev *rtwdev)
3951 {
3952 	struct rtw_dpk_info *dpk_info = &rtwdev->dm_info.dpk_info;
3953 	u32 offset[DPK_RF_PATH_NUM] = {0, 0x58};
3954 	u32 i_scaling;
3955 	u8 path;
3956 
3957 	rtw_write32_mask(rtwdev, REG_NCTL0, BIT_SUBPAGE, 0x0000000c);
3958 	rtw_write32(rtwdev, REG_RXSRAM_CTL, 0x000000f0);
3959 	rtw_write32(rtwdev, REG_NCTL0, 0x00001148);
3960 	rtw_write32(rtwdev, REG_NCTL0, 0x00001149);
3961 
3962 	check_hw_ready(rtwdev, 0x2d9c, MASKBYTE0, 0x55);
3963 
3964 	rtw_write8(rtwdev, 0x1b10, 0x0);
3965 	rtw_write32_mask(rtwdev, REG_NCTL0, BIT_SUBPAGE, 0x0000000c);
3966 
3967 	for (path = 0; path < rtwdev->hal.rf_path_num; path++) {
3968 		i_scaling = 0x16c00 / dpk_info->dpk_gs[path];
3969 
3970 		rtw_write32_mask(rtwdev, 0x1b18 + offset[path], MASKHWORD,
3971 				 i_scaling);
3972 		rtw_write32_mask(rtwdev, REG_DPD_CTL0_S0 + offset[path],
3973 				 GENMASK(31, 28), 0x9);
3974 		rtw_write32_mask(rtwdev, REG_DPD_CTL0_S0 + offset[path],
3975 				 GENMASK(31, 28), 0x1);
3976 		rtw_write32_mask(rtwdev, REG_DPD_CTL0_S0 + offset[path],
3977 				 GENMASK(31, 28), 0x0);
3978 		rtw_write32_mask(rtwdev, REG_DPD_CTL1_S0 + offset[path],
3979 				 BIT(14), 0x0);
3980 	}
3981 }
3982 
3983 static void rtw8822c_dpk_on(struct rtw_dev *rtwdev, u8 path)
3984 {
3985 	struct rtw_dpk_info *dpk_info = &rtwdev->dm_info.dpk_info;
3986 
3987 	rtw8822c_dpk_one_shot(rtwdev, path, RTW_DPK_DPK_ON);
3988 
3989 	rtw_write32_mask(rtwdev, REG_NCTL0, BIT_SUBPAGE, 0x8 | (path << 1));
3990 	rtw_write32_mask(rtwdev, REG_IQK_CTL1, BIT_TX_CFIR, 0x0);
3991 
3992 	if (test_bit(path, dpk_info->dpk_path_ok))
3993 		rtw8822c_dpk_cal_gs(rtwdev, path);
3994 }
3995 
3996 static bool rtw8822c_dpk_check_pass(struct rtw_dev *rtwdev, bool is_fail,
3997 				    u32 dpk_txagc, u8 path)
3998 {
3999 	bool result;
4000 
4001 	if (!is_fail) {
4002 		if (rtw8822c_dpk_coef_read(rtwdev, path))
4003 			result = true;
4004 		else
4005 			result = false;
4006 	} else {
4007 		result = false;
4008 	}
4009 
4010 	rtw8822c_dpk_fill_result(rtwdev, dpk_txagc, path, result);
4011 
4012 	return result;
4013 }
4014 
4015 static void rtw8822c_dpk_result_reset(struct rtw_dev *rtwdev)
4016 {
4017 	struct rtw_dpk_info *dpk_info = &rtwdev->dm_info.dpk_info;
4018 	u8 path;
4019 
4020 	for (path = 0; path < rtwdev->hal.rf_path_num; path++) {
4021 		clear_bit(path, dpk_info->dpk_path_ok);
4022 		rtw_write32_mask(rtwdev, REG_NCTL0, BIT_SUBPAGE,
4023 				 0x8 | (path << 1));
4024 		rtw_write32_mask(rtwdev, 0x1b58, 0x0000007f, 0x0);
4025 
4026 		dpk_info->dpk_txagc[path] = 0;
4027 		dpk_info->result[path] = 0;
4028 		dpk_info->dpk_gs[path] = 0x5b;
4029 		dpk_info->pre_pwsf[path] = 0;
4030 		dpk_info->thermal_dpk[path] = rtw8822c_dpk_thermal_read(rtwdev,
4031 									path);
4032 	}
4033 }
4034 
4035 static void rtw8822c_dpk_calibrate(struct rtw_dev *rtwdev, u8 path)
4036 {
4037 	struct rtw_dpk_info *dpk_info = &rtwdev->dm_info.dpk_info;
4038 	u32 dpk_txagc;
4039 	u8 dpk_fail;
4040 
4041 	rtw_dbg(rtwdev, RTW_DBG_RFK, "[DPK] s%d dpk start\n", path);
4042 
4043 	dpk_txagc = rtw8822c_dpk_gainloss(rtwdev, path);
4044 
4045 	dpk_fail = rtw8822c_dpk_by_path(rtwdev, dpk_txagc, path);
4046 
4047 	if (!rtw8822c_dpk_check_pass(rtwdev, dpk_fail, dpk_txagc, path))
4048 		rtw_err(rtwdev, "failed to do dpk calibration\n");
4049 
4050 	rtw_dbg(rtwdev, RTW_DBG_RFK, "[DPK] s%d dpk finish\n", path);
4051 
4052 	if (dpk_info->result[path])
4053 		set_bit(path, dpk_info->dpk_path_ok);
4054 }
4055 
4056 static void rtw8822c_dpk_path_select(struct rtw_dev *rtwdev)
4057 {
4058 	rtw8822c_dpk_calibrate(rtwdev, RF_PATH_A);
4059 	rtw8822c_dpk_calibrate(rtwdev, RF_PATH_B);
4060 	rtw8822c_dpk_on(rtwdev, RF_PATH_A);
4061 	rtw8822c_dpk_on(rtwdev, RF_PATH_B);
4062 	rtw8822c_dpk_cal_coef1(rtwdev);
4063 }
4064 
4065 static void rtw8822c_dpk_enable_disable(struct rtw_dev *rtwdev)
4066 {
4067 	struct rtw_dpk_info *dpk_info = &rtwdev->dm_info.dpk_info;
4068 	u32 mask = BIT(15) | BIT(14);
4069 
4070 	rtw_write32_mask(rtwdev, REG_NCTL0, BIT_SUBPAGE, 0xc);
4071 
4072 	rtw_write32_mask(rtwdev, REG_DPD_CTL1_S0, BIT_DPD_EN,
4073 			 dpk_info->is_dpk_pwr_on);
4074 	rtw_write32_mask(rtwdev, REG_DPD_CTL1_S1, BIT_DPD_EN,
4075 			 dpk_info->is_dpk_pwr_on);
4076 
4077 	if (test_bit(RF_PATH_A, dpk_info->dpk_path_ok)) {
4078 		rtw_write32_mask(rtwdev, REG_DPD_CTL1_S0, mask, 0x0);
4079 		rtw_write8(rtwdev, REG_DPD_CTL0_S0, dpk_info->dpk_gs[RF_PATH_A]);
4080 	}
4081 	if (test_bit(RF_PATH_B, dpk_info->dpk_path_ok)) {
4082 		rtw_write32_mask(rtwdev, REG_DPD_CTL1_S1, mask, 0x0);
4083 		rtw_write8(rtwdev, REG_DPD_CTL0_S1, dpk_info->dpk_gs[RF_PATH_B]);
4084 	}
4085 }
4086 
4087 static void rtw8822c_dpk_reload_data(struct rtw_dev *rtwdev)
4088 {
4089 	struct rtw_dpk_info *dpk_info = &rtwdev->dm_info.dpk_info;
4090 	u8 path;
4091 
4092 	if (!test_bit(RF_PATH_A, dpk_info->dpk_path_ok) &&
4093 	    !test_bit(RF_PATH_B, dpk_info->dpk_path_ok) &&
4094 	    dpk_info->dpk_ch == 0)
4095 		return;
4096 
4097 	for (path = 0; path < rtwdev->hal.rf_path_num; path++) {
4098 		rtw_write32_mask(rtwdev, REG_NCTL0, BIT_SUBPAGE,
4099 				 0x8 | (path << 1));
4100 		if (dpk_info->dpk_band == RTW_BAND_2G)
4101 			rtw_write32(rtwdev, REG_DPD_CTL1_S1, 0x1f100000);
4102 		else
4103 			rtw_write32(rtwdev, REG_DPD_CTL1_S1, 0x1f0d0000);
4104 
4105 		rtw_write8(rtwdev, REG_DPD_AGC, dpk_info->dpk_txagc[path]);
4106 
4107 		rtw8822c_dpk_coef_write(rtwdev, path,
4108 					test_bit(path, dpk_info->dpk_path_ok));
4109 
4110 		rtw8822c_dpk_one_shot(rtwdev, path, RTW_DPK_DPK_ON);
4111 
4112 		rtw_write32_mask(rtwdev, REG_NCTL0, BIT_SUBPAGE, 0xc);
4113 
4114 		if (path == RF_PATH_A)
4115 			rtw_write32_mask(rtwdev, REG_DPD_CTL0_S0, BIT_GS_PWSF,
4116 					 dpk_info->dpk_gs[path]);
4117 		else
4118 			rtw_write32_mask(rtwdev, REG_DPD_CTL0_S1, BIT_GS_PWSF,
4119 					 dpk_info->dpk_gs[path]);
4120 	}
4121 	rtw8822c_dpk_cal_coef1(rtwdev);
4122 }
4123 
4124 static bool rtw8822c_dpk_reload(struct rtw_dev *rtwdev)
4125 {
4126 	struct rtw_dpk_info *dpk_info = &rtwdev->dm_info.dpk_info;
4127 	u8 channel;
4128 
4129 	dpk_info->is_reload = false;
4130 
4131 #if defined(__linux__)
4132 	channel = (u8)(rtw_read_rf(rtwdev, RF_PATH_A, 0x18, RFREG_MASK) & 0xff);
4133 #elif defined(__FreeBSD__)
4134 	channel = (u8)(rtw_read_rf(rtwdev, RF_PATH_A, RF_CFGCH, RFREG_MASK) & 0xff);
4135 #endif
4136 
4137 	if (channel == dpk_info->dpk_ch) {
4138 		rtw_dbg(rtwdev, RTW_DBG_RFK,
4139 			"[DPK] DPK reload for CH%d!!\n", dpk_info->dpk_ch);
4140 		rtw8822c_dpk_reload_data(rtwdev);
4141 		dpk_info->is_reload = true;
4142 	}
4143 
4144 	return dpk_info->is_reload;
4145 }
4146 
4147 static void rtw8822c_do_dpk(struct rtw_dev *rtwdev)
4148 {
4149 	struct rtw_dpk_info *dpk_info = &rtwdev->dm_info.dpk_info;
4150 	struct rtw_backup_info bckp[DPK_BB_REG_NUM];
4151 	u32 rf_reg_backup[DPK_RF_REG_NUM][DPK_RF_PATH_NUM];
4152 	u32 bb_reg[DPK_BB_REG_NUM] = {
4153 		0x520, 0x820, 0x824, 0x1c3c, 0x1d58, 0x1864,
4154 		0x4164, 0x180c, 0x410c, 0x186c, 0x416c,
4155 		0x1a14, 0x1e70, 0x80c, 0x1d70, 0x1e7c, 0x18a4, 0x41a4};
4156 	u32 rf_reg[DPK_RF_REG_NUM] = {
4157 		0x0, 0x1a, 0x55, 0x63, 0x87, 0x8f, 0xde};
4158 	u8 path;
4159 
4160 	if (!dpk_info->is_dpk_pwr_on) {
4161 		rtw_dbg(rtwdev, RTW_DBG_RFK, "[DPK] Skip DPK due to DPD PWR off\n");
4162 		return;
4163 	} else if (rtw8822c_dpk_reload(rtwdev)) {
4164 		return;
4165 	}
4166 
4167 	for (path = RF_PATH_A; path < DPK_RF_PATH_NUM; path++)
4168 		ewma_thermal_init(&dpk_info->avg_thermal[path]);
4169 
4170 	rtw8822c_dpk_information(rtwdev);
4171 
4172 	rtw8822c_dpk_backup_registers(rtwdev, bb_reg, DPK_BB_REG_NUM, bckp);
4173 	rtw8822c_dpk_backup_rf_registers(rtwdev, rf_reg, rf_reg_backup);
4174 
4175 	rtw8822c_dpk_mac_bb_setting(rtwdev);
4176 	rtw8822c_dpk_afe_setting(rtwdev, true);
4177 	rtw8822c_dpk_pre_setting(rtwdev);
4178 	rtw8822c_dpk_result_reset(rtwdev);
4179 	rtw8822c_dpk_path_select(rtwdev);
4180 	rtw8822c_dpk_afe_setting(rtwdev, false);
4181 	rtw8822c_dpk_enable_disable(rtwdev);
4182 
4183 	rtw8822c_dpk_reload_rf_registers(rtwdev, rf_reg, rf_reg_backup);
4184 	for (path = 0; path < rtwdev->hal.rf_path_num; path++)
4185 		rtw8822c_dpk_rxbb_dc_cal(rtwdev, path);
4186 	rtw8822c_dpk_restore_registers(rtwdev, DPK_BB_REG_NUM, bckp);
4187 }
4188 
4189 static void rtw8822c_phy_calibration(struct rtw_dev *rtwdev)
4190 {
4191 	rtw8822c_rfk_power_save(rtwdev, false);
4192 	rtw8822c_do_gapk(rtwdev);
4193 	rtw8822c_do_iqk(rtwdev);
4194 	rtw8822c_do_dpk(rtwdev);
4195 	rtw8822c_rfk_power_save(rtwdev, true);
4196 }
4197 
4198 static void rtw8822c_dpk_track(struct rtw_dev *rtwdev)
4199 {
4200 	struct rtw_dpk_info *dpk_info = &rtwdev->dm_info.dpk_info;
4201 	u8 path;
4202 	u8 thermal_value[DPK_RF_PATH_NUM] = {0};
4203 	s8 offset[DPK_RF_PATH_NUM], delta_dpk[DPK_RF_PATH_NUM];
4204 
4205 	if (dpk_info->thermal_dpk[0] == 0 && dpk_info->thermal_dpk[1] == 0)
4206 		return;
4207 
4208 	for (path = 0; path < DPK_RF_PATH_NUM; path++) {
4209 		thermal_value[path] = rtw8822c_dpk_thermal_read(rtwdev, path);
4210 		ewma_thermal_add(&dpk_info->avg_thermal[path],
4211 				 thermal_value[path]);
4212 		thermal_value[path] =
4213 			ewma_thermal_read(&dpk_info->avg_thermal[path]);
4214 		delta_dpk[path] = dpk_info->thermal_dpk[path] -
4215 				  thermal_value[path];
4216 		offset[path] = delta_dpk[path] -
4217 			       dpk_info->thermal_dpk_delta[path];
4218 		offset[path] &= 0x7f;
4219 
4220 		if (offset[path] != dpk_info->pre_pwsf[path]) {
4221 			rtw_write32_mask(rtwdev, REG_NCTL0, BIT_SUBPAGE,
4222 					 0x8 | (path << 1));
4223 			rtw_write32_mask(rtwdev, 0x1b58, GENMASK(6, 0),
4224 					 offset[path]);
4225 			dpk_info->pre_pwsf[path] = offset[path];
4226 		}
4227 	}
4228 }
4229 
4230 #define XCAP_EXTEND(val) ({typeof(val) _v = (val); _v | _v << 7; })
4231 static void rtw8822c_set_crystal_cap_reg(struct rtw_dev *rtwdev, u8 crystal_cap)
4232 {
4233 	struct rtw_dm_info *dm_info = &rtwdev->dm_info;
4234 	struct rtw_cfo_track *cfo = &dm_info->cfo_track;
4235 	u32 val = 0;
4236 
4237 	val = XCAP_EXTEND(crystal_cap);
4238 	cfo->crystal_cap = crystal_cap;
4239 	rtw_write32_mask(rtwdev, REG_ANAPAR_XTAL_0, BIT_XCAP_0, val);
4240 }
4241 
4242 static void rtw8822c_set_crystal_cap(struct rtw_dev *rtwdev, u8 crystal_cap)
4243 {
4244 	struct rtw_dm_info *dm_info = &rtwdev->dm_info;
4245 	struct rtw_cfo_track *cfo = &dm_info->cfo_track;
4246 
4247 	if (cfo->crystal_cap == crystal_cap)
4248 		return;
4249 
4250 	rtw8822c_set_crystal_cap_reg(rtwdev, crystal_cap);
4251 }
4252 
4253 static void rtw8822c_cfo_tracking_reset(struct rtw_dev *rtwdev)
4254 {
4255 	struct rtw_dm_info *dm_info = &rtwdev->dm_info;
4256 	struct rtw_cfo_track *cfo = &dm_info->cfo_track;
4257 
4258 	cfo->is_adjust = true;
4259 
4260 	if (cfo->crystal_cap > rtwdev->efuse.crystal_cap)
4261 		rtw8822c_set_crystal_cap(rtwdev, cfo->crystal_cap - 1);
4262 	else if (cfo->crystal_cap < rtwdev->efuse.crystal_cap)
4263 		rtw8822c_set_crystal_cap(rtwdev, cfo->crystal_cap + 1);
4264 }
4265 
4266 static void rtw8822c_cfo_init(struct rtw_dev *rtwdev)
4267 {
4268 	struct rtw_dm_info *dm_info = &rtwdev->dm_info;
4269 	struct rtw_cfo_track *cfo = &dm_info->cfo_track;
4270 
4271 	cfo->crystal_cap = rtwdev->efuse.crystal_cap;
4272 	cfo->is_adjust = true;
4273 }
4274 
4275 #define REPORT_TO_KHZ(val) ({typeof(val) _v = (val); (_v << 1) + (_v >> 1); })
4276 static s32 rtw8822c_cfo_calc_avg(struct rtw_dev *rtwdev, u8 path_num)
4277 {
4278 	struct rtw_dm_info *dm_info = &rtwdev->dm_info;
4279 	struct rtw_cfo_track *cfo = &dm_info->cfo_track;
4280 	s32 cfo_avg, cfo_path_sum = 0, cfo_rpt_sum;
4281 	u8 i;
4282 
4283 	for (i = 0; i < path_num; i++) {
4284 		cfo_rpt_sum = REPORT_TO_KHZ(cfo->cfo_tail[i]);
4285 
4286 		if (cfo->cfo_cnt[i])
4287 			cfo_avg = cfo_rpt_sum / cfo->cfo_cnt[i];
4288 		else
4289 			cfo_avg = 0;
4290 
4291 		cfo_path_sum += cfo_avg;
4292 	}
4293 
4294 	for (i = 0; i < path_num; i++) {
4295 		cfo->cfo_tail[i] = 0;
4296 		cfo->cfo_cnt[i] = 0;
4297 	}
4298 
4299 	return cfo_path_sum / path_num;
4300 }
4301 
4302 static void rtw8822c_cfo_need_adjust(struct rtw_dev *rtwdev, s32 cfo_avg)
4303 {
4304 	struct rtw_dm_info *dm_info = &rtwdev->dm_info;
4305 	struct rtw_cfo_track *cfo = &dm_info->cfo_track;
4306 
4307 	if (!cfo->is_adjust) {
4308 		if (abs(cfo_avg) > CFO_TRK_ENABLE_TH)
4309 			cfo->is_adjust = true;
4310 	} else {
4311 		if (abs(cfo_avg) <= CFO_TRK_STOP_TH)
4312 			cfo->is_adjust = false;
4313 	}
4314 
4315 	if (!rtw_coex_disabled(rtwdev)) {
4316 		cfo->is_adjust = false;
4317 		rtw8822c_set_crystal_cap(rtwdev, rtwdev->efuse.crystal_cap);
4318 	}
4319 }
4320 
4321 static void rtw8822c_cfo_track(struct rtw_dev *rtwdev)
4322 {
4323 	struct rtw_dm_info *dm_info = &rtwdev->dm_info;
4324 	struct rtw_cfo_track *cfo = &dm_info->cfo_track;
4325 	u8 path_num = rtwdev->hal.rf_path_num;
4326 	s8 crystal_cap = cfo->crystal_cap;
4327 	s32 cfo_avg = 0;
4328 
4329 	if (rtwdev->sta_cnt != 1) {
4330 		rtw8822c_cfo_tracking_reset(rtwdev);
4331 		return;
4332 	}
4333 
4334 	if (cfo->packet_count == cfo->packet_count_pre)
4335 		return;
4336 
4337 	cfo->packet_count_pre = cfo->packet_count;
4338 	cfo_avg = rtw8822c_cfo_calc_avg(rtwdev, path_num);
4339 	rtw8822c_cfo_need_adjust(rtwdev, cfo_avg);
4340 
4341 	if (cfo->is_adjust) {
4342 		if (cfo_avg > CFO_TRK_ADJ_TH)
4343 			crystal_cap++;
4344 		else if (cfo_avg < -CFO_TRK_ADJ_TH)
4345 			crystal_cap--;
4346 
4347 		crystal_cap = clamp_t(s8, crystal_cap, 0, XCAP_MASK);
4348 		rtw8822c_set_crystal_cap(rtwdev, (u8)crystal_cap);
4349 	}
4350 }
4351 
4352 static const struct rtw_phy_cck_pd_reg
4353 rtw8822c_cck_pd_reg[RTW_CHANNEL_WIDTH_40 + 1][RTW_RF_PATH_MAX] = {
4354 	{
4355 		{0x1ac8, 0x00ff, 0x1ad0, 0x01f},
4356 		{0x1ac8, 0xff00, 0x1ad0, 0x3e0}
4357 	},
4358 	{
4359 		{0x1acc, 0x00ff, 0x1ad0, 0x01F00000},
4360 		{0x1acc, 0xff00, 0x1ad0, 0x3E000000}
4361 	},
4362 };
4363 
4364 #define RTW_CCK_PD_MAX 255
4365 #define RTW_CCK_CS_MAX 31
4366 #define RTW_CCK_CS_ERR1 27
4367 #define RTW_CCK_CS_ERR2 29
4368 static void
4369 rtw8822c_phy_cck_pd_set_reg(struct rtw_dev *rtwdev,
4370 			    s8 pd_diff, s8 cs_diff, u8 bw, u8 nrx)
4371 {
4372 	u32 pd, cs;
4373 
4374 	if (WARN_ON(bw > RTW_CHANNEL_WIDTH_40 || nrx >= RTW_RF_PATH_MAX))
4375 		return;
4376 
4377 	pd = rtw_read32_mask(rtwdev,
4378 			     rtw8822c_cck_pd_reg[bw][nrx].reg_pd,
4379 			     rtw8822c_cck_pd_reg[bw][nrx].mask_pd);
4380 	cs = rtw_read32_mask(rtwdev,
4381 			     rtw8822c_cck_pd_reg[bw][nrx].reg_cs,
4382 			     rtw8822c_cck_pd_reg[bw][nrx].mask_cs);
4383 	pd += pd_diff;
4384 	cs += cs_diff;
4385 	if (pd > RTW_CCK_PD_MAX)
4386 		pd = RTW_CCK_PD_MAX;
4387 	if (cs == RTW_CCK_CS_ERR1 || cs == RTW_CCK_CS_ERR2)
4388 		cs++;
4389 	else if (cs > RTW_CCK_CS_MAX)
4390 		cs = RTW_CCK_CS_MAX;
4391 	rtw_write32_mask(rtwdev,
4392 			 rtw8822c_cck_pd_reg[bw][nrx].reg_pd,
4393 			 rtw8822c_cck_pd_reg[bw][nrx].mask_pd,
4394 			 pd);
4395 	rtw_write32_mask(rtwdev,
4396 			 rtw8822c_cck_pd_reg[bw][nrx].reg_cs,
4397 			 rtw8822c_cck_pd_reg[bw][nrx].mask_cs,
4398 			 cs);
4399 
4400 	rtw_dbg(rtwdev, RTW_DBG_PHY,
4401 		"is_linked=%d, bw=%d, nrx=%d, cs_ratio=0x%x, pd_th=0x%x\n",
4402 		rtw_is_assoc(rtwdev), bw, nrx, cs, pd);
4403 }
4404 
4405 static void rtw8822c_phy_cck_pd_set(struct rtw_dev *rtwdev, u8 new_lvl)
4406 {
4407 	struct rtw_dm_info *dm_info = &rtwdev->dm_info;
4408 	s8 pd_lvl[CCK_PD_LV_MAX] = {0, 2, 4, 6, 8};
4409 	s8 cs_lvl[CCK_PD_LV_MAX] = {0, 2, 2, 2, 4};
4410 	u8 cur_lvl;
4411 	u8 nrx, bw;
4412 
4413 	nrx = (u8)rtw_read32_mask(rtwdev, 0x1a2c, 0x60000);
4414 	bw = (u8)rtw_read32_mask(rtwdev, 0x9b0, 0xc);
4415 
4416 	rtw_dbg(rtwdev, RTW_DBG_PHY, "lv: (%d) -> (%d) bw=%d nr=%d cck_fa_avg=%d\n",
4417 		dm_info->cck_pd_lv[bw][nrx], new_lvl, bw, nrx,
4418 		dm_info->cck_fa_avg);
4419 
4420 	if (dm_info->cck_pd_lv[bw][nrx] == new_lvl)
4421 		return;
4422 
4423 	cur_lvl = dm_info->cck_pd_lv[bw][nrx];
4424 
4425 	/* update cck pd info */
4426 	dm_info->cck_fa_avg = CCK_FA_AVG_RESET;
4427 
4428 	rtw8822c_phy_cck_pd_set_reg(rtwdev,
4429 				    pd_lvl[new_lvl] - pd_lvl[cur_lvl],
4430 				    cs_lvl[new_lvl] - cs_lvl[cur_lvl],
4431 				    bw, nrx);
4432 	dm_info->cck_pd_lv[bw][nrx] = new_lvl;
4433 }
4434 
4435 #define PWR_TRACK_MASK 0x7f
4436 static void rtw8822c_pwrtrack_set(struct rtw_dev *rtwdev, u8 rf_path)
4437 {
4438 	struct rtw_dm_info *dm_info = &rtwdev->dm_info;
4439 
4440 	switch (rf_path) {
4441 	case RF_PATH_A:
4442 		rtw_write32_mask(rtwdev, 0x18a0, PWR_TRACK_MASK,
4443 				 dm_info->delta_power_index[rf_path]);
4444 		break;
4445 	case RF_PATH_B:
4446 		rtw_write32_mask(rtwdev, 0x41a0, PWR_TRACK_MASK,
4447 				 dm_info->delta_power_index[rf_path]);
4448 		break;
4449 	default:
4450 		break;
4451 	}
4452 }
4453 
4454 static void rtw8822c_pwr_track_stats(struct rtw_dev *rtwdev, u8 path)
4455 {
4456 	u8 thermal_value;
4457 
4458 	if (rtwdev->efuse.thermal_meter[path] == 0xff)
4459 		return;
4460 
4461 	thermal_value = rtw_read_rf(rtwdev, path, RF_T_METER, 0x7e);
4462 	rtw_phy_pwrtrack_avg(rtwdev, thermal_value, path);
4463 }
4464 
4465 static void rtw8822c_pwr_track_path(struct rtw_dev *rtwdev,
4466 				    struct rtw_swing_table *swing_table,
4467 				    u8 path)
4468 {
4469 	struct rtw_dm_info *dm_info = &rtwdev->dm_info;
4470 	u8 delta;
4471 
4472 	delta = rtw_phy_pwrtrack_get_delta(rtwdev, path);
4473 	dm_info->delta_power_index[path] =
4474 		rtw_phy_pwrtrack_get_pwridx(rtwdev, swing_table, path, path,
4475 					    delta);
4476 	rtw8822c_pwrtrack_set(rtwdev, path);
4477 }
4478 
4479 static void __rtw8822c_pwr_track(struct rtw_dev *rtwdev)
4480 {
4481 	struct rtw_swing_table swing_table;
4482 	u8 i;
4483 
4484 	rtw_phy_config_swing_table(rtwdev, &swing_table);
4485 
4486 	for (i = 0; i < rtwdev->hal.rf_path_num; i++)
4487 		rtw8822c_pwr_track_stats(rtwdev, i);
4488 	if (rtw_phy_pwrtrack_need_lck(rtwdev))
4489 		rtw8822c_do_lck(rtwdev);
4490 	for (i = 0; i < rtwdev->hal.rf_path_num; i++)
4491 		rtw8822c_pwr_track_path(rtwdev, &swing_table, i);
4492 }
4493 
4494 static void rtw8822c_pwr_track(struct rtw_dev *rtwdev)
4495 {
4496 	struct rtw_efuse *efuse = &rtwdev->efuse;
4497 	struct rtw_dm_info *dm_info = &rtwdev->dm_info;
4498 
4499 	if (efuse->power_track_type != 0)
4500 		return;
4501 
4502 	if (!dm_info->pwr_trk_triggered) {
4503 		rtw_write_rf(rtwdev, RF_PATH_A, RF_T_METER, BIT(19), 0x01);
4504 		rtw_write_rf(rtwdev, RF_PATH_A, RF_T_METER, BIT(19), 0x00);
4505 		rtw_write_rf(rtwdev, RF_PATH_A, RF_T_METER, BIT(19), 0x01);
4506 
4507 		rtw_write_rf(rtwdev, RF_PATH_B, RF_T_METER, BIT(19), 0x01);
4508 		rtw_write_rf(rtwdev, RF_PATH_B, RF_T_METER, BIT(19), 0x00);
4509 		rtw_write_rf(rtwdev, RF_PATH_B, RF_T_METER, BIT(19), 0x01);
4510 
4511 		dm_info->pwr_trk_triggered = true;
4512 		return;
4513 	}
4514 
4515 	__rtw8822c_pwr_track(rtwdev);
4516 	dm_info->pwr_trk_triggered = false;
4517 }
4518 
4519 static void rtw8822c_adaptivity_init(struct rtw_dev *rtwdev)
4520 {
4521 	rtw_phy_set_edcca_th(rtwdev, RTW8822C_EDCCA_MAX, RTW8822C_EDCCA_MAX);
4522 
4523 	/* mac edcca state setting */
4524 	rtw_write32_clr(rtwdev, REG_TX_PTCL_CTRL, BIT_DIS_EDCCA);
4525 	rtw_write32_set(rtwdev, REG_RD_CTRL, BIT_EDCCA_MSK_CNTDOWN_EN);
4526 
4527 	/* edcca decistion opt */
4528 	rtw_write32_clr(rtwdev, REG_EDCCA_DECISION, BIT_EDCCA_OPTION);
4529 }
4530 
4531 static void rtw8822c_adaptivity(struct rtw_dev *rtwdev)
4532 {
4533 	struct rtw_dm_info *dm_info = &rtwdev->dm_info;
4534 	s8 l2h, h2l;
4535 	u8 igi;
4536 
4537 	igi = dm_info->igi_history[0];
4538 	if (dm_info->edcca_mode == RTW_EDCCA_NORMAL) {
4539 		l2h = max_t(s8, igi + EDCCA_IGI_L2H_DIFF, EDCCA_TH_L2H_LB);
4540 		h2l = l2h - EDCCA_L2H_H2L_DIFF_NORMAL;
4541 	} else {
4542 		if (igi < dm_info->l2h_th_ini - EDCCA_ADC_BACKOFF)
4543 			l2h = igi + EDCCA_ADC_BACKOFF;
4544 		else
4545 			l2h = dm_info->l2h_th_ini;
4546 		h2l = l2h - EDCCA_L2H_H2L_DIFF;
4547 	}
4548 
4549 	rtw_phy_set_edcca_th(rtwdev, l2h, h2l);
4550 }
4551 
4552 static void rtw8822c_led_set(struct led_classdev *led,
4553 			     enum led_brightness brightness)
4554 {
4555 	struct rtw_dev *rtwdev = container_of(led, struct rtw_dev, led_cdev);
4556 	u32 ledcfg;
4557 
4558 	ledcfg = rtw_read32(rtwdev, REG_LED_CFG);
4559 	u32p_replace_bits(&ledcfg, BIT_LED_MODE_SW_CTRL, BIT_LED2_CM);
4560 	ledcfg &= ~BIT_GPIO13_14_WL_CTRL_EN;
4561 
4562 	if (brightness == LED_OFF)
4563 		ledcfg |= BIT_LED2_SV;
4564 	else
4565 		ledcfg &= ~BIT_LED2_SV;
4566 
4567 	rtw_write32(rtwdev, REG_LED_CFG, ledcfg);
4568 }
4569 
4570 static void rtw8822c_fill_txdesc_checksum(struct rtw_dev *rtwdev,
4571 					  struct rtw_tx_pkt_info *pkt_info,
4572 					  u8 *txdesc)
4573 {
4574 	const struct rtw_chip_info *chip = rtwdev->chip;
4575 	size_t words;
4576 
4577 	words = (pkt_info->pkt_offset * 8 + chip->tx_pkt_desc_sz) / 2;
4578 
4579 	fill_txdesc_checksum_common(txdesc, words);
4580 }
4581 
4582 static const struct rtw_pwr_seq_cmd trans_carddis_to_cardemu_8822c[] = {
4583 	{0x0086,
4584 	 RTW_PWR_CUT_ALL_MSK,
4585 	 RTW_PWR_INTF_SDIO_MSK,
4586 	 RTW_PWR_ADDR_SDIO,
4587 	 RTW_PWR_CMD_WRITE, BIT(0), 0},
4588 	{0x0086,
4589 	 RTW_PWR_CUT_ALL_MSK,
4590 	 RTW_PWR_INTF_SDIO_MSK,
4591 	 RTW_PWR_ADDR_SDIO,
4592 	 RTW_PWR_CMD_POLLING, BIT(1), BIT(1)},
4593 	{0x002E,
4594 	 RTW_PWR_CUT_ALL_MSK,
4595 	 RTW_PWR_INTF_ALL_MSK,
4596 	 RTW_PWR_ADDR_MAC,
4597 	 RTW_PWR_CMD_WRITE, BIT(2), BIT(2)},
4598 	{0x002D,
4599 	 RTW_PWR_CUT_ALL_MSK,
4600 	 RTW_PWR_INTF_ALL_MSK,
4601 	 RTW_PWR_ADDR_MAC,
4602 	 RTW_PWR_CMD_WRITE, BIT(0), 0},
4603 	{0x007F,
4604 	 RTW_PWR_CUT_ALL_MSK,
4605 	 RTW_PWR_INTF_ALL_MSK,
4606 	 RTW_PWR_ADDR_MAC,
4607 	 RTW_PWR_CMD_WRITE, BIT(7), 0},
4608 	{0x004A,
4609 	 RTW_PWR_CUT_ALL_MSK,
4610 	 RTW_PWR_INTF_USB_MSK,
4611 	 RTW_PWR_ADDR_MAC,
4612 	 RTW_PWR_CMD_WRITE, BIT(0), 0},
4613 	{0x0005,
4614 	 RTW_PWR_CUT_ALL_MSK,
4615 	 RTW_PWR_INTF_ALL_MSK,
4616 	 RTW_PWR_ADDR_MAC,
4617 	 RTW_PWR_CMD_WRITE, BIT(3) | BIT(4) | BIT(7), 0},
4618 	{0xFFFF,
4619 	 RTW_PWR_CUT_ALL_MSK,
4620 	 RTW_PWR_INTF_ALL_MSK,
4621 	 0,
4622 	 RTW_PWR_CMD_END, 0, 0},
4623 };
4624 
4625 static const struct rtw_pwr_seq_cmd trans_cardemu_to_act_8822c[] = {
4626 	{0x0000,
4627 	 RTW_PWR_CUT_ALL_MSK,
4628 	 RTW_PWR_INTF_USB_MSK | RTW_PWR_INTF_SDIO_MSK,
4629 	 RTW_PWR_ADDR_MAC,
4630 	 RTW_PWR_CMD_WRITE, BIT(5), 0},
4631 	{0x0005,
4632 	 RTW_PWR_CUT_ALL_MSK,
4633 	 RTW_PWR_INTF_ALL_MSK,
4634 	 RTW_PWR_ADDR_MAC,
4635 	 RTW_PWR_CMD_WRITE, (BIT(4) | BIT(3) | BIT(2)), 0},
4636 	{0x0075,
4637 	 RTW_PWR_CUT_ALL_MSK,
4638 	 RTW_PWR_INTF_PCI_MSK,
4639 	 RTW_PWR_ADDR_MAC,
4640 	 RTW_PWR_CMD_WRITE, BIT(0), BIT(0)},
4641 	{0x0006,
4642 	 RTW_PWR_CUT_ALL_MSK,
4643 	 RTW_PWR_INTF_ALL_MSK,
4644 	 RTW_PWR_ADDR_MAC,
4645 	 RTW_PWR_CMD_POLLING, BIT(1), BIT(1)},
4646 	{0x0075,
4647 	 RTW_PWR_CUT_ALL_MSK,
4648 	 RTW_PWR_INTF_PCI_MSK,
4649 	 RTW_PWR_ADDR_MAC,
4650 	 RTW_PWR_CMD_WRITE, BIT(0), 0},
4651 	{0xFF1A,
4652 	 RTW_PWR_CUT_ALL_MSK,
4653 	 RTW_PWR_INTF_USB_MSK,
4654 	 RTW_PWR_ADDR_MAC,
4655 	 RTW_PWR_CMD_WRITE, 0xFF, 0},
4656 	{0x002E,
4657 	 RTW_PWR_CUT_ALL_MSK,
4658 	 RTW_PWR_INTF_ALL_MSK,
4659 	 RTW_PWR_ADDR_MAC,
4660 	 RTW_PWR_CMD_WRITE, BIT(3), 0},
4661 	{0x0006,
4662 	 RTW_PWR_CUT_ALL_MSK,
4663 	 RTW_PWR_INTF_ALL_MSK,
4664 	 RTW_PWR_ADDR_MAC,
4665 	 RTW_PWR_CMD_WRITE, BIT(0), BIT(0)},
4666 	{0x0005,
4667 	 RTW_PWR_CUT_ALL_MSK,
4668 	 RTW_PWR_INTF_ALL_MSK,
4669 	 RTW_PWR_ADDR_MAC,
4670 	 RTW_PWR_CMD_WRITE, (BIT(4) | BIT(3)), 0},
4671 	{0x1018,
4672 	 RTW_PWR_CUT_ALL_MSK,
4673 	 RTW_PWR_INTF_ALL_MSK,
4674 	 RTW_PWR_ADDR_MAC,
4675 	 RTW_PWR_CMD_WRITE, BIT(2), BIT(2)},
4676 	{0x0005,
4677 	 RTW_PWR_CUT_ALL_MSK,
4678 	 RTW_PWR_INTF_ALL_MSK,
4679 	 RTW_PWR_ADDR_MAC,
4680 	 RTW_PWR_CMD_WRITE, BIT(0), BIT(0)},
4681 	{0x0005,
4682 	 RTW_PWR_CUT_ALL_MSK,
4683 	 RTW_PWR_INTF_ALL_MSK,
4684 	 RTW_PWR_ADDR_MAC,
4685 	 RTW_PWR_CMD_POLLING, BIT(0), 0},
4686 	{0x0074,
4687 	 RTW_PWR_CUT_ALL_MSK,
4688 	 RTW_PWR_INTF_PCI_MSK,
4689 	 RTW_PWR_ADDR_MAC,
4690 	 RTW_PWR_CMD_WRITE, BIT(5), BIT(5)},
4691 	{0x0071,
4692 	 RTW_PWR_CUT_ALL_MSK,
4693 	 RTW_PWR_INTF_PCI_MSK,
4694 	 RTW_PWR_ADDR_MAC,
4695 	 RTW_PWR_CMD_WRITE, BIT(4), 0},
4696 	{0x0062,
4697 	 RTW_PWR_CUT_ALL_MSK,
4698 	 RTW_PWR_INTF_PCI_MSK,
4699 	 RTW_PWR_ADDR_MAC,
4700 	 RTW_PWR_CMD_WRITE, (BIT(7) | BIT(6) | BIT(5)),
4701 	 (BIT(7) | BIT(6) | BIT(5))},
4702 	{0x0061,
4703 	 RTW_PWR_CUT_ALL_MSK,
4704 	 RTW_PWR_INTF_PCI_MSK,
4705 	 RTW_PWR_ADDR_MAC,
4706 	 RTW_PWR_CMD_WRITE, (BIT(7) | BIT(6) | BIT(5)), 0},
4707 	{0x001F,
4708 	 RTW_PWR_CUT_ALL_MSK,
4709 	 RTW_PWR_INTF_ALL_MSK,
4710 	 RTW_PWR_ADDR_MAC,
4711 	 RTW_PWR_CMD_WRITE, (BIT(7) | BIT(6)), BIT(7)},
4712 	{0x00EF,
4713 	 RTW_PWR_CUT_ALL_MSK,
4714 	 RTW_PWR_INTF_ALL_MSK,
4715 	 RTW_PWR_ADDR_MAC,
4716 	 RTW_PWR_CMD_WRITE, (BIT(7) | BIT(6)), BIT(7)},
4717 	{0x1045,
4718 	 RTW_PWR_CUT_ALL_MSK,
4719 	 RTW_PWR_INTF_ALL_MSK,
4720 	 RTW_PWR_ADDR_MAC,
4721 	 RTW_PWR_CMD_WRITE, BIT(4), BIT(4)},
4722 	{0x0010,
4723 	 RTW_PWR_CUT_ALL_MSK,
4724 	 RTW_PWR_INTF_ALL_MSK,
4725 	 RTW_PWR_ADDR_MAC,
4726 	 RTW_PWR_CMD_WRITE, BIT(2), BIT(2)},
4727 	{0x1064,
4728 	 RTW_PWR_CUT_ALL_MSK,
4729 	 RTW_PWR_INTF_ALL_MSK,
4730 	 RTW_PWR_ADDR_MAC,
4731 	 RTW_PWR_CMD_WRITE, BIT(1), BIT(1)},
4732 	{0xFFFF,
4733 	 RTW_PWR_CUT_ALL_MSK,
4734 	 RTW_PWR_INTF_ALL_MSK,
4735 	 0,
4736 	 RTW_PWR_CMD_END, 0, 0},
4737 };
4738 
4739 static const struct rtw_pwr_seq_cmd trans_act_to_cardemu_8822c[] = {
4740 	{0x0093,
4741 	 RTW_PWR_CUT_ALL_MSK,
4742 	 RTW_PWR_INTF_ALL_MSK,
4743 	 RTW_PWR_ADDR_MAC,
4744 	 RTW_PWR_CMD_WRITE, BIT(3), 0},
4745 	{0x001F,
4746 	 RTW_PWR_CUT_ALL_MSK,
4747 	 RTW_PWR_INTF_ALL_MSK,
4748 	 RTW_PWR_ADDR_MAC,
4749 	 RTW_PWR_CMD_WRITE, 0xFF, 0},
4750 	{0x00EF,
4751 	 RTW_PWR_CUT_ALL_MSK,
4752 	 RTW_PWR_INTF_ALL_MSK,
4753 	 RTW_PWR_ADDR_MAC,
4754 	 RTW_PWR_CMD_WRITE, 0xFF, 0},
4755 	{0x1045,
4756 	 RTW_PWR_CUT_ALL_MSK,
4757 	 RTW_PWR_INTF_ALL_MSK,
4758 	 RTW_PWR_ADDR_MAC,
4759 	 RTW_PWR_CMD_WRITE, BIT(4), 0},
4760 	{0xFF1A,
4761 	 RTW_PWR_CUT_ALL_MSK,
4762 	 RTW_PWR_INTF_USB_MSK,
4763 	 RTW_PWR_ADDR_MAC,
4764 	 RTW_PWR_CMD_WRITE, 0xFF, 0x30},
4765 	{0x0049,
4766 	 RTW_PWR_CUT_ALL_MSK,
4767 	 RTW_PWR_INTF_ALL_MSK,
4768 	 RTW_PWR_ADDR_MAC,
4769 	 RTW_PWR_CMD_WRITE, BIT(1), 0},
4770 	{0x0006,
4771 	 RTW_PWR_CUT_ALL_MSK,
4772 	 RTW_PWR_INTF_ALL_MSK,
4773 	 RTW_PWR_ADDR_MAC,
4774 	 RTW_PWR_CMD_WRITE, BIT(0), BIT(0)},
4775 	{0x0002,
4776 	 RTW_PWR_CUT_ALL_MSK,
4777 	 RTW_PWR_INTF_ALL_MSK,
4778 	 RTW_PWR_ADDR_MAC,
4779 	 RTW_PWR_CMD_WRITE, BIT(1), 0},
4780 	{0x0005,
4781 	 RTW_PWR_CUT_ALL_MSK,
4782 	 RTW_PWR_INTF_ALL_MSK,
4783 	 RTW_PWR_ADDR_MAC,
4784 	 RTW_PWR_CMD_WRITE, BIT(1), BIT(1)},
4785 	{0x0005,
4786 	 RTW_PWR_CUT_ALL_MSK,
4787 	 RTW_PWR_INTF_ALL_MSK,
4788 	 RTW_PWR_ADDR_MAC,
4789 	 RTW_PWR_CMD_POLLING, BIT(1), 0},
4790 	{0x0000,
4791 	 RTW_PWR_CUT_ALL_MSK,
4792 	 RTW_PWR_INTF_USB_MSK | RTW_PWR_INTF_SDIO_MSK,
4793 	 RTW_PWR_ADDR_MAC,
4794 	 RTW_PWR_CMD_WRITE, BIT(5), BIT(5)},
4795 	{0xFFFF,
4796 	 RTW_PWR_CUT_ALL_MSK,
4797 	 RTW_PWR_INTF_ALL_MSK,
4798 	 0,
4799 	 RTW_PWR_CMD_END, 0, 0},
4800 };
4801 
4802 static const struct rtw_pwr_seq_cmd trans_cardemu_to_carddis_8822c[] = {
4803 	{0x0005,
4804 	 RTW_PWR_CUT_ALL_MSK,
4805 	 RTW_PWR_INTF_SDIO_MSK,
4806 	 RTW_PWR_ADDR_MAC,
4807 	 RTW_PWR_CMD_WRITE, BIT(7), BIT(7)},
4808 	{0x0007,
4809 	 RTW_PWR_CUT_ALL_MSK,
4810 	 RTW_PWR_INTF_USB_MSK | RTW_PWR_INTF_SDIO_MSK,
4811 	 RTW_PWR_ADDR_MAC,
4812 	 RTW_PWR_CMD_WRITE, 0xFF, 0x00},
4813 	{0x0067,
4814 	 RTW_PWR_CUT_ALL_MSK,
4815 	 RTW_PWR_INTF_ALL_MSK,
4816 	 RTW_PWR_ADDR_MAC,
4817 	 RTW_PWR_CMD_WRITE, BIT(5), 0},
4818 	{0x004A,
4819 	 RTW_PWR_CUT_ALL_MSK,
4820 	 RTW_PWR_INTF_USB_MSK,
4821 	 RTW_PWR_ADDR_MAC,
4822 	 RTW_PWR_CMD_WRITE, BIT(0), 0},
4823 	{0x0081,
4824 	 RTW_PWR_CUT_ALL_MSK,
4825 	 RTW_PWR_INTF_ALL_MSK,
4826 	 RTW_PWR_ADDR_MAC,
4827 	 RTW_PWR_CMD_WRITE, BIT(7) | BIT(6), 0},
4828 	{0x0090,
4829 	 RTW_PWR_CUT_ALL_MSK,
4830 	 RTW_PWR_INTF_ALL_MSK,
4831 	 RTW_PWR_ADDR_MAC,
4832 	 RTW_PWR_CMD_WRITE, BIT(1), 0},
4833 	{0x0092,
4834 	 RTW_PWR_CUT_ALL_MSK,
4835 	 RTW_PWR_INTF_PCI_MSK,
4836 	 RTW_PWR_ADDR_MAC,
4837 	 RTW_PWR_CMD_WRITE, 0xFF, 0x20},
4838 	{0x0093,
4839 	 RTW_PWR_CUT_ALL_MSK,
4840 	 RTW_PWR_INTF_PCI_MSK,
4841 	 RTW_PWR_ADDR_MAC,
4842 	 RTW_PWR_CMD_WRITE, 0xFF, 0x04},
4843 	{0x0005,
4844 	 RTW_PWR_CUT_ALL_MSK,
4845 	 RTW_PWR_INTF_USB_MSK | RTW_PWR_INTF_SDIO_MSK,
4846 	 RTW_PWR_ADDR_MAC,
4847 	 RTW_PWR_CMD_WRITE, BIT(3) | BIT(4), BIT(3)},
4848 	{0x0005,
4849 	 RTW_PWR_CUT_ALL_MSK,
4850 	 RTW_PWR_INTF_PCI_MSK,
4851 	 RTW_PWR_ADDR_MAC,
4852 	 RTW_PWR_CMD_WRITE, BIT(2), BIT(2)},
4853 	{0x0086,
4854 	 RTW_PWR_CUT_ALL_MSK,
4855 	 RTW_PWR_INTF_SDIO_MSK,
4856 	 RTW_PWR_ADDR_SDIO,
4857 	 RTW_PWR_CMD_WRITE, BIT(0), BIT(0)},
4858 	{0xFFFF,
4859 	 RTW_PWR_CUT_ALL_MSK,
4860 	 RTW_PWR_INTF_ALL_MSK,
4861 	 0,
4862 	 RTW_PWR_CMD_END, 0, 0},
4863 };
4864 
4865 static const struct rtw_pwr_seq_cmd * const card_enable_flow_8822c[] = {
4866 	trans_carddis_to_cardemu_8822c,
4867 	trans_cardemu_to_act_8822c,
4868 	NULL
4869 };
4870 
4871 static const struct rtw_pwr_seq_cmd * const card_disable_flow_8822c[] = {
4872 	trans_act_to_cardemu_8822c,
4873 	trans_cardemu_to_carddis_8822c,
4874 	NULL
4875 };
4876 
4877 static const struct rtw_intf_phy_para usb2_param_8822c[] = {
4878 	{0xFFFF, 0x00,
4879 	 RTW_IP_SEL_PHY,
4880 	 RTW_INTF_PHY_CUT_ALL,
4881 	 RTW_INTF_PHY_PLATFORM_ALL},
4882 };
4883 
4884 static const struct rtw_intf_phy_para usb3_param_8822c[] = {
4885 	{0xFFFF, 0x0000,
4886 	 RTW_IP_SEL_PHY,
4887 	 RTW_INTF_PHY_CUT_ALL,
4888 	 RTW_INTF_PHY_PLATFORM_ALL},
4889 };
4890 
4891 static const struct rtw_intf_phy_para pcie_gen1_param_8822c[] = {
4892 	{0xFFFF, 0x0000,
4893 	 RTW_IP_SEL_PHY,
4894 	 RTW_INTF_PHY_CUT_ALL,
4895 	 RTW_INTF_PHY_PLATFORM_ALL},
4896 };
4897 
4898 static const struct rtw_intf_phy_para pcie_gen2_param_8822c[] = {
4899 	{0xFFFF, 0x0000,
4900 	 RTW_IP_SEL_PHY,
4901 	 RTW_INTF_PHY_CUT_ALL,
4902 	 RTW_INTF_PHY_PLATFORM_ALL},
4903 };
4904 
4905 static const struct rtw_intf_phy_para_table phy_para_table_8822c = {
4906 	.usb2_para	= usb2_param_8822c,
4907 	.usb3_para	= usb3_param_8822c,
4908 	.gen1_para	= pcie_gen1_param_8822c,
4909 	.gen2_para	= pcie_gen2_param_8822c,
4910 	.n_usb2_para	= ARRAY_SIZE(usb2_param_8822c),
4911 	.n_usb3_para	= ARRAY_SIZE(usb2_param_8822c),
4912 	.n_gen1_para	= ARRAY_SIZE(pcie_gen1_param_8822c),
4913 	.n_gen2_para	= ARRAY_SIZE(pcie_gen2_param_8822c),
4914 };
4915 
4916 static const struct rtw_hw_reg rtw8822c_dig[] = {
4917 	[0] = { .addr = 0x1d70, .mask = 0x7f },
4918 	[1] = { .addr = 0x1d70, .mask = 0x7f00 },
4919 };
4920 
4921 static const struct rtw_ltecoex_addr rtw8822c_ltecoex_addr = {
4922 	.ctrl = LTECOEX_ACCESS_CTRL,
4923 	.wdata = LTECOEX_WRITE_DATA,
4924 	.rdata = LTECOEX_READ_DATA,
4925 };
4926 
4927 static const struct rtw_page_table page_table_8822c[] = {
4928 	{64, 64, 64, 64, 1},
4929 	{64, 64, 64, 64, 1},
4930 	{64, 64, 0, 0, 1},
4931 	{64, 64, 64, 0, 1},
4932 	{64, 64, 64, 64, 1},
4933 };
4934 
4935 static const struct rtw_rqpn rqpn_table_8822c[] = {
4936 	{RTW_DMA_MAPPING_NORMAL, RTW_DMA_MAPPING_NORMAL,
4937 	 RTW_DMA_MAPPING_LOW, RTW_DMA_MAPPING_LOW,
4938 	 RTW_DMA_MAPPING_EXTRA, RTW_DMA_MAPPING_HIGH},
4939 	{RTW_DMA_MAPPING_NORMAL, RTW_DMA_MAPPING_NORMAL,
4940 	 RTW_DMA_MAPPING_LOW, RTW_DMA_MAPPING_LOW,
4941 	 RTW_DMA_MAPPING_EXTRA, RTW_DMA_MAPPING_HIGH},
4942 	{RTW_DMA_MAPPING_NORMAL, RTW_DMA_MAPPING_NORMAL,
4943 	 RTW_DMA_MAPPING_NORMAL, RTW_DMA_MAPPING_HIGH,
4944 	 RTW_DMA_MAPPING_HIGH, RTW_DMA_MAPPING_HIGH},
4945 	{RTW_DMA_MAPPING_NORMAL, RTW_DMA_MAPPING_NORMAL,
4946 	 RTW_DMA_MAPPING_LOW, RTW_DMA_MAPPING_LOW,
4947 	 RTW_DMA_MAPPING_HIGH, RTW_DMA_MAPPING_HIGH},
4948 	{RTW_DMA_MAPPING_NORMAL, RTW_DMA_MAPPING_NORMAL,
4949 	 RTW_DMA_MAPPING_LOW, RTW_DMA_MAPPING_LOW,
4950 	 RTW_DMA_MAPPING_EXTRA, RTW_DMA_MAPPING_HIGH},
4951 };
4952 
4953 static const struct rtw_prioq_addrs prioq_addrs_8822c = {
4954 	.prio[RTW_DMA_MAPPING_EXTRA] = {
4955 		.rsvd = REG_FIFOPAGE_INFO_4, .avail = REG_FIFOPAGE_INFO_4 + 2,
4956 	},
4957 	.prio[RTW_DMA_MAPPING_LOW] = {
4958 		.rsvd = REG_FIFOPAGE_INFO_2, .avail = REG_FIFOPAGE_INFO_2 + 2,
4959 	},
4960 	.prio[RTW_DMA_MAPPING_NORMAL] = {
4961 		.rsvd = REG_FIFOPAGE_INFO_3, .avail = REG_FIFOPAGE_INFO_3 + 2,
4962 	},
4963 	.prio[RTW_DMA_MAPPING_HIGH] = {
4964 		.rsvd = REG_FIFOPAGE_INFO_1, .avail = REG_FIFOPAGE_INFO_1 + 2,
4965 	},
4966 	.wsize = true,
4967 };
4968 
4969 static const struct rtw_chip_ops rtw8822c_ops = {
4970 	.power_on		= rtw_power_on,
4971 	.power_off		= rtw_power_off,
4972 	.phy_set_param		= rtw8822c_phy_set_param,
4973 	.read_efuse		= rtw8822c_read_efuse,
4974 	.query_phy_status	= query_phy_status,
4975 	.set_channel		= rtw8822c_set_channel,
4976 	.mac_init		= rtw8822c_mac_init,
4977 	.dump_fw_crash		= rtw8822c_dump_fw_crash,
4978 	.read_rf		= rtw_phy_read_rf,
4979 	.write_rf		= rtw_phy_write_rf_reg_mix,
4980 	.set_tx_power_index	= rtw8822c_set_tx_power_index,
4981 	.set_antenna		= rtw8822c_set_antenna,
4982 	.cfg_ldo25		= rtw8822c_cfg_ldo25,
4983 	.false_alarm_statistics	= rtw8822c_false_alarm_statistics,
4984 	.dpk_track		= rtw8822c_dpk_track,
4985 	.phy_calibration	= rtw8822c_phy_calibration,
4986 	.cck_pd_set		= rtw8822c_phy_cck_pd_set,
4987 	.pwr_track		= rtw8822c_pwr_track,
4988 	.config_bfee		= rtw8822c_bf_config_bfee,
4989 	.set_gid_table		= rtw_bf_set_gid_table,
4990 	.cfg_csi_rate		= rtw_bf_cfg_csi_rate,
4991 	.adaptivity_init	= rtw8822c_adaptivity_init,
4992 	.adaptivity		= rtw8822c_adaptivity,
4993 	.cfo_init		= rtw8822c_cfo_init,
4994 	.cfo_track		= rtw8822c_cfo_track,
4995 	.config_tx_path		= rtw8822c_config_tx_path,
4996 	.config_txrx_mode	= rtw8822c_config_trx_mode,
4997 	.led_set		= rtw8822c_led_set,
4998 	.fill_txdesc_checksum	= rtw8822c_fill_txdesc_checksum,
4999 
5000 	.coex_set_init		= rtw8822c_coex_cfg_init,
5001 	.coex_set_ant_switch	= NULL,
5002 	.coex_set_gnt_fix	= rtw8822c_coex_cfg_gnt_fix,
5003 	.coex_set_gnt_debug	= rtw8822c_coex_cfg_gnt_debug,
5004 	.coex_set_rfe_type	= rtw8822c_coex_cfg_rfe_type,
5005 	.coex_set_wl_tx_power	= rtw8822c_coex_cfg_wl_tx_power,
5006 	.coex_set_wl_rx_gain	= rtw8822c_coex_cfg_wl_rx_gain,
5007 };
5008 
5009 /* Shared-Antenna Coex Table */
5010 static const struct coex_table_para table_sant_8822c[] = {
5011 	{0xffffffff, 0xffffffff}, /* case-0 */
5012 	{0x55555555, 0x55555555},
5013 	{0x66555555, 0x66555555},
5014 	{0xaaaaaaaa, 0xaaaaaaaa},
5015 	{0x5a5a5a5a, 0x5a5a5a5a},
5016 	{0xfafafafa, 0xfafafafa}, /* case-5 */
5017 	{0x6a5a5555, 0xaaaaaaaa},
5018 	{0x6a5a56aa, 0x6a5a56aa},
5019 	{0x6a5a5a5a, 0x6a5a5a5a},
5020 	{0x66555555, 0x5a5a5a5a},
5021 	{0x66555555, 0x6a5a5a5a}, /* case-10 */
5022 	{0x66555555, 0x6a5a5aaa},
5023 	{0x66555555, 0x5a5a5aaa},
5024 	{0x66555555, 0x6aaa5aaa},
5025 	{0x66555555, 0xaaaa5aaa},
5026 	{0x66555555, 0xaaaaaaaa}, /* case-15 */
5027 	{0xffff55ff, 0xfafafafa},
5028 	{0xffff55ff, 0x6afa5afa},
5029 	{0xaaffffaa, 0xfafafafa},
5030 	{0xaa5555aa, 0x5a5a5a5a},
5031 	{0xaa5555aa, 0x6a5a5a5a}, /* case-20 */
5032 	{0xaa5555aa, 0xaaaaaaaa},
5033 	{0xffffffff, 0x5a5a5a5a},
5034 	{0xffffffff, 0x5a5a5a5a},
5035 	{0xffffffff, 0x55555555},
5036 	{0xffffffff, 0x5a5a5aaa}, /* case-25 */
5037 	{0x55555555, 0x5a5a5a5a},
5038 	{0x55555555, 0xaaaaaaaa},
5039 	{0x55555555, 0x6a5a6a5a},
5040 	{0x66556655, 0x66556655},
5041 	{0x66556aaa, 0x6a5a6aaa}, /*case-30*/
5042 	{0xffffffff, 0x5aaa5aaa},
5043 	{0x56555555, 0x5a5a5aaa},
5044 	{0xdaffdaff, 0xdaffdaff},
5045 	{0xddffddff, 0xddffddff},
5046 };
5047 
5048 /* Non-Shared-Antenna Coex Table */
5049 static const struct coex_table_para table_nsant_8822c[] = {
5050 	{0xffffffff, 0xffffffff}, /* case-100 */
5051 	{0x55555555, 0x55555555},
5052 	{0x66555555, 0x66555555},
5053 	{0xaaaaaaaa, 0xaaaaaaaa},
5054 	{0x5a5a5a5a, 0x5a5a5a5a},
5055 	{0xfafafafa, 0xfafafafa}, /* case-105 */
5056 	{0x5afa5afa, 0x5afa5afa},
5057 	{0x55555555, 0xfafafafa},
5058 	{0x66555555, 0xfafafafa},
5059 	{0x66555555, 0x5a5a5a5a},
5060 	{0x66555555, 0x6a5a5a5a}, /* case-110 */
5061 	{0x66555555, 0xaaaaaaaa},
5062 	{0xffff55ff, 0xfafafafa},
5063 	{0xffff55ff, 0x5afa5afa},
5064 	{0xffff55ff, 0xaaaaaaaa},
5065 	{0xffff55ff, 0xffff55ff}, /* case-115 */
5066 	{0xaaffffaa, 0x5afa5afa},
5067 	{0xaaffffaa, 0xaaaaaaaa},
5068 	{0xffffffff, 0xfafafafa},
5069 	{0xffffffff, 0x5afa5afa},
5070 	{0xffffffff, 0xaaaaaaaa}, /* case-120 */
5071 	{0x55ff55ff, 0x5afa5afa},
5072 	{0x55ff55ff, 0xaaaaaaaa},
5073 	{0x55ff55ff, 0x55ff55ff}
5074 };
5075 
5076 /* Shared-Antenna TDMA */
5077 static const struct coex_tdma_para tdma_sant_8822c[] = {
5078 	{ {0x00, 0x00, 0x00, 0x00, 0x00} }, /* case-0 */
5079 	{ {0x61, 0x45, 0x03, 0x11, 0x11} }, /* case-1 */
5080 	{ {0x61, 0x3a, 0x03, 0x11, 0x11} },
5081 	{ {0x61, 0x30, 0x03, 0x11, 0x11} },
5082 	{ {0x61, 0x20, 0x03, 0x11, 0x11} },
5083 	{ {0x61, 0x10, 0x03, 0x11, 0x11} }, /* case-5 */
5084 	{ {0x61, 0x45, 0x03, 0x11, 0x10} },
5085 	{ {0x61, 0x3a, 0x03, 0x11, 0x10} },
5086 	{ {0x61, 0x30, 0x03, 0x11, 0x10} },
5087 	{ {0x61, 0x20, 0x03, 0x11, 0x10} },
5088 	{ {0x61, 0x10, 0x03, 0x11, 0x10} }, /* case-10 */
5089 	{ {0x61, 0x08, 0x03, 0x11, 0x14} },
5090 	{ {0x61, 0x08, 0x03, 0x10, 0x14} },
5091 	{ {0x51, 0x08, 0x03, 0x10, 0x54} },
5092 	{ {0x51, 0x08, 0x03, 0x10, 0x55} },
5093 	{ {0x51, 0x08, 0x07, 0x10, 0x54} }, /* case-15 */
5094 	{ {0x51, 0x45, 0x03, 0x10, 0x50} },
5095 	{ {0x51, 0x3a, 0x03, 0x10, 0x50} },
5096 	{ {0x51, 0x30, 0x03, 0x10, 0x50} },
5097 	{ {0x51, 0x20, 0x03, 0x10, 0x50} },
5098 	{ {0x51, 0x10, 0x03, 0x10, 0x50} }, /* case-20 */
5099 	{ {0x51, 0x4a, 0x03, 0x10, 0x50} },
5100 	{ {0x51, 0x0c, 0x03, 0x10, 0x54} },
5101 	{ {0x55, 0x08, 0x03, 0x10, 0x54} },
5102 	{ {0x65, 0x10, 0x03, 0x11, 0x10} },
5103 	{ {0x51, 0x10, 0x03, 0x10, 0x51} }, /* case-25 */
5104 	{ {0x51, 0x08, 0x03, 0x10, 0x50} },
5105 	{ {0x61, 0x08, 0x03, 0x11, 0x11} }
5106 };
5107 
5108 /* Non-Shared-Antenna TDMA */
5109 static const struct coex_tdma_para tdma_nsant_8822c[] = {
5110 	{ {0x00, 0x00, 0x00, 0x00, 0x00} }, /* case-100 */
5111 	{ {0x61, 0x45, 0x03, 0x11, 0x11} },
5112 	{ {0x61, 0x3a, 0x03, 0x11, 0x11} },
5113 	{ {0x61, 0x30, 0x03, 0x11, 0x11} },
5114 	{ {0x61, 0x20, 0x03, 0x11, 0x11} },
5115 	{ {0x61, 0x10, 0x03, 0x11, 0x11} }, /* case-105 */
5116 	{ {0x61, 0x45, 0x03, 0x11, 0x10} },
5117 	{ {0x61, 0x3a, 0x03, 0x11, 0x10} },
5118 	{ {0x61, 0x30, 0x03, 0x11, 0x10} },
5119 	{ {0x61, 0x20, 0x03, 0x11, 0x10} },
5120 	{ {0x61, 0x10, 0x03, 0x11, 0x10} }, /* case-110 */
5121 	{ {0x61, 0x08, 0x03, 0x11, 0x14} },
5122 	{ {0x61, 0x08, 0x03, 0x10, 0x14} },
5123 	{ {0x51, 0x08, 0x03, 0x10, 0x54} },
5124 	{ {0x51, 0x08, 0x03, 0x10, 0x55} },
5125 	{ {0x51, 0x08, 0x07, 0x10, 0x54} }, /* case-115 */
5126 	{ {0x51, 0x45, 0x03, 0x10, 0x50} },
5127 	{ {0x51, 0x3a, 0x03, 0x10, 0x50} },
5128 	{ {0x51, 0x30, 0x03, 0x10, 0x50} },
5129 	{ {0x51, 0x20, 0x03, 0x10, 0x50} },
5130 	{ {0x51, 0x10, 0x03, 0x10, 0x50} }, /* case-120 */
5131 	{ {0x51, 0x08, 0x03, 0x10, 0x50} }
5132 };
5133 
5134 /* rssi in percentage % (dbm = % - 100) */
5135 static const u8 wl_rssi_step_8822c[] = {60, 50, 44, 30};
5136 static const u8 bt_rssi_step_8822c[] = {8, 15, 20, 25};
5137 static const struct coex_5g_afh_map afh_5g_8822c[] = { {0, 0, 0} };
5138 
5139 /* wl_tx_dec_power, bt_tx_dec_power, wl_rx_gain, bt_rx_lna_constrain */
5140 static const struct coex_rf_para rf_para_tx_8822c[] = {
5141 	{0, 0, false, 7},  /* for normal */
5142 	{0, 16, false, 7}, /* for WL-CPT */
5143 	{8, 17, true, 4},
5144 	{7, 18, true, 4},
5145 	{6, 19, true, 4},
5146 	{5, 20, true, 4},
5147 	{0, 21, true, 4}   /* for gamg hid */
5148 };
5149 
5150 static const struct coex_rf_para rf_para_rx_8822c[] = {
5151 	{0, 0, false, 7},  /* for normal */
5152 	{0, 16, false, 7}, /* for WL-CPT */
5153 	{3, 24, true, 5},
5154 	{2, 26, true, 5},
5155 	{1, 27, true, 5},
5156 	{0, 28, true, 5},
5157 	{0, 28, true, 5}   /* for gamg hid */
5158 };
5159 
5160 #if defined(__linux__)
5161 static_assert(ARRAY_SIZE(rf_para_tx_8822c) == ARRAY_SIZE(rf_para_rx_8822c));
5162 #elif defined(__FreeBSD__)
5163 rtw88_static_assert(ARRAY_SIZE(rf_para_tx_8822c) == ARRAY_SIZE(rf_para_rx_8822c));
5164 #endif
5165 
5166 static const u8
5167 rtw8822c_pwrtrk_5gb_n[RTW_PWR_TRK_5G_NUM][RTW_PWR_TRK_TBL_SZ] = {
5168 	{ 0,  1,  2,  3,  5,  6,  7,  8,  9, 10,
5169 	 11, 12, 13, 14, 15, 16, 18, 19, 20, 21,
5170 	 22, 23, 24, 25, 26, 27, 28, 29, 30, 32 },
5171 	{ 0,  1,  2,  3,  5,  6,  7,  8,  9, 10,
5172 	 11, 12, 13, 14, 15, 16, 18, 19, 20, 21,
5173 	 22, 23, 24, 25, 26, 27, 28, 29, 30, 32 },
5174 	{ 0,  1,  2,  3,  5,  6,  7,  8,  9, 10,
5175 	 11, 12, 13, 14, 15, 16, 18, 19, 20, 21,
5176 	 22, 23, 24, 25, 26, 27, 28, 29, 30, 32 },
5177 };
5178 
5179 static const u8
5180 rtw8822c_pwrtrk_5gb_p[RTW_PWR_TRK_5G_NUM][RTW_PWR_TRK_TBL_SZ] = {
5181 	{ 0,  1,  2,  3,  4,  5,  6,  7,  8,  9,
5182 	 10, 10, 11, 12, 13, 14, 15, 16, 17, 18,
5183 	 19, 20, 21, 22, 22, 23, 24, 25, 26, 27 },
5184 	{ 0,  1,  2,  3,  4,  5,  6,  7,  8,  9,
5185 	 10, 10, 11, 12, 13, 14, 15, 16, 17, 18,
5186 	 19, 20, 21, 22, 22, 23, 24, 25, 26, 27 },
5187 	{ 0,  1,  2,  3,  4,  5,  6,  7,  8,  9,
5188 	 10, 10, 11, 12, 13, 14, 15, 16, 17, 18,
5189 	 19, 20, 21, 22, 22, 23, 24, 25, 26, 27 },
5190 };
5191 
5192 static const u8
5193 rtw8822c_pwrtrk_5ga_n[RTW_PWR_TRK_5G_NUM][RTW_PWR_TRK_TBL_SZ] = {
5194 	{ 0,  1,  2,  4,  5,  6,  7,  8,  9, 10,
5195 	 11, 13, 14, 15, 16, 17, 18, 19, 20, 21,
5196 	 23, 24, 25, 26, 27, 28, 29, 30, 31, 33 },
5197 	{ 0,  1,  2,  4,  5,  6,  7,  8,  9, 10,
5198 	 11, 13, 14, 15, 16, 17, 18, 19, 20, 21,
5199 	 23, 24, 25, 26, 27, 28, 29, 30, 31, 33 },
5200 	{ 0,  1,  2,  4,  5,  6,  7,  8,  9, 10,
5201 	 11, 13, 14, 15, 16, 17, 18, 19, 20, 21,
5202 	 23, 24, 25, 26, 27, 28, 29, 30, 31, 33 },
5203 };
5204 
5205 static const u8
5206 rtw8822c_pwrtrk_5ga_p[RTW_PWR_TRK_5G_NUM][RTW_PWR_TRK_TBL_SZ] = {
5207 	{ 0,  1,  2,  3,  4,  5,  6,  7,  8,  9,
5208 	 10, 11, 12, 13, 14, 15, 16, 17, 18, 20,
5209 	 21, 22, 23, 24, 25, 26, 27, 28, 29, 30 },
5210 	{ 0,  1,  2,  3,  4,  5,  6,  7,  8,  9,
5211 	 10, 11, 12, 13, 14, 15, 16, 17, 18, 20,
5212 	 21, 22, 23, 24, 25, 26, 27, 28, 29, 30 },
5213 	{ 0,  1,  2,  3,  4,  5,  6,  7,  8,  9,
5214 	 10, 11, 12, 13, 14, 15, 16, 17, 18, 20,
5215 	 21, 22, 23, 24, 25, 26, 27, 28, 29, 30 },
5216 };
5217 
5218 static const u8 rtw8822c_pwrtrk_2gb_n[RTW_PWR_TRK_TBL_SZ] = {
5219 	 0,  1,  2,  3,  4,  4,  5,  6,  7,  8,
5220 	 9,  9, 10, 11, 12, 13, 14, 15, 15, 16,
5221 	17, 18, 19, 20, 20, 21, 22, 23, 24, 25
5222 };
5223 
5224 static const u8 rtw8822c_pwrtrk_2gb_p[RTW_PWR_TRK_TBL_SZ] = {
5225 	 0,  1,  2,  3,  4,  5,  6,  7,  8,  9,
5226 	10, 11, 12, 13, 14, 14, 15, 16, 17, 18,
5227 	19, 20, 21, 22, 23, 24, 25, 26, 27, 28
5228 };
5229 
5230 static const u8 rtw8822c_pwrtrk_2ga_n[RTW_PWR_TRK_TBL_SZ] = {
5231 	 0,  1,  2,  2,  3,  4,  4,  5,  6,  6,
5232 	 7,  8,  8,  9,  9, 10, 11, 11, 12, 13,
5233 	13, 14, 15, 15, 16, 17, 17, 18, 19, 19
5234 };
5235 
5236 static const u8 rtw8822c_pwrtrk_2ga_p[RTW_PWR_TRK_TBL_SZ] = {
5237 	 0,  1,  2,  3,  4,  5,  6,  7,  8,  9,
5238 	10, 11, 11, 12, 13, 14, 15, 16, 17, 18,
5239 	19, 20, 21, 22, 23, 24, 25, 25, 26, 27
5240 };
5241 
5242 static const u8 rtw8822c_pwrtrk_2g_cck_b_n[RTW_PWR_TRK_TBL_SZ] = {
5243 	 0,  1,  2,  3,  4,  5,  5,  6,  7,  8,
5244 	 9, 10, 11, 11, 12, 13, 14, 15, 16, 17,
5245 	17, 18, 19, 20, 21, 22, 23, 23, 24, 25
5246 };
5247 
5248 static const u8 rtw8822c_pwrtrk_2g_cck_b_p[RTW_PWR_TRK_TBL_SZ] = {
5249 	 0,  1,  2,  3,  4,  5,  6,  7,  8,  9,
5250 	10, 11, 12, 13, 14, 15, 16, 17, 18, 19,
5251 	20, 21, 22, 23, 24, 25, 26, 27, 28, 29
5252 };
5253 
5254 static const u8 rtw8822c_pwrtrk_2g_cck_a_n[RTW_PWR_TRK_TBL_SZ] = {
5255 	 0,  1,  2,  3,  3,  4,  5,  6,  6,  7,
5256 	 8,  9,  9, 10, 11, 12, 12, 13, 14, 15,
5257 	15, 16, 17, 18, 18, 19, 20, 21, 21, 22
5258 };
5259 
5260 static const u8 rtw8822c_pwrtrk_2g_cck_a_p[RTW_PWR_TRK_TBL_SZ] = {
5261 	 0,  1,  2,  3,  4,  5,  5,  6,  7,  8,
5262 	 9, 10, 11, 11, 12, 13, 14, 15, 16, 17,
5263 	18, 18, 19, 20, 21, 22, 23, 24, 24, 25
5264 };
5265 
5266 static const struct rtw_pwr_track_tbl rtw8822c_pwr_track_type0_tbl = {
5267 	.pwrtrk_5gb_n[RTW_PWR_TRK_5G_1] = rtw8822c_pwrtrk_5gb_n[RTW_PWR_TRK_5G_1],
5268 	.pwrtrk_5gb_n[RTW_PWR_TRK_5G_2] = rtw8822c_pwrtrk_5gb_n[RTW_PWR_TRK_5G_2],
5269 	.pwrtrk_5gb_n[RTW_PWR_TRK_5G_3] = rtw8822c_pwrtrk_5gb_n[RTW_PWR_TRK_5G_3],
5270 	.pwrtrk_5gb_p[RTW_PWR_TRK_5G_1] = rtw8822c_pwrtrk_5gb_p[RTW_PWR_TRK_5G_1],
5271 	.pwrtrk_5gb_p[RTW_PWR_TRK_5G_2] = rtw8822c_pwrtrk_5gb_p[RTW_PWR_TRK_5G_2],
5272 	.pwrtrk_5gb_p[RTW_PWR_TRK_5G_3] = rtw8822c_pwrtrk_5gb_p[RTW_PWR_TRK_5G_3],
5273 	.pwrtrk_5ga_n[RTW_PWR_TRK_5G_1] = rtw8822c_pwrtrk_5ga_n[RTW_PWR_TRK_5G_1],
5274 	.pwrtrk_5ga_n[RTW_PWR_TRK_5G_2] = rtw8822c_pwrtrk_5ga_n[RTW_PWR_TRK_5G_2],
5275 	.pwrtrk_5ga_n[RTW_PWR_TRK_5G_3] = rtw8822c_pwrtrk_5ga_n[RTW_PWR_TRK_5G_3],
5276 	.pwrtrk_5ga_p[RTW_PWR_TRK_5G_1] = rtw8822c_pwrtrk_5ga_p[RTW_PWR_TRK_5G_1],
5277 	.pwrtrk_5ga_p[RTW_PWR_TRK_5G_2] = rtw8822c_pwrtrk_5ga_p[RTW_PWR_TRK_5G_2],
5278 	.pwrtrk_5ga_p[RTW_PWR_TRK_5G_3] = rtw8822c_pwrtrk_5ga_p[RTW_PWR_TRK_5G_3],
5279 	.pwrtrk_2gb_n = rtw8822c_pwrtrk_2gb_n,
5280 	.pwrtrk_2gb_p = rtw8822c_pwrtrk_2gb_p,
5281 	.pwrtrk_2ga_n = rtw8822c_pwrtrk_2ga_n,
5282 	.pwrtrk_2ga_p = rtw8822c_pwrtrk_2ga_p,
5283 	.pwrtrk_2g_cckb_n = rtw8822c_pwrtrk_2g_cck_b_n,
5284 	.pwrtrk_2g_cckb_p = rtw8822c_pwrtrk_2g_cck_b_p,
5285 	.pwrtrk_2g_ccka_n = rtw8822c_pwrtrk_2g_cck_a_n,
5286 	.pwrtrk_2g_ccka_p = rtw8822c_pwrtrk_2g_cck_a_p,
5287 };
5288 
5289 static const struct rtw_rfe_def rtw8822c_rfe_defs[] = {
5290 	[0] = RTW_DEF_RFE(8822c, 0, 0, 0),
5291 	[1] = RTW_DEF_RFE(8822c, 0, 0, 0),
5292 	[2] = RTW_DEF_RFE(8822c, 0, 0, 0),
5293 	[3] = RTW_DEF_RFE(8822c, 0, 0, 0),
5294 	[4] = RTW_DEF_RFE(8822c, 0, 0, 0),
5295 	[5] = RTW_DEF_RFE(8822c, 0, 5, 0),
5296 	[6] = RTW_DEF_RFE(8822c, 0, 0, 0),
5297 };
5298 
5299 static const struct rtw_hw_reg_offset rtw8822c_edcca_th[] = {
5300 	[EDCCA_TH_L2H_IDX] = {
5301 		{.addr = 0x84c, .mask = MASKBYTE2}, .offset = 0x80
5302 	},
5303 	[EDCCA_TH_H2L_IDX] = {
5304 		{.addr = 0x84c, .mask = MASKBYTE3}, .offset = 0x80
5305 	},
5306 };
5307 
5308 #ifdef CONFIG_PM
5309 static const struct wiphy_wowlan_support rtw_wowlan_stub_8822c = {
5310 	.flags = WIPHY_WOWLAN_MAGIC_PKT | WIPHY_WOWLAN_GTK_REKEY_FAILURE |
5311 		 WIPHY_WOWLAN_DISCONNECT | WIPHY_WOWLAN_SUPPORTS_GTK_REKEY |
5312 		 WIPHY_WOWLAN_NET_DETECT,
5313 	.n_patterns = RTW_MAX_PATTERN_NUM,
5314 	.pattern_max_len = RTW_MAX_PATTERN_SIZE,
5315 	.pattern_min_len = 1,
5316 	.max_nd_match_sets = 4,
5317 };
5318 #endif
5319 
5320 static const struct rtw_reg_domain coex_info_hw_regs_8822c[] = {
5321 	{0x1860, BIT(3), RTW_REG_DOMAIN_MAC8},
5322 	{0x4160, BIT(3), RTW_REG_DOMAIN_MAC8},
5323 	{0x1c32, BIT(6), RTW_REG_DOMAIN_MAC8},
5324 	{0x1c38, BIT(28), RTW_REG_DOMAIN_MAC32},
5325 	{0, 0, RTW_REG_DOMAIN_NL},
5326 	{0x430, MASKDWORD, RTW_REG_DOMAIN_MAC32},
5327 	{0x434, MASKDWORD, RTW_REG_DOMAIN_MAC32},
5328 	{0x42a, MASKLWORD, RTW_REG_DOMAIN_MAC16},
5329 	{0x426, MASKBYTE0, RTW_REG_DOMAIN_MAC8},
5330 	{0x45e, BIT(3), RTW_REG_DOMAIN_MAC8},
5331 	{0x454, MASKLWORD, RTW_REG_DOMAIN_MAC16},
5332 	{0, 0, RTW_REG_DOMAIN_NL},
5333 	{0x4c, BIT(24) | BIT(23), RTW_REG_DOMAIN_MAC32},
5334 	{0x64, BIT(0), RTW_REG_DOMAIN_MAC8},
5335 	{0x4c6, BIT(4), RTW_REG_DOMAIN_MAC8},
5336 	{0x40, BIT(5), RTW_REG_DOMAIN_MAC8},
5337 	{0x1, RFREG_MASK, RTW_REG_DOMAIN_RF_B},
5338 	{0, 0, RTW_REG_DOMAIN_NL},
5339 	{0x550, MASKDWORD, RTW_REG_DOMAIN_MAC32},
5340 	{0x522, MASKBYTE0, RTW_REG_DOMAIN_MAC8},
5341 	{0x953, BIT(1), RTW_REG_DOMAIN_MAC8},
5342 	{0xc50, MASKBYTE0, RTW_REG_DOMAIN_MAC8},
5343 };
5344 
5345 const struct rtw_chip_info rtw8822c_hw_spec = {
5346 	.ops = &rtw8822c_ops,
5347 	.id = RTW_CHIP_TYPE_8822C,
5348 	.fw_name = "rtw88/rtw8822c_fw.bin",
5349 	.wlan_cpu = RTW_WCPU_11AC,
5350 	.tx_pkt_desc_sz = 48,
5351 	.tx_buf_desc_sz = 16,
5352 	.rx_pkt_desc_sz = 24,
5353 	.rx_buf_desc_sz = 8,
5354 	.phy_efuse_size = 512,
5355 	.log_efuse_size = 768,
5356 	.ptct_efuse_size = 124,
5357 	.txff_size = 262144,
5358 	.rxff_size = 24576,
5359 	.fw_rxff_size = 12288,
5360 	.rsvd_drv_pg_num = 16,
5361 	.txgi_factor = 2,
5362 	.is_pwr_by_rate_dec = false,
5363 	.max_power_index = 0x7f,
5364 	.csi_buf_pg_num = 50,
5365 	.band = RTW_BAND_2G | RTW_BAND_5G,
5366 	.page_size = TX_PAGE_SIZE,
5367 	.dig_min = 0x20,
5368 	.usb_tx_agg_desc_num = 3,
5369 	.hw_feature_report = true,
5370 	.c2h_ra_report_size = 7,
5371 	.old_datarate_fb_limit = false,
5372 	.default_1ss_tx_path = BB_PATH_A,
5373 	.path_div_supported = true,
5374 	.ht_supported = true,
5375 	.vht_supported = true,
5376 	.lps_deep_mode_supported = BIT(LPS_DEEP_MODE_LCLK) | BIT(LPS_DEEP_MODE_PG),
5377 	.sys_func_en = 0xD8,
5378 	.pwr_on_seq = card_enable_flow_8822c,
5379 	.pwr_off_seq = card_disable_flow_8822c,
5380 	.page_table = page_table_8822c,
5381 	.rqpn_table = rqpn_table_8822c,
5382 	.prioq_addrs = &prioq_addrs_8822c,
5383 	.intf_table = &phy_para_table_8822c,
5384 	.dig = rtw8822c_dig,
5385 	.dig_cck = NULL,
5386 	.rf_base_addr = {0x3c00, 0x4c00},
5387 	.rf_sipi_addr = {0x1808, 0x4108},
5388 	.ltecoex_addr = &rtw8822c_ltecoex_addr,
5389 	.mac_tbl = &rtw8822c_mac_tbl,
5390 	.agc_tbl = &rtw8822c_agc_tbl,
5391 	.bb_tbl = &rtw8822c_bb_tbl,
5392 	.rfk_init_tbl = &rtw8822c_array_mp_cal_init_tbl,
5393 	.rf_tbl = {&rtw8822c_rf_b_tbl, &rtw8822c_rf_a_tbl},
5394 	.rfe_defs = rtw8822c_rfe_defs,
5395 	.rfe_defs_size = ARRAY_SIZE(rtw8822c_rfe_defs),
5396 	.en_dis_dpd = true,
5397 	.dpd_ratemask = DIS_DPD_RATEALL,
5398 	.iqk_threshold = 8,
5399 	.lck_threshold = 8,
5400 	.bfer_su_max_num = 2,
5401 	.bfer_mu_max_num = 1,
5402 	.rx_ldpc = true,
5403 	.tx_stbc = true,
5404 	.edcca_th = rtw8822c_edcca_th,
5405 	.l2h_th_ini_cs = 60,
5406 	.l2h_th_ini_ad = 45,
5407 	.ampdu_density = IEEE80211_HT_MPDU_DENSITY_2,
5408 
5409 #ifdef CONFIG_PM
5410 	.wow_fw_name = "rtw88/rtw8822c_wow_fw.bin",
5411 	.wowlan_stub = &rtw_wowlan_stub_8822c,
5412 	.max_sched_scan_ssids = 4,
5413 #endif
5414 	.max_scan_ie_len = (RTW_PROBE_PG_CNT - 1) * TX_PAGE_SIZE,
5415 	.coex_para_ver = 0x22020720,
5416 	.bt_desired_ver = 0x20,
5417 	.scbd_support = true,
5418 	.new_scbd10_def = true,
5419 	.ble_hid_profile_support = true,
5420 	.wl_mimo_ps_support = true,
5421 	.pstdma_type = COEX_PSTDMA_FORCE_LPSOFF,
5422 	.bt_rssi_type = COEX_BTRSSI_DBM,
5423 	.ant_isolation = 15,
5424 	.rssi_tolerance = 2,
5425 	.wl_rssi_step = wl_rssi_step_8822c,
5426 	.bt_rssi_step = bt_rssi_step_8822c,
5427 	.table_sant_num = ARRAY_SIZE(table_sant_8822c),
5428 	.table_sant = table_sant_8822c,
5429 	.table_nsant_num = ARRAY_SIZE(table_nsant_8822c),
5430 	.table_nsant = table_nsant_8822c,
5431 	.tdma_sant_num = ARRAY_SIZE(tdma_sant_8822c),
5432 	.tdma_sant = tdma_sant_8822c,
5433 	.tdma_nsant_num = ARRAY_SIZE(tdma_nsant_8822c),
5434 	.tdma_nsant = tdma_nsant_8822c,
5435 	.wl_rf_para_num = ARRAY_SIZE(rf_para_tx_8822c),
5436 	.wl_rf_para_tx = rf_para_tx_8822c,
5437 	.wl_rf_para_rx = rf_para_rx_8822c,
5438 	.bt_afh_span_bw20 = 0x24,
5439 	.bt_afh_span_bw40 = 0x36,
5440 	.afh_5g_num = ARRAY_SIZE(afh_5g_8822c),
5441 	.afh_5g = afh_5g_8822c,
5442 
5443 	.coex_info_hw_regs_num = ARRAY_SIZE(coex_info_hw_regs_8822c),
5444 	.coex_info_hw_regs = coex_info_hw_regs_8822c,
5445 
5446 	.fw_fifo_addr = {0x780, 0x700, 0x780, 0x660, 0x650, 0x680},
5447 	.fwcd_segs = &rtw8822c_fwcd_segs,
5448 };
5449 EXPORT_SYMBOL(rtw8822c_hw_spec);
5450 
5451 MODULE_FIRMWARE("rtw88/rtw8822c_fw.bin");
5452 MODULE_FIRMWARE("rtw88/rtw8822c_wow_fw.bin");
5453 
5454 MODULE_AUTHOR("Realtek Corporation");
5455 MODULE_DESCRIPTION("Realtek 802.11ac wireless 8822c driver");
5456 MODULE_LICENSE("Dual BSD/GPL");
5457