18c2ecf20Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0 OR BSD-3-Clause
28c2ecf20Sopenharmony_ci/* Copyright(c) 2018-2019  Realtek Corporation
38c2ecf20Sopenharmony_ci */
48c2ecf20Sopenharmony_ci
58c2ecf20Sopenharmony_ci#include <linux/module.h>
68c2ecf20Sopenharmony_ci#include "main.h"
78c2ecf20Sopenharmony_ci#include "coex.h"
88c2ecf20Sopenharmony_ci#include "fw.h"
98c2ecf20Sopenharmony_ci#include "tx.h"
108c2ecf20Sopenharmony_ci#include "rx.h"
118c2ecf20Sopenharmony_ci#include "phy.h"
128c2ecf20Sopenharmony_ci#include "rtw8822c.h"
138c2ecf20Sopenharmony_ci#include "rtw8822c_table.h"
148c2ecf20Sopenharmony_ci#include "mac.h"
158c2ecf20Sopenharmony_ci#include "reg.h"
168c2ecf20Sopenharmony_ci#include "debug.h"
178c2ecf20Sopenharmony_ci#include "util.h"
188c2ecf20Sopenharmony_ci#include "bf.h"
198c2ecf20Sopenharmony_ci#include "efuse.h"
208c2ecf20Sopenharmony_ci
218c2ecf20Sopenharmony_cistatic void rtw8822c_config_trx_mode(struct rtw_dev *rtwdev, u8 tx_path,
228c2ecf20Sopenharmony_ci				     u8 rx_path, bool is_tx2_path);
238c2ecf20Sopenharmony_ci
248c2ecf20Sopenharmony_cistatic void rtw8822ce_efuse_parsing(struct rtw_efuse *efuse,
258c2ecf20Sopenharmony_ci				    struct rtw8822c_efuse *map)
268c2ecf20Sopenharmony_ci{
278c2ecf20Sopenharmony_ci	ether_addr_copy(efuse->addr, map->e.mac_addr);
288c2ecf20Sopenharmony_ci}
298c2ecf20Sopenharmony_ci
308c2ecf20Sopenharmony_cistatic int rtw8822c_read_efuse(struct rtw_dev *rtwdev, u8 *log_map)
318c2ecf20Sopenharmony_ci{
328c2ecf20Sopenharmony_ci	struct rtw_efuse *efuse = &rtwdev->efuse;
338c2ecf20Sopenharmony_ci	struct rtw8822c_efuse *map;
348c2ecf20Sopenharmony_ci	int i;
358c2ecf20Sopenharmony_ci
368c2ecf20Sopenharmony_ci	map = (struct rtw8822c_efuse *)log_map;
378c2ecf20Sopenharmony_ci
388c2ecf20Sopenharmony_ci	efuse->rfe_option = map->rfe_option;
398c2ecf20Sopenharmony_ci	efuse->rf_board_option = map->rf_board_option;
408c2ecf20Sopenharmony_ci	efuse->crystal_cap = map->xtal_k;
418c2ecf20Sopenharmony_ci	efuse->channel_plan = map->channel_plan;
428c2ecf20Sopenharmony_ci	efuse->country_code[0] = map->country_code[0];
438c2ecf20Sopenharmony_ci	efuse->country_code[1] = map->country_code[1];
448c2ecf20Sopenharmony_ci	efuse->bt_setting = map->rf_bt_setting;
458c2ecf20Sopenharmony_ci	efuse->regd = map->rf_board_option & 0x7;
468c2ecf20Sopenharmony_ci	efuse->thermal_meter[RF_PATH_A] = map->path_a_thermal;
478c2ecf20Sopenharmony_ci	efuse->thermal_meter[RF_PATH_B] = map->path_b_thermal;
488c2ecf20Sopenharmony_ci	efuse->thermal_meter_k =
498c2ecf20Sopenharmony_ci			(map->path_a_thermal + map->path_b_thermal) >> 1;
508c2ecf20Sopenharmony_ci	efuse->power_track_type = (map->tx_pwr_calibrate_rate >> 4) & 0xf;
518c2ecf20Sopenharmony_ci
528c2ecf20Sopenharmony_ci	for (i = 0; i < 4; i++)
538c2ecf20Sopenharmony_ci		efuse->txpwr_idx_table[i] = map->txpwr_idx_table[i];
548c2ecf20Sopenharmony_ci
558c2ecf20Sopenharmony_ci	switch (rtw_hci_type(rtwdev)) {
568c2ecf20Sopenharmony_ci	case RTW_HCI_TYPE_PCIE:
578c2ecf20Sopenharmony_ci		rtw8822ce_efuse_parsing(efuse, map);
588c2ecf20Sopenharmony_ci		break;
598c2ecf20Sopenharmony_ci	default:
608c2ecf20Sopenharmony_ci		/* unsupported now */
618c2ecf20Sopenharmony_ci		return -ENOTSUPP;
628c2ecf20Sopenharmony_ci	}
638c2ecf20Sopenharmony_ci
648c2ecf20Sopenharmony_ci	return 0;
658c2ecf20Sopenharmony_ci}
668c2ecf20Sopenharmony_ci
678c2ecf20Sopenharmony_cistatic void rtw8822c_header_file_init(struct rtw_dev *rtwdev, bool pre)
688c2ecf20Sopenharmony_ci{
698c2ecf20Sopenharmony_ci	rtw_write32_set(rtwdev, REG_3WIRE, BIT_3WIRE_TX_EN | BIT_3WIRE_RX_EN);
708c2ecf20Sopenharmony_ci	rtw_write32_set(rtwdev, REG_3WIRE, BIT_3WIRE_PI_ON);
718c2ecf20Sopenharmony_ci	rtw_write32_set(rtwdev, REG_3WIRE2, BIT_3WIRE_TX_EN | BIT_3WIRE_RX_EN);
728c2ecf20Sopenharmony_ci	rtw_write32_set(rtwdev, REG_3WIRE2, BIT_3WIRE_PI_ON);
738c2ecf20Sopenharmony_ci
748c2ecf20Sopenharmony_ci	if (pre)
758c2ecf20Sopenharmony_ci		rtw_write32_clr(rtwdev, REG_ENCCK, BIT_CCK_OFDM_BLK_EN);
768c2ecf20Sopenharmony_ci	else
778c2ecf20Sopenharmony_ci		rtw_write32_set(rtwdev, REG_ENCCK, BIT_CCK_OFDM_BLK_EN);
788c2ecf20Sopenharmony_ci}
798c2ecf20Sopenharmony_ci
808c2ecf20Sopenharmony_cistatic void rtw8822c_dac_backup_reg(struct rtw_dev *rtwdev,
818c2ecf20Sopenharmony_ci				    struct rtw_backup_info *backup,
828c2ecf20Sopenharmony_ci				    struct rtw_backup_info *backup_rf)
838c2ecf20Sopenharmony_ci{
848c2ecf20Sopenharmony_ci	u32 path, i;
858c2ecf20Sopenharmony_ci	u32 val;
868c2ecf20Sopenharmony_ci	u32 reg;
878c2ecf20Sopenharmony_ci	u32 rf_addr[DACK_RF_8822C] = {0x8f};
888c2ecf20Sopenharmony_ci	u32 addrs[DACK_REG_8822C] = {0x180c, 0x1810, 0x410c, 0x4110,
898c2ecf20Sopenharmony_ci				     0x1c3c, 0x1c24, 0x1d70, 0x9b4,
908c2ecf20Sopenharmony_ci				     0x1a00, 0x1a14, 0x1d58, 0x1c38,
918c2ecf20Sopenharmony_ci				     0x1e24, 0x1e28, 0x1860, 0x4160};
928c2ecf20Sopenharmony_ci
938c2ecf20Sopenharmony_ci	for (i = 0; i < DACK_REG_8822C; i++) {
948c2ecf20Sopenharmony_ci		backup[i].len = 4;
958c2ecf20Sopenharmony_ci		backup[i].reg = addrs[i];
968c2ecf20Sopenharmony_ci		backup[i].val = rtw_read32(rtwdev, addrs[i]);
978c2ecf20Sopenharmony_ci	}
988c2ecf20Sopenharmony_ci
998c2ecf20Sopenharmony_ci	for (path = 0; path < DACK_PATH_8822C; path++) {
1008c2ecf20Sopenharmony_ci		for (i = 0; i < DACK_RF_8822C; i++) {
1018c2ecf20Sopenharmony_ci			reg = rf_addr[i];
1028c2ecf20Sopenharmony_ci			val = rtw_read_rf(rtwdev, path, reg, RFREG_MASK);
1038c2ecf20Sopenharmony_ci			backup_rf[path * i + i].reg = reg;
1048c2ecf20Sopenharmony_ci			backup_rf[path * i + i].val = val;
1058c2ecf20Sopenharmony_ci		}
1068c2ecf20Sopenharmony_ci	}
1078c2ecf20Sopenharmony_ci}
1088c2ecf20Sopenharmony_ci
1098c2ecf20Sopenharmony_cistatic void rtw8822c_dac_restore_reg(struct rtw_dev *rtwdev,
1108c2ecf20Sopenharmony_ci				     struct rtw_backup_info *backup,
1118c2ecf20Sopenharmony_ci				     struct rtw_backup_info *backup_rf)
1128c2ecf20Sopenharmony_ci{
1138c2ecf20Sopenharmony_ci	u32 path, i;
1148c2ecf20Sopenharmony_ci	u32 val;
1158c2ecf20Sopenharmony_ci	u32 reg;
1168c2ecf20Sopenharmony_ci
1178c2ecf20Sopenharmony_ci	rtw_restore_reg(rtwdev, backup, DACK_REG_8822C);
1188c2ecf20Sopenharmony_ci
1198c2ecf20Sopenharmony_ci	for (path = 0; path < DACK_PATH_8822C; path++) {
1208c2ecf20Sopenharmony_ci		for (i = 0; i < DACK_RF_8822C; i++) {
1218c2ecf20Sopenharmony_ci			val = backup_rf[path * i + i].val;
1228c2ecf20Sopenharmony_ci			reg = backup_rf[path * i + i].reg;
1238c2ecf20Sopenharmony_ci			rtw_write_rf(rtwdev, path, reg, RFREG_MASK, val);
1248c2ecf20Sopenharmony_ci		}
1258c2ecf20Sopenharmony_ci	}
1268c2ecf20Sopenharmony_ci}
1278c2ecf20Sopenharmony_ci
1288c2ecf20Sopenharmony_cistatic void rtw8822c_rf_minmax_cmp(struct rtw_dev *rtwdev, u32 value,
1298c2ecf20Sopenharmony_ci				   u32 *min, u32 *max)
1308c2ecf20Sopenharmony_ci{
1318c2ecf20Sopenharmony_ci	if (value >= 0x200) {
1328c2ecf20Sopenharmony_ci		if (*min >= 0x200) {
1338c2ecf20Sopenharmony_ci			if (*min > value)
1348c2ecf20Sopenharmony_ci				*min = value;
1358c2ecf20Sopenharmony_ci		} else {
1368c2ecf20Sopenharmony_ci			*min = value;
1378c2ecf20Sopenharmony_ci		}
1388c2ecf20Sopenharmony_ci		if (*max >= 0x200) {
1398c2ecf20Sopenharmony_ci			if (*max < value)
1408c2ecf20Sopenharmony_ci				*max = value;
1418c2ecf20Sopenharmony_ci		}
1428c2ecf20Sopenharmony_ci	} else {
1438c2ecf20Sopenharmony_ci		if (*min < 0x200) {
1448c2ecf20Sopenharmony_ci			if (*min > value)
1458c2ecf20Sopenharmony_ci				*min = value;
1468c2ecf20Sopenharmony_ci		}
1478c2ecf20Sopenharmony_ci
1488c2ecf20Sopenharmony_ci		if (*max  >= 0x200) {
1498c2ecf20Sopenharmony_ci			*max = value;
1508c2ecf20Sopenharmony_ci		} else {
1518c2ecf20Sopenharmony_ci			if (*max < value)
1528c2ecf20Sopenharmony_ci				*max = value;
1538c2ecf20Sopenharmony_ci		}
1548c2ecf20Sopenharmony_ci	}
1558c2ecf20Sopenharmony_ci}
1568c2ecf20Sopenharmony_ci
1578c2ecf20Sopenharmony_cistatic void __rtw8822c_dac_iq_sort(struct rtw_dev *rtwdev, u32 *v1, u32 *v2)
1588c2ecf20Sopenharmony_ci{
1598c2ecf20Sopenharmony_ci	if (*v1 >= 0x200 && *v2 >= 0x200) {
1608c2ecf20Sopenharmony_ci		if (*v1 > *v2)
1618c2ecf20Sopenharmony_ci			swap(*v1, *v2);
1628c2ecf20Sopenharmony_ci	} else if (*v1 < 0x200 && *v2 < 0x200) {
1638c2ecf20Sopenharmony_ci		if (*v1 > *v2)
1648c2ecf20Sopenharmony_ci			swap(*v1, *v2);
1658c2ecf20Sopenharmony_ci	} else if (*v1 < 0x200 && *v2 >= 0x200) {
1668c2ecf20Sopenharmony_ci		swap(*v1, *v2);
1678c2ecf20Sopenharmony_ci	}
1688c2ecf20Sopenharmony_ci}
1698c2ecf20Sopenharmony_ci
1708c2ecf20Sopenharmony_cistatic void rtw8822c_dac_iq_sort(struct rtw_dev *rtwdev, u32 *iv, u32 *qv)
1718c2ecf20Sopenharmony_ci{
1728c2ecf20Sopenharmony_ci	u32 i, j;
1738c2ecf20Sopenharmony_ci
1748c2ecf20Sopenharmony_ci	for (i = 0; i < DACK_SN_8822C - 1; i++) {
1758c2ecf20Sopenharmony_ci		for (j = 0; j < (DACK_SN_8822C - 1 - i) ; j++) {
1768c2ecf20Sopenharmony_ci			__rtw8822c_dac_iq_sort(rtwdev, &iv[j], &iv[j + 1]);
1778c2ecf20Sopenharmony_ci			__rtw8822c_dac_iq_sort(rtwdev, &qv[j], &qv[j + 1]);
1788c2ecf20Sopenharmony_ci		}
1798c2ecf20Sopenharmony_ci	}
1808c2ecf20Sopenharmony_ci}
1818c2ecf20Sopenharmony_ci
1828c2ecf20Sopenharmony_cistatic void rtw8822c_dac_iq_offset(struct rtw_dev *rtwdev, u32 *vec, u32 *val)
1838c2ecf20Sopenharmony_ci{
1848c2ecf20Sopenharmony_ci	u32 p, m, t, i;
1858c2ecf20Sopenharmony_ci
1868c2ecf20Sopenharmony_ci	m = 0;
1878c2ecf20Sopenharmony_ci	p = 0;
1888c2ecf20Sopenharmony_ci	for (i = 10; i < DACK_SN_8822C - 10; i++) {
1898c2ecf20Sopenharmony_ci		if (vec[i] > 0x200)
1908c2ecf20Sopenharmony_ci			m = (0x400 - vec[i]) + m;
1918c2ecf20Sopenharmony_ci		else
1928c2ecf20Sopenharmony_ci			p = vec[i] + p;
1938c2ecf20Sopenharmony_ci	}
1948c2ecf20Sopenharmony_ci
1958c2ecf20Sopenharmony_ci	if (p > m) {
1968c2ecf20Sopenharmony_ci		t = p - m;
1978c2ecf20Sopenharmony_ci		t = t / (DACK_SN_8822C - 20);
1988c2ecf20Sopenharmony_ci	} else {
1998c2ecf20Sopenharmony_ci		t = m - p;
2008c2ecf20Sopenharmony_ci		t = t / (DACK_SN_8822C - 20);
2018c2ecf20Sopenharmony_ci		if (t != 0x0)
2028c2ecf20Sopenharmony_ci			t = 0x400 - t;
2038c2ecf20Sopenharmony_ci	}
2048c2ecf20Sopenharmony_ci
2058c2ecf20Sopenharmony_ci	*val = t;
2068c2ecf20Sopenharmony_ci}
2078c2ecf20Sopenharmony_ci
2088c2ecf20Sopenharmony_cistatic u32 rtw8822c_get_path_write_addr(u8 path)
2098c2ecf20Sopenharmony_ci{
2108c2ecf20Sopenharmony_ci	u32 base_addr;
2118c2ecf20Sopenharmony_ci
2128c2ecf20Sopenharmony_ci	switch (path) {
2138c2ecf20Sopenharmony_ci	case RF_PATH_A:
2148c2ecf20Sopenharmony_ci		base_addr = 0x1800;
2158c2ecf20Sopenharmony_ci		break;
2168c2ecf20Sopenharmony_ci	case RF_PATH_B:
2178c2ecf20Sopenharmony_ci		base_addr = 0x4100;
2188c2ecf20Sopenharmony_ci		break;
2198c2ecf20Sopenharmony_ci	default:
2208c2ecf20Sopenharmony_ci		WARN_ON(1);
2218c2ecf20Sopenharmony_ci		return -1;
2228c2ecf20Sopenharmony_ci	}
2238c2ecf20Sopenharmony_ci
2248c2ecf20Sopenharmony_ci	return base_addr;
2258c2ecf20Sopenharmony_ci}
2268c2ecf20Sopenharmony_ci
2278c2ecf20Sopenharmony_cistatic u32 rtw8822c_get_path_read_addr(u8 path)
2288c2ecf20Sopenharmony_ci{
2298c2ecf20Sopenharmony_ci	u32 base_addr;
2308c2ecf20Sopenharmony_ci
2318c2ecf20Sopenharmony_ci	switch (path) {
2328c2ecf20Sopenharmony_ci	case RF_PATH_A:
2338c2ecf20Sopenharmony_ci		base_addr = 0x2800;
2348c2ecf20Sopenharmony_ci		break;
2358c2ecf20Sopenharmony_ci	case RF_PATH_B:
2368c2ecf20Sopenharmony_ci		base_addr = 0x4500;
2378c2ecf20Sopenharmony_ci		break;
2388c2ecf20Sopenharmony_ci	default:
2398c2ecf20Sopenharmony_ci		WARN_ON(1);
2408c2ecf20Sopenharmony_ci		return -1;
2418c2ecf20Sopenharmony_ci	}
2428c2ecf20Sopenharmony_ci
2438c2ecf20Sopenharmony_ci	return base_addr;
2448c2ecf20Sopenharmony_ci}
2458c2ecf20Sopenharmony_ci
2468c2ecf20Sopenharmony_cistatic bool rtw8822c_dac_iq_check(struct rtw_dev *rtwdev, u32 value)
2478c2ecf20Sopenharmony_ci{
2488c2ecf20Sopenharmony_ci	bool ret = true;
2498c2ecf20Sopenharmony_ci
2508c2ecf20Sopenharmony_ci	if ((value >= 0x200 && (0x400 - value) > 0x64) ||
2518c2ecf20Sopenharmony_ci	    (value < 0x200 && value > 0x64)) {
2528c2ecf20Sopenharmony_ci		ret = false;
2538c2ecf20Sopenharmony_ci		rtw_dbg(rtwdev, RTW_DBG_RFK, "[DACK] Error overflow\n");
2548c2ecf20Sopenharmony_ci	}
2558c2ecf20Sopenharmony_ci
2568c2ecf20Sopenharmony_ci	return ret;
2578c2ecf20Sopenharmony_ci}
2588c2ecf20Sopenharmony_ci
2598c2ecf20Sopenharmony_cistatic void rtw8822c_dac_cal_iq_sample(struct rtw_dev *rtwdev, u32 *iv, u32 *qv)
2608c2ecf20Sopenharmony_ci{
2618c2ecf20Sopenharmony_ci	u32 temp;
2628c2ecf20Sopenharmony_ci	int i = 0, cnt = 0;
2638c2ecf20Sopenharmony_ci
2648c2ecf20Sopenharmony_ci	while (i < DACK_SN_8822C && cnt < 10000) {
2658c2ecf20Sopenharmony_ci		cnt++;
2668c2ecf20Sopenharmony_ci		temp = rtw_read32_mask(rtwdev, 0x2dbc, 0x3fffff);
2678c2ecf20Sopenharmony_ci		iv[i] = (temp & 0x3ff000) >> 12;
2688c2ecf20Sopenharmony_ci		qv[i] = temp & 0x3ff;
2698c2ecf20Sopenharmony_ci
2708c2ecf20Sopenharmony_ci		if (rtw8822c_dac_iq_check(rtwdev, iv[i]) &&
2718c2ecf20Sopenharmony_ci		    rtw8822c_dac_iq_check(rtwdev, qv[i]))
2728c2ecf20Sopenharmony_ci			i++;
2738c2ecf20Sopenharmony_ci	}
2748c2ecf20Sopenharmony_ci}
2758c2ecf20Sopenharmony_ci
2768c2ecf20Sopenharmony_cistatic void rtw8822c_dac_cal_iq_search(struct rtw_dev *rtwdev,
2778c2ecf20Sopenharmony_ci				       u32 *iv, u32 *qv,
2788c2ecf20Sopenharmony_ci				       u32 *i_value, u32 *q_value)
2798c2ecf20Sopenharmony_ci{
2808c2ecf20Sopenharmony_ci	u32 i_max = 0, q_max = 0, i_min = 0, q_min = 0;
2818c2ecf20Sopenharmony_ci	u32 i_delta, q_delta;
2828c2ecf20Sopenharmony_ci	u32 temp;
2838c2ecf20Sopenharmony_ci	int i, cnt = 0;
2848c2ecf20Sopenharmony_ci
2858c2ecf20Sopenharmony_ci	do {
2868c2ecf20Sopenharmony_ci		i_min = iv[0];
2878c2ecf20Sopenharmony_ci		i_max = iv[0];
2888c2ecf20Sopenharmony_ci		q_min = qv[0];
2898c2ecf20Sopenharmony_ci		q_max = qv[0];
2908c2ecf20Sopenharmony_ci		for (i = 0; i < DACK_SN_8822C; i++) {
2918c2ecf20Sopenharmony_ci			rtw8822c_rf_minmax_cmp(rtwdev, iv[i], &i_min, &i_max);
2928c2ecf20Sopenharmony_ci			rtw8822c_rf_minmax_cmp(rtwdev, qv[i], &q_min, &q_max);
2938c2ecf20Sopenharmony_ci		}
2948c2ecf20Sopenharmony_ci
2958c2ecf20Sopenharmony_ci		if (i_max < 0x200 && i_min < 0x200)
2968c2ecf20Sopenharmony_ci			i_delta = i_max - i_min;
2978c2ecf20Sopenharmony_ci		else if (i_max >= 0x200 && i_min >= 0x200)
2988c2ecf20Sopenharmony_ci			i_delta = i_max - i_min;
2998c2ecf20Sopenharmony_ci		else
3008c2ecf20Sopenharmony_ci			i_delta = i_max + (0x400 - i_min);
3018c2ecf20Sopenharmony_ci
3028c2ecf20Sopenharmony_ci		if (q_max < 0x200 && q_min < 0x200)
3038c2ecf20Sopenharmony_ci			q_delta = q_max - q_min;
3048c2ecf20Sopenharmony_ci		else if (q_max >= 0x200 && q_min >= 0x200)
3058c2ecf20Sopenharmony_ci			q_delta = q_max - q_min;
3068c2ecf20Sopenharmony_ci		else
3078c2ecf20Sopenharmony_ci			q_delta = q_max + (0x400 - q_min);
3088c2ecf20Sopenharmony_ci
3098c2ecf20Sopenharmony_ci		rtw_dbg(rtwdev, RTW_DBG_RFK,
3108c2ecf20Sopenharmony_ci			"[DACK] i: min=0x%08x, max=0x%08x, delta=0x%08x\n",
3118c2ecf20Sopenharmony_ci			i_min, i_max, i_delta);
3128c2ecf20Sopenharmony_ci		rtw_dbg(rtwdev, RTW_DBG_RFK,
3138c2ecf20Sopenharmony_ci			"[DACK] q: min=0x%08x, max=0x%08x, delta=0x%08x\n",
3148c2ecf20Sopenharmony_ci			q_min, q_max, q_delta);
3158c2ecf20Sopenharmony_ci
3168c2ecf20Sopenharmony_ci		rtw8822c_dac_iq_sort(rtwdev, iv, qv);
3178c2ecf20Sopenharmony_ci
3188c2ecf20Sopenharmony_ci		if (i_delta > 5 || q_delta > 5) {
3198c2ecf20Sopenharmony_ci			temp = rtw_read32_mask(rtwdev, 0x2dbc, 0x3fffff);
3208c2ecf20Sopenharmony_ci			iv[0] = (temp & 0x3ff000) >> 12;
3218c2ecf20Sopenharmony_ci			qv[0] = temp & 0x3ff;
3228c2ecf20Sopenharmony_ci			temp = rtw_read32_mask(rtwdev, 0x2dbc, 0x3fffff);
3238c2ecf20Sopenharmony_ci			iv[DACK_SN_8822C - 1] = (temp & 0x3ff000) >> 12;
3248c2ecf20Sopenharmony_ci			qv[DACK_SN_8822C - 1] = temp & 0x3ff;
3258c2ecf20Sopenharmony_ci		} else {
3268c2ecf20Sopenharmony_ci			break;
3278c2ecf20Sopenharmony_ci		}
3288c2ecf20Sopenharmony_ci	} while (cnt++ < 100);
3298c2ecf20Sopenharmony_ci
3308c2ecf20Sopenharmony_ci	rtw8822c_dac_iq_offset(rtwdev, iv, i_value);
3318c2ecf20Sopenharmony_ci	rtw8822c_dac_iq_offset(rtwdev, qv, q_value);
3328c2ecf20Sopenharmony_ci}
3338c2ecf20Sopenharmony_ci
3348c2ecf20Sopenharmony_cistatic void rtw8822c_dac_cal_rf_mode(struct rtw_dev *rtwdev,
3358c2ecf20Sopenharmony_ci				     u32 *i_value, u32 *q_value)
3368c2ecf20Sopenharmony_ci{
3378c2ecf20Sopenharmony_ci	u32 iv[DACK_SN_8822C], qv[DACK_SN_8822C];
3388c2ecf20Sopenharmony_ci	u32 rf_a, rf_b;
3398c2ecf20Sopenharmony_ci
3408c2ecf20Sopenharmony_ci	rf_a = rtw_read_rf(rtwdev, RF_PATH_A, 0x0, RFREG_MASK);
3418c2ecf20Sopenharmony_ci	rf_b = rtw_read_rf(rtwdev, RF_PATH_B, 0x0, RFREG_MASK);
3428c2ecf20Sopenharmony_ci
3438c2ecf20Sopenharmony_ci	rtw_dbg(rtwdev, RTW_DBG_RFK, "[DACK] RF path-A=0x%05x\n", rf_a);
3448c2ecf20Sopenharmony_ci	rtw_dbg(rtwdev, RTW_DBG_RFK, "[DACK] RF path-B=0x%05x\n", rf_b);
3458c2ecf20Sopenharmony_ci
3468c2ecf20Sopenharmony_ci	rtw8822c_dac_cal_iq_sample(rtwdev, iv, qv);
3478c2ecf20Sopenharmony_ci	rtw8822c_dac_cal_iq_search(rtwdev, iv, qv, i_value, q_value);
3488c2ecf20Sopenharmony_ci}
3498c2ecf20Sopenharmony_ci
3508c2ecf20Sopenharmony_cistatic void rtw8822c_dac_bb_setting(struct rtw_dev *rtwdev)
3518c2ecf20Sopenharmony_ci{
3528c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x1d58, 0xff8, 0x1ff);
3538c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x1a00, 0x3, 0x2);
3548c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x1a14, 0x300, 0x3);
3558c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, 0x1d70, 0x7e7e7e7e);
3568c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x180c, 0x3, 0x0);
3578c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x410c, 0x3, 0x0);
3588c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, 0x1b00, 0x00000008);
3598c2ecf20Sopenharmony_ci	rtw_write8(rtwdev, 0x1bcc, 0x3f);
3608c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, 0x1b00, 0x0000000a);
3618c2ecf20Sopenharmony_ci	rtw_write8(rtwdev, 0x1bcc, 0x3f);
3628c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x1e24, BIT(31), 0x0);
3638c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x1e28, 0xf, 0x3);
3648c2ecf20Sopenharmony_ci}
3658c2ecf20Sopenharmony_ci
3668c2ecf20Sopenharmony_cistatic void rtw8822c_dac_cal_adc(struct rtw_dev *rtwdev,
3678c2ecf20Sopenharmony_ci				 u8 path, u32 *adc_ic, u32 *adc_qc)
3688c2ecf20Sopenharmony_ci{
3698c2ecf20Sopenharmony_ci	struct rtw_dm_info *dm_info = &rtwdev->dm_info;
3708c2ecf20Sopenharmony_ci	u32 ic = 0, qc = 0, temp = 0;
3718c2ecf20Sopenharmony_ci	u32 base_addr;
3728c2ecf20Sopenharmony_ci	u32 path_sel;
3738c2ecf20Sopenharmony_ci	int i;
3748c2ecf20Sopenharmony_ci
3758c2ecf20Sopenharmony_ci	rtw_dbg(rtwdev, RTW_DBG_RFK, "[DACK] ADCK path(%d)\n", path);
3768c2ecf20Sopenharmony_ci
3778c2ecf20Sopenharmony_ci	base_addr = rtw8822c_get_path_write_addr(path);
3788c2ecf20Sopenharmony_ci	switch (path) {
3798c2ecf20Sopenharmony_ci	case RF_PATH_A:
3808c2ecf20Sopenharmony_ci		path_sel = 0xa0000;
3818c2ecf20Sopenharmony_ci		break;
3828c2ecf20Sopenharmony_ci	case RF_PATH_B:
3838c2ecf20Sopenharmony_ci		path_sel = 0x80000;
3848c2ecf20Sopenharmony_ci		break;
3858c2ecf20Sopenharmony_ci	default:
3868c2ecf20Sopenharmony_ci		WARN_ON(1);
3878c2ecf20Sopenharmony_ci		return;
3888c2ecf20Sopenharmony_ci	}
3898c2ecf20Sopenharmony_ci
3908c2ecf20Sopenharmony_ci	/* ADCK step1 */
3918c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, base_addr + 0x30, BIT(30), 0x0);
3928c2ecf20Sopenharmony_ci	if (path == RF_PATH_B)
3938c2ecf20Sopenharmony_ci		rtw_write32(rtwdev, base_addr + 0x30, 0x30db8041);
3948c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, base_addr + 0x60, 0xf0040ff0);
3958c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, base_addr + 0x0c, 0xdff00220);
3968c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, base_addr + 0x10, 0x02dd08c4);
3978c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, base_addr + 0x0c, 0x10000260);
3988c2ecf20Sopenharmony_ci	rtw_write_rf(rtwdev, RF_PATH_A, 0x0, RFREG_MASK, 0x10000);
3998c2ecf20Sopenharmony_ci	rtw_write_rf(rtwdev, RF_PATH_B, 0x0, RFREG_MASK, 0x10000);
4008c2ecf20Sopenharmony_ci	for (i = 0; i < 10; i++) {
4018c2ecf20Sopenharmony_ci		rtw_dbg(rtwdev, RTW_DBG_RFK, "[DACK] ADCK count=%d\n", i);
4028c2ecf20Sopenharmony_ci		rtw_write32(rtwdev, 0x1c3c, path_sel + 0x8003);
4038c2ecf20Sopenharmony_ci		rtw_write32(rtwdev, 0x1c24, 0x00010002);
4048c2ecf20Sopenharmony_ci		rtw8822c_dac_cal_rf_mode(rtwdev, &ic, &qc);
4058c2ecf20Sopenharmony_ci		rtw_dbg(rtwdev, RTW_DBG_RFK,
4068c2ecf20Sopenharmony_ci			"[DACK] before: i=0x%x, q=0x%x\n", ic, qc);
4078c2ecf20Sopenharmony_ci
4088c2ecf20Sopenharmony_ci		/* compensation value */
4098c2ecf20Sopenharmony_ci		if (ic != 0x0) {
4108c2ecf20Sopenharmony_ci			ic = 0x400 - ic;
4118c2ecf20Sopenharmony_ci			*adc_ic = ic;
4128c2ecf20Sopenharmony_ci		}
4138c2ecf20Sopenharmony_ci		if (qc != 0x0) {
4148c2ecf20Sopenharmony_ci			qc = 0x400 - qc;
4158c2ecf20Sopenharmony_ci			*adc_qc = qc;
4168c2ecf20Sopenharmony_ci		}
4178c2ecf20Sopenharmony_ci		temp = (ic & 0x3ff) | ((qc & 0x3ff) << 10);
4188c2ecf20Sopenharmony_ci		rtw_write32(rtwdev, base_addr + 0x68, temp);
4198c2ecf20Sopenharmony_ci		dm_info->dack_adck[path] = temp;
4208c2ecf20Sopenharmony_ci		rtw_dbg(rtwdev, RTW_DBG_RFK, "[DACK] ADCK 0x%08x=0x08%x\n",
4218c2ecf20Sopenharmony_ci			base_addr + 0x68, temp);
4228c2ecf20Sopenharmony_ci		/* check ADC DC offset */
4238c2ecf20Sopenharmony_ci		rtw_write32(rtwdev, 0x1c3c, path_sel + 0x8103);
4248c2ecf20Sopenharmony_ci		rtw8822c_dac_cal_rf_mode(rtwdev, &ic, &qc);
4258c2ecf20Sopenharmony_ci		rtw_dbg(rtwdev, RTW_DBG_RFK,
4268c2ecf20Sopenharmony_ci			"[DACK] after:  i=0x%08x, q=0x%08x\n", ic, qc);
4278c2ecf20Sopenharmony_ci		if (ic >= 0x200)
4288c2ecf20Sopenharmony_ci			ic = 0x400 - ic;
4298c2ecf20Sopenharmony_ci		if (qc >= 0x200)
4308c2ecf20Sopenharmony_ci			qc = 0x400 - qc;
4318c2ecf20Sopenharmony_ci		if (ic < 5 && qc < 5)
4328c2ecf20Sopenharmony_ci			break;
4338c2ecf20Sopenharmony_ci	}
4348c2ecf20Sopenharmony_ci
4358c2ecf20Sopenharmony_ci	/* ADCK step2 */
4368c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, 0x1c3c, 0x00000003);
4378c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, base_addr + 0x0c, 0x10000260);
4388c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, base_addr + 0x10, 0x02d508c4);
4398c2ecf20Sopenharmony_ci
4408c2ecf20Sopenharmony_ci	/* release pull low switch on IQ path */
4418c2ecf20Sopenharmony_ci	rtw_write_rf(rtwdev, path, 0x8f, BIT(13), 0x1);
4428c2ecf20Sopenharmony_ci}
4438c2ecf20Sopenharmony_ci
4448c2ecf20Sopenharmony_cistatic void rtw8822c_dac_cal_step1(struct rtw_dev *rtwdev, u8 path)
4458c2ecf20Sopenharmony_ci{
4468c2ecf20Sopenharmony_ci	struct rtw_dm_info *dm_info = &rtwdev->dm_info;
4478c2ecf20Sopenharmony_ci	u32 base_addr;
4488c2ecf20Sopenharmony_ci	u32 read_addr;
4498c2ecf20Sopenharmony_ci
4508c2ecf20Sopenharmony_ci	base_addr = rtw8822c_get_path_write_addr(path);
4518c2ecf20Sopenharmony_ci	read_addr = rtw8822c_get_path_read_addr(path);
4528c2ecf20Sopenharmony_ci
4538c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, base_addr + 0x68, dm_info->dack_adck[path]);
4548c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, base_addr + 0x0c, 0xdff00220);
4558c2ecf20Sopenharmony_ci	if (path == RF_PATH_A) {
4568c2ecf20Sopenharmony_ci		rtw_write32(rtwdev, base_addr + 0x60, 0xf0040ff0);
4578c2ecf20Sopenharmony_ci		rtw_write32(rtwdev, 0x1c38, 0xffffffff);
4588c2ecf20Sopenharmony_ci	}
4598c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, base_addr + 0x10, 0x02d508c5);
4608c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, 0x9b4, 0xdb66db00);
4618c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, base_addr + 0xb0, 0x0a11fb88);
4628c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, base_addr + 0xbc, 0x0008ff81);
4638c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, base_addr + 0xc0, 0x0003d208);
4648c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, base_addr + 0xcc, 0x0a11fb88);
4658c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, base_addr + 0xd8, 0x0008ff81);
4668c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, base_addr + 0xdc, 0x0003d208);
4678c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, base_addr + 0xb8, 0x60000000);
4688c2ecf20Sopenharmony_ci	mdelay(2);
4698c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, base_addr + 0xbc, 0x000aff8d);
4708c2ecf20Sopenharmony_ci	mdelay(2);
4718c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, base_addr + 0xb0, 0x0a11fb89);
4728c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, base_addr + 0xcc, 0x0a11fb89);
4738c2ecf20Sopenharmony_ci	mdelay(1);
4748c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, base_addr + 0xb8, 0x62000000);
4758c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, base_addr + 0xd4, 0x62000000);
4768c2ecf20Sopenharmony_ci	mdelay(20);
4778c2ecf20Sopenharmony_ci	if (!check_hw_ready(rtwdev, read_addr + 0x08, 0x7fff80, 0xffff) ||
4788c2ecf20Sopenharmony_ci	    !check_hw_ready(rtwdev, read_addr + 0x34, 0x7fff80, 0xffff))
4798c2ecf20Sopenharmony_ci		rtw_err(rtwdev, "failed to wait for dack ready\n");
4808c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, base_addr + 0xb8, 0x02000000);
4818c2ecf20Sopenharmony_ci	mdelay(1);
4828c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, base_addr + 0xbc, 0x0008ff87);
4838c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, 0x9b4, 0xdb6db600);
4848c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, base_addr + 0x10, 0x02d508c5);
4858c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, base_addr + 0xbc, 0x0008ff87);
4868c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, base_addr + 0x60, 0xf0000000);
4878c2ecf20Sopenharmony_ci}
4888c2ecf20Sopenharmony_ci
4898c2ecf20Sopenharmony_cistatic void rtw8822c_dac_cal_step2(struct rtw_dev *rtwdev,
4908c2ecf20Sopenharmony_ci				   u8 path, u32 *ic_out, u32 *qc_out)
4918c2ecf20Sopenharmony_ci{
4928c2ecf20Sopenharmony_ci	u32 base_addr;
4938c2ecf20Sopenharmony_ci	u32 ic, qc, ic_in, qc_in;
4948c2ecf20Sopenharmony_ci
4958c2ecf20Sopenharmony_ci	base_addr = rtw8822c_get_path_write_addr(path);
4968c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, base_addr + 0xbc, 0xf0000000, 0x0);
4978c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, base_addr + 0xc0, 0xf, 0x8);
4988c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, base_addr + 0xd8, 0xf0000000, 0x0);
4998c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, base_addr + 0xdc, 0xf, 0x8);
5008c2ecf20Sopenharmony_ci
5018c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, 0x1b00, 0x00000008);
5028c2ecf20Sopenharmony_ci	rtw_write8(rtwdev, 0x1bcc, 0x03f);
5038c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, base_addr + 0x0c, 0xdff00220);
5048c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, base_addr + 0x10, 0x02d508c5);
5058c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, 0x1c3c, 0x00088103);
5068c2ecf20Sopenharmony_ci
5078c2ecf20Sopenharmony_ci	rtw8822c_dac_cal_rf_mode(rtwdev, &ic_in, &qc_in);
5088c2ecf20Sopenharmony_ci	ic = ic_in;
5098c2ecf20Sopenharmony_ci	qc = qc_in;
5108c2ecf20Sopenharmony_ci
5118c2ecf20Sopenharmony_ci	/* compensation value */
5128c2ecf20Sopenharmony_ci	if (ic != 0x0)
5138c2ecf20Sopenharmony_ci		ic = 0x400 - ic;
5148c2ecf20Sopenharmony_ci	if (qc != 0x0)
5158c2ecf20Sopenharmony_ci		qc = 0x400 - qc;
5168c2ecf20Sopenharmony_ci	if (ic < 0x300) {
5178c2ecf20Sopenharmony_ci		ic = ic * 2 * 6 / 5;
5188c2ecf20Sopenharmony_ci		ic = ic + 0x80;
5198c2ecf20Sopenharmony_ci	} else {
5208c2ecf20Sopenharmony_ci		ic = (0x400 - ic) * 2 * 6 / 5;
5218c2ecf20Sopenharmony_ci		ic = 0x7f - ic;
5228c2ecf20Sopenharmony_ci	}
5238c2ecf20Sopenharmony_ci	if (qc < 0x300) {
5248c2ecf20Sopenharmony_ci		qc = qc * 2 * 6 / 5;
5258c2ecf20Sopenharmony_ci		qc = qc + 0x80;
5268c2ecf20Sopenharmony_ci	} else {
5278c2ecf20Sopenharmony_ci		qc = (0x400 - qc) * 2 * 6 / 5;
5288c2ecf20Sopenharmony_ci		qc = 0x7f - qc;
5298c2ecf20Sopenharmony_ci	}
5308c2ecf20Sopenharmony_ci
5318c2ecf20Sopenharmony_ci	*ic_out = ic;
5328c2ecf20Sopenharmony_ci	*qc_out = qc;
5338c2ecf20Sopenharmony_ci
5348c2ecf20Sopenharmony_ci	rtw_dbg(rtwdev, RTW_DBG_RFK, "[DACK] before i=0x%x, q=0x%x\n", ic_in, qc_in);
5358c2ecf20Sopenharmony_ci	rtw_dbg(rtwdev, RTW_DBG_RFK, "[DACK] after  i=0x%x, q=0x%x\n", ic, qc);
5368c2ecf20Sopenharmony_ci}
5378c2ecf20Sopenharmony_ci
5388c2ecf20Sopenharmony_cistatic void rtw8822c_dac_cal_step3(struct rtw_dev *rtwdev, u8 path,
5398c2ecf20Sopenharmony_ci				   u32 adc_ic, u32 adc_qc,
5408c2ecf20Sopenharmony_ci				   u32 *ic_in, u32 *qc_in,
5418c2ecf20Sopenharmony_ci				   u32 *i_out, u32 *q_out)
5428c2ecf20Sopenharmony_ci{
5438c2ecf20Sopenharmony_ci	u32 base_addr;
5448c2ecf20Sopenharmony_ci	u32 read_addr;
5458c2ecf20Sopenharmony_ci	u32 ic, qc;
5468c2ecf20Sopenharmony_ci	u32 temp;
5478c2ecf20Sopenharmony_ci
5488c2ecf20Sopenharmony_ci	base_addr = rtw8822c_get_path_write_addr(path);
5498c2ecf20Sopenharmony_ci	read_addr = rtw8822c_get_path_read_addr(path);
5508c2ecf20Sopenharmony_ci	ic = *ic_in;
5518c2ecf20Sopenharmony_ci	qc = *qc_in;
5528c2ecf20Sopenharmony_ci
5538c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, base_addr + 0x0c, 0xdff00220);
5548c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, base_addr + 0x10, 0x02d508c5);
5558c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, 0x9b4, 0xdb66db00);
5568c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, base_addr + 0xb0, 0x0a11fb88);
5578c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, base_addr + 0xbc, 0xc008ff81);
5588c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, base_addr + 0xc0, 0x0003d208);
5598c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, base_addr + 0xbc, 0xf0000000, ic & 0xf);
5608c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, base_addr + 0xc0, 0xf, (ic & 0xf0) >> 4);
5618c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, base_addr + 0xcc, 0x0a11fb88);
5628c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, base_addr + 0xd8, 0xe008ff81);
5638c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, base_addr + 0xdc, 0x0003d208);
5648c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, base_addr + 0xd8, 0xf0000000, qc & 0xf);
5658c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, base_addr + 0xdc, 0xf, (qc & 0xf0) >> 4);
5668c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, base_addr + 0xb8, 0x60000000);
5678c2ecf20Sopenharmony_ci	mdelay(2);
5688c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, base_addr + 0xbc, 0xe, 0x6);
5698c2ecf20Sopenharmony_ci	mdelay(2);
5708c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, base_addr + 0xb0, 0x0a11fb89);
5718c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, base_addr + 0xcc, 0x0a11fb89);
5728c2ecf20Sopenharmony_ci	mdelay(1);
5738c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, base_addr + 0xb8, 0x62000000);
5748c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, base_addr + 0xd4, 0x62000000);
5758c2ecf20Sopenharmony_ci	mdelay(20);
5768c2ecf20Sopenharmony_ci	if (!check_hw_ready(rtwdev, read_addr + 0x24, 0x07f80000, ic) ||
5778c2ecf20Sopenharmony_ci	    !check_hw_ready(rtwdev, read_addr + 0x50, 0x07f80000, qc))
5788c2ecf20Sopenharmony_ci		rtw_err(rtwdev, "failed to write IQ vector to hardware\n");
5798c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, base_addr + 0xb8, 0x02000000);
5808c2ecf20Sopenharmony_ci	mdelay(1);
5818c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, base_addr + 0xbc, 0xe, 0x3);
5828c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, 0x9b4, 0xdb6db600);
5838c2ecf20Sopenharmony_ci
5848c2ecf20Sopenharmony_ci	/* check DAC DC offset */
5858c2ecf20Sopenharmony_ci	temp = ((adc_ic + 0x10) & 0x3ff) | (((adc_qc + 0x10) & 0x3ff) << 10);
5868c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, base_addr + 0x68, temp);
5878c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, base_addr + 0x10, 0x02d508c5);
5888c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, base_addr + 0x60, 0xf0000000);
5898c2ecf20Sopenharmony_ci	rtw8822c_dac_cal_rf_mode(rtwdev, &ic, &qc);
5908c2ecf20Sopenharmony_ci	if (ic >= 0x10)
5918c2ecf20Sopenharmony_ci		ic = ic - 0x10;
5928c2ecf20Sopenharmony_ci	else
5938c2ecf20Sopenharmony_ci		ic = 0x400 - (0x10 - ic);
5948c2ecf20Sopenharmony_ci
5958c2ecf20Sopenharmony_ci	if (qc >= 0x10)
5968c2ecf20Sopenharmony_ci		qc = qc - 0x10;
5978c2ecf20Sopenharmony_ci	else
5988c2ecf20Sopenharmony_ci		qc = 0x400 - (0x10 - qc);
5998c2ecf20Sopenharmony_ci
6008c2ecf20Sopenharmony_ci	*i_out = ic;
6018c2ecf20Sopenharmony_ci	*q_out = qc;
6028c2ecf20Sopenharmony_ci
6038c2ecf20Sopenharmony_ci	if (ic >= 0x200)
6048c2ecf20Sopenharmony_ci		ic = 0x400 - ic;
6058c2ecf20Sopenharmony_ci	if (qc >= 0x200)
6068c2ecf20Sopenharmony_ci		qc = 0x400 - qc;
6078c2ecf20Sopenharmony_ci
6088c2ecf20Sopenharmony_ci	*ic_in = ic;
6098c2ecf20Sopenharmony_ci	*qc_in = qc;
6108c2ecf20Sopenharmony_ci
6118c2ecf20Sopenharmony_ci	rtw_dbg(rtwdev, RTW_DBG_RFK,
6128c2ecf20Sopenharmony_ci		"[DACK] after  DACK i=0x%x, q=0x%x\n", *i_out, *q_out);
6138c2ecf20Sopenharmony_ci}
6148c2ecf20Sopenharmony_ci
6158c2ecf20Sopenharmony_cistatic void rtw8822c_dac_cal_step4(struct rtw_dev *rtwdev, u8 path)
6168c2ecf20Sopenharmony_ci{
6178c2ecf20Sopenharmony_ci	u32 base_addr = rtw8822c_get_path_write_addr(path);
6188c2ecf20Sopenharmony_ci
6198c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, base_addr + 0x68, 0x0);
6208c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, base_addr + 0x10, 0x02d508c4);
6218c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, base_addr + 0xbc, 0x1, 0x0);
6228c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, base_addr + 0x30, BIT(30), 0x1);
6238c2ecf20Sopenharmony_ci}
6248c2ecf20Sopenharmony_ci
6258c2ecf20Sopenharmony_cistatic void rtw8822c_dac_cal_backup_vec(struct rtw_dev *rtwdev,
6268c2ecf20Sopenharmony_ci					u8 path, u8 vec, u32 w_addr, u32 r_addr)
6278c2ecf20Sopenharmony_ci{
6288c2ecf20Sopenharmony_ci	struct rtw_dm_info *dm_info = &rtwdev->dm_info;
6298c2ecf20Sopenharmony_ci	u16 val;
6308c2ecf20Sopenharmony_ci	u32 i;
6318c2ecf20Sopenharmony_ci
6328c2ecf20Sopenharmony_ci	if (WARN_ON(vec >= 2))
6338c2ecf20Sopenharmony_ci		return;
6348c2ecf20Sopenharmony_ci
6358c2ecf20Sopenharmony_ci	for (i = 0; i < DACK_MSBK_BACKUP_NUM; i++) {
6368c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, w_addr, 0xf0000000, i);
6378c2ecf20Sopenharmony_ci		val = (u16)rtw_read32_mask(rtwdev, r_addr, 0x7fc0000);
6388c2ecf20Sopenharmony_ci		dm_info->dack_msbk[path][vec][i] = val;
6398c2ecf20Sopenharmony_ci	}
6408c2ecf20Sopenharmony_ci}
6418c2ecf20Sopenharmony_ci
6428c2ecf20Sopenharmony_cistatic void rtw8822c_dac_cal_backup_path(struct rtw_dev *rtwdev, u8 path)
6438c2ecf20Sopenharmony_ci{
6448c2ecf20Sopenharmony_ci	u32 w_off = 0x1c;
6458c2ecf20Sopenharmony_ci	u32 r_off = 0x2c;
6468c2ecf20Sopenharmony_ci	u32 w_addr, r_addr;
6478c2ecf20Sopenharmony_ci
6488c2ecf20Sopenharmony_ci	if (WARN_ON(path >= 2))
6498c2ecf20Sopenharmony_ci		return;
6508c2ecf20Sopenharmony_ci
6518c2ecf20Sopenharmony_ci	/* backup I vector */
6528c2ecf20Sopenharmony_ci	w_addr = rtw8822c_get_path_write_addr(path) + 0xb0;
6538c2ecf20Sopenharmony_ci	r_addr = rtw8822c_get_path_read_addr(path) + 0x10;
6548c2ecf20Sopenharmony_ci	rtw8822c_dac_cal_backup_vec(rtwdev, path, 0, w_addr, r_addr);
6558c2ecf20Sopenharmony_ci
6568c2ecf20Sopenharmony_ci	/* backup Q vector */
6578c2ecf20Sopenharmony_ci	w_addr = rtw8822c_get_path_write_addr(path) + 0xb0 + w_off;
6588c2ecf20Sopenharmony_ci	r_addr = rtw8822c_get_path_read_addr(path) + 0x10 + r_off;
6598c2ecf20Sopenharmony_ci	rtw8822c_dac_cal_backup_vec(rtwdev, path, 1, w_addr, r_addr);
6608c2ecf20Sopenharmony_ci}
6618c2ecf20Sopenharmony_ci
6628c2ecf20Sopenharmony_cistatic void rtw8822c_dac_cal_backup_dck(struct rtw_dev *rtwdev)
6638c2ecf20Sopenharmony_ci{
6648c2ecf20Sopenharmony_ci	struct rtw_dm_info *dm_info = &rtwdev->dm_info;
6658c2ecf20Sopenharmony_ci	u8 val;
6668c2ecf20Sopenharmony_ci
6678c2ecf20Sopenharmony_ci	val = (u8)rtw_read32_mask(rtwdev, REG_DCKA_I_0, 0xf0000000);
6688c2ecf20Sopenharmony_ci	dm_info->dack_dck[RF_PATH_A][0][0] = val;
6698c2ecf20Sopenharmony_ci	val = (u8)rtw_read32_mask(rtwdev, REG_DCKA_I_1, 0xf);
6708c2ecf20Sopenharmony_ci	dm_info->dack_dck[RF_PATH_A][0][1] = val;
6718c2ecf20Sopenharmony_ci	val = (u8)rtw_read32_mask(rtwdev, REG_DCKA_Q_0, 0xf0000000);
6728c2ecf20Sopenharmony_ci	dm_info->dack_dck[RF_PATH_A][1][0] = val;
6738c2ecf20Sopenharmony_ci	val = (u8)rtw_read32_mask(rtwdev, REG_DCKA_Q_1, 0xf);
6748c2ecf20Sopenharmony_ci	dm_info->dack_dck[RF_PATH_A][1][1] = val;
6758c2ecf20Sopenharmony_ci
6768c2ecf20Sopenharmony_ci	val = (u8)rtw_read32_mask(rtwdev, REG_DCKB_I_0, 0xf0000000);
6778c2ecf20Sopenharmony_ci	dm_info->dack_dck[RF_PATH_B][0][0] = val;
6788c2ecf20Sopenharmony_ci	val = (u8)rtw_read32_mask(rtwdev, REG_DCKB_I_1, 0xf);
6798c2ecf20Sopenharmony_ci	dm_info->dack_dck[RF_PATH_B][1][0] = val;
6808c2ecf20Sopenharmony_ci	val = (u8)rtw_read32_mask(rtwdev, REG_DCKB_Q_0, 0xf0000000);
6818c2ecf20Sopenharmony_ci	dm_info->dack_dck[RF_PATH_B][0][1] = val;
6828c2ecf20Sopenharmony_ci	val = (u8)rtw_read32_mask(rtwdev, REG_DCKB_Q_1, 0xf);
6838c2ecf20Sopenharmony_ci	dm_info->dack_dck[RF_PATH_B][1][1] = val;
6848c2ecf20Sopenharmony_ci}
6858c2ecf20Sopenharmony_ci
6868c2ecf20Sopenharmony_cistatic void rtw8822c_dac_cal_backup(struct rtw_dev *rtwdev)
6878c2ecf20Sopenharmony_ci{
6888c2ecf20Sopenharmony_ci	u32 temp[3];
6898c2ecf20Sopenharmony_ci
6908c2ecf20Sopenharmony_ci	temp[0] = rtw_read32(rtwdev, 0x1860);
6918c2ecf20Sopenharmony_ci	temp[1] = rtw_read32(rtwdev, 0x4160);
6928c2ecf20Sopenharmony_ci	temp[2] = rtw_read32(rtwdev, 0x9b4);
6938c2ecf20Sopenharmony_ci
6948c2ecf20Sopenharmony_ci	/* set clock */
6958c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, 0x9b4, 0xdb66db00);
6968c2ecf20Sopenharmony_ci
6978c2ecf20Sopenharmony_ci	/* backup path-A I/Q */
6988c2ecf20Sopenharmony_ci	rtw_write32_clr(rtwdev, 0x1830, BIT(30));
6998c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x1860, 0xfc000000, 0x3c);
7008c2ecf20Sopenharmony_ci	rtw8822c_dac_cal_backup_path(rtwdev, RF_PATH_A);
7018c2ecf20Sopenharmony_ci
7028c2ecf20Sopenharmony_ci	/* backup path-B I/Q */
7038c2ecf20Sopenharmony_ci	rtw_write32_clr(rtwdev, 0x4130, BIT(30));
7048c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x4160, 0xfc000000, 0x3c);
7058c2ecf20Sopenharmony_ci	rtw8822c_dac_cal_backup_path(rtwdev, RF_PATH_B);
7068c2ecf20Sopenharmony_ci
7078c2ecf20Sopenharmony_ci	rtw8822c_dac_cal_backup_dck(rtwdev);
7088c2ecf20Sopenharmony_ci	rtw_write32_set(rtwdev, 0x1830, BIT(30));
7098c2ecf20Sopenharmony_ci	rtw_write32_set(rtwdev, 0x4130, BIT(30));
7108c2ecf20Sopenharmony_ci
7118c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, 0x1860, temp[0]);
7128c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, 0x4160, temp[1]);
7138c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, 0x9b4, temp[2]);
7148c2ecf20Sopenharmony_ci}
7158c2ecf20Sopenharmony_ci
7168c2ecf20Sopenharmony_cistatic void rtw8822c_dac_cal_restore_dck(struct rtw_dev *rtwdev)
7178c2ecf20Sopenharmony_ci{
7188c2ecf20Sopenharmony_ci	struct rtw_dm_info *dm_info = &rtwdev->dm_info;
7198c2ecf20Sopenharmony_ci	u8 val;
7208c2ecf20Sopenharmony_ci
7218c2ecf20Sopenharmony_ci	rtw_write32_set(rtwdev, REG_DCKA_I_0, BIT(19));
7228c2ecf20Sopenharmony_ci	val = dm_info->dack_dck[RF_PATH_A][0][0];
7238c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, REG_DCKA_I_0, 0xf0000000, val);
7248c2ecf20Sopenharmony_ci	val = dm_info->dack_dck[RF_PATH_A][0][1];
7258c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, REG_DCKA_I_1, 0xf, val);
7268c2ecf20Sopenharmony_ci
7278c2ecf20Sopenharmony_ci	rtw_write32_set(rtwdev, REG_DCKA_Q_0, BIT(19));
7288c2ecf20Sopenharmony_ci	val = dm_info->dack_dck[RF_PATH_A][1][0];
7298c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, REG_DCKA_Q_0, 0xf0000000, val);
7308c2ecf20Sopenharmony_ci	val = dm_info->dack_dck[RF_PATH_A][1][1];
7318c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, REG_DCKA_Q_1, 0xf, val);
7328c2ecf20Sopenharmony_ci
7338c2ecf20Sopenharmony_ci	rtw_write32_set(rtwdev, REG_DCKB_I_0, BIT(19));
7348c2ecf20Sopenharmony_ci	val = dm_info->dack_dck[RF_PATH_B][0][0];
7358c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, REG_DCKB_I_0, 0xf0000000, val);
7368c2ecf20Sopenharmony_ci	val = dm_info->dack_dck[RF_PATH_B][0][1];
7378c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, REG_DCKB_I_1, 0xf, val);
7388c2ecf20Sopenharmony_ci
7398c2ecf20Sopenharmony_ci	rtw_write32_set(rtwdev, REG_DCKB_Q_0, BIT(19));
7408c2ecf20Sopenharmony_ci	val = dm_info->dack_dck[RF_PATH_B][1][0];
7418c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, REG_DCKB_Q_0, 0xf0000000, val);
7428c2ecf20Sopenharmony_ci	val = dm_info->dack_dck[RF_PATH_B][1][1];
7438c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, REG_DCKB_Q_1, 0xf, val);
7448c2ecf20Sopenharmony_ci}
7458c2ecf20Sopenharmony_ci
7468c2ecf20Sopenharmony_cistatic void rtw8822c_dac_cal_restore_prepare(struct rtw_dev *rtwdev)
7478c2ecf20Sopenharmony_ci{
7488c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, 0x9b4, 0xdb66db00);
7498c2ecf20Sopenharmony_ci
7508c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x18b0, BIT(27), 0x0);
7518c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x18cc, BIT(27), 0x0);
7528c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x41b0, BIT(27), 0x0);
7538c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x41cc, BIT(27), 0x0);
7548c2ecf20Sopenharmony_ci
7558c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x1830, BIT(30), 0x0);
7568c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x1860, 0xfc000000, 0x3c);
7578c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x18b4, BIT(0), 0x1);
7588c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x18d0, BIT(0), 0x1);
7598c2ecf20Sopenharmony_ci
7608c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x4130, BIT(30), 0x0);
7618c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x4160, 0xfc000000, 0x3c);
7628c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x41b4, BIT(0), 0x1);
7638c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x41d0, BIT(0), 0x1);
7648c2ecf20Sopenharmony_ci
7658c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x18b0, 0xf00, 0x0);
7668c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x18c0, BIT(14), 0x0);
7678c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x18cc, 0xf00, 0x0);
7688c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x18dc, BIT(14), 0x0);
7698c2ecf20Sopenharmony_ci
7708c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x18b0, BIT(0), 0x0);
7718c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x18cc, BIT(0), 0x0);
7728c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x18b0, BIT(0), 0x1);
7738c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x18cc, BIT(0), 0x1);
7748c2ecf20Sopenharmony_ci
7758c2ecf20Sopenharmony_ci	rtw8822c_dac_cal_restore_dck(rtwdev);
7768c2ecf20Sopenharmony_ci
7778c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x18c0, 0x38000, 0x7);
7788c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x18dc, 0x38000, 0x7);
7798c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x41c0, 0x38000, 0x7);
7808c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x41dc, 0x38000, 0x7);
7818c2ecf20Sopenharmony_ci
7828c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x18b8, BIT(26) | BIT(25), 0x1);
7838c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x18d4, BIT(26) | BIT(25), 0x1);
7848c2ecf20Sopenharmony_ci
7858c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x41b0, 0xf00, 0x0);
7868c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x41c0, BIT(14), 0x0);
7878c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x41cc, 0xf00, 0x0);
7888c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x41dc, BIT(14), 0x0);
7898c2ecf20Sopenharmony_ci
7908c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x41b0, BIT(0), 0x0);
7918c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x41cc, BIT(0), 0x0);
7928c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x41b0, BIT(0), 0x1);
7938c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x41cc, BIT(0), 0x1);
7948c2ecf20Sopenharmony_ci
7958c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x41b8, BIT(26) | BIT(25), 0x1);
7968c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x41d4, BIT(26) | BIT(25), 0x1);
7978c2ecf20Sopenharmony_ci}
7988c2ecf20Sopenharmony_ci
7998c2ecf20Sopenharmony_cistatic bool rtw8822c_dac_cal_restore_wait(struct rtw_dev *rtwdev,
8008c2ecf20Sopenharmony_ci					  u32 target_addr, u32 toggle_addr)
8018c2ecf20Sopenharmony_ci{
8028c2ecf20Sopenharmony_ci	u32 cnt = 0;
8038c2ecf20Sopenharmony_ci
8048c2ecf20Sopenharmony_ci	do {
8058c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, toggle_addr, BIT(26) | BIT(25), 0x0);
8068c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, toggle_addr, BIT(26) | BIT(25), 0x2);
8078c2ecf20Sopenharmony_ci
8088c2ecf20Sopenharmony_ci		if (rtw_read32_mask(rtwdev, target_addr, 0xf) == 0x6)
8098c2ecf20Sopenharmony_ci			return true;
8108c2ecf20Sopenharmony_ci
8118c2ecf20Sopenharmony_ci	} while (cnt++ < 100);
8128c2ecf20Sopenharmony_ci
8138c2ecf20Sopenharmony_ci	return false;
8148c2ecf20Sopenharmony_ci}
8158c2ecf20Sopenharmony_ci
8168c2ecf20Sopenharmony_cistatic bool rtw8822c_dac_cal_restore_path(struct rtw_dev *rtwdev, u8 path)
8178c2ecf20Sopenharmony_ci{
8188c2ecf20Sopenharmony_ci	struct rtw_dm_info *dm_info = &rtwdev->dm_info;
8198c2ecf20Sopenharmony_ci	u32 w_off = 0x1c;
8208c2ecf20Sopenharmony_ci	u32 r_off = 0x2c;
8218c2ecf20Sopenharmony_ci	u32 w_i, r_i, w_q, r_q;
8228c2ecf20Sopenharmony_ci	u32 value;
8238c2ecf20Sopenharmony_ci	u32 i;
8248c2ecf20Sopenharmony_ci
8258c2ecf20Sopenharmony_ci	w_i = rtw8822c_get_path_write_addr(path) + 0xb0;
8268c2ecf20Sopenharmony_ci	r_i = rtw8822c_get_path_read_addr(path) + 0x08;
8278c2ecf20Sopenharmony_ci	w_q = rtw8822c_get_path_write_addr(path) + 0xb0 + w_off;
8288c2ecf20Sopenharmony_ci	r_q = rtw8822c_get_path_read_addr(path) + 0x08 + r_off;
8298c2ecf20Sopenharmony_ci
8308c2ecf20Sopenharmony_ci	if (!rtw8822c_dac_cal_restore_wait(rtwdev, r_i, w_i + 0x8))
8318c2ecf20Sopenharmony_ci		return false;
8328c2ecf20Sopenharmony_ci
8338c2ecf20Sopenharmony_ci	for (i = 0; i < DACK_MSBK_BACKUP_NUM; i++) {
8348c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, w_i + 0x4, BIT(2), 0x0);
8358c2ecf20Sopenharmony_ci		value = dm_info->dack_msbk[path][0][i];
8368c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, w_i + 0x4, 0xff8, value);
8378c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, w_i, 0xf0000000, i);
8388c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, w_i + 0x4, BIT(2), 0x1);
8398c2ecf20Sopenharmony_ci	}
8408c2ecf20Sopenharmony_ci
8418c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, w_i + 0x4, BIT(2), 0x0);
8428c2ecf20Sopenharmony_ci
8438c2ecf20Sopenharmony_ci	if (!rtw8822c_dac_cal_restore_wait(rtwdev, r_q, w_q + 0x8))
8448c2ecf20Sopenharmony_ci		return false;
8458c2ecf20Sopenharmony_ci
8468c2ecf20Sopenharmony_ci	for (i = 0; i < DACK_MSBK_BACKUP_NUM; i++) {
8478c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, w_q + 0x4, BIT(2), 0x0);
8488c2ecf20Sopenharmony_ci		value = dm_info->dack_msbk[path][1][i];
8498c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, w_q + 0x4, 0xff8, value);
8508c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, w_q, 0xf0000000, i);
8518c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, w_q + 0x4, BIT(2), 0x1);
8528c2ecf20Sopenharmony_ci	}
8538c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, w_q + 0x4, BIT(2), 0x0);
8548c2ecf20Sopenharmony_ci
8558c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, w_i + 0x8, BIT(26) | BIT(25), 0x0);
8568c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, w_q + 0x8, BIT(26) | BIT(25), 0x0);
8578c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, w_i + 0x4, BIT(0), 0x0);
8588c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, w_q + 0x4, BIT(0), 0x0);
8598c2ecf20Sopenharmony_ci
8608c2ecf20Sopenharmony_ci	return true;
8618c2ecf20Sopenharmony_ci}
8628c2ecf20Sopenharmony_ci
8638c2ecf20Sopenharmony_cistatic bool __rtw8822c_dac_cal_restore(struct rtw_dev *rtwdev)
8648c2ecf20Sopenharmony_ci{
8658c2ecf20Sopenharmony_ci	if (!rtw8822c_dac_cal_restore_path(rtwdev, RF_PATH_A))
8668c2ecf20Sopenharmony_ci		return false;
8678c2ecf20Sopenharmony_ci
8688c2ecf20Sopenharmony_ci	if (!rtw8822c_dac_cal_restore_path(rtwdev, RF_PATH_B))
8698c2ecf20Sopenharmony_ci		return false;
8708c2ecf20Sopenharmony_ci
8718c2ecf20Sopenharmony_ci	return true;
8728c2ecf20Sopenharmony_ci}
8738c2ecf20Sopenharmony_ci
8748c2ecf20Sopenharmony_cistatic bool rtw8822c_dac_cal_restore(struct rtw_dev *rtwdev)
8758c2ecf20Sopenharmony_ci{
8768c2ecf20Sopenharmony_ci	struct rtw_dm_info *dm_info = &rtwdev->dm_info;
8778c2ecf20Sopenharmony_ci	u32 temp[3];
8788c2ecf20Sopenharmony_ci
8798c2ecf20Sopenharmony_ci	/* sample the first element for both path's IQ vector */
8808c2ecf20Sopenharmony_ci	if (dm_info->dack_msbk[RF_PATH_A][0][0] == 0 &&
8818c2ecf20Sopenharmony_ci	    dm_info->dack_msbk[RF_PATH_A][1][0] == 0 &&
8828c2ecf20Sopenharmony_ci	    dm_info->dack_msbk[RF_PATH_B][0][0] == 0 &&
8838c2ecf20Sopenharmony_ci	    dm_info->dack_msbk[RF_PATH_B][1][0] == 0)
8848c2ecf20Sopenharmony_ci		return false;
8858c2ecf20Sopenharmony_ci
8868c2ecf20Sopenharmony_ci	temp[0] = rtw_read32(rtwdev, 0x1860);
8878c2ecf20Sopenharmony_ci	temp[1] = rtw_read32(rtwdev, 0x4160);
8888c2ecf20Sopenharmony_ci	temp[2] = rtw_read32(rtwdev, 0x9b4);
8898c2ecf20Sopenharmony_ci
8908c2ecf20Sopenharmony_ci	rtw8822c_dac_cal_restore_prepare(rtwdev);
8918c2ecf20Sopenharmony_ci	if (!check_hw_ready(rtwdev, 0x2808, 0x7fff80, 0xffff) ||
8928c2ecf20Sopenharmony_ci	    !check_hw_ready(rtwdev, 0x2834, 0x7fff80, 0xffff) ||
8938c2ecf20Sopenharmony_ci	    !check_hw_ready(rtwdev, 0x4508, 0x7fff80, 0xffff) ||
8948c2ecf20Sopenharmony_ci	    !check_hw_ready(rtwdev, 0x4534, 0x7fff80, 0xffff))
8958c2ecf20Sopenharmony_ci		return false;
8968c2ecf20Sopenharmony_ci
8978c2ecf20Sopenharmony_ci	if (!__rtw8822c_dac_cal_restore(rtwdev)) {
8988c2ecf20Sopenharmony_ci		rtw_err(rtwdev, "failed to restore dack vectors\n");
8998c2ecf20Sopenharmony_ci		return false;
9008c2ecf20Sopenharmony_ci	}
9018c2ecf20Sopenharmony_ci
9028c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x1830, BIT(30), 0x1);
9038c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x4130, BIT(30), 0x1);
9048c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, 0x1860, temp[0]);
9058c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, 0x4160, temp[1]);
9068c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x18b0, BIT(27), 0x1);
9078c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x18cc, BIT(27), 0x1);
9088c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x41b0, BIT(27), 0x1);
9098c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x41cc, BIT(27), 0x1);
9108c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, 0x9b4, temp[2]);
9118c2ecf20Sopenharmony_ci
9128c2ecf20Sopenharmony_ci	return true;
9138c2ecf20Sopenharmony_ci}
9148c2ecf20Sopenharmony_ci
9158c2ecf20Sopenharmony_cistatic void rtw8822c_rf_dac_cal(struct rtw_dev *rtwdev)
9168c2ecf20Sopenharmony_ci{
9178c2ecf20Sopenharmony_ci	struct rtw_backup_info backup_rf[DACK_RF_8822C * DACK_PATH_8822C];
9188c2ecf20Sopenharmony_ci	struct rtw_backup_info backup[DACK_REG_8822C];
9198c2ecf20Sopenharmony_ci	u32 ic = 0, qc = 0, i;
9208c2ecf20Sopenharmony_ci	u32 i_a = 0x0, q_a = 0x0, i_b = 0x0, q_b = 0x0;
9218c2ecf20Sopenharmony_ci	u32 ic_a = 0x0, qc_a = 0x0, ic_b = 0x0, qc_b = 0x0;
9228c2ecf20Sopenharmony_ci	u32 adc_ic_a = 0x0, adc_qc_a = 0x0, adc_ic_b = 0x0, adc_qc_b = 0x0;
9238c2ecf20Sopenharmony_ci
9248c2ecf20Sopenharmony_ci	if (rtw8822c_dac_cal_restore(rtwdev))
9258c2ecf20Sopenharmony_ci		return;
9268c2ecf20Sopenharmony_ci
9278c2ecf20Sopenharmony_ci	/* not able to restore, do it */
9288c2ecf20Sopenharmony_ci
9298c2ecf20Sopenharmony_ci	rtw8822c_dac_backup_reg(rtwdev, backup, backup_rf);
9308c2ecf20Sopenharmony_ci
9318c2ecf20Sopenharmony_ci	rtw8822c_dac_bb_setting(rtwdev);
9328c2ecf20Sopenharmony_ci
9338c2ecf20Sopenharmony_ci	/* path-A */
9348c2ecf20Sopenharmony_ci	rtw8822c_dac_cal_adc(rtwdev, RF_PATH_A, &adc_ic_a, &adc_qc_a);
9358c2ecf20Sopenharmony_ci	for (i = 0; i < 10; i++) {
9368c2ecf20Sopenharmony_ci		rtw8822c_dac_cal_step1(rtwdev, RF_PATH_A);
9378c2ecf20Sopenharmony_ci		rtw8822c_dac_cal_step2(rtwdev, RF_PATH_A, &ic, &qc);
9388c2ecf20Sopenharmony_ci		ic_a = ic;
9398c2ecf20Sopenharmony_ci		qc_a = qc;
9408c2ecf20Sopenharmony_ci
9418c2ecf20Sopenharmony_ci		rtw8822c_dac_cal_step3(rtwdev, RF_PATH_A, adc_ic_a, adc_qc_a,
9428c2ecf20Sopenharmony_ci				       &ic, &qc, &i_a, &q_a);
9438c2ecf20Sopenharmony_ci
9448c2ecf20Sopenharmony_ci		if (ic < 5 && qc < 5)
9458c2ecf20Sopenharmony_ci			break;
9468c2ecf20Sopenharmony_ci	}
9478c2ecf20Sopenharmony_ci	rtw8822c_dac_cal_step4(rtwdev, RF_PATH_A);
9488c2ecf20Sopenharmony_ci
9498c2ecf20Sopenharmony_ci	/* path-B */
9508c2ecf20Sopenharmony_ci	rtw8822c_dac_cal_adc(rtwdev, RF_PATH_B, &adc_ic_b, &adc_qc_b);
9518c2ecf20Sopenharmony_ci	for (i = 0; i < 10; i++) {
9528c2ecf20Sopenharmony_ci		rtw8822c_dac_cal_step1(rtwdev, RF_PATH_B);
9538c2ecf20Sopenharmony_ci		rtw8822c_dac_cal_step2(rtwdev, RF_PATH_B, &ic, &qc);
9548c2ecf20Sopenharmony_ci		ic_b = ic;
9558c2ecf20Sopenharmony_ci		qc_b = qc;
9568c2ecf20Sopenharmony_ci
9578c2ecf20Sopenharmony_ci		rtw8822c_dac_cal_step3(rtwdev, RF_PATH_B, adc_ic_b, adc_qc_b,
9588c2ecf20Sopenharmony_ci				       &ic, &qc, &i_b, &q_b);
9598c2ecf20Sopenharmony_ci
9608c2ecf20Sopenharmony_ci		if (ic < 5 && qc < 5)
9618c2ecf20Sopenharmony_ci			break;
9628c2ecf20Sopenharmony_ci	}
9638c2ecf20Sopenharmony_ci	rtw8822c_dac_cal_step4(rtwdev, RF_PATH_B);
9648c2ecf20Sopenharmony_ci
9658c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, 0x1b00, 0x00000008);
9668c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x4130, BIT(30), 0x1);
9678c2ecf20Sopenharmony_ci	rtw_write8(rtwdev, 0x1bcc, 0x0);
9688c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, 0x1b00, 0x0000000a);
9698c2ecf20Sopenharmony_ci	rtw_write8(rtwdev, 0x1bcc, 0x0);
9708c2ecf20Sopenharmony_ci
9718c2ecf20Sopenharmony_ci	rtw8822c_dac_restore_reg(rtwdev, backup, backup_rf);
9728c2ecf20Sopenharmony_ci
9738c2ecf20Sopenharmony_ci	/* backup results to restore, saving a lot of time */
9748c2ecf20Sopenharmony_ci	rtw8822c_dac_cal_backup(rtwdev);
9758c2ecf20Sopenharmony_ci
9768c2ecf20Sopenharmony_ci	rtw_dbg(rtwdev, RTW_DBG_RFK, "[DACK] path A: ic=0x%x, qc=0x%x\n", ic_a, qc_a);
9778c2ecf20Sopenharmony_ci	rtw_dbg(rtwdev, RTW_DBG_RFK, "[DACK] path B: ic=0x%x, qc=0x%x\n", ic_b, qc_b);
9788c2ecf20Sopenharmony_ci	rtw_dbg(rtwdev, RTW_DBG_RFK, "[DACK] path A: i=0x%x, q=0x%x\n", i_a, q_a);
9798c2ecf20Sopenharmony_ci	rtw_dbg(rtwdev, RTW_DBG_RFK, "[DACK] path B: i=0x%x, q=0x%x\n", i_b, q_b);
9808c2ecf20Sopenharmony_ci}
9818c2ecf20Sopenharmony_ci
9828c2ecf20Sopenharmony_cistatic void rtw8822c_rf_x2_check(struct rtw_dev *rtwdev)
9838c2ecf20Sopenharmony_ci{
9848c2ecf20Sopenharmony_ci	u8 x2k_busy;
9858c2ecf20Sopenharmony_ci
9868c2ecf20Sopenharmony_ci	mdelay(1);
9878c2ecf20Sopenharmony_ci	x2k_busy = rtw_read_rf(rtwdev, RF_PATH_A, 0xb8, BIT(15));
9888c2ecf20Sopenharmony_ci	if (x2k_busy == 1) {
9898c2ecf20Sopenharmony_ci		rtw_write_rf(rtwdev, RF_PATH_A, 0xb8, RFREG_MASK, 0xC4440);
9908c2ecf20Sopenharmony_ci		rtw_write_rf(rtwdev, RF_PATH_A, 0xba, RFREG_MASK, 0x6840D);
9918c2ecf20Sopenharmony_ci		rtw_write_rf(rtwdev, RF_PATH_A, 0xb8, RFREG_MASK, 0x80440);
9928c2ecf20Sopenharmony_ci		mdelay(1);
9938c2ecf20Sopenharmony_ci	}
9948c2ecf20Sopenharmony_ci}
9958c2ecf20Sopenharmony_ci
9968c2ecf20Sopenharmony_cistatic void rtw8822c_set_power_trim(struct rtw_dev *rtwdev, s8 bb_gain[2][8])
9978c2ecf20Sopenharmony_ci{
9988c2ecf20Sopenharmony_ci#define RF_SET_POWER_TRIM(_path, _seq, _idx)					\
9998c2ecf20Sopenharmony_ci		do {								\
10008c2ecf20Sopenharmony_ci			rtw_write_rf(rtwdev, _path, 0x33, RFREG_MASK, _seq);	\
10018c2ecf20Sopenharmony_ci			rtw_write_rf(rtwdev, _path, 0x3f, RFREG_MASK,		\
10028c2ecf20Sopenharmony_ci				     bb_gain[_path][_idx]);			\
10038c2ecf20Sopenharmony_ci		} while (0)
10048c2ecf20Sopenharmony_ci	u8 path;
10058c2ecf20Sopenharmony_ci
10068c2ecf20Sopenharmony_ci	for (path = 0; path < rtwdev->hal.rf_path_num; path++) {
10078c2ecf20Sopenharmony_ci		rtw_write_rf(rtwdev, path, 0xee, BIT(19), 1);
10088c2ecf20Sopenharmony_ci		RF_SET_POWER_TRIM(path, 0x0, 0);
10098c2ecf20Sopenharmony_ci		RF_SET_POWER_TRIM(path, 0x1, 1);
10108c2ecf20Sopenharmony_ci		RF_SET_POWER_TRIM(path, 0x2, 2);
10118c2ecf20Sopenharmony_ci		RF_SET_POWER_TRIM(path, 0x3, 2);
10128c2ecf20Sopenharmony_ci		RF_SET_POWER_TRIM(path, 0x4, 3);
10138c2ecf20Sopenharmony_ci		RF_SET_POWER_TRIM(path, 0x5, 4);
10148c2ecf20Sopenharmony_ci		RF_SET_POWER_TRIM(path, 0x6, 5);
10158c2ecf20Sopenharmony_ci		RF_SET_POWER_TRIM(path, 0x7, 6);
10168c2ecf20Sopenharmony_ci		RF_SET_POWER_TRIM(path, 0x8, 7);
10178c2ecf20Sopenharmony_ci		RF_SET_POWER_TRIM(path, 0x9, 3);
10188c2ecf20Sopenharmony_ci		RF_SET_POWER_TRIM(path, 0xa, 4);
10198c2ecf20Sopenharmony_ci		RF_SET_POWER_TRIM(path, 0xb, 5);
10208c2ecf20Sopenharmony_ci		RF_SET_POWER_TRIM(path, 0xc, 6);
10218c2ecf20Sopenharmony_ci		RF_SET_POWER_TRIM(path, 0xd, 7);
10228c2ecf20Sopenharmony_ci		RF_SET_POWER_TRIM(path, 0xe, 7);
10238c2ecf20Sopenharmony_ci		rtw_write_rf(rtwdev, path, 0xee, BIT(19), 0);
10248c2ecf20Sopenharmony_ci	}
10258c2ecf20Sopenharmony_ci#undef RF_SET_POWER_TRIM
10268c2ecf20Sopenharmony_ci}
10278c2ecf20Sopenharmony_ci
10288c2ecf20Sopenharmony_cistatic void rtw8822c_power_trim(struct rtw_dev *rtwdev)
10298c2ecf20Sopenharmony_ci{
10308c2ecf20Sopenharmony_ci	u8 pg_pwr = 0xff, i, path, idx;
10318c2ecf20Sopenharmony_ci	s8 bb_gain[2][8] = {};
10328c2ecf20Sopenharmony_ci	u16 rf_efuse_2g[3] = {PPG_2GL_TXAB, PPG_2GM_TXAB, PPG_2GH_TXAB};
10338c2ecf20Sopenharmony_ci	u16 rf_efuse_5g[2][5] = {{PPG_5GL1_TXA, PPG_5GL2_TXA, PPG_5GM1_TXA,
10348c2ecf20Sopenharmony_ci				  PPG_5GM2_TXA, PPG_5GH1_TXA},
10358c2ecf20Sopenharmony_ci				 {PPG_5GL1_TXB, PPG_5GL2_TXB, PPG_5GM1_TXB,
10368c2ecf20Sopenharmony_ci				  PPG_5GM2_TXB, PPG_5GH1_TXB} };
10378c2ecf20Sopenharmony_ci	bool set = false;
10388c2ecf20Sopenharmony_ci
10398c2ecf20Sopenharmony_ci	for (i = 0; i < ARRAY_SIZE(rf_efuse_2g); i++) {
10408c2ecf20Sopenharmony_ci		rtw_read8_physical_efuse(rtwdev, rf_efuse_2g[i], &pg_pwr);
10418c2ecf20Sopenharmony_ci		if (pg_pwr == EFUSE_READ_FAIL)
10428c2ecf20Sopenharmony_ci			continue;
10438c2ecf20Sopenharmony_ci		set = true;
10448c2ecf20Sopenharmony_ci		bb_gain[RF_PATH_A][i] = FIELD_GET(PPG_2G_A_MASK, pg_pwr);
10458c2ecf20Sopenharmony_ci		bb_gain[RF_PATH_B][i] = FIELD_GET(PPG_2G_B_MASK, pg_pwr);
10468c2ecf20Sopenharmony_ci	}
10478c2ecf20Sopenharmony_ci
10488c2ecf20Sopenharmony_ci	for (i = 0; i < ARRAY_SIZE(rf_efuse_5g[0]); i++) {
10498c2ecf20Sopenharmony_ci		for (path = 0; path < rtwdev->hal.rf_path_num; path++) {
10508c2ecf20Sopenharmony_ci			rtw_read8_physical_efuse(rtwdev, rf_efuse_5g[path][i],
10518c2ecf20Sopenharmony_ci						 &pg_pwr);
10528c2ecf20Sopenharmony_ci			if (pg_pwr == EFUSE_READ_FAIL)
10538c2ecf20Sopenharmony_ci				continue;
10548c2ecf20Sopenharmony_ci			set = true;
10558c2ecf20Sopenharmony_ci			idx = i + ARRAY_SIZE(rf_efuse_2g);
10568c2ecf20Sopenharmony_ci			bb_gain[path][idx] = FIELD_GET(PPG_5G_MASK, pg_pwr);
10578c2ecf20Sopenharmony_ci		}
10588c2ecf20Sopenharmony_ci	}
10598c2ecf20Sopenharmony_ci	if (set)
10608c2ecf20Sopenharmony_ci		rtw8822c_set_power_trim(rtwdev, bb_gain);
10618c2ecf20Sopenharmony_ci
10628c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, REG_DIS_DPD, DIS_DPD_MASK, DIS_DPD_RATEALL);
10638c2ecf20Sopenharmony_ci}
10648c2ecf20Sopenharmony_ci
10658c2ecf20Sopenharmony_cistatic void rtw8822c_thermal_trim(struct rtw_dev *rtwdev)
10668c2ecf20Sopenharmony_ci{
10678c2ecf20Sopenharmony_ci	u16 rf_efuse[2] = {PPG_THERMAL_A, PPG_THERMAL_B};
10688c2ecf20Sopenharmony_ci	u8 pg_therm = 0xff, thermal[2] = {0}, path;
10698c2ecf20Sopenharmony_ci
10708c2ecf20Sopenharmony_ci	for (path = 0; path < rtwdev->hal.rf_path_num; path++) {
10718c2ecf20Sopenharmony_ci		rtw_read8_physical_efuse(rtwdev, rf_efuse[path], &pg_therm);
10728c2ecf20Sopenharmony_ci		if (pg_therm == EFUSE_READ_FAIL)
10738c2ecf20Sopenharmony_ci			return;
10748c2ecf20Sopenharmony_ci		/* Efuse value of BIT(0) shall be move to BIT(3), and the value
10758c2ecf20Sopenharmony_ci		 * of BIT(1) to BIT(3) should be right shifted 1 bit.
10768c2ecf20Sopenharmony_ci		 */
10778c2ecf20Sopenharmony_ci		thermal[path] = FIELD_GET(GENMASK(3, 1), pg_therm);
10788c2ecf20Sopenharmony_ci		thermal[path] |= FIELD_PREP(BIT(3), pg_therm & BIT(0));
10798c2ecf20Sopenharmony_ci		rtw_write_rf(rtwdev, path, 0x43, RF_THEMAL_MASK, thermal[path]);
10808c2ecf20Sopenharmony_ci	}
10818c2ecf20Sopenharmony_ci}
10828c2ecf20Sopenharmony_ci
10838c2ecf20Sopenharmony_cistatic void rtw8822c_pa_bias(struct rtw_dev *rtwdev)
10848c2ecf20Sopenharmony_ci{
10858c2ecf20Sopenharmony_ci	u16 rf_efuse_2g[2] = {PPG_PABIAS_2GA, PPG_PABIAS_2GB};
10868c2ecf20Sopenharmony_ci	u16 rf_efuse_5g[2] = {PPG_PABIAS_5GA, PPG_PABIAS_5GB};
10878c2ecf20Sopenharmony_ci	u8 pg_pa_bias = 0xff, path;
10888c2ecf20Sopenharmony_ci
10898c2ecf20Sopenharmony_ci	for (path = 0; path < rtwdev->hal.rf_path_num; path++) {
10908c2ecf20Sopenharmony_ci		rtw_read8_physical_efuse(rtwdev, rf_efuse_2g[path],
10918c2ecf20Sopenharmony_ci					 &pg_pa_bias);
10928c2ecf20Sopenharmony_ci		if (pg_pa_bias == EFUSE_READ_FAIL)
10938c2ecf20Sopenharmony_ci			return;
10948c2ecf20Sopenharmony_ci		pg_pa_bias = FIELD_GET(PPG_PABIAS_MASK, pg_pa_bias);
10958c2ecf20Sopenharmony_ci		rtw_write_rf(rtwdev, path, 0x60, RF_PABIAS_2G_MASK, pg_pa_bias);
10968c2ecf20Sopenharmony_ci	}
10978c2ecf20Sopenharmony_ci	for (path = 0; path < rtwdev->hal.rf_path_num; path++) {
10988c2ecf20Sopenharmony_ci		rtw_read8_physical_efuse(rtwdev, rf_efuse_5g[path],
10998c2ecf20Sopenharmony_ci					 &pg_pa_bias);
11008c2ecf20Sopenharmony_ci		pg_pa_bias = FIELD_GET(PPG_PABIAS_MASK, pg_pa_bias);
11018c2ecf20Sopenharmony_ci		rtw_write_rf(rtwdev, path, 0x60, RF_PABIAS_5G_MASK, pg_pa_bias);
11028c2ecf20Sopenharmony_ci	}
11038c2ecf20Sopenharmony_ci}
11048c2ecf20Sopenharmony_ci
11058c2ecf20Sopenharmony_cistatic void rtw8822c_rf_init(struct rtw_dev *rtwdev)
11068c2ecf20Sopenharmony_ci{
11078c2ecf20Sopenharmony_ci	rtw8822c_rf_dac_cal(rtwdev);
11088c2ecf20Sopenharmony_ci	rtw8822c_rf_x2_check(rtwdev);
11098c2ecf20Sopenharmony_ci	rtw8822c_thermal_trim(rtwdev);
11108c2ecf20Sopenharmony_ci	rtw8822c_power_trim(rtwdev);
11118c2ecf20Sopenharmony_ci	rtw8822c_pa_bias(rtwdev);
11128c2ecf20Sopenharmony_ci}
11138c2ecf20Sopenharmony_ci
11148c2ecf20Sopenharmony_cistatic void rtw8822c_pwrtrack_init(struct rtw_dev *rtwdev)
11158c2ecf20Sopenharmony_ci{
11168c2ecf20Sopenharmony_ci	struct rtw_dm_info *dm_info = &rtwdev->dm_info;
11178c2ecf20Sopenharmony_ci	u8 path;
11188c2ecf20Sopenharmony_ci
11198c2ecf20Sopenharmony_ci	for (path = RF_PATH_A; path < RTW_RF_PATH_MAX; path++) {
11208c2ecf20Sopenharmony_ci		dm_info->delta_power_index[path] = 0;
11218c2ecf20Sopenharmony_ci		ewma_thermal_init(&dm_info->avg_thermal[path]);
11228c2ecf20Sopenharmony_ci		dm_info->thermal_avg[path] = 0xff;
11238c2ecf20Sopenharmony_ci	}
11248c2ecf20Sopenharmony_ci
11258c2ecf20Sopenharmony_ci	dm_info->pwr_trk_triggered = false;
11268c2ecf20Sopenharmony_ci	dm_info->thermal_meter_k = rtwdev->efuse.thermal_meter_k;
11278c2ecf20Sopenharmony_ci	dm_info->thermal_meter_lck = rtwdev->efuse.thermal_meter_k;
11288c2ecf20Sopenharmony_ci}
11298c2ecf20Sopenharmony_ci
11308c2ecf20Sopenharmony_cistatic void rtw8822c_phy_set_param(struct rtw_dev *rtwdev)
11318c2ecf20Sopenharmony_ci{
11328c2ecf20Sopenharmony_ci	struct rtw_dm_info *dm_info = &rtwdev->dm_info;
11338c2ecf20Sopenharmony_ci	struct rtw_hal *hal = &rtwdev->hal;
11348c2ecf20Sopenharmony_ci	u8 crystal_cap;
11358c2ecf20Sopenharmony_ci	u8 cck_gi_u_bnd_msb = 0;
11368c2ecf20Sopenharmony_ci	u8 cck_gi_u_bnd_lsb = 0;
11378c2ecf20Sopenharmony_ci	u8 cck_gi_l_bnd_msb = 0;
11388c2ecf20Sopenharmony_ci	u8 cck_gi_l_bnd_lsb = 0;
11398c2ecf20Sopenharmony_ci	bool is_tx2_path;
11408c2ecf20Sopenharmony_ci
11418c2ecf20Sopenharmony_ci	/* power on BB/RF domain */
11428c2ecf20Sopenharmony_ci	rtw_write8_set(rtwdev, REG_SYS_FUNC_EN,
11438c2ecf20Sopenharmony_ci		       BIT_FEN_BB_GLB_RST | BIT_FEN_BB_RSTB);
11448c2ecf20Sopenharmony_ci	rtw_write8_set(rtwdev, REG_RF_CTRL,
11458c2ecf20Sopenharmony_ci		       BIT_RF_EN | BIT_RF_RSTB | BIT_RF_SDM_RSTB);
11468c2ecf20Sopenharmony_ci	rtw_write32_set(rtwdev, REG_WLRF1, BIT_WLRF1_BBRF_EN);
11478c2ecf20Sopenharmony_ci
11488c2ecf20Sopenharmony_ci	/* disable low rate DPD */
11498c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, REG_DIS_DPD, DIS_DPD_MASK, DIS_DPD_RATEALL);
11508c2ecf20Sopenharmony_ci
11518c2ecf20Sopenharmony_ci	/* pre init before header files config */
11528c2ecf20Sopenharmony_ci	rtw8822c_header_file_init(rtwdev, true);
11538c2ecf20Sopenharmony_ci
11548c2ecf20Sopenharmony_ci	rtw_phy_load_tables(rtwdev);
11558c2ecf20Sopenharmony_ci
11568c2ecf20Sopenharmony_ci	crystal_cap = rtwdev->efuse.crystal_cap & 0x7f;
11578c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, REG_ANAPAR_XTAL_0, 0xfffc00,
11588c2ecf20Sopenharmony_ci			 crystal_cap | (crystal_cap << 7));
11598c2ecf20Sopenharmony_ci
11608c2ecf20Sopenharmony_ci	/* post init after header files config */
11618c2ecf20Sopenharmony_ci	rtw8822c_header_file_init(rtwdev, false);
11628c2ecf20Sopenharmony_ci
11638c2ecf20Sopenharmony_ci	is_tx2_path = false;
11648c2ecf20Sopenharmony_ci	rtw8822c_config_trx_mode(rtwdev, hal->antenna_tx, hal->antenna_rx,
11658c2ecf20Sopenharmony_ci				 is_tx2_path);
11668c2ecf20Sopenharmony_ci	rtw_phy_init(rtwdev);
11678c2ecf20Sopenharmony_ci
11688c2ecf20Sopenharmony_ci	cck_gi_u_bnd_msb = (u8)rtw_read32_mask(rtwdev, 0x1a98, 0xc000);
11698c2ecf20Sopenharmony_ci	cck_gi_u_bnd_lsb = (u8)rtw_read32_mask(rtwdev, 0x1aa8, 0xf0000);
11708c2ecf20Sopenharmony_ci	cck_gi_l_bnd_msb = (u8)rtw_read32_mask(rtwdev, 0x1a98, 0xc0);
11718c2ecf20Sopenharmony_ci	cck_gi_l_bnd_lsb = (u8)rtw_read32_mask(rtwdev, 0x1a70, 0x0f000000);
11728c2ecf20Sopenharmony_ci
11738c2ecf20Sopenharmony_ci	dm_info->cck_gi_u_bnd = ((cck_gi_u_bnd_msb << 4) | (cck_gi_u_bnd_lsb));
11748c2ecf20Sopenharmony_ci	dm_info->cck_gi_l_bnd = ((cck_gi_l_bnd_msb << 4) | (cck_gi_l_bnd_lsb));
11758c2ecf20Sopenharmony_ci
11768c2ecf20Sopenharmony_ci	rtw8822c_rf_init(rtwdev);
11778c2ecf20Sopenharmony_ci	rtw8822c_pwrtrack_init(rtwdev);
11788c2ecf20Sopenharmony_ci
11798c2ecf20Sopenharmony_ci	rtw_bf_phy_init(rtwdev);
11808c2ecf20Sopenharmony_ci}
11818c2ecf20Sopenharmony_ci
11828c2ecf20Sopenharmony_ci#define WLAN_TXQ_RPT_EN		0x1F
11838c2ecf20Sopenharmony_ci#define WLAN_SLOT_TIME		0x09
11848c2ecf20Sopenharmony_ci#define WLAN_PIFS_TIME		0x1C
11858c2ecf20Sopenharmony_ci#define WLAN_SIFS_CCK_CONT_TX	0x0A
11868c2ecf20Sopenharmony_ci#define WLAN_SIFS_OFDM_CONT_TX	0x0E
11878c2ecf20Sopenharmony_ci#define WLAN_SIFS_CCK_TRX	0x0A
11888c2ecf20Sopenharmony_ci#define WLAN_SIFS_OFDM_TRX	0x10
11898c2ecf20Sopenharmony_ci#define WLAN_NAV_MAX		0xC8
11908c2ecf20Sopenharmony_ci#define WLAN_RDG_NAV		0x05
11918c2ecf20Sopenharmony_ci#define WLAN_TXOP_NAV		0x1B
11928c2ecf20Sopenharmony_ci#define WLAN_CCK_RX_TSF		0x30
11938c2ecf20Sopenharmony_ci#define WLAN_OFDM_RX_TSF	0x30
11948c2ecf20Sopenharmony_ci#define WLAN_TBTT_PROHIBIT	0x04 /* unit : 32us */
11958c2ecf20Sopenharmony_ci#define WLAN_TBTT_HOLD_TIME	0x064 /* unit : 32us */
11968c2ecf20Sopenharmony_ci#define WLAN_DRV_EARLY_INT	0x04
11978c2ecf20Sopenharmony_ci#define WLAN_BCN_CTRL_CLT0	0x10
11988c2ecf20Sopenharmony_ci#define WLAN_BCN_DMA_TIME	0x02
11998c2ecf20Sopenharmony_ci#define WLAN_BCN_MAX_ERR	0xFF
12008c2ecf20Sopenharmony_ci#define WLAN_SIFS_CCK_DUR_TUNE	0x0A
12018c2ecf20Sopenharmony_ci#define WLAN_SIFS_OFDM_DUR_TUNE	0x10
12028c2ecf20Sopenharmony_ci#define WLAN_SIFS_CCK_CTX	0x0A
12038c2ecf20Sopenharmony_ci#define WLAN_SIFS_CCK_IRX	0x0A
12048c2ecf20Sopenharmony_ci#define WLAN_SIFS_OFDM_CTX	0x0E
12058c2ecf20Sopenharmony_ci#define WLAN_SIFS_OFDM_IRX	0x0E
12068c2ecf20Sopenharmony_ci#define WLAN_EIFS_DUR_TUNE	0x40
12078c2ecf20Sopenharmony_ci#define WLAN_EDCA_VO_PARAM	0x002FA226
12088c2ecf20Sopenharmony_ci#define WLAN_EDCA_VI_PARAM	0x005EA328
12098c2ecf20Sopenharmony_ci#define WLAN_EDCA_BE_PARAM	0x005EA42B
12108c2ecf20Sopenharmony_ci#define WLAN_EDCA_BK_PARAM	0x0000A44F
12118c2ecf20Sopenharmony_ci
12128c2ecf20Sopenharmony_ci#define WLAN_RX_FILTER0		0xFFFFFFFF
12138c2ecf20Sopenharmony_ci#define WLAN_RX_FILTER2		0xFFFF
12148c2ecf20Sopenharmony_ci#define WLAN_RCR_CFG		0xE400220E
12158c2ecf20Sopenharmony_ci#define WLAN_RXPKT_MAX_SZ	12288
12168c2ecf20Sopenharmony_ci#define WLAN_RXPKT_MAX_SZ_512	(WLAN_RXPKT_MAX_SZ >> 9)
12178c2ecf20Sopenharmony_ci
12188c2ecf20Sopenharmony_ci#define WLAN_AMPDU_MAX_TIME		0x70
12198c2ecf20Sopenharmony_ci#define WLAN_RTS_LEN_TH			0xFF
12208c2ecf20Sopenharmony_ci#define WLAN_RTS_TX_TIME_TH		0x08
12218c2ecf20Sopenharmony_ci#define WLAN_MAX_AGG_PKT_LIMIT		0x3f
12228c2ecf20Sopenharmony_ci#define WLAN_RTS_MAX_AGG_PKT_LIMIT	0x3f
12238c2ecf20Sopenharmony_ci#define WLAN_PRE_TXCNT_TIME_TH		0x1E0
12248c2ecf20Sopenharmony_ci#define FAST_EDCA_VO_TH		0x06
12258c2ecf20Sopenharmony_ci#define FAST_EDCA_VI_TH		0x06
12268c2ecf20Sopenharmony_ci#define FAST_EDCA_BE_TH		0x06
12278c2ecf20Sopenharmony_ci#define FAST_EDCA_BK_TH		0x06
12288c2ecf20Sopenharmony_ci#define WLAN_BAR_RETRY_LIMIT		0x01
12298c2ecf20Sopenharmony_ci#define WLAN_BAR_ACK_TYPE		0x05
12308c2ecf20Sopenharmony_ci#define WLAN_RA_TRY_RATE_AGG_LIMIT	0x08
12318c2ecf20Sopenharmony_ci#define WLAN_RESP_TXRATE		0x84
12328c2ecf20Sopenharmony_ci#define WLAN_ACK_TO			0x21
12338c2ecf20Sopenharmony_ci#define WLAN_ACK_TO_CCK			0x6A
12348c2ecf20Sopenharmony_ci#define WLAN_DATA_RATE_FB_CNT_1_4	0x01000000
12358c2ecf20Sopenharmony_ci#define WLAN_DATA_RATE_FB_CNT_5_8	0x08070504
12368c2ecf20Sopenharmony_ci#define WLAN_RTS_RATE_FB_CNT_5_8	0x08070504
12378c2ecf20Sopenharmony_ci#define WLAN_DATA_RATE_FB_RATE0		0xFE01F010
12388c2ecf20Sopenharmony_ci#define WLAN_DATA_RATE_FB_RATE0_H	0x40000000
12398c2ecf20Sopenharmony_ci#define WLAN_RTS_RATE_FB_RATE1		0x003FF010
12408c2ecf20Sopenharmony_ci#define WLAN_RTS_RATE_FB_RATE1_H	0x40000000
12418c2ecf20Sopenharmony_ci#define WLAN_RTS_RATE_FB_RATE4		0x0600F010
12428c2ecf20Sopenharmony_ci#define WLAN_RTS_RATE_FB_RATE4_H	0x400003E0
12438c2ecf20Sopenharmony_ci#define WLAN_RTS_RATE_FB_RATE5		0x0600F015
12448c2ecf20Sopenharmony_ci#define WLAN_RTS_RATE_FB_RATE5_H	0x000000E0
12458c2ecf20Sopenharmony_ci#define WLAN_MULTI_ADDR			0xFFFFFFFF
12468c2ecf20Sopenharmony_ci
12478c2ecf20Sopenharmony_ci#define WLAN_TX_FUNC_CFG1		0x30
12488c2ecf20Sopenharmony_ci#define WLAN_TX_FUNC_CFG2		0x30
12498c2ecf20Sopenharmony_ci#define WLAN_MAC_OPT_NORM_FUNC1		0x98
12508c2ecf20Sopenharmony_ci#define WLAN_MAC_OPT_LB_FUNC1		0x80
12518c2ecf20Sopenharmony_ci#define WLAN_MAC_OPT_FUNC2		0xb0810041
12528c2ecf20Sopenharmony_ci#define WLAN_MAC_INT_MIG_CFG		0x33330000
12538c2ecf20Sopenharmony_ci
12548c2ecf20Sopenharmony_ci#define WLAN_SIFS_CFG	(WLAN_SIFS_CCK_CONT_TX | \
12558c2ecf20Sopenharmony_ci			(WLAN_SIFS_OFDM_CONT_TX << BIT_SHIFT_SIFS_OFDM_CTX) | \
12568c2ecf20Sopenharmony_ci			(WLAN_SIFS_CCK_TRX << BIT_SHIFT_SIFS_CCK_TRX) | \
12578c2ecf20Sopenharmony_ci			(WLAN_SIFS_OFDM_TRX << BIT_SHIFT_SIFS_OFDM_TRX))
12588c2ecf20Sopenharmony_ci
12598c2ecf20Sopenharmony_ci#define WLAN_SIFS_DUR_TUNE	(WLAN_SIFS_CCK_DUR_TUNE | \
12608c2ecf20Sopenharmony_ci				(WLAN_SIFS_OFDM_DUR_TUNE << 8))
12618c2ecf20Sopenharmony_ci
12628c2ecf20Sopenharmony_ci#define WLAN_TBTT_TIME	(WLAN_TBTT_PROHIBIT |\
12638c2ecf20Sopenharmony_ci			(WLAN_TBTT_HOLD_TIME << BIT_SHIFT_TBTT_HOLD_TIME_AP))
12648c2ecf20Sopenharmony_ci
12658c2ecf20Sopenharmony_ci#define WLAN_NAV_CFG		(WLAN_RDG_NAV | (WLAN_TXOP_NAV << 16))
12668c2ecf20Sopenharmony_ci#define WLAN_RX_TSF_CFG		(WLAN_CCK_RX_TSF | (WLAN_OFDM_RX_TSF) << 8)
12678c2ecf20Sopenharmony_ci
12688c2ecf20Sopenharmony_ci#define MAC_CLK_SPEED	80 /* 80M */
12698c2ecf20Sopenharmony_ci#define EFUSE_PCB_INFO_OFFSET	0xCA
12708c2ecf20Sopenharmony_ci
12718c2ecf20Sopenharmony_cistatic int rtw8822c_mac_init(struct rtw_dev *rtwdev)
12728c2ecf20Sopenharmony_ci{
12738c2ecf20Sopenharmony_ci	u8 value8;
12748c2ecf20Sopenharmony_ci	u16 value16;
12758c2ecf20Sopenharmony_ci	u32 value32;
12768c2ecf20Sopenharmony_ci	u16 pre_txcnt;
12778c2ecf20Sopenharmony_ci
12788c2ecf20Sopenharmony_ci	/* txq control */
12798c2ecf20Sopenharmony_ci	value8 = rtw_read8(rtwdev, REG_FWHW_TXQ_CTRL);
12808c2ecf20Sopenharmony_ci	value8 |= (BIT(7) & ~BIT(1) & ~BIT(2));
12818c2ecf20Sopenharmony_ci	rtw_write8(rtwdev, REG_FWHW_TXQ_CTRL, value8);
12828c2ecf20Sopenharmony_ci	rtw_write8(rtwdev, REG_FWHW_TXQ_CTRL + 1, WLAN_TXQ_RPT_EN);
12838c2ecf20Sopenharmony_ci	/* sifs control */
12848c2ecf20Sopenharmony_ci	rtw_write16(rtwdev, REG_SPEC_SIFS, WLAN_SIFS_DUR_TUNE);
12858c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, REG_SIFS, WLAN_SIFS_CFG);
12868c2ecf20Sopenharmony_ci	rtw_write16(rtwdev, REG_RESP_SIFS_CCK,
12878c2ecf20Sopenharmony_ci		    WLAN_SIFS_CCK_CTX | WLAN_SIFS_CCK_IRX << 8);
12888c2ecf20Sopenharmony_ci	rtw_write16(rtwdev, REG_RESP_SIFS_OFDM,
12898c2ecf20Sopenharmony_ci		    WLAN_SIFS_OFDM_CTX | WLAN_SIFS_OFDM_IRX << 8);
12908c2ecf20Sopenharmony_ci	/* rate fallback control */
12918c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, REG_DARFRC, WLAN_DATA_RATE_FB_CNT_1_4);
12928c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, REG_DARFRCH, WLAN_DATA_RATE_FB_CNT_5_8);
12938c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, REG_RARFRCH, WLAN_RTS_RATE_FB_CNT_5_8);
12948c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, REG_ARFR0, WLAN_DATA_RATE_FB_RATE0);
12958c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, REG_ARFRH0, WLAN_DATA_RATE_FB_RATE0_H);
12968c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, REG_ARFR1_V1, WLAN_RTS_RATE_FB_RATE1);
12978c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, REG_ARFRH1_V1, WLAN_RTS_RATE_FB_RATE1_H);
12988c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, REG_ARFR4, WLAN_RTS_RATE_FB_RATE4);
12998c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, REG_ARFRH4, WLAN_RTS_RATE_FB_RATE4_H);
13008c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, REG_ARFR5, WLAN_RTS_RATE_FB_RATE5);
13018c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, REG_ARFRH5, WLAN_RTS_RATE_FB_RATE5_H);
13028c2ecf20Sopenharmony_ci	/* protocol configuration */
13038c2ecf20Sopenharmony_ci	rtw_write8(rtwdev, REG_AMPDU_MAX_TIME_V1, WLAN_AMPDU_MAX_TIME);
13048c2ecf20Sopenharmony_ci	rtw_write8_set(rtwdev, REG_TX_HANG_CTRL, BIT_EN_EOF_V1);
13058c2ecf20Sopenharmony_ci	pre_txcnt = WLAN_PRE_TXCNT_TIME_TH | BIT_EN_PRECNT;
13068c2ecf20Sopenharmony_ci	rtw_write8(rtwdev, REG_PRECNT_CTRL, (u8)(pre_txcnt & 0xFF));
13078c2ecf20Sopenharmony_ci	rtw_write8(rtwdev, REG_PRECNT_CTRL + 1, (u8)(pre_txcnt >> 8));
13088c2ecf20Sopenharmony_ci	value32 = WLAN_RTS_LEN_TH | (WLAN_RTS_TX_TIME_TH << 8) |
13098c2ecf20Sopenharmony_ci		  (WLAN_MAX_AGG_PKT_LIMIT << 16) |
13108c2ecf20Sopenharmony_ci		  (WLAN_RTS_MAX_AGG_PKT_LIMIT << 24);
13118c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, REG_PROT_MODE_CTRL, value32);
13128c2ecf20Sopenharmony_ci	rtw_write16(rtwdev, REG_BAR_MODE_CTRL + 2,
13138c2ecf20Sopenharmony_ci		    WLAN_BAR_RETRY_LIMIT | WLAN_RA_TRY_RATE_AGG_LIMIT << 8);
13148c2ecf20Sopenharmony_ci	rtw_write8(rtwdev, REG_FAST_EDCA_VOVI_SETTING, FAST_EDCA_VO_TH);
13158c2ecf20Sopenharmony_ci	rtw_write8(rtwdev, REG_FAST_EDCA_VOVI_SETTING + 2, FAST_EDCA_VI_TH);
13168c2ecf20Sopenharmony_ci	rtw_write8(rtwdev, REG_FAST_EDCA_BEBK_SETTING, FAST_EDCA_BE_TH);
13178c2ecf20Sopenharmony_ci	rtw_write8(rtwdev, REG_FAST_EDCA_BEBK_SETTING + 2, FAST_EDCA_BK_TH);
13188c2ecf20Sopenharmony_ci	/* close BA parser */
13198c2ecf20Sopenharmony_ci	rtw_write8_clr(rtwdev, REG_LIFETIME_EN, BIT_BA_PARSER_EN);
13208c2ecf20Sopenharmony_ci	rtw_write32_clr(rtwdev, REG_RRSR, BITS_RRSR_RSC);
13218c2ecf20Sopenharmony_ci
13228c2ecf20Sopenharmony_ci	/* EDCA configuration */
13238c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, REG_EDCA_VO_PARAM, WLAN_EDCA_VO_PARAM);
13248c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, REG_EDCA_VI_PARAM, WLAN_EDCA_VI_PARAM);
13258c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, REG_EDCA_BE_PARAM, WLAN_EDCA_BE_PARAM);
13268c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, REG_EDCA_BK_PARAM, WLAN_EDCA_BK_PARAM);
13278c2ecf20Sopenharmony_ci	rtw_write8(rtwdev, REG_PIFS, WLAN_PIFS_TIME);
13288c2ecf20Sopenharmony_ci	rtw_write8_clr(rtwdev, REG_TX_PTCL_CTRL + 1, BIT_SIFS_BK_EN >> 8);
13298c2ecf20Sopenharmony_ci	rtw_write8_set(rtwdev, REG_RD_CTRL + 1,
13308c2ecf20Sopenharmony_ci		       (BIT_DIS_TXOP_CFE | BIT_DIS_LSIG_CFE |
13318c2ecf20Sopenharmony_ci			BIT_DIS_STBC_CFE) >> 8);
13328c2ecf20Sopenharmony_ci
13338c2ecf20Sopenharmony_ci	/* MAC clock configuration */
13348c2ecf20Sopenharmony_ci	rtw_write32_clr(rtwdev, REG_AFE_CTRL1, BIT_MAC_CLK_SEL);
13358c2ecf20Sopenharmony_ci	rtw_write8(rtwdev, REG_USTIME_TSF, MAC_CLK_SPEED);
13368c2ecf20Sopenharmony_ci	rtw_write8(rtwdev, REG_USTIME_EDCA, MAC_CLK_SPEED);
13378c2ecf20Sopenharmony_ci
13388c2ecf20Sopenharmony_ci	rtw_write8_set(rtwdev, REG_MISC_CTRL,
13398c2ecf20Sopenharmony_ci		       BIT_EN_FREE_CNT | BIT_DIS_SECOND_CCA);
13408c2ecf20Sopenharmony_ci	rtw_write8_clr(rtwdev, REG_TIMER0_SRC_SEL, BIT_TSFT_SEL_TIMER0);
13418c2ecf20Sopenharmony_ci	rtw_write16(rtwdev, REG_TXPAUSE, 0x0000);
13428c2ecf20Sopenharmony_ci	rtw_write8(rtwdev, REG_SLOT, WLAN_SLOT_TIME);
13438c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, REG_RD_NAV_NXT, WLAN_NAV_CFG);
13448c2ecf20Sopenharmony_ci	rtw_write16(rtwdev, REG_RXTSF_OFFSET_CCK, WLAN_RX_TSF_CFG);
13458c2ecf20Sopenharmony_ci	/* Set beacon cotnrol - enable TSF and other related functions */
13468c2ecf20Sopenharmony_ci	rtw_write8_set(rtwdev, REG_BCN_CTRL, BIT_EN_BCN_FUNCTION);
13478c2ecf20Sopenharmony_ci	/* Set send beacon related registers */
13488c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, REG_TBTT_PROHIBIT, WLAN_TBTT_TIME);
13498c2ecf20Sopenharmony_ci	rtw_write8(rtwdev, REG_DRVERLYINT, WLAN_DRV_EARLY_INT);
13508c2ecf20Sopenharmony_ci	rtw_write8(rtwdev, REG_BCN_CTRL_CLINT0, WLAN_BCN_CTRL_CLT0);
13518c2ecf20Sopenharmony_ci	rtw_write8(rtwdev, REG_BCNDMATIM, WLAN_BCN_DMA_TIME);
13528c2ecf20Sopenharmony_ci	rtw_write8(rtwdev, REG_BCN_MAX_ERR, WLAN_BCN_MAX_ERR);
13538c2ecf20Sopenharmony_ci
13548c2ecf20Sopenharmony_ci	/* WMAC configuration */
13558c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, REG_MAR, WLAN_MULTI_ADDR);
13568c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, REG_MAR + 4, WLAN_MULTI_ADDR);
13578c2ecf20Sopenharmony_ci	rtw_write8(rtwdev, REG_BBPSF_CTRL + 2, WLAN_RESP_TXRATE);
13588c2ecf20Sopenharmony_ci	rtw_write8(rtwdev, REG_ACKTO, WLAN_ACK_TO);
13598c2ecf20Sopenharmony_ci	rtw_write8(rtwdev, REG_ACKTO_CCK, WLAN_ACK_TO_CCK);
13608c2ecf20Sopenharmony_ci	rtw_write16(rtwdev, REG_EIFS, WLAN_EIFS_DUR_TUNE);
13618c2ecf20Sopenharmony_ci	rtw_write8(rtwdev, REG_NAV_CTRL + 2, WLAN_NAV_MAX);
13628c2ecf20Sopenharmony_ci	rtw_write8(rtwdev, REG_WMAC_TRXPTCL_CTL_H  + 2, WLAN_BAR_ACK_TYPE);
13638c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, REG_RXFLTMAP0, WLAN_RX_FILTER0);
13648c2ecf20Sopenharmony_ci	rtw_write16(rtwdev, REG_RXFLTMAP2, WLAN_RX_FILTER2);
13658c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, REG_RCR, WLAN_RCR_CFG);
13668c2ecf20Sopenharmony_ci	rtw_write8(rtwdev, REG_RX_PKT_LIMIT, WLAN_RXPKT_MAX_SZ_512);
13678c2ecf20Sopenharmony_ci	rtw_write8(rtwdev, REG_TCR + 2, WLAN_TX_FUNC_CFG2);
13688c2ecf20Sopenharmony_ci	rtw_write8(rtwdev, REG_TCR + 1, WLAN_TX_FUNC_CFG1);
13698c2ecf20Sopenharmony_ci	rtw_write32_set(rtwdev, REG_GENERAL_OPTION, BIT_DUMMY_FCS_READY_MASK_EN);
13708c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, REG_WMAC_OPTION_FUNCTION + 8, WLAN_MAC_OPT_FUNC2);
13718c2ecf20Sopenharmony_ci	rtw_write8(rtwdev, REG_WMAC_OPTION_FUNCTION_1, WLAN_MAC_OPT_NORM_FUNC1);
13728c2ecf20Sopenharmony_ci
13738c2ecf20Sopenharmony_ci	/* init low power */
13748c2ecf20Sopenharmony_ci	value16 = rtw_read16(rtwdev, REG_RXPSF_CTRL + 2) & 0xF00F;
13758c2ecf20Sopenharmony_ci	value16 |= (BIT_RXGCK_VHT_FIFOTHR(1) | BIT_RXGCK_HT_FIFOTHR(1) |
13768c2ecf20Sopenharmony_ci		    BIT_RXGCK_OFDM_FIFOTHR(1) | BIT_RXGCK_CCK_FIFOTHR(1)) >> 16;
13778c2ecf20Sopenharmony_ci	rtw_write16(rtwdev, REG_RXPSF_CTRL + 2, value16);
13788c2ecf20Sopenharmony_ci	value16 = 0;
13798c2ecf20Sopenharmony_ci	value16 = BIT_SET_RXPSF_PKTLENTHR(value16, 1);
13808c2ecf20Sopenharmony_ci	value16 |= BIT_RXPSF_CTRLEN | BIT_RXPSF_VHTCHKEN | BIT_RXPSF_HTCHKEN
13818c2ecf20Sopenharmony_ci		| BIT_RXPSF_OFDMCHKEN | BIT_RXPSF_CCKCHKEN
13828c2ecf20Sopenharmony_ci		| BIT_RXPSF_OFDMRST;
13838c2ecf20Sopenharmony_ci	rtw_write16(rtwdev, REG_RXPSF_CTRL, value16);
13848c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, REG_RXPSF_TYPE_CTRL, 0xFFFFFFFF);
13858c2ecf20Sopenharmony_ci	/* rx ignore configuration */
13868c2ecf20Sopenharmony_ci	value16 = rtw_read16(rtwdev, REG_RXPSF_CTRL);
13878c2ecf20Sopenharmony_ci	value16 &= ~(BIT_RXPSF_MHCHKEN | BIT_RXPSF_CCKRST |
13888c2ecf20Sopenharmony_ci		     BIT_RXPSF_CONT_ERRCHKEN);
13898c2ecf20Sopenharmony_ci	value16 = BIT_SET_RXPSF_ERRTHR(value16, 0x07);
13908c2ecf20Sopenharmony_ci	rtw_write16(rtwdev, REG_RXPSF_CTRL, value16);
13918c2ecf20Sopenharmony_ci
13928c2ecf20Sopenharmony_ci	/* Interrupt migration configuration */
13938c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, REG_INT_MIG, WLAN_MAC_INT_MIG_CFG);
13948c2ecf20Sopenharmony_ci
13958c2ecf20Sopenharmony_ci	return 0;
13968c2ecf20Sopenharmony_ci}
13978c2ecf20Sopenharmony_ci
13988c2ecf20Sopenharmony_cistatic void rtw8822c_rstb_3wire(struct rtw_dev *rtwdev, bool enable)
13998c2ecf20Sopenharmony_ci{
14008c2ecf20Sopenharmony_ci	if (enable) {
14018c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_RSTB, BIT_RSTB_3WIRE, 0x1);
14028c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_ANAPAR_A, BIT_ANAPAR_UPDATE, 0x1);
14038c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_ANAPAR_B, BIT_ANAPAR_UPDATE, 0x1);
14048c2ecf20Sopenharmony_ci	} else {
14058c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_RSTB, BIT_RSTB_3WIRE, 0x0);
14068c2ecf20Sopenharmony_ci	}
14078c2ecf20Sopenharmony_ci}
14088c2ecf20Sopenharmony_ci
14098c2ecf20Sopenharmony_cistatic void rtw8822c_set_channel_rf(struct rtw_dev *rtwdev, u8 channel, u8 bw)
14108c2ecf20Sopenharmony_ci{
14118c2ecf20Sopenharmony_ci#define RF18_BAND_MASK		(BIT(16) | BIT(9) | BIT(8))
14128c2ecf20Sopenharmony_ci#define RF18_BAND_2G		(0)
14138c2ecf20Sopenharmony_ci#define RF18_BAND_5G		(BIT(16) | BIT(8))
14148c2ecf20Sopenharmony_ci#define RF18_CHANNEL_MASK	(MASKBYTE0)
14158c2ecf20Sopenharmony_ci#define RF18_RFSI_MASK		(BIT(18) | BIT(17))
14168c2ecf20Sopenharmony_ci#define RF18_RFSI_GE_CH80	(BIT(17))
14178c2ecf20Sopenharmony_ci#define RF18_RFSI_GT_CH140	(BIT(18))
14188c2ecf20Sopenharmony_ci#define RF18_BW_MASK		(BIT(13) | BIT(12))
14198c2ecf20Sopenharmony_ci#define RF18_BW_20M		(BIT(13) | BIT(12))
14208c2ecf20Sopenharmony_ci#define RF18_BW_40M		(BIT(13))
14218c2ecf20Sopenharmony_ci#define RF18_BW_80M		(BIT(12))
14228c2ecf20Sopenharmony_ci
14238c2ecf20Sopenharmony_ci	u32 rf_reg18 = 0;
14248c2ecf20Sopenharmony_ci	u32 rf_rxbb = 0;
14258c2ecf20Sopenharmony_ci
14268c2ecf20Sopenharmony_ci	rf_reg18 = rtw_read_rf(rtwdev, RF_PATH_A, 0x18, RFREG_MASK);
14278c2ecf20Sopenharmony_ci
14288c2ecf20Sopenharmony_ci	rf_reg18 &= ~(RF18_BAND_MASK | RF18_CHANNEL_MASK | RF18_RFSI_MASK |
14298c2ecf20Sopenharmony_ci		      RF18_BW_MASK);
14308c2ecf20Sopenharmony_ci
14318c2ecf20Sopenharmony_ci	rf_reg18 |= (IS_CH_2G_BAND(channel) ? RF18_BAND_2G : RF18_BAND_5G);
14328c2ecf20Sopenharmony_ci	rf_reg18 |= (channel & RF18_CHANNEL_MASK);
14338c2ecf20Sopenharmony_ci	if (IS_CH_5G_BAND_4(channel))
14348c2ecf20Sopenharmony_ci		rf_reg18 |= RF18_RFSI_GT_CH140;
14358c2ecf20Sopenharmony_ci	else if (IS_CH_5G_BAND_3(channel))
14368c2ecf20Sopenharmony_ci		rf_reg18 |= RF18_RFSI_GE_CH80;
14378c2ecf20Sopenharmony_ci
14388c2ecf20Sopenharmony_ci	switch (bw) {
14398c2ecf20Sopenharmony_ci	case RTW_CHANNEL_WIDTH_5:
14408c2ecf20Sopenharmony_ci	case RTW_CHANNEL_WIDTH_10:
14418c2ecf20Sopenharmony_ci	case RTW_CHANNEL_WIDTH_20:
14428c2ecf20Sopenharmony_ci	default:
14438c2ecf20Sopenharmony_ci		rf_reg18 |= RF18_BW_20M;
14448c2ecf20Sopenharmony_ci		rf_rxbb = 0x18;
14458c2ecf20Sopenharmony_ci		break;
14468c2ecf20Sopenharmony_ci	case RTW_CHANNEL_WIDTH_40:
14478c2ecf20Sopenharmony_ci		/* RF bandwidth */
14488c2ecf20Sopenharmony_ci		rf_reg18 |= RF18_BW_40M;
14498c2ecf20Sopenharmony_ci		rf_rxbb = 0x10;
14508c2ecf20Sopenharmony_ci		break;
14518c2ecf20Sopenharmony_ci	case RTW_CHANNEL_WIDTH_80:
14528c2ecf20Sopenharmony_ci		rf_reg18 |= RF18_BW_80M;
14538c2ecf20Sopenharmony_ci		rf_rxbb = 0x8;
14548c2ecf20Sopenharmony_ci		break;
14558c2ecf20Sopenharmony_ci	}
14568c2ecf20Sopenharmony_ci
14578c2ecf20Sopenharmony_ci	rtw8822c_rstb_3wire(rtwdev, false);
14588c2ecf20Sopenharmony_ci
14598c2ecf20Sopenharmony_ci	rtw_write_rf(rtwdev, RF_PATH_A, RF_LUTWE2, 0x04, 0x01);
14608c2ecf20Sopenharmony_ci	rtw_write_rf(rtwdev, RF_PATH_A, RF_LUTWA, 0x1f, 0x12);
14618c2ecf20Sopenharmony_ci	rtw_write_rf(rtwdev, RF_PATH_A, RF_LUTWD0, 0xfffff, rf_rxbb);
14628c2ecf20Sopenharmony_ci	rtw_write_rf(rtwdev, RF_PATH_A, RF_LUTWE2, 0x04, 0x00);
14638c2ecf20Sopenharmony_ci
14648c2ecf20Sopenharmony_ci	rtw_write_rf(rtwdev, RF_PATH_B, RF_LUTWE2, 0x04, 0x01);
14658c2ecf20Sopenharmony_ci	rtw_write_rf(rtwdev, RF_PATH_B, RF_LUTWA, 0x1f, 0x12);
14668c2ecf20Sopenharmony_ci	rtw_write_rf(rtwdev, RF_PATH_B, RF_LUTWD0, 0xfffff, rf_rxbb);
14678c2ecf20Sopenharmony_ci	rtw_write_rf(rtwdev, RF_PATH_B, RF_LUTWE2, 0x04, 0x00);
14688c2ecf20Sopenharmony_ci
14698c2ecf20Sopenharmony_ci	rtw_write_rf(rtwdev, RF_PATH_A, RF_CFGCH, RFREG_MASK, rf_reg18);
14708c2ecf20Sopenharmony_ci	rtw_write_rf(rtwdev, RF_PATH_B, RF_CFGCH, RFREG_MASK, rf_reg18);
14718c2ecf20Sopenharmony_ci
14728c2ecf20Sopenharmony_ci	rtw8822c_rstb_3wire(rtwdev, true);
14738c2ecf20Sopenharmony_ci}
14748c2ecf20Sopenharmony_ci
14758c2ecf20Sopenharmony_cistatic void rtw8822c_toggle_igi(struct rtw_dev *rtwdev)
14768c2ecf20Sopenharmony_ci{
14778c2ecf20Sopenharmony_ci	u32 igi;
14788c2ecf20Sopenharmony_ci
14798c2ecf20Sopenharmony_ci	igi = rtw_read32_mask(rtwdev, REG_RXIGI, 0x7f);
14808c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, REG_RXIGI, 0x7f, igi - 2);
14818c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, REG_RXIGI, 0x7f00, igi - 2);
14828c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, REG_RXIGI, 0x7f, igi);
14838c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, REG_RXIGI, 0x7f00, igi);
14848c2ecf20Sopenharmony_ci}
14858c2ecf20Sopenharmony_ci
14868c2ecf20Sopenharmony_cistatic void rtw8822c_set_channel_bb(struct rtw_dev *rtwdev, u8 channel, u8 bw,
14878c2ecf20Sopenharmony_ci				    u8 primary_ch_idx)
14888c2ecf20Sopenharmony_ci{
14898c2ecf20Sopenharmony_ci	if (IS_CH_2G_BAND(channel)) {
14908c2ecf20Sopenharmony_ci		rtw_write32_clr(rtwdev, REG_BGCTRL, BITS_RX_IQ_WEIGHT);
14918c2ecf20Sopenharmony_ci		rtw_write32_set(rtwdev, REG_TXF4, BIT(20));
14928c2ecf20Sopenharmony_ci		rtw_write32_clr(rtwdev, REG_CCK_CHECK, BIT_CHECK_CCK_EN);
14938c2ecf20Sopenharmony_ci		rtw_write32_clr(rtwdev, REG_CCKTXONLY, BIT_BB_CCK_CHECK_EN);
14948c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_CCAMSK, 0x3F000000, 0xF);
14958c2ecf20Sopenharmony_ci
14968c2ecf20Sopenharmony_ci		switch (bw) {
14978c2ecf20Sopenharmony_ci		case RTW_CHANNEL_WIDTH_20:
14988c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_RXAGCCTL0, BITS_RXAGC_CCK,
14998c2ecf20Sopenharmony_ci					 0x5);
15008c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_RXAGCCTL, BITS_RXAGC_CCK,
15018c2ecf20Sopenharmony_ci					 0x5);
15028c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_RXAGCCTL0, BITS_RXAGC_OFDM,
15038c2ecf20Sopenharmony_ci					 0x6);
15048c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_RXAGCCTL, BITS_RXAGC_OFDM,
15058c2ecf20Sopenharmony_ci					 0x6);
15068c2ecf20Sopenharmony_ci			break;
15078c2ecf20Sopenharmony_ci		case RTW_CHANNEL_WIDTH_40:
15088c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_RXAGCCTL0, BITS_RXAGC_CCK,
15098c2ecf20Sopenharmony_ci					 0x4);
15108c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_RXAGCCTL, BITS_RXAGC_CCK,
15118c2ecf20Sopenharmony_ci					 0x4);
15128c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_RXAGCCTL0, BITS_RXAGC_OFDM,
15138c2ecf20Sopenharmony_ci					 0x0);
15148c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_RXAGCCTL, BITS_RXAGC_OFDM,
15158c2ecf20Sopenharmony_ci					 0x0);
15168c2ecf20Sopenharmony_ci			break;
15178c2ecf20Sopenharmony_ci		}
15188c2ecf20Sopenharmony_ci		if (channel == 13 || channel == 14)
15198c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_SCOTRK, 0xfff, 0x969);
15208c2ecf20Sopenharmony_ci		else if (channel == 11 || channel == 12)
15218c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_SCOTRK, 0xfff, 0x96a);
15228c2ecf20Sopenharmony_ci		else
15238c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_SCOTRK, 0xfff, 0x9aa);
15248c2ecf20Sopenharmony_ci		if (channel == 14) {
15258c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_TXF0, MASKHWORD, 0x3da0);
15268c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_TXF1, MASKDWORD,
15278c2ecf20Sopenharmony_ci					 0x4962c931);
15288c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_TXF2, MASKLWORD, 0x6aa3);
15298c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_TXF3, MASKHWORD, 0xaa7b);
15308c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_TXF4, MASKLWORD, 0xf3d7);
15318c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_TXF5, MASKDWORD, 0x0);
15328c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_TXF6, MASKDWORD,
15338c2ecf20Sopenharmony_ci					 0xff012455);
15348c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_TXF7, MASKDWORD, 0xffff);
15358c2ecf20Sopenharmony_ci		} else {
15368c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_TXF0, MASKHWORD, 0x5284);
15378c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_TXF1, MASKDWORD,
15388c2ecf20Sopenharmony_ci					 0x3e18fec8);
15398c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_TXF2, MASKLWORD, 0x0a88);
15408c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_TXF3, MASKHWORD, 0xacc4);
15418c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_TXF4, MASKLWORD, 0xc8b2);
15428c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_TXF5, MASKDWORD,
15438c2ecf20Sopenharmony_ci					 0x00faf0de);
15448c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_TXF6, MASKDWORD,
15458c2ecf20Sopenharmony_ci					 0x00122344);
15468c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_TXF7, MASKDWORD,
15478c2ecf20Sopenharmony_ci					 0x0fffffff);
15488c2ecf20Sopenharmony_ci		}
15498c2ecf20Sopenharmony_ci		if (channel == 13)
15508c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_TXDFIR0, 0x70, 0x3);
15518c2ecf20Sopenharmony_ci		else
15528c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_TXDFIR0, 0x70, 0x1);
15538c2ecf20Sopenharmony_ci	} else if (IS_CH_5G_BAND(channel)) {
15548c2ecf20Sopenharmony_ci		rtw_write32_set(rtwdev, REG_CCKTXONLY, BIT_BB_CCK_CHECK_EN);
15558c2ecf20Sopenharmony_ci		rtw_write32_set(rtwdev, REG_CCK_CHECK, BIT_CHECK_CCK_EN);
15568c2ecf20Sopenharmony_ci		rtw_write32_set(rtwdev, REG_BGCTRL, BITS_RX_IQ_WEIGHT);
15578c2ecf20Sopenharmony_ci		rtw_write32_clr(rtwdev, REG_TXF4, BIT(20));
15588c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_CCAMSK, 0x3F000000, 0x22);
15598c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_TXDFIR0, 0x70, 0x3);
15608c2ecf20Sopenharmony_ci		if (IS_CH_5G_BAND_1(channel) || IS_CH_5G_BAND_2(channel)) {
15618c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_RXAGCCTL0, BITS_RXAGC_OFDM,
15628c2ecf20Sopenharmony_ci					 0x1);
15638c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_RXAGCCTL, BITS_RXAGC_OFDM,
15648c2ecf20Sopenharmony_ci					 0x1);
15658c2ecf20Sopenharmony_ci		} else if (IS_CH_5G_BAND_3(channel)) {
15668c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_RXAGCCTL0, BITS_RXAGC_OFDM,
15678c2ecf20Sopenharmony_ci					 0x2);
15688c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_RXAGCCTL, BITS_RXAGC_OFDM,
15698c2ecf20Sopenharmony_ci					 0x2);
15708c2ecf20Sopenharmony_ci		} else if (IS_CH_5G_BAND_4(channel)) {
15718c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_RXAGCCTL0, BITS_RXAGC_OFDM,
15728c2ecf20Sopenharmony_ci					 0x3);
15738c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_RXAGCCTL, BITS_RXAGC_OFDM,
15748c2ecf20Sopenharmony_ci					 0x3);
15758c2ecf20Sopenharmony_ci		}
15768c2ecf20Sopenharmony_ci
15778c2ecf20Sopenharmony_ci		if (channel >= 36 && channel <= 51)
15788c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_SCOTRK, 0xfff, 0x494);
15798c2ecf20Sopenharmony_ci		else if (channel >= 52 && channel <= 55)
15808c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_SCOTRK, 0xfff, 0x493);
15818c2ecf20Sopenharmony_ci		else if (channel >= 56 && channel <= 111)
15828c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_SCOTRK, 0xfff, 0x453);
15838c2ecf20Sopenharmony_ci		else if (channel >= 112 && channel <= 119)
15848c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_SCOTRK, 0xfff, 0x452);
15858c2ecf20Sopenharmony_ci		else if (channel >= 120 && channel <= 172)
15868c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_SCOTRK, 0xfff, 0x412);
15878c2ecf20Sopenharmony_ci		else if (channel >= 173 && channel <= 177)
15888c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_SCOTRK, 0xfff, 0x411);
15898c2ecf20Sopenharmony_ci	}
15908c2ecf20Sopenharmony_ci
15918c2ecf20Sopenharmony_ci	switch (bw) {
15928c2ecf20Sopenharmony_ci	case RTW_CHANNEL_WIDTH_20:
15938c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_DFIRBW, 0x3FF0, 0x19B);
15948c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_TXBWCTL, 0xf, 0x0);
15958c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_TXBWCTL, 0xffc0, 0x0);
15968c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_TXCLK, 0x700, 0x7);
15978c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_TXCLK, 0x700000, 0x6);
15988c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_CCK_SOURCE, BIT_NBI_EN, 0x0);
15998c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_SBD, BITS_SUBTUNE, 0x1);
16008c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_PT_CHSMO, BIT_PT_OPT, 0x0);
16018c2ecf20Sopenharmony_ci		break;
16028c2ecf20Sopenharmony_ci	case RTW_CHANNEL_WIDTH_40:
16038c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_CCKSB, BIT(4),
16048c2ecf20Sopenharmony_ci				 (primary_ch_idx == RTW_SC_20_UPPER ? 1 : 0));
16058c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_TXBWCTL, 0xf, 0x5);
16068c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_TXBWCTL, 0xc0, 0x0);
16078c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_TXBWCTL, 0xff00,
16088c2ecf20Sopenharmony_ci				 (primary_ch_idx | (primary_ch_idx << 4)));
16098c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_CCK_SOURCE, BIT_NBI_EN, 0x1);
16108c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_SBD, BITS_SUBTUNE, 0x1);
16118c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_PT_CHSMO, BIT_PT_OPT, 0x1);
16128c2ecf20Sopenharmony_ci		break;
16138c2ecf20Sopenharmony_ci	case RTW_CHANNEL_WIDTH_80:
16148c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_TXBWCTL, 0xf, 0xa);
16158c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_TXBWCTL, 0xc0, 0x0);
16168c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_TXBWCTL, 0xff00,
16178c2ecf20Sopenharmony_ci				 (primary_ch_idx | (primary_ch_idx << 4)));
16188c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_SBD, BITS_SUBTUNE, 0x6);
16198c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_PT_CHSMO, BIT_PT_OPT, 0x1);
16208c2ecf20Sopenharmony_ci		break;
16218c2ecf20Sopenharmony_ci	case RTW_CHANNEL_WIDTH_5:
16228c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_DFIRBW, 0x3FF0, 0x2AB);
16238c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_TXBWCTL, 0xf, 0x0);
16248c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_TXBWCTL, 0xffc0, 0x1);
16258c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_TXCLK, 0x700, 0x4);
16268c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_TXCLK, 0x700000, 0x4);
16278c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_CCK_SOURCE, BIT_NBI_EN, 0x0);
16288c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_SBD, BITS_SUBTUNE, 0x1);
16298c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_PT_CHSMO, BIT_PT_OPT, 0x0);
16308c2ecf20Sopenharmony_ci		break;
16318c2ecf20Sopenharmony_ci	case RTW_CHANNEL_WIDTH_10:
16328c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_DFIRBW, 0x3FF0, 0x2AB);
16338c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_TXBWCTL, 0xf, 0x0);
16348c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_TXBWCTL, 0xffc0, 0x2);
16358c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_TXCLK, 0x700, 0x6);
16368c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_TXCLK, 0x700000, 0x5);
16378c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_CCK_SOURCE, BIT_NBI_EN, 0x0);
16388c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_SBD, BITS_SUBTUNE, 0x1);
16398c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_PT_CHSMO, BIT_PT_OPT, 0x0);
16408c2ecf20Sopenharmony_ci		break;
16418c2ecf20Sopenharmony_ci	}
16428c2ecf20Sopenharmony_ci}
16438c2ecf20Sopenharmony_ci
16448c2ecf20Sopenharmony_cistatic void rtw8822c_set_channel(struct rtw_dev *rtwdev, u8 channel, u8 bw,
16458c2ecf20Sopenharmony_ci				 u8 primary_chan_idx)
16468c2ecf20Sopenharmony_ci{
16478c2ecf20Sopenharmony_ci	rtw8822c_set_channel_bb(rtwdev, channel, bw, primary_chan_idx);
16488c2ecf20Sopenharmony_ci	rtw_set_channel_mac(rtwdev, channel, bw, primary_chan_idx);
16498c2ecf20Sopenharmony_ci	rtw8822c_set_channel_rf(rtwdev, channel, bw);
16508c2ecf20Sopenharmony_ci	rtw8822c_toggle_igi(rtwdev);
16518c2ecf20Sopenharmony_ci}
16528c2ecf20Sopenharmony_ci
16538c2ecf20Sopenharmony_cistatic void rtw8822c_config_cck_rx_path(struct rtw_dev *rtwdev, u8 rx_path)
16548c2ecf20Sopenharmony_ci{
16558c2ecf20Sopenharmony_ci	if (rx_path == BB_PATH_A || rx_path == BB_PATH_B) {
16568c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_CCANRX, 0x00060000, 0x0);
16578c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_CCANRX, 0x00600000, 0x0);
16588c2ecf20Sopenharmony_ci	} else if (rx_path == BB_PATH_AB) {
16598c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_CCANRX, 0x00600000, 0x1);
16608c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_CCANRX, 0x00060000, 0x1);
16618c2ecf20Sopenharmony_ci	}
16628c2ecf20Sopenharmony_ci
16638c2ecf20Sopenharmony_ci	if (rx_path == BB_PATH_A)
16648c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_RXCCKSEL, 0x0f000000, 0x0);
16658c2ecf20Sopenharmony_ci	else if (rx_path == BB_PATH_B)
16668c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_RXCCKSEL, 0x0f000000, 0x5);
16678c2ecf20Sopenharmony_ci	else if (rx_path == BB_PATH_AB)
16688c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_RXCCKSEL, 0x0f000000, 0x1);
16698c2ecf20Sopenharmony_ci}
16708c2ecf20Sopenharmony_ci
16718c2ecf20Sopenharmony_cistatic void rtw8822c_config_ofdm_rx_path(struct rtw_dev *rtwdev, u8 rx_path)
16728c2ecf20Sopenharmony_ci{
16738c2ecf20Sopenharmony_ci	if (rx_path == BB_PATH_A || rx_path == BB_PATH_B) {
16748c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_RXFNCTL, 0x300, 0x0);
16758c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_RXFNCTL, 0x600000, 0x0);
16768c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_AGCSWSH, BIT(17), 0x0);
16778c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_ANTWTPD, BIT(20), 0x0);
16788c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_MRCM, BIT(24), 0x0);
16798c2ecf20Sopenharmony_ci	} else if (rx_path == BB_PATH_AB) {
16808c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_RXFNCTL, 0x300, 0x1);
16818c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_RXFNCTL, 0x600000, 0x1);
16828c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_AGCSWSH, BIT(17), 0x1);
16838c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_ANTWTPD, BIT(20), 0x1);
16848c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_MRCM, BIT(24), 0x1);
16858c2ecf20Sopenharmony_ci	}
16868c2ecf20Sopenharmony_ci
16878c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x824, 0x0f000000, rx_path);
16888c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x824, 0x000f0000, rx_path);
16898c2ecf20Sopenharmony_ci}
16908c2ecf20Sopenharmony_ci
16918c2ecf20Sopenharmony_cistatic void rtw8822c_config_rx_path(struct rtw_dev *rtwdev, u8 rx_path)
16928c2ecf20Sopenharmony_ci{
16938c2ecf20Sopenharmony_ci	rtw8822c_config_cck_rx_path(rtwdev, rx_path);
16948c2ecf20Sopenharmony_ci	rtw8822c_config_ofdm_rx_path(rtwdev, rx_path);
16958c2ecf20Sopenharmony_ci}
16968c2ecf20Sopenharmony_ci
16978c2ecf20Sopenharmony_cistatic void rtw8822c_config_cck_tx_path(struct rtw_dev *rtwdev, u8 tx_path,
16988c2ecf20Sopenharmony_ci					bool is_tx2_path)
16998c2ecf20Sopenharmony_ci{
17008c2ecf20Sopenharmony_ci	if (tx_path == BB_PATH_A) {
17018c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_RXCCKSEL, 0xf0000000, 0x8);
17028c2ecf20Sopenharmony_ci	} else if (tx_path == BB_PATH_B) {
17038c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_RXCCKSEL, 0xf0000000, 0x4);
17048c2ecf20Sopenharmony_ci	} else {
17058c2ecf20Sopenharmony_ci		if (is_tx2_path)
17068c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_RXCCKSEL, 0xf0000000, 0xc);
17078c2ecf20Sopenharmony_ci		else
17088c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_RXCCKSEL, 0xf0000000, 0x8);
17098c2ecf20Sopenharmony_ci	}
17108c2ecf20Sopenharmony_ci}
17118c2ecf20Sopenharmony_ci
17128c2ecf20Sopenharmony_cistatic void rtw8822c_config_ofdm_tx_path(struct rtw_dev *rtwdev, u8 tx_path,
17138c2ecf20Sopenharmony_ci					 bool is_tx2_path)
17148c2ecf20Sopenharmony_ci{
17158c2ecf20Sopenharmony_ci	if (tx_path == BB_PATH_A) {
17168c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_ANTMAP0, 0xff, 0x11);
17178c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_TXLGMAP, 0xff, 0x0);
17188c2ecf20Sopenharmony_ci	} else if (tx_path == BB_PATH_B) {
17198c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_ANTMAP0, 0xff, 0x12);
17208c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_TXLGMAP, 0xff, 0x0);
17218c2ecf20Sopenharmony_ci	} else {
17228c2ecf20Sopenharmony_ci		if (is_tx2_path) {
17238c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_ANTMAP0, 0xff, 0x33);
17248c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_TXLGMAP, 0xffff, 0x0404);
17258c2ecf20Sopenharmony_ci		} else {
17268c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_ANTMAP0, 0xff, 0x31);
17278c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_TXLGMAP, 0xffff, 0x0400);
17288c2ecf20Sopenharmony_ci		}
17298c2ecf20Sopenharmony_ci	}
17308c2ecf20Sopenharmony_ci}
17318c2ecf20Sopenharmony_ci
17328c2ecf20Sopenharmony_cistatic void rtw8822c_config_tx_path(struct rtw_dev *rtwdev, u8 tx_path,
17338c2ecf20Sopenharmony_ci				    bool is_tx2_path)
17348c2ecf20Sopenharmony_ci{
17358c2ecf20Sopenharmony_ci	rtw8822c_config_cck_tx_path(rtwdev, tx_path, is_tx2_path);
17368c2ecf20Sopenharmony_ci	rtw8822c_config_ofdm_tx_path(rtwdev, tx_path, is_tx2_path);
17378c2ecf20Sopenharmony_ci}
17388c2ecf20Sopenharmony_ci
17398c2ecf20Sopenharmony_cistatic void rtw8822c_config_trx_mode(struct rtw_dev *rtwdev, u8 tx_path,
17408c2ecf20Sopenharmony_ci				     u8 rx_path, bool is_tx2_path)
17418c2ecf20Sopenharmony_ci{
17428c2ecf20Sopenharmony_ci	if ((tx_path | rx_path) & BB_PATH_A)
17438c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_ORITXCODE, MASK20BITS, 0x33312);
17448c2ecf20Sopenharmony_ci	else
17458c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_ORITXCODE, MASK20BITS, 0x11111);
17468c2ecf20Sopenharmony_ci	if ((tx_path | rx_path) & BB_PATH_B)
17478c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_ORITXCODE2, MASK20BITS, 0x33312);
17488c2ecf20Sopenharmony_ci	else
17498c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_ORITXCODE2, MASK20BITS, 0x11111);
17508c2ecf20Sopenharmony_ci
17518c2ecf20Sopenharmony_ci	rtw8822c_config_rx_path(rtwdev, rx_path);
17528c2ecf20Sopenharmony_ci	rtw8822c_config_tx_path(rtwdev, tx_path, is_tx2_path);
17538c2ecf20Sopenharmony_ci
17548c2ecf20Sopenharmony_ci	rtw8822c_toggle_igi(rtwdev);
17558c2ecf20Sopenharmony_ci}
17568c2ecf20Sopenharmony_ci
17578c2ecf20Sopenharmony_cistatic void query_phy_status_page0(struct rtw_dev *rtwdev, u8 *phy_status,
17588c2ecf20Sopenharmony_ci				   struct rtw_rx_pkt_stat *pkt_stat)
17598c2ecf20Sopenharmony_ci{
17608c2ecf20Sopenharmony_ci	struct rtw_dm_info *dm_info = &rtwdev->dm_info;
17618c2ecf20Sopenharmony_ci	u8 l_bnd, u_bnd;
17628c2ecf20Sopenharmony_ci	u8 gain_a, gain_b;
17638c2ecf20Sopenharmony_ci	s8 rx_power[RTW_RF_PATH_MAX];
17648c2ecf20Sopenharmony_ci	s8 min_rx_power = -120;
17658c2ecf20Sopenharmony_ci	u8 rssi;
17668c2ecf20Sopenharmony_ci	int path;
17678c2ecf20Sopenharmony_ci
17688c2ecf20Sopenharmony_ci	rx_power[RF_PATH_A] = GET_PHY_STAT_P0_PWDB_A(phy_status);
17698c2ecf20Sopenharmony_ci	rx_power[RF_PATH_B] = GET_PHY_STAT_P0_PWDB_B(phy_status);
17708c2ecf20Sopenharmony_ci	l_bnd = dm_info->cck_gi_l_bnd;
17718c2ecf20Sopenharmony_ci	u_bnd = dm_info->cck_gi_u_bnd;
17728c2ecf20Sopenharmony_ci	gain_a = GET_PHY_STAT_P0_GAIN_A(phy_status);
17738c2ecf20Sopenharmony_ci	gain_b = GET_PHY_STAT_P0_GAIN_B(phy_status);
17748c2ecf20Sopenharmony_ci	if (gain_a < l_bnd)
17758c2ecf20Sopenharmony_ci		rx_power[RF_PATH_A] += (l_bnd - gain_a) << 1;
17768c2ecf20Sopenharmony_ci	else if (gain_a > u_bnd)
17778c2ecf20Sopenharmony_ci		rx_power[RF_PATH_A] -= (gain_a - u_bnd) << 1;
17788c2ecf20Sopenharmony_ci	if (gain_b < l_bnd)
17798c2ecf20Sopenharmony_ci		rx_power[RF_PATH_B] += (l_bnd - gain_b) << 1;
17808c2ecf20Sopenharmony_ci	else if (gain_b > u_bnd)
17818c2ecf20Sopenharmony_ci		rx_power[RF_PATH_B] -= (gain_b - u_bnd) << 1;
17828c2ecf20Sopenharmony_ci
17838c2ecf20Sopenharmony_ci	rx_power[RF_PATH_A] -= 110;
17848c2ecf20Sopenharmony_ci	rx_power[RF_PATH_B] -= 110;
17858c2ecf20Sopenharmony_ci
17868c2ecf20Sopenharmony_ci	pkt_stat->rx_power[RF_PATH_A] = rx_power[RF_PATH_A];
17878c2ecf20Sopenharmony_ci	pkt_stat->rx_power[RF_PATH_B] = rx_power[RF_PATH_B];
17888c2ecf20Sopenharmony_ci
17898c2ecf20Sopenharmony_ci	for (path = 0; path <= rtwdev->hal.rf_path_num; path++) {
17908c2ecf20Sopenharmony_ci		rssi = rtw_phy_rf_power_2_rssi(&pkt_stat->rx_power[path], 1);
17918c2ecf20Sopenharmony_ci		dm_info->rssi[path] = rssi;
17928c2ecf20Sopenharmony_ci	}
17938c2ecf20Sopenharmony_ci
17948c2ecf20Sopenharmony_ci	pkt_stat->rssi = rtw_phy_rf_power_2_rssi(pkt_stat->rx_power, 1);
17958c2ecf20Sopenharmony_ci	pkt_stat->bw = RTW_CHANNEL_WIDTH_20;
17968c2ecf20Sopenharmony_ci	pkt_stat->signal_power = max(pkt_stat->rx_power[RF_PATH_A],
17978c2ecf20Sopenharmony_ci				     min_rx_power);
17988c2ecf20Sopenharmony_ci}
17998c2ecf20Sopenharmony_ci
18008c2ecf20Sopenharmony_cistatic void query_phy_status_page1(struct rtw_dev *rtwdev, u8 *phy_status,
18018c2ecf20Sopenharmony_ci				   struct rtw_rx_pkt_stat *pkt_stat)
18028c2ecf20Sopenharmony_ci{
18038c2ecf20Sopenharmony_ci	struct rtw_dm_info *dm_info = &rtwdev->dm_info;
18048c2ecf20Sopenharmony_ci	u8 rxsc, bw;
18058c2ecf20Sopenharmony_ci	s8 min_rx_power = -120;
18068c2ecf20Sopenharmony_ci	s8 rx_evm;
18078c2ecf20Sopenharmony_ci	u8 evm_dbm = 0;
18088c2ecf20Sopenharmony_ci	u8 rssi;
18098c2ecf20Sopenharmony_ci	int path;
18108c2ecf20Sopenharmony_ci
18118c2ecf20Sopenharmony_ci	if (pkt_stat->rate > DESC_RATE11M && pkt_stat->rate < DESC_RATEMCS0)
18128c2ecf20Sopenharmony_ci		rxsc = GET_PHY_STAT_P1_L_RXSC(phy_status);
18138c2ecf20Sopenharmony_ci	else
18148c2ecf20Sopenharmony_ci		rxsc = GET_PHY_STAT_P1_HT_RXSC(phy_status);
18158c2ecf20Sopenharmony_ci
18168c2ecf20Sopenharmony_ci	if (rxsc >= 9 && rxsc <= 12)
18178c2ecf20Sopenharmony_ci		bw = RTW_CHANNEL_WIDTH_40;
18188c2ecf20Sopenharmony_ci	else if (rxsc >= 13)
18198c2ecf20Sopenharmony_ci		bw = RTW_CHANNEL_WIDTH_80;
18208c2ecf20Sopenharmony_ci	else
18218c2ecf20Sopenharmony_ci		bw = RTW_CHANNEL_WIDTH_20;
18228c2ecf20Sopenharmony_ci
18238c2ecf20Sopenharmony_ci	pkt_stat->rx_power[RF_PATH_A] = GET_PHY_STAT_P1_PWDB_A(phy_status) - 110;
18248c2ecf20Sopenharmony_ci	pkt_stat->rx_power[RF_PATH_B] = GET_PHY_STAT_P1_PWDB_B(phy_status) - 110;
18258c2ecf20Sopenharmony_ci	pkt_stat->rssi = rtw_phy_rf_power_2_rssi(pkt_stat->rx_power, 2);
18268c2ecf20Sopenharmony_ci	pkt_stat->bw = bw;
18278c2ecf20Sopenharmony_ci	pkt_stat->signal_power = max3(pkt_stat->rx_power[RF_PATH_A],
18288c2ecf20Sopenharmony_ci				      pkt_stat->rx_power[RF_PATH_B],
18298c2ecf20Sopenharmony_ci				      min_rx_power);
18308c2ecf20Sopenharmony_ci
18318c2ecf20Sopenharmony_ci	dm_info->curr_rx_rate = pkt_stat->rate;
18328c2ecf20Sopenharmony_ci
18338c2ecf20Sopenharmony_ci	pkt_stat->rx_evm[RF_PATH_A] = GET_PHY_STAT_P1_RXEVM_A(phy_status);
18348c2ecf20Sopenharmony_ci	pkt_stat->rx_evm[RF_PATH_B] = GET_PHY_STAT_P1_RXEVM_B(phy_status);
18358c2ecf20Sopenharmony_ci
18368c2ecf20Sopenharmony_ci	pkt_stat->rx_snr[RF_PATH_A] = GET_PHY_STAT_P1_RXSNR_A(phy_status);
18378c2ecf20Sopenharmony_ci	pkt_stat->rx_snr[RF_PATH_B] = GET_PHY_STAT_P1_RXSNR_B(phy_status);
18388c2ecf20Sopenharmony_ci
18398c2ecf20Sopenharmony_ci	pkt_stat->cfo_tail[RF_PATH_A] = GET_PHY_STAT_P1_CFO_TAIL_A(phy_status);
18408c2ecf20Sopenharmony_ci	pkt_stat->cfo_tail[RF_PATH_B] = GET_PHY_STAT_P1_CFO_TAIL_B(phy_status);
18418c2ecf20Sopenharmony_ci
18428c2ecf20Sopenharmony_ci	for (path = 0; path <= rtwdev->hal.rf_path_num; path++) {
18438c2ecf20Sopenharmony_ci		rssi = rtw_phy_rf_power_2_rssi(&pkt_stat->rx_power[path], 1);
18448c2ecf20Sopenharmony_ci		dm_info->rssi[path] = rssi;
18458c2ecf20Sopenharmony_ci		dm_info->rx_snr[path] = pkt_stat->rx_snr[path] >> 1;
18468c2ecf20Sopenharmony_ci		dm_info->cfo_tail[path] = (pkt_stat->cfo_tail[path] * 5) >> 1;
18478c2ecf20Sopenharmony_ci
18488c2ecf20Sopenharmony_ci		rx_evm = pkt_stat->rx_evm[path];
18498c2ecf20Sopenharmony_ci
18508c2ecf20Sopenharmony_ci		if (rx_evm < 0) {
18518c2ecf20Sopenharmony_ci			if (rx_evm == S8_MIN)
18528c2ecf20Sopenharmony_ci				evm_dbm = 0;
18538c2ecf20Sopenharmony_ci			else
18548c2ecf20Sopenharmony_ci				evm_dbm = ((u8)-rx_evm >> 1);
18558c2ecf20Sopenharmony_ci		}
18568c2ecf20Sopenharmony_ci		dm_info->rx_evm_dbm[path] = evm_dbm;
18578c2ecf20Sopenharmony_ci	}
18588c2ecf20Sopenharmony_ci}
18598c2ecf20Sopenharmony_ci
18608c2ecf20Sopenharmony_cistatic void query_phy_status(struct rtw_dev *rtwdev, u8 *phy_status,
18618c2ecf20Sopenharmony_ci			     struct rtw_rx_pkt_stat *pkt_stat)
18628c2ecf20Sopenharmony_ci{
18638c2ecf20Sopenharmony_ci	u8 page;
18648c2ecf20Sopenharmony_ci
18658c2ecf20Sopenharmony_ci	page = *phy_status & 0xf;
18668c2ecf20Sopenharmony_ci
18678c2ecf20Sopenharmony_ci	switch (page) {
18688c2ecf20Sopenharmony_ci	case 0:
18698c2ecf20Sopenharmony_ci		query_phy_status_page0(rtwdev, phy_status, pkt_stat);
18708c2ecf20Sopenharmony_ci		break;
18718c2ecf20Sopenharmony_ci	case 1:
18728c2ecf20Sopenharmony_ci		query_phy_status_page1(rtwdev, phy_status, pkt_stat);
18738c2ecf20Sopenharmony_ci		break;
18748c2ecf20Sopenharmony_ci	default:
18758c2ecf20Sopenharmony_ci		rtw_warn(rtwdev, "unused phy status page (%d)\n", page);
18768c2ecf20Sopenharmony_ci		return;
18778c2ecf20Sopenharmony_ci	}
18788c2ecf20Sopenharmony_ci}
18798c2ecf20Sopenharmony_ci
18808c2ecf20Sopenharmony_cistatic void rtw8822c_query_rx_desc(struct rtw_dev *rtwdev, u8 *rx_desc,
18818c2ecf20Sopenharmony_ci				   struct rtw_rx_pkt_stat *pkt_stat,
18828c2ecf20Sopenharmony_ci				   struct ieee80211_rx_status *rx_status)
18838c2ecf20Sopenharmony_ci{
18848c2ecf20Sopenharmony_ci	struct ieee80211_hdr *hdr;
18858c2ecf20Sopenharmony_ci	u32 desc_sz = rtwdev->chip->rx_pkt_desc_sz;
18868c2ecf20Sopenharmony_ci	u8 *phy_status = NULL;
18878c2ecf20Sopenharmony_ci
18888c2ecf20Sopenharmony_ci	memset(pkt_stat, 0, sizeof(*pkt_stat));
18898c2ecf20Sopenharmony_ci
18908c2ecf20Sopenharmony_ci	pkt_stat->phy_status = GET_RX_DESC_PHYST(rx_desc);
18918c2ecf20Sopenharmony_ci	pkt_stat->icv_err = GET_RX_DESC_ICV_ERR(rx_desc);
18928c2ecf20Sopenharmony_ci	pkt_stat->crc_err = GET_RX_DESC_CRC32(rx_desc);
18938c2ecf20Sopenharmony_ci	pkt_stat->decrypted = !GET_RX_DESC_SWDEC(rx_desc) &&
18948c2ecf20Sopenharmony_ci			      GET_RX_DESC_ENC_TYPE(rx_desc) != RX_DESC_ENC_NONE;
18958c2ecf20Sopenharmony_ci	pkt_stat->is_c2h = GET_RX_DESC_C2H(rx_desc);
18968c2ecf20Sopenharmony_ci	pkt_stat->pkt_len = GET_RX_DESC_PKT_LEN(rx_desc);
18978c2ecf20Sopenharmony_ci	pkt_stat->drv_info_sz = GET_RX_DESC_DRV_INFO_SIZE(rx_desc);
18988c2ecf20Sopenharmony_ci	pkt_stat->shift = GET_RX_DESC_SHIFT(rx_desc);
18998c2ecf20Sopenharmony_ci	pkt_stat->rate = GET_RX_DESC_RX_RATE(rx_desc);
19008c2ecf20Sopenharmony_ci	pkt_stat->cam_id = GET_RX_DESC_MACID(rx_desc);
19018c2ecf20Sopenharmony_ci	pkt_stat->ppdu_cnt = GET_RX_DESC_PPDU_CNT(rx_desc);
19028c2ecf20Sopenharmony_ci	pkt_stat->tsf_low = GET_RX_DESC_TSFL(rx_desc);
19038c2ecf20Sopenharmony_ci
19048c2ecf20Sopenharmony_ci	/* drv_info_sz is in unit of 8-bytes */
19058c2ecf20Sopenharmony_ci	pkt_stat->drv_info_sz *= 8;
19068c2ecf20Sopenharmony_ci
19078c2ecf20Sopenharmony_ci	/* c2h cmd pkt's rx/phy status is not interested */
19088c2ecf20Sopenharmony_ci	if (pkt_stat->is_c2h)
19098c2ecf20Sopenharmony_ci		return;
19108c2ecf20Sopenharmony_ci
19118c2ecf20Sopenharmony_ci	hdr = (struct ieee80211_hdr *)(rx_desc + desc_sz + pkt_stat->shift +
19128c2ecf20Sopenharmony_ci				       pkt_stat->drv_info_sz);
19138c2ecf20Sopenharmony_ci	if (pkt_stat->phy_status) {
19148c2ecf20Sopenharmony_ci		phy_status = rx_desc + desc_sz + pkt_stat->shift;
19158c2ecf20Sopenharmony_ci		query_phy_status(rtwdev, phy_status, pkt_stat);
19168c2ecf20Sopenharmony_ci	}
19178c2ecf20Sopenharmony_ci
19188c2ecf20Sopenharmony_ci	rtw_rx_fill_rx_status(rtwdev, pkt_stat, hdr, rx_status, phy_status);
19198c2ecf20Sopenharmony_ci}
19208c2ecf20Sopenharmony_ci
19218c2ecf20Sopenharmony_cistatic void
19228c2ecf20Sopenharmony_cirtw8822c_set_write_tx_power_ref(struct rtw_dev *rtwdev, u8 *tx_pwr_ref_cck,
19238c2ecf20Sopenharmony_ci				u8 *tx_pwr_ref_ofdm)
19248c2ecf20Sopenharmony_ci{
19258c2ecf20Sopenharmony_ci	struct rtw_hal *hal = &rtwdev->hal;
19268c2ecf20Sopenharmony_ci	u32 txref_cck[2] = {0x18a0, 0x41a0};
19278c2ecf20Sopenharmony_ci	u32 txref_ofdm[2] = {0x18e8, 0x41e8};
19288c2ecf20Sopenharmony_ci	u8 path;
19298c2ecf20Sopenharmony_ci
19308c2ecf20Sopenharmony_ci	for (path = 0; path < hal->rf_path_num; path++) {
19318c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, 0x1c90, BIT(15), 0);
19328c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, txref_cck[path], 0x7f0000,
19338c2ecf20Sopenharmony_ci				 tx_pwr_ref_cck[path]);
19348c2ecf20Sopenharmony_ci	}
19358c2ecf20Sopenharmony_ci	for (path = 0; path < hal->rf_path_num; path++) {
19368c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, 0x1c90, BIT(15), 0);
19378c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, txref_ofdm[path], 0x1fc00,
19388c2ecf20Sopenharmony_ci				 tx_pwr_ref_ofdm[path]);
19398c2ecf20Sopenharmony_ci	}
19408c2ecf20Sopenharmony_ci}
19418c2ecf20Sopenharmony_ci
19428c2ecf20Sopenharmony_cistatic void rtw8822c_set_tx_power_diff(struct rtw_dev *rtwdev, u8 rate,
19438c2ecf20Sopenharmony_ci				       s8 *diff_idx)
19448c2ecf20Sopenharmony_ci{
19458c2ecf20Sopenharmony_ci	u32 offset_txagc = 0x3a00;
19468c2ecf20Sopenharmony_ci	u8 rate_idx = rate & 0xfc;
19478c2ecf20Sopenharmony_ci	u8 pwr_idx[4];
19488c2ecf20Sopenharmony_ci	u32 phy_pwr_idx;
19498c2ecf20Sopenharmony_ci	int i;
19508c2ecf20Sopenharmony_ci
19518c2ecf20Sopenharmony_ci	for (i = 0; i < 4; i++)
19528c2ecf20Sopenharmony_ci		pwr_idx[i] = diff_idx[i] & 0x7f;
19538c2ecf20Sopenharmony_ci
19548c2ecf20Sopenharmony_ci	phy_pwr_idx = pwr_idx[0] |
19558c2ecf20Sopenharmony_ci		      (pwr_idx[1] << 8) |
19568c2ecf20Sopenharmony_ci		      (pwr_idx[2] << 16) |
19578c2ecf20Sopenharmony_ci		      (pwr_idx[3] << 24);
19588c2ecf20Sopenharmony_ci
19598c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x1c90, BIT(15), 0x0);
19608c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, offset_txagc + rate_idx, MASKDWORD,
19618c2ecf20Sopenharmony_ci			 phy_pwr_idx);
19628c2ecf20Sopenharmony_ci}
19638c2ecf20Sopenharmony_ci
19648c2ecf20Sopenharmony_cistatic void rtw8822c_set_tx_power_index(struct rtw_dev *rtwdev)
19658c2ecf20Sopenharmony_ci{
19668c2ecf20Sopenharmony_ci	struct rtw_hal *hal = &rtwdev->hal;
19678c2ecf20Sopenharmony_ci	u8 rs, rate, j;
19688c2ecf20Sopenharmony_ci	u8 pwr_ref_cck[2] = {hal->tx_pwr_tbl[RF_PATH_A][DESC_RATE11M],
19698c2ecf20Sopenharmony_ci			     hal->tx_pwr_tbl[RF_PATH_B][DESC_RATE11M]};
19708c2ecf20Sopenharmony_ci	u8 pwr_ref_ofdm[2] = {hal->tx_pwr_tbl[RF_PATH_A][DESC_RATEMCS7],
19718c2ecf20Sopenharmony_ci			      hal->tx_pwr_tbl[RF_PATH_B][DESC_RATEMCS7]};
19728c2ecf20Sopenharmony_ci	s8 diff_a, diff_b;
19738c2ecf20Sopenharmony_ci	u8 pwr_a, pwr_b;
19748c2ecf20Sopenharmony_ci	s8 diff_idx[4];
19758c2ecf20Sopenharmony_ci
19768c2ecf20Sopenharmony_ci	rtw8822c_set_write_tx_power_ref(rtwdev, pwr_ref_cck, pwr_ref_ofdm);
19778c2ecf20Sopenharmony_ci	for (rs = 0; rs < RTW_RATE_SECTION_MAX; rs++) {
19788c2ecf20Sopenharmony_ci		for (j = 0; j < rtw_rate_size[rs]; j++) {
19798c2ecf20Sopenharmony_ci			rate = rtw_rate_section[rs][j];
19808c2ecf20Sopenharmony_ci			pwr_a = hal->tx_pwr_tbl[RF_PATH_A][rate];
19818c2ecf20Sopenharmony_ci			pwr_b = hal->tx_pwr_tbl[RF_PATH_B][rate];
19828c2ecf20Sopenharmony_ci			if (rs == 0) {
19838c2ecf20Sopenharmony_ci				diff_a = (s8)pwr_a - (s8)pwr_ref_cck[0];
19848c2ecf20Sopenharmony_ci				diff_b = (s8)pwr_b - (s8)pwr_ref_cck[1];
19858c2ecf20Sopenharmony_ci			} else {
19868c2ecf20Sopenharmony_ci				diff_a = (s8)pwr_a - (s8)pwr_ref_ofdm[0];
19878c2ecf20Sopenharmony_ci				diff_b = (s8)pwr_b - (s8)pwr_ref_ofdm[1];
19888c2ecf20Sopenharmony_ci			}
19898c2ecf20Sopenharmony_ci			diff_idx[rate % 4] = min(diff_a, diff_b);
19908c2ecf20Sopenharmony_ci			if (rate % 4 == 3)
19918c2ecf20Sopenharmony_ci				rtw8822c_set_tx_power_diff(rtwdev, rate - 3,
19928c2ecf20Sopenharmony_ci							   diff_idx);
19938c2ecf20Sopenharmony_ci		}
19948c2ecf20Sopenharmony_ci	}
19958c2ecf20Sopenharmony_ci}
19968c2ecf20Sopenharmony_ci
19978c2ecf20Sopenharmony_cistatic int rtw8822c_set_antenna(struct rtw_dev *rtwdev,
19988c2ecf20Sopenharmony_ci				u32 antenna_tx,
19998c2ecf20Sopenharmony_ci				u32 antenna_rx)
20008c2ecf20Sopenharmony_ci{
20018c2ecf20Sopenharmony_ci	struct rtw_hal *hal = &rtwdev->hal;
20028c2ecf20Sopenharmony_ci
20038c2ecf20Sopenharmony_ci	switch (antenna_tx) {
20048c2ecf20Sopenharmony_ci	case BB_PATH_A:
20058c2ecf20Sopenharmony_ci	case BB_PATH_B:
20068c2ecf20Sopenharmony_ci	case BB_PATH_AB:
20078c2ecf20Sopenharmony_ci		break;
20088c2ecf20Sopenharmony_ci	default:
20098c2ecf20Sopenharmony_ci		rtw_info(rtwdev, "unsupported tx path 0x%x\n", antenna_tx);
20108c2ecf20Sopenharmony_ci		return -EINVAL;
20118c2ecf20Sopenharmony_ci	}
20128c2ecf20Sopenharmony_ci
20138c2ecf20Sopenharmony_ci	/* path B only is not available for RX */
20148c2ecf20Sopenharmony_ci	switch (antenna_rx) {
20158c2ecf20Sopenharmony_ci	case BB_PATH_A:
20168c2ecf20Sopenharmony_ci	case BB_PATH_AB:
20178c2ecf20Sopenharmony_ci		break;
20188c2ecf20Sopenharmony_ci	default:
20198c2ecf20Sopenharmony_ci		rtw_info(rtwdev, "unsupported rx path 0x%x\n", antenna_rx);
20208c2ecf20Sopenharmony_ci		return -EINVAL;
20218c2ecf20Sopenharmony_ci	}
20228c2ecf20Sopenharmony_ci
20238c2ecf20Sopenharmony_ci	hal->antenna_tx = antenna_tx;
20248c2ecf20Sopenharmony_ci	hal->antenna_rx = antenna_rx;
20258c2ecf20Sopenharmony_ci
20268c2ecf20Sopenharmony_ci	rtw8822c_config_trx_mode(rtwdev, antenna_tx, antenna_rx, false);
20278c2ecf20Sopenharmony_ci
20288c2ecf20Sopenharmony_ci	return 0;
20298c2ecf20Sopenharmony_ci}
20308c2ecf20Sopenharmony_ci
20318c2ecf20Sopenharmony_cistatic void rtw8822c_cfg_ldo25(struct rtw_dev *rtwdev, bool enable)
20328c2ecf20Sopenharmony_ci{
20338c2ecf20Sopenharmony_ci	u8 ldo_pwr;
20348c2ecf20Sopenharmony_ci
20358c2ecf20Sopenharmony_ci	ldo_pwr = rtw_read8(rtwdev, REG_ANAPARLDO_POW_MAC);
20368c2ecf20Sopenharmony_ci	ldo_pwr = enable ? ldo_pwr | BIT_LDOE25_PON : ldo_pwr & ~BIT_LDOE25_PON;
20378c2ecf20Sopenharmony_ci	rtw_write8(rtwdev, REG_ANAPARLDO_POW_MAC, ldo_pwr);
20388c2ecf20Sopenharmony_ci}
20398c2ecf20Sopenharmony_ci
20408c2ecf20Sopenharmony_cistatic void rtw8822c_false_alarm_statistics(struct rtw_dev *rtwdev)
20418c2ecf20Sopenharmony_ci{
20428c2ecf20Sopenharmony_ci	struct rtw_dm_info *dm_info = &rtwdev->dm_info;
20438c2ecf20Sopenharmony_ci	u32 cck_enable;
20448c2ecf20Sopenharmony_ci	u32 cck_fa_cnt;
20458c2ecf20Sopenharmony_ci	u32 crc32_cnt;
20468c2ecf20Sopenharmony_ci	u32 cca32_cnt;
20478c2ecf20Sopenharmony_ci	u32 ofdm_fa_cnt;
20488c2ecf20Sopenharmony_ci	u32 ofdm_fa_cnt1, ofdm_fa_cnt2, ofdm_fa_cnt3, ofdm_fa_cnt4, ofdm_fa_cnt5;
20498c2ecf20Sopenharmony_ci	u16 parity_fail, rate_illegal, crc8_fail, mcs_fail, sb_search_fail,
20508c2ecf20Sopenharmony_ci	    fast_fsync, crc8_fail_vhta, mcs_fail_vht;
20518c2ecf20Sopenharmony_ci
20528c2ecf20Sopenharmony_ci	cck_enable = rtw_read32(rtwdev, REG_ENCCK) & BIT_CCK_BLK_EN;
20538c2ecf20Sopenharmony_ci	cck_fa_cnt = rtw_read16(rtwdev, REG_CCK_FACNT);
20548c2ecf20Sopenharmony_ci
20558c2ecf20Sopenharmony_ci	ofdm_fa_cnt1 = rtw_read32(rtwdev, REG_OFDM_FACNT1);
20568c2ecf20Sopenharmony_ci	ofdm_fa_cnt2 = rtw_read32(rtwdev, REG_OFDM_FACNT2);
20578c2ecf20Sopenharmony_ci	ofdm_fa_cnt3 = rtw_read32(rtwdev, REG_OFDM_FACNT3);
20588c2ecf20Sopenharmony_ci	ofdm_fa_cnt4 = rtw_read32(rtwdev, REG_OFDM_FACNT4);
20598c2ecf20Sopenharmony_ci	ofdm_fa_cnt5 = rtw_read32(rtwdev, REG_OFDM_FACNT5);
20608c2ecf20Sopenharmony_ci
20618c2ecf20Sopenharmony_ci	parity_fail	= FIELD_GET(GENMASK(31, 16), ofdm_fa_cnt1);
20628c2ecf20Sopenharmony_ci	rate_illegal	= FIELD_GET(GENMASK(15, 0), ofdm_fa_cnt2);
20638c2ecf20Sopenharmony_ci	crc8_fail	= FIELD_GET(GENMASK(31, 16), ofdm_fa_cnt2);
20648c2ecf20Sopenharmony_ci	crc8_fail_vhta	= FIELD_GET(GENMASK(15, 0), ofdm_fa_cnt3);
20658c2ecf20Sopenharmony_ci	mcs_fail	= FIELD_GET(GENMASK(15, 0), ofdm_fa_cnt4);
20668c2ecf20Sopenharmony_ci	mcs_fail_vht	= FIELD_GET(GENMASK(31, 16), ofdm_fa_cnt4);
20678c2ecf20Sopenharmony_ci	fast_fsync	= FIELD_GET(GENMASK(15, 0), ofdm_fa_cnt5);
20688c2ecf20Sopenharmony_ci	sb_search_fail	= FIELD_GET(GENMASK(31, 16), ofdm_fa_cnt5);
20698c2ecf20Sopenharmony_ci
20708c2ecf20Sopenharmony_ci	ofdm_fa_cnt = parity_fail + rate_illegal + crc8_fail + crc8_fail_vhta +
20718c2ecf20Sopenharmony_ci		      mcs_fail + mcs_fail_vht + fast_fsync + sb_search_fail;
20728c2ecf20Sopenharmony_ci
20738c2ecf20Sopenharmony_ci	dm_info->cck_fa_cnt = cck_fa_cnt;
20748c2ecf20Sopenharmony_ci	dm_info->ofdm_fa_cnt = ofdm_fa_cnt;
20758c2ecf20Sopenharmony_ci	dm_info->total_fa_cnt = ofdm_fa_cnt;
20768c2ecf20Sopenharmony_ci	dm_info->total_fa_cnt += cck_enable ? cck_fa_cnt : 0;
20778c2ecf20Sopenharmony_ci
20788c2ecf20Sopenharmony_ci	crc32_cnt = rtw_read32(rtwdev, 0x2c04);
20798c2ecf20Sopenharmony_ci	dm_info->cck_ok_cnt = crc32_cnt & 0xffff;
20808c2ecf20Sopenharmony_ci	dm_info->cck_err_cnt = (crc32_cnt & 0xffff0000) >> 16;
20818c2ecf20Sopenharmony_ci	crc32_cnt = rtw_read32(rtwdev, 0x2c14);
20828c2ecf20Sopenharmony_ci	dm_info->ofdm_ok_cnt = crc32_cnt & 0xffff;
20838c2ecf20Sopenharmony_ci	dm_info->ofdm_err_cnt = (crc32_cnt & 0xffff0000) >> 16;
20848c2ecf20Sopenharmony_ci	crc32_cnt = rtw_read32(rtwdev, 0x2c10);
20858c2ecf20Sopenharmony_ci	dm_info->ht_ok_cnt = crc32_cnt & 0xffff;
20868c2ecf20Sopenharmony_ci	dm_info->ht_err_cnt = (crc32_cnt & 0xffff0000) >> 16;
20878c2ecf20Sopenharmony_ci	crc32_cnt = rtw_read32(rtwdev, 0x2c0c);
20888c2ecf20Sopenharmony_ci	dm_info->vht_ok_cnt = crc32_cnt & 0xffff;
20898c2ecf20Sopenharmony_ci	dm_info->vht_err_cnt = (crc32_cnt & 0xffff0000) >> 16;
20908c2ecf20Sopenharmony_ci
20918c2ecf20Sopenharmony_ci	cca32_cnt = rtw_read32(rtwdev, 0x2c08);
20928c2ecf20Sopenharmony_ci	dm_info->ofdm_cca_cnt = ((cca32_cnt & 0xffff0000) >> 16);
20938c2ecf20Sopenharmony_ci	dm_info->cck_cca_cnt = cca32_cnt & 0xffff;
20948c2ecf20Sopenharmony_ci	dm_info->total_cca_cnt = dm_info->ofdm_cca_cnt;
20958c2ecf20Sopenharmony_ci	if (cck_enable)
20968c2ecf20Sopenharmony_ci		dm_info->total_cca_cnt += dm_info->cck_cca_cnt;
20978c2ecf20Sopenharmony_ci
20988c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, REG_CCANRX, BIT_CCK_FA_RST, 0);
20998c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, REG_CCANRX, BIT_CCK_FA_RST, 2);
21008c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, REG_CCANRX, BIT_OFDM_FA_RST, 0);
21018c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, REG_CCANRX, BIT_OFDM_FA_RST, 2);
21028c2ecf20Sopenharmony_ci
21038c2ecf20Sopenharmony_ci	/* disable rx clk gating to reset counters */
21048c2ecf20Sopenharmony_ci	rtw_write32_clr(rtwdev, REG_RX_BREAK, BIT_COM_RX_GCK_EN);
21058c2ecf20Sopenharmony_ci	rtw_write32_set(rtwdev, REG_CNT_CTRL, BIT_ALL_CNT_RST);
21068c2ecf20Sopenharmony_ci	rtw_write32_clr(rtwdev, REG_CNT_CTRL, BIT_ALL_CNT_RST);
21078c2ecf20Sopenharmony_ci	rtw_write32_set(rtwdev, REG_RX_BREAK, BIT_COM_RX_GCK_EN);
21088c2ecf20Sopenharmony_ci}
21098c2ecf20Sopenharmony_ci
21108c2ecf20Sopenharmony_cistatic void rtw8822c_do_lck(struct rtw_dev *rtwdev)
21118c2ecf20Sopenharmony_ci{
21128c2ecf20Sopenharmony_ci	u32 val;
21138c2ecf20Sopenharmony_ci
21148c2ecf20Sopenharmony_ci	rtw_write_rf(rtwdev, RF_PATH_A, RF_SYN_CTRL, RFREG_MASK, 0x80010);
21158c2ecf20Sopenharmony_ci	rtw_write_rf(rtwdev, RF_PATH_A, RF_SYN_PFD, RFREG_MASK, 0x1F0FA);
21168c2ecf20Sopenharmony_ci	fsleep(1);
21178c2ecf20Sopenharmony_ci	rtw_write_rf(rtwdev, RF_PATH_A, RF_AAC_CTRL, RFREG_MASK, 0x80000);
21188c2ecf20Sopenharmony_ci	rtw_write_rf(rtwdev, RF_PATH_A, RF_SYN_AAC, RFREG_MASK, 0x80001);
21198c2ecf20Sopenharmony_ci	read_poll_timeout(rtw_read_rf, val, val != 0x1, 1000, 100000,
21208c2ecf20Sopenharmony_ci			  true, rtwdev, RF_PATH_A, RF_AAC_CTRL, 0x1000);
21218c2ecf20Sopenharmony_ci	rtw_write_rf(rtwdev, RF_PATH_A, RF_SYN_PFD, RFREG_MASK, 0x1F0F8);
21228c2ecf20Sopenharmony_ci	rtw_write_rf(rtwdev, RF_PATH_B, RF_SYN_CTRL, RFREG_MASK, 0x80010);
21238c2ecf20Sopenharmony_ci
21248c2ecf20Sopenharmony_ci	rtw_write_rf(rtwdev, RF_PATH_A, RF_FAST_LCK, RFREG_MASK, 0x0f000);
21258c2ecf20Sopenharmony_ci	rtw_write_rf(rtwdev, RF_PATH_A, RF_FAST_LCK, RFREG_MASK, 0x4f000);
21268c2ecf20Sopenharmony_ci	fsleep(1);
21278c2ecf20Sopenharmony_ci	rtw_write_rf(rtwdev, RF_PATH_A, RF_FAST_LCK, RFREG_MASK, 0x0f000);
21288c2ecf20Sopenharmony_ci}
21298c2ecf20Sopenharmony_ci
21308c2ecf20Sopenharmony_cistatic void rtw8822c_do_iqk(struct rtw_dev *rtwdev)
21318c2ecf20Sopenharmony_ci{
21328c2ecf20Sopenharmony_ci	struct rtw_iqk_para para = {0};
21338c2ecf20Sopenharmony_ci	u8 iqk_chk;
21348c2ecf20Sopenharmony_ci	int counter;
21358c2ecf20Sopenharmony_ci
21368c2ecf20Sopenharmony_ci	para.clear = 1;
21378c2ecf20Sopenharmony_ci	rtw_fw_do_iqk(rtwdev, &para);
21388c2ecf20Sopenharmony_ci
21398c2ecf20Sopenharmony_ci	for (counter = 0; counter < 300; counter++) {
21408c2ecf20Sopenharmony_ci		iqk_chk = rtw_read8(rtwdev, REG_RPT_CIP);
21418c2ecf20Sopenharmony_ci		if (iqk_chk == 0xaa)
21428c2ecf20Sopenharmony_ci			break;
21438c2ecf20Sopenharmony_ci		msleep(20);
21448c2ecf20Sopenharmony_ci	}
21458c2ecf20Sopenharmony_ci	rtw_write8(rtwdev, REG_IQKSTAT, 0x0);
21468c2ecf20Sopenharmony_ci
21478c2ecf20Sopenharmony_ci	rtw_dbg(rtwdev, RTW_DBG_RFK, "iqk counter=%d\n", counter);
21488c2ecf20Sopenharmony_ci}
21498c2ecf20Sopenharmony_ci
21508c2ecf20Sopenharmony_ci/* for coex */
21518c2ecf20Sopenharmony_cistatic void rtw8822c_coex_cfg_init(struct rtw_dev *rtwdev)
21528c2ecf20Sopenharmony_ci{
21538c2ecf20Sopenharmony_ci	/* enable TBTT nterrupt */
21548c2ecf20Sopenharmony_ci	rtw_write8_set(rtwdev, REG_BCN_CTRL, BIT_EN_BCN_FUNCTION);
21558c2ecf20Sopenharmony_ci
21568c2ecf20Sopenharmony_ci	/* BT report packet sample rate	 */
21578c2ecf20Sopenharmony_ci	/* 0x790[5:0]=0x5 */
21588c2ecf20Sopenharmony_ci	rtw_write8_set(rtwdev, REG_BT_TDMA_TIME, 0x05);
21598c2ecf20Sopenharmony_ci
21608c2ecf20Sopenharmony_ci	/* enable BT counter statistics */
21618c2ecf20Sopenharmony_ci	rtw_write8(rtwdev, REG_BT_STAT_CTRL, 0x1);
21628c2ecf20Sopenharmony_ci
21638c2ecf20Sopenharmony_ci	/* enable PTA (3-wire function form BT side) */
21648c2ecf20Sopenharmony_ci	rtw_write32_set(rtwdev, REG_GPIO_MUXCFG, BIT_BT_PTA_EN);
21658c2ecf20Sopenharmony_ci	rtw_write32_set(rtwdev, REG_GPIO_MUXCFG, BIT_BT_AOD_GPIO3);
21668c2ecf20Sopenharmony_ci
21678c2ecf20Sopenharmony_ci	/* enable PTA (tx/rx signal form WiFi side) */
21688c2ecf20Sopenharmony_ci	rtw_write8_set(rtwdev, REG_QUEUE_CTRL, BIT_PTA_WL_TX_EN);
21698c2ecf20Sopenharmony_ci	/* wl tx signal to PTA not case EDCCA */
21708c2ecf20Sopenharmony_ci	rtw_write8_clr(rtwdev, REG_QUEUE_CTRL, BIT_PTA_EDCCA_EN);
21718c2ecf20Sopenharmony_ci	/* GNT_BT=1 while select both */
21728c2ecf20Sopenharmony_ci	rtw_write8_set(rtwdev, REG_BT_COEX_V2, BIT_GNT_BT_POLARITY);
21738c2ecf20Sopenharmony_ci	/* BT_CCA = ~GNT_WL_BB, (not or GNT_BT_BB, LTE_Rx */
21748c2ecf20Sopenharmony_ci	rtw_write8_clr(rtwdev, REG_DUMMY_PAGE4_V1, BIT_BTCCA_CTRL);
21758c2ecf20Sopenharmony_ci
21768c2ecf20Sopenharmony_ci	/* to avoid RF parameter error */
21778c2ecf20Sopenharmony_ci	rtw_write_rf(rtwdev, RF_PATH_B, 0x1, 0xfffff, 0x40000);
21788c2ecf20Sopenharmony_ci}
21798c2ecf20Sopenharmony_ci
21808c2ecf20Sopenharmony_cistatic void rtw8822c_coex_cfg_gnt_fix(struct rtw_dev *rtwdev)
21818c2ecf20Sopenharmony_ci{
21828c2ecf20Sopenharmony_ci	struct rtw_coex *coex = &rtwdev->coex;
21838c2ecf20Sopenharmony_ci	struct rtw_coex_stat *coex_stat = &coex->stat;
21848c2ecf20Sopenharmony_ci	struct rtw_efuse *efuse = &rtwdev->efuse;
21858c2ecf20Sopenharmony_ci	u32 rf_0x1;
21868c2ecf20Sopenharmony_ci
21878c2ecf20Sopenharmony_ci	if (coex_stat->gnt_workaround_state == coex_stat->wl_coex_mode)
21888c2ecf20Sopenharmony_ci		return;
21898c2ecf20Sopenharmony_ci
21908c2ecf20Sopenharmony_ci	coex_stat->gnt_workaround_state = coex_stat->wl_coex_mode;
21918c2ecf20Sopenharmony_ci
21928c2ecf20Sopenharmony_ci	if ((coex_stat->kt_ver == 0 && coex->under_5g) || coex->freerun)
21938c2ecf20Sopenharmony_ci		rf_0x1 = 0x40021;
21948c2ecf20Sopenharmony_ci	else
21958c2ecf20Sopenharmony_ci		rf_0x1 = 0x40000;
21968c2ecf20Sopenharmony_ci
21978c2ecf20Sopenharmony_ci	/* BT at S1 for Shared-Ant */
21988c2ecf20Sopenharmony_ci	if (efuse->share_ant)
21998c2ecf20Sopenharmony_ci		rf_0x1 |= BIT(13);
22008c2ecf20Sopenharmony_ci
22018c2ecf20Sopenharmony_ci	rtw_write_rf(rtwdev, RF_PATH_B, 0x1, 0xfffff, rf_0x1);
22028c2ecf20Sopenharmony_ci
22038c2ecf20Sopenharmony_ci	/* WL-S0 2G RF TRX cannot be masked by GNT_BT
22048c2ecf20Sopenharmony_ci	 * enable "WLS0 BB chage RF mode if GNT_BT = 1" for shared-antenna type
22058c2ecf20Sopenharmony_ci	 * disable:0x1860[3] = 1, enable:0x1860[3] = 0
22068c2ecf20Sopenharmony_ci	 *
22078c2ecf20Sopenharmony_ci	 * enable "DAC off if GNT_WL = 0" for non-shared-antenna
22088c2ecf20Sopenharmony_ci	 * disable 0x1c30[22] = 0,
22098c2ecf20Sopenharmony_ci	 * enable: 0x1c30[22] = 1, 0x1c38[12] = 0, 0x1c38[28] = 1
22108c2ecf20Sopenharmony_ci	 *
22118c2ecf20Sopenharmony_ci	 * disable WL-S1 BB chage RF mode if GNT_BT
22128c2ecf20Sopenharmony_ci	 * since RF TRx mask can do it
22138c2ecf20Sopenharmony_ci	 */
22148c2ecf20Sopenharmony_ci	rtw_write8_mask(rtwdev, 0x1c32, BIT(6), 1);
22158c2ecf20Sopenharmony_ci	rtw_write8_mask(rtwdev, 0x1c39, BIT(4), 0);
22168c2ecf20Sopenharmony_ci	rtw_write8_mask(rtwdev, 0x1c3b, BIT(4), 1);
22178c2ecf20Sopenharmony_ci	rtw_write8_mask(rtwdev, 0x4160, BIT(3), 1);
22188c2ecf20Sopenharmony_ci
22198c2ecf20Sopenharmony_ci	/* disable WL-S0 BB chage RF mode if wifi is at 5G,
22208c2ecf20Sopenharmony_ci	 * or antenna path is separated
22218c2ecf20Sopenharmony_ci	 */
22228c2ecf20Sopenharmony_ci	if (coex_stat->wl_coex_mode == COEX_WLINK_5G ||
22238c2ecf20Sopenharmony_ci	    coex->under_5g || !efuse->share_ant) {
22248c2ecf20Sopenharmony_ci		if (coex_stat->kt_ver >= 3) {
22258c2ecf20Sopenharmony_ci			rtw_write8_mask(rtwdev, 0x1860, BIT(3), 0);
22268c2ecf20Sopenharmony_ci			rtw_write8_mask(rtwdev, 0x1ca7, BIT(3), 1);
22278c2ecf20Sopenharmony_ci		} else {
22288c2ecf20Sopenharmony_ci			rtw_write8_mask(rtwdev, 0x1860, BIT(3), 1);
22298c2ecf20Sopenharmony_ci		}
22308c2ecf20Sopenharmony_ci	} else {
22318c2ecf20Sopenharmony_ci		/* shared-antenna */
22328c2ecf20Sopenharmony_ci		rtw_write8_mask(rtwdev, 0x1860, BIT(3), 0);
22338c2ecf20Sopenharmony_ci		if (coex_stat->kt_ver >= 3)
22348c2ecf20Sopenharmony_ci			rtw_write8_mask(rtwdev, 0x1ca7, BIT(3), 0);
22358c2ecf20Sopenharmony_ci	}
22368c2ecf20Sopenharmony_ci}
22378c2ecf20Sopenharmony_ci
22388c2ecf20Sopenharmony_cistatic void rtw8822c_coex_cfg_gnt_debug(struct rtw_dev *rtwdev)
22398c2ecf20Sopenharmony_ci{
22408c2ecf20Sopenharmony_ci	rtw_write8_mask(rtwdev, 0x66, BIT(4), 0);
22418c2ecf20Sopenharmony_ci	rtw_write8_mask(rtwdev, 0x67, BIT(0), 0);
22428c2ecf20Sopenharmony_ci	rtw_write8_mask(rtwdev, 0x42, BIT(3), 0);
22438c2ecf20Sopenharmony_ci	rtw_write8_mask(rtwdev, 0x65, BIT(7), 0);
22448c2ecf20Sopenharmony_ci	rtw_write8_mask(rtwdev, 0x73, BIT(3), 0);
22458c2ecf20Sopenharmony_ci}
22468c2ecf20Sopenharmony_ci
22478c2ecf20Sopenharmony_cistatic void rtw8822c_coex_cfg_rfe_type(struct rtw_dev *rtwdev)
22488c2ecf20Sopenharmony_ci{
22498c2ecf20Sopenharmony_ci	struct rtw_coex *coex = &rtwdev->coex;
22508c2ecf20Sopenharmony_ci	struct rtw_coex_rfe *coex_rfe = &coex->rfe;
22518c2ecf20Sopenharmony_ci	struct rtw_efuse *efuse = &rtwdev->efuse;
22528c2ecf20Sopenharmony_ci
22538c2ecf20Sopenharmony_ci	coex_rfe->rfe_module_type = rtwdev->efuse.rfe_option;
22548c2ecf20Sopenharmony_ci	coex_rfe->ant_switch_polarity = 0;
22558c2ecf20Sopenharmony_ci	coex_rfe->ant_switch_exist = false;
22568c2ecf20Sopenharmony_ci	coex_rfe->ant_switch_with_bt = false;
22578c2ecf20Sopenharmony_ci	coex_rfe->ant_switch_diversity = false;
22588c2ecf20Sopenharmony_ci
22598c2ecf20Sopenharmony_ci	if (efuse->share_ant)
22608c2ecf20Sopenharmony_ci		coex_rfe->wlg_at_btg = true;
22618c2ecf20Sopenharmony_ci	else
22628c2ecf20Sopenharmony_ci		coex_rfe->wlg_at_btg = false;
22638c2ecf20Sopenharmony_ci
22648c2ecf20Sopenharmony_ci	/* disable LTE coex in wifi side */
22658c2ecf20Sopenharmony_ci	rtw_coex_write_indirect_reg(rtwdev, 0x38, BIT_LTE_COEX_EN, 0x0);
22668c2ecf20Sopenharmony_ci	rtw_coex_write_indirect_reg(rtwdev, 0xa0, MASKLWORD, 0xffff);
22678c2ecf20Sopenharmony_ci	rtw_coex_write_indirect_reg(rtwdev, 0xa4, MASKLWORD, 0xffff);
22688c2ecf20Sopenharmony_ci}
22698c2ecf20Sopenharmony_ci
22708c2ecf20Sopenharmony_cistatic void rtw8822c_coex_cfg_wl_tx_power(struct rtw_dev *rtwdev, u8 wl_pwr)
22718c2ecf20Sopenharmony_ci{
22728c2ecf20Sopenharmony_ci	struct rtw_coex *coex = &rtwdev->coex;
22738c2ecf20Sopenharmony_ci	struct rtw_coex_dm *coex_dm = &coex->dm;
22748c2ecf20Sopenharmony_ci
22758c2ecf20Sopenharmony_ci	if (wl_pwr == coex_dm->cur_wl_pwr_lvl)
22768c2ecf20Sopenharmony_ci		return;
22778c2ecf20Sopenharmony_ci
22788c2ecf20Sopenharmony_ci	coex_dm->cur_wl_pwr_lvl = wl_pwr;
22798c2ecf20Sopenharmony_ci}
22808c2ecf20Sopenharmony_ci
22818c2ecf20Sopenharmony_cistatic void rtw8822c_coex_cfg_wl_rx_gain(struct rtw_dev *rtwdev, bool low_gain)
22828c2ecf20Sopenharmony_ci{
22838c2ecf20Sopenharmony_ci	struct rtw_coex *coex = &rtwdev->coex;
22848c2ecf20Sopenharmony_ci	struct rtw_coex_dm *coex_dm = &coex->dm;
22858c2ecf20Sopenharmony_ci
22868c2ecf20Sopenharmony_ci	if (low_gain == coex_dm->cur_wl_rx_low_gain_en)
22878c2ecf20Sopenharmony_ci		return;
22888c2ecf20Sopenharmony_ci
22898c2ecf20Sopenharmony_ci	coex_dm->cur_wl_rx_low_gain_en = low_gain;
22908c2ecf20Sopenharmony_ci
22918c2ecf20Sopenharmony_ci	if (coex_dm->cur_wl_rx_low_gain_en) {
22928c2ecf20Sopenharmony_ci		/* set Rx filter corner RCK offset */
22938c2ecf20Sopenharmony_ci		rtw_write_rf(rtwdev, RF_PATH_A, 0xde, 0xfffff, 0x22);
22948c2ecf20Sopenharmony_ci		rtw_write_rf(rtwdev, RF_PATH_A, 0x1d, 0xfffff, 0x36);
22958c2ecf20Sopenharmony_ci		rtw_write_rf(rtwdev, RF_PATH_B, 0xde, 0xfffff, 0x22);
22968c2ecf20Sopenharmony_ci		rtw_write_rf(rtwdev, RF_PATH_B, 0x1d, 0xfffff, 0x36);
22978c2ecf20Sopenharmony_ci	} else {
22988c2ecf20Sopenharmony_ci		/* set Rx filter corner RCK offset */
22998c2ecf20Sopenharmony_ci		rtw_write_rf(rtwdev, RF_PATH_A, 0xde, 0xfffff, 0x20);
23008c2ecf20Sopenharmony_ci		rtw_write_rf(rtwdev, RF_PATH_A, 0x1d, 0xfffff, 0x0);
23018c2ecf20Sopenharmony_ci		rtw_write_rf(rtwdev, RF_PATH_B, 0x1d, 0xfffff, 0x0);
23028c2ecf20Sopenharmony_ci	}
23038c2ecf20Sopenharmony_ci}
23048c2ecf20Sopenharmony_ci
23058c2ecf20Sopenharmony_cistatic void rtw8822c_bf_enable_bfee_su(struct rtw_dev *rtwdev,
23068c2ecf20Sopenharmony_ci				       struct rtw_vif *vif,
23078c2ecf20Sopenharmony_ci				       struct rtw_bfee *bfee)
23088c2ecf20Sopenharmony_ci{
23098c2ecf20Sopenharmony_ci	u8 csi_rsc = 0;
23108c2ecf20Sopenharmony_ci	u32 tmp6dc;
23118c2ecf20Sopenharmony_ci
23128c2ecf20Sopenharmony_ci	rtw_bf_enable_bfee_su(rtwdev, vif, bfee);
23138c2ecf20Sopenharmony_ci
23148c2ecf20Sopenharmony_ci	tmp6dc = rtw_read32(rtwdev, REG_BBPSF_CTRL) |
23158c2ecf20Sopenharmony_ci			    BIT_WMAC_USE_NDPARATE |
23168c2ecf20Sopenharmony_ci			    (csi_rsc << 13);
23178c2ecf20Sopenharmony_ci	if (vif->net_type == RTW_NET_AP_MODE)
23188c2ecf20Sopenharmony_ci		rtw_write32(rtwdev, REG_BBPSF_CTRL, tmp6dc | BIT(12));
23198c2ecf20Sopenharmony_ci	else
23208c2ecf20Sopenharmony_ci		rtw_write32(rtwdev, REG_BBPSF_CTRL, tmp6dc & ~BIT(12));
23218c2ecf20Sopenharmony_ci
23228c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, REG_CSI_RRSR, 0x550);
23238c2ecf20Sopenharmony_ci}
23248c2ecf20Sopenharmony_ci
23258c2ecf20Sopenharmony_cistatic void rtw8822c_bf_config_bfee_su(struct rtw_dev *rtwdev,
23268c2ecf20Sopenharmony_ci				       struct rtw_vif *vif,
23278c2ecf20Sopenharmony_ci				       struct rtw_bfee *bfee, bool enable)
23288c2ecf20Sopenharmony_ci{
23298c2ecf20Sopenharmony_ci	if (enable)
23308c2ecf20Sopenharmony_ci		rtw8822c_bf_enable_bfee_su(rtwdev, vif, bfee);
23318c2ecf20Sopenharmony_ci	else
23328c2ecf20Sopenharmony_ci		rtw_bf_remove_bfee_su(rtwdev, bfee);
23338c2ecf20Sopenharmony_ci}
23348c2ecf20Sopenharmony_ci
23358c2ecf20Sopenharmony_cistatic void rtw8822c_bf_config_bfee_mu(struct rtw_dev *rtwdev,
23368c2ecf20Sopenharmony_ci				       struct rtw_vif *vif,
23378c2ecf20Sopenharmony_ci				       struct rtw_bfee *bfee, bool enable)
23388c2ecf20Sopenharmony_ci{
23398c2ecf20Sopenharmony_ci	if (enable)
23408c2ecf20Sopenharmony_ci		rtw_bf_enable_bfee_mu(rtwdev, vif, bfee);
23418c2ecf20Sopenharmony_ci	else
23428c2ecf20Sopenharmony_ci		rtw_bf_remove_bfee_mu(rtwdev, bfee);
23438c2ecf20Sopenharmony_ci}
23448c2ecf20Sopenharmony_ci
23458c2ecf20Sopenharmony_cistatic void rtw8822c_bf_config_bfee(struct rtw_dev *rtwdev, struct rtw_vif *vif,
23468c2ecf20Sopenharmony_ci				    struct rtw_bfee *bfee, bool enable)
23478c2ecf20Sopenharmony_ci{
23488c2ecf20Sopenharmony_ci	if (bfee->role == RTW_BFEE_SU)
23498c2ecf20Sopenharmony_ci		rtw8822c_bf_config_bfee_su(rtwdev, vif, bfee, enable);
23508c2ecf20Sopenharmony_ci	else if (bfee->role == RTW_BFEE_MU)
23518c2ecf20Sopenharmony_ci		rtw8822c_bf_config_bfee_mu(rtwdev, vif, bfee, enable);
23528c2ecf20Sopenharmony_ci	else
23538c2ecf20Sopenharmony_ci		rtw_warn(rtwdev, "wrong bfee role\n");
23548c2ecf20Sopenharmony_ci}
23558c2ecf20Sopenharmony_ci
23568c2ecf20Sopenharmony_cistruct dpk_cfg_pair {
23578c2ecf20Sopenharmony_ci	u32 addr;
23588c2ecf20Sopenharmony_ci	u32 bitmask;
23598c2ecf20Sopenharmony_ci	u32 data;
23608c2ecf20Sopenharmony_ci};
23618c2ecf20Sopenharmony_ci
23628c2ecf20Sopenharmony_civoid rtw8822c_parse_tbl_dpk(struct rtw_dev *rtwdev,
23638c2ecf20Sopenharmony_ci			    const struct rtw_table *tbl)
23648c2ecf20Sopenharmony_ci{
23658c2ecf20Sopenharmony_ci	const struct dpk_cfg_pair *p = tbl->data;
23668c2ecf20Sopenharmony_ci	const struct dpk_cfg_pair *end = p + tbl->size / 3;
23678c2ecf20Sopenharmony_ci
23688c2ecf20Sopenharmony_ci	BUILD_BUG_ON(sizeof(struct dpk_cfg_pair) != sizeof(u32) * 3);
23698c2ecf20Sopenharmony_ci
23708c2ecf20Sopenharmony_ci	for (; p < end; p++)
23718c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, p->addr, p->bitmask, p->data);
23728c2ecf20Sopenharmony_ci}
23738c2ecf20Sopenharmony_ci
23748c2ecf20Sopenharmony_cistatic void rtw8822c_dpk_set_gnt_wl(struct rtw_dev *rtwdev, bool is_before_k)
23758c2ecf20Sopenharmony_ci{
23768c2ecf20Sopenharmony_ci	struct rtw_dpk_info *dpk_info = &rtwdev->dm_info.dpk_info;
23778c2ecf20Sopenharmony_ci
23788c2ecf20Sopenharmony_ci	if (is_before_k) {
23798c2ecf20Sopenharmony_ci		dpk_info->gnt_control = rtw_read32(rtwdev, 0x70);
23808c2ecf20Sopenharmony_ci		dpk_info->gnt_value = rtw_coex_read_indirect_reg(rtwdev, 0x38);
23818c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, 0x70, BIT(26), 0x1);
23828c2ecf20Sopenharmony_ci		rtw_coex_write_indirect_reg(rtwdev, 0x38, MASKBYTE1, 0x77);
23838c2ecf20Sopenharmony_ci	} else {
23848c2ecf20Sopenharmony_ci		rtw_coex_write_indirect_reg(rtwdev, 0x38, MASKDWORD,
23858c2ecf20Sopenharmony_ci					    dpk_info->gnt_value);
23868c2ecf20Sopenharmony_ci		rtw_write32(rtwdev, 0x70, dpk_info->gnt_control);
23878c2ecf20Sopenharmony_ci	}
23888c2ecf20Sopenharmony_ci}
23898c2ecf20Sopenharmony_ci
23908c2ecf20Sopenharmony_cistatic void
23918c2ecf20Sopenharmony_cirtw8822c_dpk_restore_registers(struct rtw_dev *rtwdev, u32 reg_num,
23928c2ecf20Sopenharmony_ci			       struct rtw_backup_info *bckp)
23938c2ecf20Sopenharmony_ci{
23948c2ecf20Sopenharmony_ci	rtw_restore_reg(rtwdev, bckp, reg_num);
23958c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, REG_NCTL0, BIT_SUBPAGE, 0xc);
23968c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, REG_RXSRAM_CTL, BIT_DPD_CLK, 0x4);
23978c2ecf20Sopenharmony_ci}
23988c2ecf20Sopenharmony_ci
23998c2ecf20Sopenharmony_cistatic void
24008c2ecf20Sopenharmony_cirtw8822c_dpk_backup_registers(struct rtw_dev *rtwdev, u32 *reg,
24018c2ecf20Sopenharmony_ci			      u32 reg_num, struct rtw_backup_info *bckp)
24028c2ecf20Sopenharmony_ci{
24038c2ecf20Sopenharmony_ci	u32 i;
24048c2ecf20Sopenharmony_ci
24058c2ecf20Sopenharmony_ci	for (i = 0; i < reg_num; i++) {
24068c2ecf20Sopenharmony_ci		bckp[i].len = 4;
24078c2ecf20Sopenharmony_ci		bckp[i].reg = reg[i];
24088c2ecf20Sopenharmony_ci		bckp[i].val = rtw_read32(rtwdev, reg[i]);
24098c2ecf20Sopenharmony_ci	}
24108c2ecf20Sopenharmony_ci}
24118c2ecf20Sopenharmony_ci
24128c2ecf20Sopenharmony_cistatic void rtw8822c_dpk_backup_rf_registers(struct rtw_dev *rtwdev,
24138c2ecf20Sopenharmony_ci					     u32 *rf_reg,
24148c2ecf20Sopenharmony_ci					     u32 rf_reg_bak[][2])
24158c2ecf20Sopenharmony_ci{
24168c2ecf20Sopenharmony_ci	u32 i;
24178c2ecf20Sopenharmony_ci
24188c2ecf20Sopenharmony_ci	for (i = 0; i < DPK_RF_REG_NUM; i++) {
24198c2ecf20Sopenharmony_ci		rf_reg_bak[i][RF_PATH_A] = rtw_read_rf(rtwdev, RF_PATH_A,
24208c2ecf20Sopenharmony_ci						       rf_reg[i], RFREG_MASK);
24218c2ecf20Sopenharmony_ci		rf_reg_bak[i][RF_PATH_B] = rtw_read_rf(rtwdev, RF_PATH_B,
24228c2ecf20Sopenharmony_ci						       rf_reg[i], RFREG_MASK);
24238c2ecf20Sopenharmony_ci	}
24248c2ecf20Sopenharmony_ci}
24258c2ecf20Sopenharmony_ci
24268c2ecf20Sopenharmony_cistatic void rtw8822c_dpk_reload_rf_registers(struct rtw_dev *rtwdev,
24278c2ecf20Sopenharmony_ci					     u32 *rf_reg,
24288c2ecf20Sopenharmony_ci					     u32 rf_reg_bak[][2])
24298c2ecf20Sopenharmony_ci{
24308c2ecf20Sopenharmony_ci	u32 i;
24318c2ecf20Sopenharmony_ci
24328c2ecf20Sopenharmony_ci	for (i = 0; i < DPK_RF_REG_NUM; i++) {
24338c2ecf20Sopenharmony_ci		rtw_write_rf(rtwdev, RF_PATH_A, rf_reg[i], RFREG_MASK,
24348c2ecf20Sopenharmony_ci			     rf_reg_bak[i][RF_PATH_A]);
24358c2ecf20Sopenharmony_ci		rtw_write_rf(rtwdev, RF_PATH_B, rf_reg[i], RFREG_MASK,
24368c2ecf20Sopenharmony_ci			     rf_reg_bak[i][RF_PATH_B]);
24378c2ecf20Sopenharmony_ci	}
24388c2ecf20Sopenharmony_ci}
24398c2ecf20Sopenharmony_ci
24408c2ecf20Sopenharmony_cistatic void rtw8822c_dpk_information(struct rtw_dev *rtwdev)
24418c2ecf20Sopenharmony_ci{
24428c2ecf20Sopenharmony_ci	struct rtw_dpk_info *dpk_info = &rtwdev->dm_info.dpk_info;
24438c2ecf20Sopenharmony_ci	u32  reg;
24448c2ecf20Sopenharmony_ci	u8 band_shift;
24458c2ecf20Sopenharmony_ci
24468c2ecf20Sopenharmony_ci	reg = rtw_read_rf(rtwdev, RF_PATH_A, 0x18, RFREG_MASK);
24478c2ecf20Sopenharmony_ci
24488c2ecf20Sopenharmony_ci	band_shift = FIELD_GET(BIT(16), reg);
24498c2ecf20Sopenharmony_ci	dpk_info->dpk_band = 1 << band_shift;
24508c2ecf20Sopenharmony_ci	dpk_info->dpk_ch = FIELD_GET(0xff, reg);
24518c2ecf20Sopenharmony_ci	dpk_info->dpk_bw = FIELD_GET(0x3000, reg);
24528c2ecf20Sopenharmony_ci}
24538c2ecf20Sopenharmony_ci
24548c2ecf20Sopenharmony_cistatic void rtw8822c_dpk_rxbb_dc_cal(struct rtw_dev *rtwdev, u8 path)
24558c2ecf20Sopenharmony_ci{
24568c2ecf20Sopenharmony_ci	rtw_write_rf(rtwdev, path, 0x92, RFREG_MASK, 0x84800);
24578c2ecf20Sopenharmony_ci	udelay(5);
24588c2ecf20Sopenharmony_ci	rtw_write_rf(rtwdev, path, 0x92, RFREG_MASK, 0x84801);
24598c2ecf20Sopenharmony_ci	usleep_range(600, 610);
24608c2ecf20Sopenharmony_ci	rtw_write_rf(rtwdev, path, 0x92, RFREG_MASK, 0x84800);
24618c2ecf20Sopenharmony_ci}
24628c2ecf20Sopenharmony_ci
24638c2ecf20Sopenharmony_cistatic u8 rtw8822c_dpk_dc_corr_check(struct rtw_dev *rtwdev, u8 path)
24648c2ecf20Sopenharmony_ci{
24658c2ecf20Sopenharmony_ci	u16 dc_i, dc_q;
24668c2ecf20Sopenharmony_ci	u8 corr_val, corr_idx;
24678c2ecf20Sopenharmony_ci
24688c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, REG_RXSRAM_CTL, 0x000900f0);
24698c2ecf20Sopenharmony_ci	dc_i = (u16)rtw_read32_mask(rtwdev, REG_STAT_RPT, GENMASK(27, 16));
24708c2ecf20Sopenharmony_ci	dc_q = (u16)rtw_read32_mask(rtwdev, REG_STAT_RPT, GENMASK(11, 0));
24718c2ecf20Sopenharmony_ci
24728c2ecf20Sopenharmony_ci	if (dc_i & BIT(11))
24738c2ecf20Sopenharmony_ci		dc_i = 0x1000 - dc_i;
24748c2ecf20Sopenharmony_ci	if (dc_q & BIT(11))
24758c2ecf20Sopenharmony_ci		dc_q = 0x1000 - dc_q;
24768c2ecf20Sopenharmony_ci
24778c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, REG_RXSRAM_CTL, 0x000000f0);
24788c2ecf20Sopenharmony_ci	corr_idx = (u8)rtw_read32_mask(rtwdev, REG_STAT_RPT, GENMASK(7, 0));
24798c2ecf20Sopenharmony_ci	corr_val = (u8)rtw_read32_mask(rtwdev, REG_STAT_RPT, GENMASK(15, 8));
24808c2ecf20Sopenharmony_ci
24818c2ecf20Sopenharmony_ci	if (dc_i > 200 || dc_q > 200 || corr_idx < 40 || corr_idx > 65)
24828c2ecf20Sopenharmony_ci		return 1;
24838c2ecf20Sopenharmony_ci	else
24848c2ecf20Sopenharmony_ci		return 0;
24858c2ecf20Sopenharmony_ci
24868c2ecf20Sopenharmony_ci}
24878c2ecf20Sopenharmony_ci
24888c2ecf20Sopenharmony_cistatic void rtw8822c_dpk_tx_pause(struct rtw_dev *rtwdev)
24898c2ecf20Sopenharmony_ci{
24908c2ecf20Sopenharmony_ci	u8 reg_a, reg_b;
24918c2ecf20Sopenharmony_ci	u16 count = 0;
24928c2ecf20Sopenharmony_ci
24938c2ecf20Sopenharmony_ci	rtw_write8(rtwdev, 0x522, 0xff);
24948c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x1e70, 0xf, 0x2);
24958c2ecf20Sopenharmony_ci
24968c2ecf20Sopenharmony_ci	do {
24978c2ecf20Sopenharmony_ci		reg_a = (u8)rtw_read_rf(rtwdev, RF_PATH_A, 0x00, 0xf0000);
24988c2ecf20Sopenharmony_ci		reg_b = (u8)rtw_read_rf(rtwdev, RF_PATH_B, 0x00, 0xf0000);
24998c2ecf20Sopenharmony_ci		udelay(2);
25008c2ecf20Sopenharmony_ci		count++;
25018c2ecf20Sopenharmony_ci	} while ((reg_a == 2 || reg_b == 2) && count < 2500);
25028c2ecf20Sopenharmony_ci}
25038c2ecf20Sopenharmony_ci
25048c2ecf20Sopenharmony_cistatic void rtw8822c_dpk_mac_bb_setting(struct rtw_dev *rtwdev)
25058c2ecf20Sopenharmony_ci{
25068c2ecf20Sopenharmony_ci	rtw8822c_dpk_tx_pause(rtwdev);
25078c2ecf20Sopenharmony_ci	rtw_load_table(rtwdev, &rtw8822c_dpk_mac_bb_tbl);
25088c2ecf20Sopenharmony_ci}
25098c2ecf20Sopenharmony_ci
25108c2ecf20Sopenharmony_cistatic void rtw8822c_dpk_afe_setting(struct rtw_dev *rtwdev, bool is_do_dpk)
25118c2ecf20Sopenharmony_ci{
25128c2ecf20Sopenharmony_ci	if (is_do_dpk)
25138c2ecf20Sopenharmony_ci		rtw_load_table(rtwdev, &rtw8822c_dpk_afe_is_dpk_tbl);
25148c2ecf20Sopenharmony_ci	else
25158c2ecf20Sopenharmony_ci		rtw_load_table(rtwdev, &rtw8822c_dpk_afe_no_dpk_tbl);
25168c2ecf20Sopenharmony_ci}
25178c2ecf20Sopenharmony_ci
25188c2ecf20Sopenharmony_cistatic void rtw8822c_dpk_pre_setting(struct rtw_dev *rtwdev)
25198c2ecf20Sopenharmony_ci{
25208c2ecf20Sopenharmony_ci	u8 path;
25218c2ecf20Sopenharmony_ci
25228c2ecf20Sopenharmony_ci	for (path = 0; path < rtwdev->hal.rf_path_num; path++) {
25238c2ecf20Sopenharmony_ci		rtw_write_rf(rtwdev, path, RF_RXAGC_OFFSET, RFREG_MASK, 0x0);
25248c2ecf20Sopenharmony_ci		rtw_write32(rtwdev, REG_NCTL0, 0x8 | (path << 1));
25258c2ecf20Sopenharmony_ci		if (rtwdev->dm_info.dpk_info.dpk_band == RTW_BAND_2G)
25268c2ecf20Sopenharmony_ci			rtw_write32(rtwdev, REG_DPD_LUT3, 0x1f100000);
25278c2ecf20Sopenharmony_ci		else
25288c2ecf20Sopenharmony_ci			rtw_write32(rtwdev, REG_DPD_LUT3, 0x1f0d0000);
25298c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_DPD_LUT0, BIT_GLOSS_DB, 0x4);
25308c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_IQK_CTL1, BIT_TX_CFIR, 0x3);
25318c2ecf20Sopenharmony_ci	}
25328c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, REG_NCTL0, BIT_SUBPAGE, 0xc);
25338c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, REG_DPD_CTL11, 0x3b23170b);
25348c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, REG_DPD_CTL12, 0x775f5347);
25358c2ecf20Sopenharmony_ci}
25368c2ecf20Sopenharmony_ci
25378c2ecf20Sopenharmony_cistatic u32 rtw8822c_dpk_rf_setting(struct rtw_dev *rtwdev, u8 path)
25388c2ecf20Sopenharmony_ci{
25398c2ecf20Sopenharmony_ci	u32 ori_txbb;
25408c2ecf20Sopenharmony_ci
25418c2ecf20Sopenharmony_ci	rtw_write_rf(rtwdev, path, RF_MODE_TRXAGC, RFREG_MASK, 0x50017);
25428c2ecf20Sopenharmony_ci	ori_txbb = rtw_read_rf(rtwdev, path, RF_TX_GAIN, RFREG_MASK);
25438c2ecf20Sopenharmony_ci
25448c2ecf20Sopenharmony_ci	rtw_write_rf(rtwdev, path, RF_DEBUG, BIT_DE_TX_GAIN, 0x1);
25458c2ecf20Sopenharmony_ci	rtw_write_rf(rtwdev, path, RF_DEBUG, BIT_DE_PWR_TRIM, 0x1);
25468c2ecf20Sopenharmony_ci	rtw_write_rf(rtwdev, path, RF_TX_GAIN_OFFSET, BIT_TX_OFFSET_VAL, 0x0);
25478c2ecf20Sopenharmony_ci	rtw_write_rf(rtwdev, path, RF_TX_GAIN, RFREG_MASK, ori_txbb);
25488c2ecf20Sopenharmony_ci
25498c2ecf20Sopenharmony_ci	if (rtwdev->dm_info.dpk_info.dpk_band == RTW_BAND_2G) {
25508c2ecf20Sopenharmony_ci		rtw_write_rf(rtwdev, path, RF_TX_GAIN_OFFSET, BIT_LB_ATT, 0x1);
25518c2ecf20Sopenharmony_ci		rtw_write_rf(rtwdev, path, RF_RXG_GAIN, BIT_RXG_GAIN, 0x0);
25528c2ecf20Sopenharmony_ci	} else {
25538c2ecf20Sopenharmony_ci		rtw_write_rf(rtwdev, path, RF_TXA_LB_SW, BIT_TXA_LB_ATT, 0x0);
25548c2ecf20Sopenharmony_ci		rtw_write_rf(rtwdev, path, RF_TXA_LB_SW, BIT_LB_ATT, 0x6);
25558c2ecf20Sopenharmony_ci		rtw_write_rf(rtwdev, path, RF_TXA_LB_SW, BIT_LB_SW, 0x1);
25568c2ecf20Sopenharmony_ci		rtw_write_rf(rtwdev, path, RF_RXA_MIX_GAIN, BIT_RXA_MIX_GAIN, 0);
25578c2ecf20Sopenharmony_ci	}
25588c2ecf20Sopenharmony_ci
25598c2ecf20Sopenharmony_ci	rtw_write_rf(rtwdev, path, RF_MODE_TRXAGC, BIT_RXAGC, 0xf);
25608c2ecf20Sopenharmony_ci	rtw_write_rf(rtwdev, path, RF_DEBUG, BIT_DE_TRXBW, 0x1);
25618c2ecf20Sopenharmony_ci	rtw_write_rf(rtwdev, path, RF_BW_TRXBB, BIT_BW_RXBB, 0x0);
25628c2ecf20Sopenharmony_ci
25638c2ecf20Sopenharmony_ci	if (rtwdev->dm_info.dpk_info.dpk_bw == DPK_CHANNEL_WIDTH_80)
25648c2ecf20Sopenharmony_ci		rtw_write_rf(rtwdev, path, RF_BW_TRXBB, BIT_BW_TXBB, 0x2);
25658c2ecf20Sopenharmony_ci	else
25668c2ecf20Sopenharmony_ci		rtw_write_rf(rtwdev, path, RF_BW_TRXBB, BIT_BW_TXBB, 0x1);
25678c2ecf20Sopenharmony_ci
25688c2ecf20Sopenharmony_ci	rtw_write_rf(rtwdev, path, RF_EXT_TIA_BW, BIT(1), 0x1);
25698c2ecf20Sopenharmony_ci
25708c2ecf20Sopenharmony_ci	usleep_range(100, 110);
25718c2ecf20Sopenharmony_ci
25728c2ecf20Sopenharmony_ci	return ori_txbb & 0x1f;
25738c2ecf20Sopenharmony_ci}
25748c2ecf20Sopenharmony_ci
25758c2ecf20Sopenharmony_cistatic u16 rtw8822c_dpk_get_cmd(struct rtw_dev *rtwdev, u8 action, u8 path)
25768c2ecf20Sopenharmony_ci{
25778c2ecf20Sopenharmony_ci	u16 cmd;
25788c2ecf20Sopenharmony_ci	u8 bw = rtwdev->dm_info.dpk_info.dpk_bw == DPK_CHANNEL_WIDTH_80 ? 2 : 0;
25798c2ecf20Sopenharmony_ci
25808c2ecf20Sopenharmony_ci	switch (action) {
25818c2ecf20Sopenharmony_ci	case RTW_DPK_GAIN_LOSS:
25828c2ecf20Sopenharmony_ci		cmd = 0x14 + path;
25838c2ecf20Sopenharmony_ci		break;
25848c2ecf20Sopenharmony_ci	case RTW_DPK_DO_DPK:
25858c2ecf20Sopenharmony_ci		cmd = 0x16 + path + bw;
25868c2ecf20Sopenharmony_ci		break;
25878c2ecf20Sopenharmony_ci	case RTW_DPK_DPK_ON:
25888c2ecf20Sopenharmony_ci		cmd = 0x1a + path;
25898c2ecf20Sopenharmony_ci		break;
25908c2ecf20Sopenharmony_ci	case RTW_DPK_DAGC:
25918c2ecf20Sopenharmony_ci		cmd = 0x1c + path + bw;
25928c2ecf20Sopenharmony_ci		break;
25938c2ecf20Sopenharmony_ci	default:
25948c2ecf20Sopenharmony_ci		return 0;
25958c2ecf20Sopenharmony_ci	}
25968c2ecf20Sopenharmony_ci
25978c2ecf20Sopenharmony_ci	return (cmd << 8) | 0x48;
25988c2ecf20Sopenharmony_ci}
25998c2ecf20Sopenharmony_ci
26008c2ecf20Sopenharmony_cistatic u8 rtw8822c_dpk_one_shot(struct rtw_dev *rtwdev, u8 path, u8 action)
26018c2ecf20Sopenharmony_ci{
26028c2ecf20Sopenharmony_ci	u16 dpk_cmd;
26038c2ecf20Sopenharmony_ci	u8 result = 0;
26048c2ecf20Sopenharmony_ci
26058c2ecf20Sopenharmony_ci	rtw8822c_dpk_set_gnt_wl(rtwdev, true);
26068c2ecf20Sopenharmony_ci
26078c2ecf20Sopenharmony_ci	if (action == RTW_DPK_CAL_PWR) {
26088c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_DPD_CTL0, BIT(12), 0x1);
26098c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_DPD_CTL0, BIT(12), 0x0);
26108c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_RXSRAM_CTL, BIT_RPT_SEL, 0x0);
26118c2ecf20Sopenharmony_ci		msleep(10);
26128c2ecf20Sopenharmony_ci		if (!check_hw_ready(rtwdev, REG_STAT_RPT, BIT(31), 0x1)) {
26138c2ecf20Sopenharmony_ci			result = 1;
26148c2ecf20Sopenharmony_ci			rtw_dbg(rtwdev, RTW_DBG_RFK, "[DPK] one-shot over 20ms\n");
26158c2ecf20Sopenharmony_ci		}
26168c2ecf20Sopenharmony_ci	} else {
26178c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_NCTL0, BIT_SUBPAGE,
26188c2ecf20Sopenharmony_ci				 0x8 | (path << 1));
26198c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_R_CONFIG, BIT_IQ_SWITCH, 0x9);
26208c2ecf20Sopenharmony_ci
26218c2ecf20Sopenharmony_ci		dpk_cmd = rtw8822c_dpk_get_cmd(rtwdev, action, path);
26228c2ecf20Sopenharmony_ci		rtw_write32(rtwdev, REG_NCTL0, dpk_cmd);
26238c2ecf20Sopenharmony_ci		rtw_write32(rtwdev, REG_NCTL0, dpk_cmd + 1);
26248c2ecf20Sopenharmony_ci		msleep(10);
26258c2ecf20Sopenharmony_ci		if (!check_hw_ready(rtwdev, 0x2d9c, 0xff, 0x55)) {
26268c2ecf20Sopenharmony_ci			result = 1;
26278c2ecf20Sopenharmony_ci			rtw_dbg(rtwdev, RTW_DBG_RFK, "[DPK] one-shot over 20ms\n");
26288c2ecf20Sopenharmony_ci		}
26298c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_NCTL0, BIT_SUBPAGE,
26308c2ecf20Sopenharmony_ci				 0x8 | (path << 1));
26318c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_R_CONFIG, BIT_IQ_SWITCH, 0x0);
26328c2ecf20Sopenharmony_ci	}
26338c2ecf20Sopenharmony_ci
26348c2ecf20Sopenharmony_ci	rtw8822c_dpk_set_gnt_wl(rtwdev, false);
26358c2ecf20Sopenharmony_ci
26368c2ecf20Sopenharmony_ci	rtw_write8(rtwdev, 0x1b10, 0x0);
26378c2ecf20Sopenharmony_ci
26388c2ecf20Sopenharmony_ci	return result;
26398c2ecf20Sopenharmony_ci}
26408c2ecf20Sopenharmony_ci
26418c2ecf20Sopenharmony_cistatic u16 rtw8822c_dpk_dgain_read(struct rtw_dev *rtwdev, u8 path)
26428c2ecf20Sopenharmony_ci{
26438c2ecf20Sopenharmony_ci	u16 dgain;
26448c2ecf20Sopenharmony_ci
26458c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, REG_NCTL0, BIT_SUBPAGE, 0xc);
26468c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, REG_RXSRAM_CTL, 0x00ff0000, 0x0);
26478c2ecf20Sopenharmony_ci
26488c2ecf20Sopenharmony_ci	dgain = (u16)rtw_read32_mask(rtwdev, REG_STAT_RPT, GENMASK(27, 16));
26498c2ecf20Sopenharmony_ci
26508c2ecf20Sopenharmony_ci	return dgain;
26518c2ecf20Sopenharmony_ci}
26528c2ecf20Sopenharmony_ci
26538c2ecf20Sopenharmony_cistatic u8 rtw8822c_dpk_thermal_read(struct rtw_dev *rtwdev, u8 path)
26548c2ecf20Sopenharmony_ci{
26558c2ecf20Sopenharmony_ci	rtw_write_rf(rtwdev, path, RF_T_METER, BIT(19), 0x1);
26568c2ecf20Sopenharmony_ci	rtw_write_rf(rtwdev, path, RF_T_METER, BIT(19), 0x0);
26578c2ecf20Sopenharmony_ci	rtw_write_rf(rtwdev, path, RF_T_METER, BIT(19), 0x1);
26588c2ecf20Sopenharmony_ci	udelay(15);
26598c2ecf20Sopenharmony_ci
26608c2ecf20Sopenharmony_ci	return (u8)rtw_read_rf(rtwdev, path, RF_T_METER, 0x0007e);
26618c2ecf20Sopenharmony_ci}
26628c2ecf20Sopenharmony_ci
26638c2ecf20Sopenharmony_cistatic u32 rtw8822c_dpk_pas_read(struct rtw_dev *rtwdev, u8 path)
26648c2ecf20Sopenharmony_ci{
26658c2ecf20Sopenharmony_ci	u32 i_val, q_val;
26668c2ecf20Sopenharmony_ci
26678c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, REG_NCTL0, 0x8 | (path << 1));
26688c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x1b48, BIT(14), 0x0);
26698c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, REG_RXSRAM_CTL, 0x00060001);
26708c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, 0x1b4c, 0x00000000);
26718c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, 0x1b4c, 0x00080000);
26728c2ecf20Sopenharmony_ci
26738c2ecf20Sopenharmony_ci	q_val = rtw_read32_mask(rtwdev, REG_STAT_RPT, MASKHWORD);
26748c2ecf20Sopenharmony_ci	i_val = rtw_read32_mask(rtwdev, REG_STAT_RPT, MASKLWORD);
26758c2ecf20Sopenharmony_ci
26768c2ecf20Sopenharmony_ci	if (i_val & BIT(15))
26778c2ecf20Sopenharmony_ci		i_val = 0x10000 - i_val;
26788c2ecf20Sopenharmony_ci	if (q_val & BIT(15))
26798c2ecf20Sopenharmony_ci		q_val = 0x10000 - q_val;
26808c2ecf20Sopenharmony_ci
26818c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, 0x1b4c, 0x00000000);
26828c2ecf20Sopenharmony_ci
26838c2ecf20Sopenharmony_ci	return i_val * i_val + q_val * q_val;
26848c2ecf20Sopenharmony_ci}
26858c2ecf20Sopenharmony_ci
26868c2ecf20Sopenharmony_cistatic u32 rtw8822c_psd_log2base(u32 val)
26878c2ecf20Sopenharmony_ci{
26888c2ecf20Sopenharmony_ci	u32 tmp, val_integerd_b, tindex;
26898c2ecf20Sopenharmony_ci	u32 result, val_fractiond_b;
26908c2ecf20Sopenharmony_ci	u32 table_fraction[21] = {0, 432, 332, 274, 232, 200, 174,
26918c2ecf20Sopenharmony_ci				  151, 132, 115, 100, 86, 74, 62, 51,
26928c2ecf20Sopenharmony_ci				  42, 32, 23, 15, 7, 0};
26938c2ecf20Sopenharmony_ci
26948c2ecf20Sopenharmony_ci	if (val == 0)
26958c2ecf20Sopenharmony_ci		return 0;
26968c2ecf20Sopenharmony_ci
26978c2ecf20Sopenharmony_ci	val_integerd_b = __fls(val) + 1;
26988c2ecf20Sopenharmony_ci
26998c2ecf20Sopenharmony_ci	tmp = (val * 100) / (1 << val_integerd_b);
27008c2ecf20Sopenharmony_ci	tindex = tmp / 5;
27018c2ecf20Sopenharmony_ci
27028c2ecf20Sopenharmony_ci	if (tindex >= ARRAY_SIZE(table_fraction))
27038c2ecf20Sopenharmony_ci		tindex = ARRAY_SIZE(table_fraction) - 1;
27048c2ecf20Sopenharmony_ci
27058c2ecf20Sopenharmony_ci	val_fractiond_b = table_fraction[tindex];
27068c2ecf20Sopenharmony_ci
27078c2ecf20Sopenharmony_ci	result = val_integerd_b * 100 - val_fractiond_b;
27088c2ecf20Sopenharmony_ci
27098c2ecf20Sopenharmony_ci	return result;
27108c2ecf20Sopenharmony_ci}
27118c2ecf20Sopenharmony_ci
27128c2ecf20Sopenharmony_cistatic u8 rtw8822c_dpk_gainloss_result(struct rtw_dev *rtwdev, u8 path)
27138c2ecf20Sopenharmony_ci{
27148c2ecf20Sopenharmony_ci	u8 result;
27158c2ecf20Sopenharmony_ci
27168c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, REG_NCTL0, BIT_SUBPAGE, 0x8 | (path << 1));
27178c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x1b48, BIT(14), 0x1);
27188c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, REG_RXSRAM_CTL, 0x00060000);
27198c2ecf20Sopenharmony_ci
27208c2ecf20Sopenharmony_ci	result = (u8)rtw_read32_mask(rtwdev, REG_STAT_RPT, 0x000000f0);
27218c2ecf20Sopenharmony_ci
27228c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, 0x1b48, BIT(14), 0x0);
27238c2ecf20Sopenharmony_ci
27248c2ecf20Sopenharmony_ci	return result;
27258c2ecf20Sopenharmony_ci}
27268c2ecf20Sopenharmony_ci
27278c2ecf20Sopenharmony_cistatic u8 rtw8822c_dpk_agc_gain_chk(struct rtw_dev *rtwdev, u8 path,
27288c2ecf20Sopenharmony_ci				    u8 limited_pga)
27298c2ecf20Sopenharmony_ci{
27308c2ecf20Sopenharmony_ci	u8 result = 0;
27318c2ecf20Sopenharmony_ci	u16 dgain;
27328c2ecf20Sopenharmony_ci
27338c2ecf20Sopenharmony_ci	rtw8822c_dpk_one_shot(rtwdev, path, RTW_DPK_DAGC);
27348c2ecf20Sopenharmony_ci	dgain = rtw8822c_dpk_dgain_read(rtwdev, path);
27358c2ecf20Sopenharmony_ci
27368c2ecf20Sopenharmony_ci	if (dgain > 1535 && !limited_pga)
27378c2ecf20Sopenharmony_ci		return RTW_DPK_GAIN_LESS;
27388c2ecf20Sopenharmony_ci	else if (dgain < 768 && !limited_pga)
27398c2ecf20Sopenharmony_ci		return RTW_DPK_GAIN_LARGE;
27408c2ecf20Sopenharmony_ci	else
27418c2ecf20Sopenharmony_ci		return result;
27428c2ecf20Sopenharmony_ci}
27438c2ecf20Sopenharmony_ci
27448c2ecf20Sopenharmony_cistatic u8 rtw8822c_dpk_agc_loss_chk(struct rtw_dev *rtwdev, u8 path)
27458c2ecf20Sopenharmony_ci{
27468c2ecf20Sopenharmony_ci	u32 loss, loss_db;
27478c2ecf20Sopenharmony_ci
27488c2ecf20Sopenharmony_ci	loss = rtw8822c_dpk_pas_read(rtwdev, path);
27498c2ecf20Sopenharmony_ci	if (loss < 0x4000000)
27508c2ecf20Sopenharmony_ci		return RTW_DPK_GL_LESS;
27518c2ecf20Sopenharmony_ci	loss_db = 3 * rtw8822c_psd_log2base(loss >> 13) - 3870;
27528c2ecf20Sopenharmony_ci
27538c2ecf20Sopenharmony_ci	if (loss_db > 1000)
27548c2ecf20Sopenharmony_ci		return RTW_DPK_GL_LARGE;
27558c2ecf20Sopenharmony_ci	else if (loss_db < 250)
27568c2ecf20Sopenharmony_ci		return RTW_DPK_GL_LESS;
27578c2ecf20Sopenharmony_ci	else
27588c2ecf20Sopenharmony_ci		return RTW_DPK_AGC_OUT;
27598c2ecf20Sopenharmony_ci}
27608c2ecf20Sopenharmony_ci
27618c2ecf20Sopenharmony_cistruct rtw8822c_dpk_data {
27628c2ecf20Sopenharmony_ci	u8 txbb;
27638c2ecf20Sopenharmony_ci	u8 pga;
27648c2ecf20Sopenharmony_ci	u8 limited_pga;
27658c2ecf20Sopenharmony_ci	u8 agc_cnt;
27668c2ecf20Sopenharmony_ci	bool loss_only;
27678c2ecf20Sopenharmony_ci	bool gain_only;
27688c2ecf20Sopenharmony_ci	u8 path;
27698c2ecf20Sopenharmony_ci};
27708c2ecf20Sopenharmony_ci
27718c2ecf20Sopenharmony_cistatic u8 rtw8822c_gain_check_state(struct rtw_dev *rtwdev,
27728c2ecf20Sopenharmony_ci				    struct rtw8822c_dpk_data *data)
27738c2ecf20Sopenharmony_ci{
27748c2ecf20Sopenharmony_ci	u8 state;
27758c2ecf20Sopenharmony_ci
27768c2ecf20Sopenharmony_ci	data->txbb = (u8)rtw_read_rf(rtwdev, data->path, RF_TX_GAIN,
27778c2ecf20Sopenharmony_ci				     BIT_GAIN_TXBB);
27788c2ecf20Sopenharmony_ci	data->pga = (u8)rtw_read_rf(rtwdev, data->path, RF_MODE_TRXAGC,
27798c2ecf20Sopenharmony_ci				    BIT_RXAGC);
27808c2ecf20Sopenharmony_ci
27818c2ecf20Sopenharmony_ci	if (data->loss_only) {
27828c2ecf20Sopenharmony_ci		state = RTW_DPK_LOSS_CHECK;
27838c2ecf20Sopenharmony_ci		goto check_end;
27848c2ecf20Sopenharmony_ci	}
27858c2ecf20Sopenharmony_ci
27868c2ecf20Sopenharmony_ci	state = rtw8822c_dpk_agc_gain_chk(rtwdev, data->path,
27878c2ecf20Sopenharmony_ci					  data->limited_pga);
27888c2ecf20Sopenharmony_ci	if (state == RTW_DPK_GAIN_CHECK && data->gain_only)
27898c2ecf20Sopenharmony_ci		state = RTW_DPK_AGC_OUT;
27908c2ecf20Sopenharmony_ci	else if (state == RTW_DPK_GAIN_CHECK)
27918c2ecf20Sopenharmony_ci		state = RTW_DPK_LOSS_CHECK;
27928c2ecf20Sopenharmony_ci
27938c2ecf20Sopenharmony_cicheck_end:
27948c2ecf20Sopenharmony_ci	data->agc_cnt++;
27958c2ecf20Sopenharmony_ci	if (data->agc_cnt >= 6)
27968c2ecf20Sopenharmony_ci		state = RTW_DPK_AGC_OUT;
27978c2ecf20Sopenharmony_ci
27988c2ecf20Sopenharmony_ci	return state;
27998c2ecf20Sopenharmony_ci}
28008c2ecf20Sopenharmony_ci
28018c2ecf20Sopenharmony_cistatic u8 rtw8822c_gain_large_state(struct rtw_dev *rtwdev,
28028c2ecf20Sopenharmony_ci				    struct rtw8822c_dpk_data *data)
28038c2ecf20Sopenharmony_ci{
28048c2ecf20Sopenharmony_ci	u8 pga = data->pga;
28058c2ecf20Sopenharmony_ci
28068c2ecf20Sopenharmony_ci	if (pga > 0xe)
28078c2ecf20Sopenharmony_ci		rtw_write_rf(rtwdev, data->path, RF_MODE_TRXAGC, BIT_RXAGC, 0xc);
28088c2ecf20Sopenharmony_ci	else if (pga > 0xb && pga < 0xf)
28098c2ecf20Sopenharmony_ci		rtw_write_rf(rtwdev, data->path, RF_MODE_TRXAGC, BIT_RXAGC, 0x0);
28108c2ecf20Sopenharmony_ci	else if (pga < 0xc)
28118c2ecf20Sopenharmony_ci		data->limited_pga = 1;
28128c2ecf20Sopenharmony_ci
28138c2ecf20Sopenharmony_ci	return RTW_DPK_GAIN_CHECK;
28148c2ecf20Sopenharmony_ci}
28158c2ecf20Sopenharmony_ci
28168c2ecf20Sopenharmony_cistatic u8 rtw8822c_gain_less_state(struct rtw_dev *rtwdev,
28178c2ecf20Sopenharmony_ci				   struct rtw8822c_dpk_data *data)
28188c2ecf20Sopenharmony_ci{
28198c2ecf20Sopenharmony_ci	u8 pga = data->pga;
28208c2ecf20Sopenharmony_ci
28218c2ecf20Sopenharmony_ci	if (pga < 0xc)
28228c2ecf20Sopenharmony_ci		rtw_write_rf(rtwdev, data->path, RF_MODE_TRXAGC, BIT_RXAGC, 0xc);
28238c2ecf20Sopenharmony_ci	else if (pga > 0xb && pga < 0xf)
28248c2ecf20Sopenharmony_ci		rtw_write_rf(rtwdev, data->path, RF_MODE_TRXAGC, BIT_RXAGC, 0xf);
28258c2ecf20Sopenharmony_ci	else if (pga > 0xe)
28268c2ecf20Sopenharmony_ci		data->limited_pga = 1;
28278c2ecf20Sopenharmony_ci
28288c2ecf20Sopenharmony_ci	return RTW_DPK_GAIN_CHECK;
28298c2ecf20Sopenharmony_ci}
28308c2ecf20Sopenharmony_ci
28318c2ecf20Sopenharmony_cistatic u8 rtw8822c_gl_state(struct rtw_dev *rtwdev,
28328c2ecf20Sopenharmony_ci			    struct rtw8822c_dpk_data *data, u8 is_large)
28338c2ecf20Sopenharmony_ci{
28348c2ecf20Sopenharmony_ci	u8 txbb_bound[] = {0x1f, 0};
28358c2ecf20Sopenharmony_ci
28368c2ecf20Sopenharmony_ci	if (data->txbb == txbb_bound[is_large])
28378c2ecf20Sopenharmony_ci		return RTW_DPK_AGC_OUT;
28388c2ecf20Sopenharmony_ci
28398c2ecf20Sopenharmony_ci	if (is_large == 1)
28408c2ecf20Sopenharmony_ci		data->txbb -= 2;
28418c2ecf20Sopenharmony_ci	else
28428c2ecf20Sopenharmony_ci		data->txbb += 3;
28438c2ecf20Sopenharmony_ci
28448c2ecf20Sopenharmony_ci	rtw_write_rf(rtwdev, data->path, RF_TX_GAIN, BIT_GAIN_TXBB, data->txbb);
28458c2ecf20Sopenharmony_ci	data->limited_pga = 0;
28468c2ecf20Sopenharmony_ci
28478c2ecf20Sopenharmony_ci	return RTW_DPK_GAIN_CHECK;
28488c2ecf20Sopenharmony_ci}
28498c2ecf20Sopenharmony_ci
28508c2ecf20Sopenharmony_cistatic u8 rtw8822c_gl_large_state(struct rtw_dev *rtwdev,
28518c2ecf20Sopenharmony_ci				  struct rtw8822c_dpk_data *data)
28528c2ecf20Sopenharmony_ci{
28538c2ecf20Sopenharmony_ci	return rtw8822c_gl_state(rtwdev, data, 1);
28548c2ecf20Sopenharmony_ci}
28558c2ecf20Sopenharmony_ci
28568c2ecf20Sopenharmony_cistatic u8 rtw8822c_gl_less_state(struct rtw_dev *rtwdev,
28578c2ecf20Sopenharmony_ci				 struct rtw8822c_dpk_data *data)
28588c2ecf20Sopenharmony_ci{
28598c2ecf20Sopenharmony_ci	return rtw8822c_gl_state(rtwdev, data, 0);
28608c2ecf20Sopenharmony_ci}
28618c2ecf20Sopenharmony_ci
28628c2ecf20Sopenharmony_cistatic u8 rtw8822c_loss_check_state(struct rtw_dev *rtwdev,
28638c2ecf20Sopenharmony_ci				    struct rtw8822c_dpk_data *data)
28648c2ecf20Sopenharmony_ci{
28658c2ecf20Sopenharmony_ci	u8 path = data->path;
28668c2ecf20Sopenharmony_ci	u8 state;
28678c2ecf20Sopenharmony_ci
28688c2ecf20Sopenharmony_ci	rtw8822c_dpk_one_shot(rtwdev, path, RTW_DPK_GAIN_LOSS);
28698c2ecf20Sopenharmony_ci	state = rtw8822c_dpk_agc_loss_chk(rtwdev, path);
28708c2ecf20Sopenharmony_ci
28718c2ecf20Sopenharmony_ci	return state;
28728c2ecf20Sopenharmony_ci}
28738c2ecf20Sopenharmony_ci
28748c2ecf20Sopenharmony_cistatic u8 (*dpk_state[])(struct rtw_dev *rtwdev,
28758c2ecf20Sopenharmony_ci			  struct rtw8822c_dpk_data *data) = {
28768c2ecf20Sopenharmony_ci	rtw8822c_gain_check_state, rtw8822c_gain_large_state,
28778c2ecf20Sopenharmony_ci	rtw8822c_gain_less_state, rtw8822c_gl_large_state,
28788c2ecf20Sopenharmony_ci	rtw8822c_gl_less_state, rtw8822c_loss_check_state };
28798c2ecf20Sopenharmony_ci
28808c2ecf20Sopenharmony_cistatic u8 rtw8822c_dpk_pas_agc(struct rtw_dev *rtwdev, u8 path,
28818c2ecf20Sopenharmony_ci			       bool gain_only, bool loss_only)
28828c2ecf20Sopenharmony_ci{
28838c2ecf20Sopenharmony_ci	struct rtw8822c_dpk_data data = {0};
28848c2ecf20Sopenharmony_ci	u8 (*func)(struct rtw_dev *rtwdev, struct rtw8822c_dpk_data *data);
28858c2ecf20Sopenharmony_ci	u8 state = RTW_DPK_GAIN_CHECK;
28868c2ecf20Sopenharmony_ci
28878c2ecf20Sopenharmony_ci	data.loss_only = loss_only;
28888c2ecf20Sopenharmony_ci	data.gain_only = gain_only;
28898c2ecf20Sopenharmony_ci	data.path = path;
28908c2ecf20Sopenharmony_ci
28918c2ecf20Sopenharmony_ci	for (;;) {
28928c2ecf20Sopenharmony_ci		func = dpk_state[state];
28938c2ecf20Sopenharmony_ci		state = func(rtwdev, &data);
28948c2ecf20Sopenharmony_ci		if (state == RTW_DPK_AGC_OUT)
28958c2ecf20Sopenharmony_ci			break;
28968c2ecf20Sopenharmony_ci	}
28978c2ecf20Sopenharmony_ci
28988c2ecf20Sopenharmony_ci	return data.txbb;
28998c2ecf20Sopenharmony_ci}
29008c2ecf20Sopenharmony_ci
29018c2ecf20Sopenharmony_cistatic bool rtw8822c_dpk_coef_iq_check(struct rtw_dev *rtwdev,
29028c2ecf20Sopenharmony_ci				       u16 coef_i, u16 coef_q)
29038c2ecf20Sopenharmony_ci{
29048c2ecf20Sopenharmony_ci	if (coef_i == 0x1000 || coef_i == 0x0fff ||
29058c2ecf20Sopenharmony_ci	    coef_q == 0x1000 || coef_q == 0x0fff)
29068c2ecf20Sopenharmony_ci		return true;
29078c2ecf20Sopenharmony_ci
29088c2ecf20Sopenharmony_ci	return false;
29098c2ecf20Sopenharmony_ci}
29108c2ecf20Sopenharmony_ci
29118c2ecf20Sopenharmony_cistatic u32 rtw8822c_dpk_coef_transfer(struct rtw_dev *rtwdev)
29128c2ecf20Sopenharmony_ci{
29138c2ecf20Sopenharmony_ci	u32 reg = 0;
29148c2ecf20Sopenharmony_ci	u16 coef_i = 0, coef_q = 0;
29158c2ecf20Sopenharmony_ci
29168c2ecf20Sopenharmony_ci	reg = rtw_read32(rtwdev, REG_STAT_RPT);
29178c2ecf20Sopenharmony_ci
29188c2ecf20Sopenharmony_ci	coef_i = (u16)rtw_read32_mask(rtwdev, REG_STAT_RPT, MASKHWORD) & 0x1fff;
29198c2ecf20Sopenharmony_ci	coef_q = (u16)rtw_read32_mask(rtwdev, REG_STAT_RPT, MASKLWORD) & 0x1fff;
29208c2ecf20Sopenharmony_ci
29218c2ecf20Sopenharmony_ci	coef_q = ((0x2000 - coef_q) & 0x1fff) - 1;
29228c2ecf20Sopenharmony_ci
29238c2ecf20Sopenharmony_ci	reg = (coef_i << 16) | coef_q;
29248c2ecf20Sopenharmony_ci
29258c2ecf20Sopenharmony_ci	return reg;
29268c2ecf20Sopenharmony_ci}
29278c2ecf20Sopenharmony_ci
29288c2ecf20Sopenharmony_cistatic const u32 rtw8822c_dpk_get_coef_tbl[] = {
29298c2ecf20Sopenharmony_ci	0x000400f0, 0x040400f0, 0x080400f0, 0x010400f0, 0x050400f0,
29308c2ecf20Sopenharmony_ci	0x090400f0, 0x020400f0, 0x060400f0, 0x0a0400f0, 0x030400f0,
29318c2ecf20Sopenharmony_ci	0x070400f0, 0x0b0400f0, 0x0c0400f0, 0x100400f0, 0x0d0400f0,
29328c2ecf20Sopenharmony_ci	0x110400f0, 0x0e0400f0, 0x120400f0, 0x0f0400f0, 0x130400f0,
29338c2ecf20Sopenharmony_ci};
29348c2ecf20Sopenharmony_ci
29358c2ecf20Sopenharmony_cistatic void rtw8822c_dpk_coef_tbl_apply(struct rtw_dev *rtwdev, u8 path)
29368c2ecf20Sopenharmony_ci{
29378c2ecf20Sopenharmony_ci	struct rtw_dpk_info *dpk_info = &rtwdev->dm_info.dpk_info;
29388c2ecf20Sopenharmony_ci	int i;
29398c2ecf20Sopenharmony_ci
29408c2ecf20Sopenharmony_ci	for (i = 0; i < 20; i++) {
29418c2ecf20Sopenharmony_ci		rtw_write32(rtwdev, REG_RXSRAM_CTL,
29428c2ecf20Sopenharmony_ci			    rtw8822c_dpk_get_coef_tbl[i]);
29438c2ecf20Sopenharmony_ci		dpk_info->coef[path][i] = rtw8822c_dpk_coef_transfer(rtwdev);
29448c2ecf20Sopenharmony_ci	}
29458c2ecf20Sopenharmony_ci}
29468c2ecf20Sopenharmony_ci
29478c2ecf20Sopenharmony_cistatic void rtw8822c_dpk_get_coef(struct rtw_dev *rtwdev, u8 path)
29488c2ecf20Sopenharmony_ci{
29498c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, REG_NCTL0, 0x0000000c);
29508c2ecf20Sopenharmony_ci
29518c2ecf20Sopenharmony_ci	if (path == RF_PATH_A) {
29528c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_DPD_CTL0, BIT(24), 0x0);
29538c2ecf20Sopenharmony_ci		rtw_write32(rtwdev, REG_DPD_CTL0_S0, 0x30000080);
29548c2ecf20Sopenharmony_ci	} else if (path == RF_PATH_B) {
29558c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_DPD_CTL0, BIT(24), 0x1);
29568c2ecf20Sopenharmony_ci		rtw_write32(rtwdev, REG_DPD_CTL0_S1, 0x30000080);
29578c2ecf20Sopenharmony_ci	}
29588c2ecf20Sopenharmony_ci
29598c2ecf20Sopenharmony_ci	rtw8822c_dpk_coef_tbl_apply(rtwdev, path);
29608c2ecf20Sopenharmony_ci}
29618c2ecf20Sopenharmony_ci
29628c2ecf20Sopenharmony_cistatic u8 rtw8822c_dpk_coef_read(struct rtw_dev *rtwdev, u8 path)
29638c2ecf20Sopenharmony_ci{
29648c2ecf20Sopenharmony_ci	struct rtw_dpk_info *dpk_info = &rtwdev->dm_info.dpk_info;
29658c2ecf20Sopenharmony_ci	u8 addr, result = 1;
29668c2ecf20Sopenharmony_ci	u16 coef_i, coef_q;
29678c2ecf20Sopenharmony_ci
29688c2ecf20Sopenharmony_ci	for (addr = 0; addr < 20; addr++) {
29698c2ecf20Sopenharmony_ci		coef_i = FIELD_GET(0x1fff0000, dpk_info->coef[path][addr]);
29708c2ecf20Sopenharmony_ci		coef_q = FIELD_GET(0x1fff, dpk_info->coef[path][addr]);
29718c2ecf20Sopenharmony_ci
29728c2ecf20Sopenharmony_ci		if (rtw8822c_dpk_coef_iq_check(rtwdev, coef_i, coef_q)) {
29738c2ecf20Sopenharmony_ci			result = 0;
29748c2ecf20Sopenharmony_ci			break;
29758c2ecf20Sopenharmony_ci		}
29768c2ecf20Sopenharmony_ci	}
29778c2ecf20Sopenharmony_ci	return result;
29788c2ecf20Sopenharmony_ci}
29798c2ecf20Sopenharmony_ci
29808c2ecf20Sopenharmony_cistatic void rtw8822c_dpk_coef_write(struct rtw_dev *rtwdev, u8 path, u8 result)
29818c2ecf20Sopenharmony_ci{
29828c2ecf20Sopenharmony_ci	struct rtw_dpk_info *dpk_info = &rtwdev->dm_info.dpk_info;
29838c2ecf20Sopenharmony_ci	u16 reg[DPK_RF_PATH_NUM] = {0x1b0c, 0x1b64};
29848c2ecf20Sopenharmony_ci	u32 coef;
29858c2ecf20Sopenharmony_ci	u8 addr;
29868c2ecf20Sopenharmony_ci
29878c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, REG_NCTL0, 0x0000000c);
29888c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, REG_RXSRAM_CTL, 0x000000f0);
29898c2ecf20Sopenharmony_ci
29908c2ecf20Sopenharmony_ci	for (addr = 0; addr < 20; addr++) {
29918c2ecf20Sopenharmony_ci		if (result == 0) {
29928c2ecf20Sopenharmony_ci			if (addr == 3)
29938c2ecf20Sopenharmony_ci				coef = 0x04001fff;
29948c2ecf20Sopenharmony_ci			else
29958c2ecf20Sopenharmony_ci				coef = 0x00001fff;
29968c2ecf20Sopenharmony_ci		} else {
29978c2ecf20Sopenharmony_ci			coef = dpk_info->coef[path][addr];
29988c2ecf20Sopenharmony_ci		}
29998c2ecf20Sopenharmony_ci		rtw_write32(rtwdev, reg[path] + addr * 4, coef);
30008c2ecf20Sopenharmony_ci	}
30018c2ecf20Sopenharmony_ci}
30028c2ecf20Sopenharmony_ci
30038c2ecf20Sopenharmony_cistatic void rtw8822c_dpk_fill_result(struct rtw_dev *rtwdev, u32 dpk_txagc,
30048c2ecf20Sopenharmony_ci				     u8 path, u8 result)
30058c2ecf20Sopenharmony_ci{
30068c2ecf20Sopenharmony_ci	struct rtw_dpk_info *dpk_info = &rtwdev->dm_info.dpk_info;
30078c2ecf20Sopenharmony_ci
30088c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, REG_NCTL0, BIT_SUBPAGE, 0x8 | (path << 1));
30098c2ecf20Sopenharmony_ci
30108c2ecf20Sopenharmony_ci	if (result)
30118c2ecf20Sopenharmony_ci		rtw_write8(rtwdev, REG_DPD_AGC, (u8)(dpk_txagc - 6));
30128c2ecf20Sopenharmony_ci	else
30138c2ecf20Sopenharmony_ci		rtw_write8(rtwdev, REG_DPD_AGC, 0x00);
30148c2ecf20Sopenharmony_ci
30158c2ecf20Sopenharmony_ci	dpk_info->result[path] = result;
30168c2ecf20Sopenharmony_ci	dpk_info->dpk_txagc[path] = rtw_read8(rtwdev, REG_DPD_AGC);
30178c2ecf20Sopenharmony_ci
30188c2ecf20Sopenharmony_ci	rtw8822c_dpk_coef_write(rtwdev, path, result);
30198c2ecf20Sopenharmony_ci}
30208c2ecf20Sopenharmony_ci
30218c2ecf20Sopenharmony_cistatic u32 rtw8822c_dpk_gainloss(struct rtw_dev *rtwdev, u8 path)
30228c2ecf20Sopenharmony_ci{
30238c2ecf20Sopenharmony_ci	struct rtw_dpk_info *dpk_info = &rtwdev->dm_info.dpk_info;
30248c2ecf20Sopenharmony_ci	u8 tx_agc, tx_bb, ori_txbb, ori_txagc, tx_agc_search, t1, t2;
30258c2ecf20Sopenharmony_ci
30268c2ecf20Sopenharmony_ci	ori_txbb = rtw8822c_dpk_rf_setting(rtwdev, path);
30278c2ecf20Sopenharmony_ci	ori_txagc = (u8)rtw_read_rf(rtwdev, path, RF_MODE_TRXAGC, BIT_TXAGC);
30288c2ecf20Sopenharmony_ci
30298c2ecf20Sopenharmony_ci	rtw8822c_dpk_rxbb_dc_cal(rtwdev, path);
30308c2ecf20Sopenharmony_ci	rtw8822c_dpk_one_shot(rtwdev, path, RTW_DPK_DAGC);
30318c2ecf20Sopenharmony_ci	rtw8822c_dpk_dgain_read(rtwdev, path);
30328c2ecf20Sopenharmony_ci
30338c2ecf20Sopenharmony_ci	if (rtw8822c_dpk_dc_corr_check(rtwdev, path)) {
30348c2ecf20Sopenharmony_ci		rtw8822c_dpk_rxbb_dc_cal(rtwdev, path);
30358c2ecf20Sopenharmony_ci		rtw8822c_dpk_one_shot(rtwdev, path, RTW_DPK_DAGC);
30368c2ecf20Sopenharmony_ci		rtw8822c_dpk_dc_corr_check(rtwdev, path);
30378c2ecf20Sopenharmony_ci	}
30388c2ecf20Sopenharmony_ci
30398c2ecf20Sopenharmony_ci	t1 = rtw8822c_dpk_thermal_read(rtwdev, path);
30408c2ecf20Sopenharmony_ci	tx_bb = rtw8822c_dpk_pas_agc(rtwdev, path, false, true);
30418c2ecf20Sopenharmony_ci	tx_agc_search = rtw8822c_dpk_gainloss_result(rtwdev, path);
30428c2ecf20Sopenharmony_ci
30438c2ecf20Sopenharmony_ci	if (tx_bb < tx_agc_search)
30448c2ecf20Sopenharmony_ci		tx_bb = 0;
30458c2ecf20Sopenharmony_ci	else
30468c2ecf20Sopenharmony_ci		tx_bb = tx_bb - tx_agc_search;
30478c2ecf20Sopenharmony_ci
30488c2ecf20Sopenharmony_ci	rtw_write_rf(rtwdev, path, RF_TX_GAIN, BIT_GAIN_TXBB, tx_bb);
30498c2ecf20Sopenharmony_ci
30508c2ecf20Sopenharmony_ci	tx_agc = ori_txagc - (ori_txbb - tx_bb);
30518c2ecf20Sopenharmony_ci
30528c2ecf20Sopenharmony_ci	t2 = rtw8822c_dpk_thermal_read(rtwdev, path);
30538c2ecf20Sopenharmony_ci
30548c2ecf20Sopenharmony_ci	dpk_info->thermal_dpk_delta[path] = abs(t2 - t1);
30558c2ecf20Sopenharmony_ci
30568c2ecf20Sopenharmony_ci	return tx_agc;
30578c2ecf20Sopenharmony_ci}
30588c2ecf20Sopenharmony_ci
30598c2ecf20Sopenharmony_cistatic u8 rtw8822c_dpk_by_path(struct rtw_dev *rtwdev, u32 tx_agc, u8 path)
30608c2ecf20Sopenharmony_ci{
30618c2ecf20Sopenharmony_ci	u8 result;
30628c2ecf20Sopenharmony_ci
30638c2ecf20Sopenharmony_ci	result = rtw8822c_dpk_one_shot(rtwdev, path, RTW_DPK_DO_DPK);
30648c2ecf20Sopenharmony_ci
30658c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, REG_NCTL0, BIT_SUBPAGE, 0x8 | (path << 1));
30668c2ecf20Sopenharmony_ci
30678c2ecf20Sopenharmony_ci	result = result | (u8)rtw_read32_mask(rtwdev, REG_DPD_CTL1_S0, BIT(26));
30688c2ecf20Sopenharmony_ci
30698c2ecf20Sopenharmony_ci	rtw_write_rf(rtwdev, path, RF_MODE_TRXAGC, RFREG_MASK, 0x33e14);
30708c2ecf20Sopenharmony_ci
30718c2ecf20Sopenharmony_ci	rtw8822c_dpk_get_coef(rtwdev, path);
30728c2ecf20Sopenharmony_ci
30738c2ecf20Sopenharmony_ci	return result;
30748c2ecf20Sopenharmony_ci}
30758c2ecf20Sopenharmony_ci
30768c2ecf20Sopenharmony_cistatic void rtw8822c_dpk_cal_gs(struct rtw_dev *rtwdev, u8 path)
30778c2ecf20Sopenharmony_ci{
30788c2ecf20Sopenharmony_ci	struct rtw_dpk_info *dpk_info = &rtwdev->dm_info.dpk_info;
30798c2ecf20Sopenharmony_ci	u32 tmp_gs = 0;
30808c2ecf20Sopenharmony_ci
30818c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, REG_NCTL0, BIT_SUBPAGE, 0x8 | (path << 1));
30828c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, REG_IQK_CTL1, BIT_BYPASS_DPD, 0x0);
30838c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, REG_IQK_CTL1, BIT_TX_CFIR, 0x0);
30848c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, REG_R_CONFIG, BIT_IQ_SWITCH, 0x9);
30858c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, REG_R_CONFIG, BIT_INNER_LB, 0x1);
30868c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, REG_NCTL0, BIT_SUBPAGE, 0xc);
30878c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, REG_RXSRAM_CTL, BIT_DPD_CLK, 0xf);
30888c2ecf20Sopenharmony_ci
30898c2ecf20Sopenharmony_ci	if (path == RF_PATH_A) {
30908c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_DPD_CTL0_S0, BIT_GS_PWSF,
30918c2ecf20Sopenharmony_ci				 0x1066680);
30928c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_DPD_CTL1_S0, BIT_DPD_EN, 0x1);
30938c2ecf20Sopenharmony_ci	} else {
30948c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_DPD_CTL0_S1, BIT_GS_PWSF,
30958c2ecf20Sopenharmony_ci				 0x1066680);
30968c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_DPD_CTL1_S1, BIT_DPD_EN, 0x1);
30978c2ecf20Sopenharmony_ci	}
30988c2ecf20Sopenharmony_ci
30998c2ecf20Sopenharmony_ci	if (dpk_info->dpk_bw == DPK_CHANNEL_WIDTH_80) {
31008c2ecf20Sopenharmony_ci		rtw_write32(rtwdev, REG_DPD_CTL16, 0x80001310);
31018c2ecf20Sopenharmony_ci		rtw_write32(rtwdev, REG_DPD_CTL16, 0x00001310);
31028c2ecf20Sopenharmony_ci		rtw_write32(rtwdev, REG_DPD_CTL16, 0x810000db);
31038c2ecf20Sopenharmony_ci		rtw_write32(rtwdev, REG_DPD_CTL16, 0x010000db);
31048c2ecf20Sopenharmony_ci		rtw_write32(rtwdev, REG_DPD_CTL16, 0x0000b428);
31058c2ecf20Sopenharmony_ci		rtw_write32(rtwdev, REG_DPD_CTL15,
31068c2ecf20Sopenharmony_ci			    0x05020000 | (BIT(path) << 28));
31078c2ecf20Sopenharmony_ci	} else {
31088c2ecf20Sopenharmony_ci		rtw_write32(rtwdev, REG_DPD_CTL16, 0x8200190c);
31098c2ecf20Sopenharmony_ci		rtw_write32(rtwdev, REG_DPD_CTL16, 0x0200190c);
31108c2ecf20Sopenharmony_ci		rtw_write32(rtwdev, REG_DPD_CTL16, 0x8301ee14);
31118c2ecf20Sopenharmony_ci		rtw_write32(rtwdev, REG_DPD_CTL16, 0x0301ee14);
31128c2ecf20Sopenharmony_ci		rtw_write32(rtwdev, REG_DPD_CTL16, 0x0000b428);
31138c2ecf20Sopenharmony_ci		rtw_write32(rtwdev, REG_DPD_CTL15,
31148c2ecf20Sopenharmony_ci			    0x05020008 | (BIT(path) << 28));
31158c2ecf20Sopenharmony_ci	}
31168c2ecf20Sopenharmony_ci
31178c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, REG_DPD_CTL0, MASKBYTE3, 0x8 | path);
31188c2ecf20Sopenharmony_ci
31198c2ecf20Sopenharmony_ci	rtw8822c_dpk_one_shot(rtwdev, path, RTW_DPK_CAL_PWR);
31208c2ecf20Sopenharmony_ci
31218c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, REG_DPD_CTL15, MASKBYTE3, 0x0);
31228c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, REG_NCTL0, BIT_SUBPAGE, 0x8 | (path << 1));
31238c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, REG_R_CONFIG, BIT_IQ_SWITCH, 0x0);
31248c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, REG_R_CONFIG, BIT_INNER_LB, 0x0);
31258c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, REG_NCTL0, BIT_SUBPAGE, 0xc);
31268c2ecf20Sopenharmony_ci
31278c2ecf20Sopenharmony_ci	if (path == RF_PATH_A)
31288c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_DPD_CTL0_S0, BIT_GS_PWSF, 0x5b);
31298c2ecf20Sopenharmony_ci	else
31308c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_DPD_CTL0_S1, BIT_GS_PWSF, 0x5b);
31318c2ecf20Sopenharmony_ci
31328c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, REG_RXSRAM_CTL, BIT_RPT_SEL, 0x0);
31338c2ecf20Sopenharmony_ci
31348c2ecf20Sopenharmony_ci	tmp_gs = (u16)rtw_read32_mask(rtwdev, REG_STAT_RPT, BIT_RPT_DGAIN);
31358c2ecf20Sopenharmony_ci	tmp_gs = (tmp_gs * 910) >> 10;
31368c2ecf20Sopenharmony_ci	tmp_gs = DIV_ROUND_CLOSEST(tmp_gs, 10);
31378c2ecf20Sopenharmony_ci
31388c2ecf20Sopenharmony_ci	if (path == RF_PATH_A)
31398c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_DPD_CTL0_S0, BIT_GS_PWSF, tmp_gs);
31408c2ecf20Sopenharmony_ci	else
31418c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_DPD_CTL0_S1, BIT_GS_PWSF, tmp_gs);
31428c2ecf20Sopenharmony_ci
31438c2ecf20Sopenharmony_ci	dpk_info->dpk_gs[path] = tmp_gs;
31448c2ecf20Sopenharmony_ci}
31458c2ecf20Sopenharmony_ci
31468c2ecf20Sopenharmony_cistatic void rtw8822c_dpk_cal_coef1(struct rtw_dev *rtwdev)
31478c2ecf20Sopenharmony_ci{
31488c2ecf20Sopenharmony_ci	struct rtw_dpk_info *dpk_info = &rtwdev->dm_info.dpk_info;
31498c2ecf20Sopenharmony_ci	u32 offset[DPK_RF_PATH_NUM] = {0, 0x58};
31508c2ecf20Sopenharmony_ci	u32 i_scaling;
31518c2ecf20Sopenharmony_ci	u8 path;
31528c2ecf20Sopenharmony_ci
31538c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, REG_NCTL0, BIT_SUBPAGE, 0x0000000c);
31548c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, REG_RXSRAM_CTL, 0x000000f0);
31558c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, REG_NCTL0, 0x00001148);
31568c2ecf20Sopenharmony_ci	rtw_write32(rtwdev, REG_NCTL0, 0x00001149);
31578c2ecf20Sopenharmony_ci
31588c2ecf20Sopenharmony_ci	check_hw_ready(rtwdev, 0x2d9c, MASKBYTE0, 0x55);
31598c2ecf20Sopenharmony_ci
31608c2ecf20Sopenharmony_ci	rtw_write8(rtwdev, 0x1b10, 0x0);
31618c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, REG_NCTL0, BIT_SUBPAGE, 0x0000000c);
31628c2ecf20Sopenharmony_ci
31638c2ecf20Sopenharmony_ci	for (path = 0; path < rtwdev->hal.rf_path_num; path++) {
31648c2ecf20Sopenharmony_ci		i_scaling = 0x16c00 / dpk_info->dpk_gs[path];
31658c2ecf20Sopenharmony_ci
31668c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, 0x1b18 + offset[path], MASKHWORD,
31678c2ecf20Sopenharmony_ci				 i_scaling);
31688c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_DPD_CTL0_S0 + offset[path],
31698c2ecf20Sopenharmony_ci				 GENMASK(31, 28), 0x9);
31708c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_DPD_CTL0_S0 + offset[path],
31718c2ecf20Sopenharmony_ci				 GENMASK(31, 28), 0x1);
31728c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_DPD_CTL0_S0 + offset[path],
31738c2ecf20Sopenharmony_ci				 GENMASK(31, 28), 0x0);
31748c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_DPD_CTL1_S0 + offset[path],
31758c2ecf20Sopenharmony_ci				 BIT(14), 0x0);
31768c2ecf20Sopenharmony_ci	}
31778c2ecf20Sopenharmony_ci}
31788c2ecf20Sopenharmony_ci
31798c2ecf20Sopenharmony_cistatic void rtw8822c_dpk_on(struct rtw_dev *rtwdev, u8 path)
31808c2ecf20Sopenharmony_ci{
31818c2ecf20Sopenharmony_ci	struct rtw_dpk_info *dpk_info = &rtwdev->dm_info.dpk_info;
31828c2ecf20Sopenharmony_ci
31838c2ecf20Sopenharmony_ci	rtw8822c_dpk_one_shot(rtwdev, path, RTW_DPK_DPK_ON);
31848c2ecf20Sopenharmony_ci
31858c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, REG_NCTL0, BIT_SUBPAGE, 0x8 | (path << 1));
31868c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, REG_IQK_CTL1, BIT_TX_CFIR, 0x0);
31878c2ecf20Sopenharmony_ci
31888c2ecf20Sopenharmony_ci	if (test_bit(path, dpk_info->dpk_path_ok))
31898c2ecf20Sopenharmony_ci		rtw8822c_dpk_cal_gs(rtwdev, path);
31908c2ecf20Sopenharmony_ci}
31918c2ecf20Sopenharmony_ci
31928c2ecf20Sopenharmony_cistatic bool rtw8822c_dpk_check_pass(struct rtw_dev *rtwdev, bool is_fail,
31938c2ecf20Sopenharmony_ci				    u32 dpk_txagc, u8 path)
31948c2ecf20Sopenharmony_ci{
31958c2ecf20Sopenharmony_ci	bool result;
31968c2ecf20Sopenharmony_ci
31978c2ecf20Sopenharmony_ci	if (!is_fail) {
31988c2ecf20Sopenharmony_ci		if (rtw8822c_dpk_coef_read(rtwdev, path))
31998c2ecf20Sopenharmony_ci			result = true;
32008c2ecf20Sopenharmony_ci		else
32018c2ecf20Sopenharmony_ci			result = false;
32028c2ecf20Sopenharmony_ci	} else {
32038c2ecf20Sopenharmony_ci		result = false;
32048c2ecf20Sopenharmony_ci	}
32058c2ecf20Sopenharmony_ci
32068c2ecf20Sopenharmony_ci	rtw8822c_dpk_fill_result(rtwdev, dpk_txagc, path, result);
32078c2ecf20Sopenharmony_ci
32088c2ecf20Sopenharmony_ci	return result;
32098c2ecf20Sopenharmony_ci}
32108c2ecf20Sopenharmony_ci
32118c2ecf20Sopenharmony_cistatic void rtw8822c_dpk_result_reset(struct rtw_dev *rtwdev)
32128c2ecf20Sopenharmony_ci{
32138c2ecf20Sopenharmony_ci	struct rtw_dpk_info *dpk_info = &rtwdev->dm_info.dpk_info;
32148c2ecf20Sopenharmony_ci	u8 path;
32158c2ecf20Sopenharmony_ci
32168c2ecf20Sopenharmony_ci	for (path = 0; path < rtwdev->hal.rf_path_num; path++) {
32178c2ecf20Sopenharmony_ci		clear_bit(path, dpk_info->dpk_path_ok);
32188c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_NCTL0, BIT_SUBPAGE,
32198c2ecf20Sopenharmony_ci				 0x8 | (path << 1));
32208c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, 0x1b58, 0x0000007f, 0x0);
32218c2ecf20Sopenharmony_ci
32228c2ecf20Sopenharmony_ci		dpk_info->dpk_txagc[path] = 0;
32238c2ecf20Sopenharmony_ci		dpk_info->result[path] = 0;
32248c2ecf20Sopenharmony_ci		dpk_info->dpk_gs[path] = 0x5b;
32258c2ecf20Sopenharmony_ci		dpk_info->pre_pwsf[path] = 0;
32268c2ecf20Sopenharmony_ci		dpk_info->thermal_dpk[path] = rtw8822c_dpk_thermal_read(rtwdev,
32278c2ecf20Sopenharmony_ci									path);
32288c2ecf20Sopenharmony_ci	}
32298c2ecf20Sopenharmony_ci}
32308c2ecf20Sopenharmony_ci
32318c2ecf20Sopenharmony_cistatic void rtw8822c_dpk_calibrate(struct rtw_dev *rtwdev, u8 path)
32328c2ecf20Sopenharmony_ci{
32338c2ecf20Sopenharmony_ci	struct rtw_dpk_info *dpk_info = &rtwdev->dm_info.dpk_info;
32348c2ecf20Sopenharmony_ci	u32 dpk_txagc;
32358c2ecf20Sopenharmony_ci	u8 dpk_fail;
32368c2ecf20Sopenharmony_ci
32378c2ecf20Sopenharmony_ci	rtw_dbg(rtwdev, RTW_DBG_RFK, "[DPK] s%d dpk start\n", path);
32388c2ecf20Sopenharmony_ci
32398c2ecf20Sopenharmony_ci	dpk_txagc = rtw8822c_dpk_gainloss(rtwdev, path);
32408c2ecf20Sopenharmony_ci
32418c2ecf20Sopenharmony_ci	dpk_fail = rtw8822c_dpk_by_path(rtwdev, dpk_txagc, path);
32428c2ecf20Sopenharmony_ci
32438c2ecf20Sopenharmony_ci	if (!rtw8822c_dpk_check_pass(rtwdev, dpk_fail, dpk_txagc, path))
32448c2ecf20Sopenharmony_ci		rtw_err(rtwdev, "failed to do dpk calibration\n");
32458c2ecf20Sopenharmony_ci
32468c2ecf20Sopenharmony_ci	rtw_dbg(rtwdev, RTW_DBG_RFK, "[DPK] s%d dpk finish\n", path);
32478c2ecf20Sopenharmony_ci
32488c2ecf20Sopenharmony_ci	if (dpk_info->result[path])
32498c2ecf20Sopenharmony_ci		set_bit(path, dpk_info->dpk_path_ok);
32508c2ecf20Sopenharmony_ci}
32518c2ecf20Sopenharmony_ci
32528c2ecf20Sopenharmony_cistatic void rtw8822c_dpk_path_select(struct rtw_dev *rtwdev)
32538c2ecf20Sopenharmony_ci{
32548c2ecf20Sopenharmony_ci	rtw8822c_dpk_calibrate(rtwdev, RF_PATH_A);
32558c2ecf20Sopenharmony_ci	rtw8822c_dpk_calibrate(rtwdev, RF_PATH_B);
32568c2ecf20Sopenharmony_ci	rtw8822c_dpk_on(rtwdev, RF_PATH_A);
32578c2ecf20Sopenharmony_ci	rtw8822c_dpk_on(rtwdev, RF_PATH_B);
32588c2ecf20Sopenharmony_ci	rtw8822c_dpk_cal_coef1(rtwdev);
32598c2ecf20Sopenharmony_ci}
32608c2ecf20Sopenharmony_ci
32618c2ecf20Sopenharmony_cistatic void rtw8822c_dpk_enable_disable(struct rtw_dev *rtwdev)
32628c2ecf20Sopenharmony_ci{
32638c2ecf20Sopenharmony_ci	struct rtw_dpk_info *dpk_info = &rtwdev->dm_info.dpk_info;
32648c2ecf20Sopenharmony_ci	u32 mask = BIT(15) | BIT(14);
32658c2ecf20Sopenharmony_ci
32668c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, REG_NCTL0, BIT_SUBPAGE, 0xc);
32678c2ecf20Sopenharmony_ci
32688c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, REG_DPD_CTL1_S0, BIT_DPD_EN,
32698c2ecf20Sopenharmony_ci			 dpk_info->is_dpk_pwr_on);
32708c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev, REG_DPD_CTL1_S1, BIT_DPD_EN,
32718c2ecf20Sopenharmony_ci			 dpk_info->is_dpk_pwr_on);
32728c2ecf20Sopenharmony_ci
32738c2ecf20Sopenharmony_ci	if (test_bit(RF_PATH_A, dpk_info->dpk_path_ok)) {
32748c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_DPD_CTL1_S0, mask, 0x0);
32758c2ecf20Sopenharmony_ci		rtw_write8(rtwdev, REG_DPD_CTL0_S0, dpk_info->dpk_gs[RF_PATH_A]);
32768c2ecf20Sopenharmony_ci	}
32778c2ecf20Sopenharmony_ci	if (test_bit(RF_PATH_B, dpk_info->dpk_path_ok)) {
32788c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_DPD_CTL1_S1, mask, 0x0);
32798c2ecf20Sopenharmony_ci		rtw_write8(rtwdev, REG_DPD_CTL0_S1, dpk_info->dpk_gs[RF_PATH_B]);
32808c2ecf20Sopenharmony_ci	}
32818c2ecf20Sopenharmony_ci}
32828c2ecf20Sopenharmony_ci
32838c2ecf20Sopenharmony_cistatic void rtw8822c_dpk_reload_data(struct rtw_dev *rtwdev)
32848c2ecf20Sopenharmony_ci{
32858c2ecf20Sopenharmony_ci	struct rtw_dpk_info *dpk_info = &rtwdev->dm_info.dpk_info;
32868c2ecf20Sopenharmony_ci	u8 path;
32878c2ecf20Sopenharmony_ci
32888c2ecf20Sopenharmony_ci	if (!test_bit(RF_PATH_A, dpk_info->dpk_path_ok) &&
32898c2ecf20Sopenharmony_ci	    !test_bit(RF_PATH_B, dpk_info->dpk_path_ok) &&
32908c2ecf20Sopenharmony_ci	    dpk_info->dpk_ch == 0)
32918c2ecf20Sopenharmony_ci		return;
32928c2ecf20Sopenharmony_ci
32938c2ecf20Sopenharmony_ci	for (path = 0; path < rtwdev->hal.rf_path_num; path++) {
32948c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_NCTL0, BIT_SUBPAGE,
32958c2ecf20Sopenharmony_ci				 0x8 | (path << 1));
32968c2ecf20Sopenharmony_ci		if (dpk_info->dpk_band == RTW_BAND_2G)
32978c2ecf20Sopenharmony_ci			rtw_write32(rtwdev, REG_DPD_LUT3, 0x1f100000);
32988c2ecf20Sopenharmony_ci		else
32998c2ecf20Sopenharmony_ci			rtw_write32(rtwdev, REG_DPD_LUT3, 0x1f0d0000);
33008c2ecf20Sopenharmony_ci
33018c2ecf20Sopenharmony_ci		rtw_write8(rtwdev, REG_DPD_AGC, dpk_info->dpk_txagc[path]);
33028c2ecf20Sopenharmony_ci
33038c2ecf20Sopenharmony_ci		rtw8822c_dpk_coef_write(rtwdev, path,
33048c2ecf20Sopenharmony_ci					test_bit(path, dpk_info->dpk_path_ok));
33058c2ecf20Sopenharmony_ci
33068c2ecf20Sopenharmony_ci		rtw8822c_dpk_one_shot(rtwdev, path, RTW_DPK_DPK_ON);
33078c2ecf20Sopenharmony_ci
33088c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, REG_NCTL0, BIT_SUBPAGE, 0xc);
33098c2ecf20Sopenharmony_ci
33108c2ecf20Sopenharmony_ci		if (path == RF_PATH_A)
33118c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_DPD_CTL0_S0, BIT_GS_PWSF,
33128c2ecf20Sopenharmony_ci					 dpk_info->dpk_gs[path]);
33138c2ecf20Sopenharmony_ci		else
33148c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_DPD_CTL0_S1, BIT_GS_PWSF,
33158c2ecf20Sopenharmony_ci					 dpk_info->dpk_gs[path]);
33168c2ecf20Sopenharmony_ci	}
33178c2ecf20Sopenharmony_ci	rtw8822c_dpk_cal_coef1(rtwdev);
33188c2ecf20Sopenharmony_ci}
33198c2ecf20Sopenharmony_ci
33208c2ecf20Sopenharmony_cistatic bool rtw8822c_dpk_reload(struct rtw_dev *rtwdev)
33218c2ecf20Sopenharmony_ci{
33228c2ecf20Sopenharmony_ci	struct rtw_dpk_info *dpk_info = &rtwdev->dm_info.dpk_info;
33238c2ecf20Sopenharmony_ci	u8 channel;
33248c2ecf20Sopenharmony_ci
33258c2ecf20Sopenharmony_ci	dpk_info->is_reload = false;
33268c2ecf20Sopenharmony_ci
33278c2ecf20Sopenharmony_ci	channel = (u8)(rtw_read_rf(rtwdev, RF_PATH_A, 0x18, RFREG_MASK) & 0xff);
33288c2ecf20Sopenharmony_ci
33298c2ecf20Sopenharmony_ci	if (channel == dpk_info->dpk_ch) {
33308c2ecf20Sopenharmony_ci		rtw_dbg(rtwdev, RTW_DBG_RFK,
33318c2ecf20Sopenharmony_ci			"[DPK] DPK reload for CH%d!!\n", dpk_info->dpk_ch);
33328c2ecf20Sopenharmony_ci		rtw8822c_dpk_reload_data(rtwdev);
33338c2ecf20Sopenharmony_ci		dpk_info->is_reload = true;
33348c2ecf20Sopenharmony_ci	}
33358c2ecf20Sopenharmony_ci
33368c2ecf20Sopenharmony_ci	return dpk_info->is_reload;
33378c2ecf20Sopenharmony_ci}
33388c2ecf20Sopenharmony_ci
33398c2ecf20Sopenharmony_cistatic void rtw8822c_do_dpk(struct rtw_dev *rtwdev)
33408c2ecf20Sopenharmony_ci{
33418c2ecf20Sopenharmony_ci	struct rtw_dpk_info *dpk_info = &rtwdev->dm_info.dpk_info;
33428c2ecf20Sopenharmony_ci	struct rtw_backup_info bckp[DPK_BB_REG_NUM];
33438c2ecf20Sopenharmony_ci	u32 rf_reg_backup[DPK_RF_REG_NUM][DPK_RF_PATH_NUM];
33448c2ecf20Sopenharmony_ci	u32 bb_reg[DPK_BB_REG_NUM] = {
33458c2ecf20Sopenharmony_ci		0x520, 0x820, 0x824, 0x1c3c, 0x1d58, 0x1864,
33468c2ecf20Sopenharmony_ci		0x4164, 0x180c, 0x410c, 0x186c, 0x416c,
33478c2ecf20Sopenharmony_ci		0x1a14, 0x1e70, 0x80c, 0x1d70, 0x1e7c, 0x18a4, 0x41a4};
33488c2ecf20Sopenharmony_ci	u32 rf_reg[DPK_RF_REG_NUM] = {
33498c2ecf20Sopenharmony_ci		0x0, 0x1a, 0x55, 0x63, 0x87, 0x8f, 0xde};
33508c2ecf20Sopenharmony_ci	u8 path;
33518c2ecf20Sopenharmony_ci
33528c2ecf20Sopenharmony_ci	if (!dpk_info->is_dpk_pwr_on) {
33538c2ecf20Sopenharmony_ci		rtw_dbg(rtwdev, RTW_DBG_RFK, "[DPK] Skip DPK due to DPD PWR off\n");
33548c2ecf20Sopenharmony_ci		return;
33558c2ecf20Sopenharmony_ci	} else if (rtw8822c_dpk_reload(rtwdev)) {
33568c2ecf20Sopenharmony_ci		return;
33578c2ecf20Sopenharmony_ci	}
33588c2ecf20Sopenharmony_ci
33598c2ecf20Sopenharmony_ci	for (path = RF_PATH_A; path < DPK_RF_PATH_NUM; path++)
33608c2ecf20Sopenharmony_ci		ewma_thermal_init(&dpk_info->avg_thermal[path]);
33618c2ecf20Sopenharmony_ci
33628c2ecf20Sopenharmony_ci	rtw8822c_dpk_information(rtwdev);
33638c2ecf20Sopenharmony_ci
33648c2ecf20Sopenharmony_ci	rtw8822c_dpk_backup_registers(rtwdev, bb_reg, DPK_BB_REG_NUM, bckp);
33658c2ecf20Sopenharmony_ci	rtw8822c_dpk_backup_rf_registers(rtwdev, rf_reg, rf_reg_backup);
33668c2ecf20Sopenharmony_ci
33678c2ecf20Sopenharmony_ci	rtw8822c_dpk_mac_bb_setting(rtwdev);
33688c2ecf20Sopenharmony_ci	rtw8822c_dpk_afe_setting(rtwdev, true);
33698c2ecf20Sopenharmony_ci	rtw8822c_dpk_pre_setting(rtwdev);
33708c2ecf20Sopenharmony_ci	rtw8822c_dpk_result_reset(rtwdev);
33718c2ecf20Sopenharmony_ci	rtw8822c_dpk_path_select(rtwdev);
33728c2ecf20Sopenharmony_ci	rtw8822c_dpk_afe_setting(rtwdev, false);
33738c2ecf20Sopenharmony_ci	rtw8822c_dpk_enable_disable(rtwdev);
33748c2ecf20Sopenharmony_ci
33758c2ecf20Sopenharmony_ci	rtw8822c_dpk_reload_rf_registers(rtwdev, rf_reg, rf_reg_backup);
33768c2ecf20Sopenharmony_ci	for (path = 0; path < rtwdev->hal.rf_path_num; path++)
33778c2ecf20Sopenharmony_ci		rtw8822c_dpk_rxbb_dc_cal(rtwdev, path);
33788c2ecf20Sopenharmony_ci	rtw8822c_dpk_restore_registers(rtwdev, DPK_BB_REG_NUM, bckp);
33798c2ecf20Sopenharmony_ci}
33808c2ecf20Sopenharmony_ci
33818c2ecf20Sopenharmony_cistatic void rtw8822c_phy_calibration(struct rtw_dev *rtwdev)
33828c2ecf20Sopenharmony_ci{
33838c2ecf20Sopenharmony_ci	rtw8822c_do_iqk(rtwdev);
33848c2ecf20Sopenharmony_ci	rtw8822c_do_dpk(rtwdev);
33858c2ecf20Sopenharmony_ci}
33868c2ecf20Sopenharmony_ci
33878c2ecf20Sopenharmony_cistatic void rtw8822c_dpk_track(struct rtw_dev *rtwdev)
33888c2ecf20Sopenharmony_ci{
33898c2ecf20Sopenharmony_ci	struct rtw_dpk_info *dpk_info = &rtwdev->dm_info.dpk_info;
33908c2ecf20Sopenharmony_ci	u8 path;
33918c2ecf20Sopenharmony_ci	u8 thermal_value[DPK_RF_PATH_NUM] = {0};
33928c2ecf20Sopenharmony_ci	s8 offset[DPK_RF_PATH_NUM], delta_dpk[DPK_RF_PATH_NUM];
33938c2ecf20Sopenharmony_ci
33948c2ecf20Sopenharmony_ci	if (dpk_info->thermal_dpk[0] == 0 && dpk_info->thermal_dpk[1] == 0)
33958c2ecf20Sopenharmony_ci		return;
33968c2ecf20Sopenharmony_ci
33978c2ecf20Sopenharmony_ci	for (path = 0; path < DPK_RF_PATH_NUM; path++) {
33988c2ecf20Sopenharmony_ci		thermal_value[path] = rtw8822c_dpk_thermal_read(rtwdev, path);
33998c2ecf20Sopenharmony_ci		ewma_thermal_add(&dpk_info->avg_thermal[path],
34008c2ecf20Sopenharmony_ci				 thermal_value[path]);
34018c2ecf20Sopenharmony_ci		thermal_value[path] =
34028c2ecf20Sopenharmony_ci			ewma_thermal_read(&dpk_info->avg_thermal[path]);
34038c2ecf20Sopenharmony_ci		delta_dpk[path] = dpk_info->thermal_dpk[path] -
34048c2ecf20Sopenharmony_ci				  thermal_value[path];
34058c2ecf20Sopenharmony_ci		offset[path] = delta_dpk[path] -
34068c2ecf20Sopenharmony_ci			       dpk_info->thermal_dpk_delta[path];
34078c2ecf20Sopenharmony_ci		offset[path] &= 0x7f;
34088c2ecf20Sopenharmony_ci
34098c2ecf20Sopenharmony_ci		if (offset[path] != dpk_info->pre_pwsf[path]) {
34108c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, REG_NCTL0, BIT_SUBPAGE,
34118c2ecf20Sopenharmony_ci					 0x8 | (path << 1));
34128c2ecf20Sopenharmony_ci			rtw_write32_mask(rtwdev, 0x1b58, GENMASK(6, 0),
34138c2ecf20Sopenharmony_ci					 offset[path]);
34148c2ecf20Sopenharmony_ci			dpk_info->pre_pwsf[path] = offset[path];
34158c2ecf20Sopenharmony_ci		}
34168c2ecf20Sopenharmony_ci	}
34178c2ecf20Sopenharmony_ci}
34188c2ecf20Sopenharmony_ci
34198c2ecf20Sopenharmony_cistatic const struct rtw_phy_cck_pd_reg
34208c2ecf20Sopenharmony_cirtw8822c_cck_pd_reg[RTW_CHANNEL_WIDTH_40 + 1][RTW_RF_PATH_MAX] = {
34218c2ecf20Sopenharmony_ci	{
34228c2ecf20Sopenharmony_ci		{0x1ac8, 0x00ff, 0x1ad0, 0x01f},
34238c2ecf20Sopenharmony_ci		{0x1ac8, 0xff00, 0x1ad0, 0x3e0}
34248c2ecf20Sopenharmony_ci	},
34258c2ecf20Sopenharmony_ci	{
34268c2ecf20Sopenharmony_ci		{0x1acc, 0x00ff, 0x1ad0, 0x01F00000},
34278c2ecf20Sopenharmony_ci		{0x1acc, 0xff00, 0x1ad0, 0x3E000000}
34288c2ecf20Sopenharmony_ci	},
34298c2ecf20Sopenharmony_ci};
34308c2ecf20Sopenharmony_ci
34318c2ecf20Sopenharmony_ci#define RTW_CCK_PD_MAX 255
34328c2ecf20Sopenharmony_ci#define RTW_CCK_CS_MAX 31
34338c2ecf20Sopenharmony_ci#define RTW_CCK_CS_ERR1 27
34348c2ecf20Sopenharmony_ci#define RTW_CCK_CS_ERR2 29
34358c2ecf20Sopenharmony_cistatic void
34368c2ecf20Sopenharmony_cirtw8822c_phy_cck_pd_set_reg(struct rtw_dev *rtwdev,
34378c2ecf20Sopenharmony_ci			    s8 pd_diff, s8 cs_diff, u8 bw, u8 nrx)
34388c2ecf20Sopenharmony_ci{
34398c2ecf20Sopenharmony_ci	u32 pd, cs;
34408c2ecf20Sopenharmony_ci
34418c2ecf20Sopenharmony_ci	if (WARN_ON(bw > RTW_CHANNEL_WIDTH_40 || nrx >= RTW_RF_PATH_MAX))
34428c2ecf20Sopenharmony_ci		return;
34438c2ecf20Sopenharmony_ci
34448c2ecf20Sopenharmony_ci	pd = rtw_read32_mask(rtwdev,
34458c2ecf20Sopenharmony_ci			     rtw8822c_cck_pd_reg[bw][nrx].reg_pd,
34468c2ecf20Sopenharmony_ci			     rtw8822c_cck_pd_reg[bw][nrx].mask_pd);
34478c2ecf20Sopenharmony_ci	cs = rtw_read32_mask(rtwdev,
34488c2ecf20Sopenharmony_ci			     rtw8822c_cck_pd_reg[bw][nrx].reg_cs,
34498c2ecf20Sopenharmony_ci			     rtw8822c_cck_pd_reg[bw][nrx].mask_cs);
34508c2ecf20Sopenharmony_ci	pd += pd_diff;
34518c2ecf20Sopenharmony_ci	cs += cs_diff;
34528c2ecf20Sopenharmony_ci	if (pd > RTW_CCK_PD_MAX)
34538c2ecf20Sopenharmony_ci		pd = RTW_CCK_PD_MAX;
34548c2ecf20Sopenharmony_ci	if (cs == RTW_CCK_CS_ERR1 || cs == RTW_CCK_CS_ERR2)
34558c2ecf20Sopenharmony_ci		cs++;
34568c2ecf20Sopenharmony_ci	else if (cs > RTW_CCK_CS_MAX)
34578c2ecf20Sopenharmony_ci		cs = RTW_CCK_CS_MAX;
34588c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev,
34598c2ecf20Sopenharmony_ci			 rtw8822c_cck_pd_reg[bw][nrx].reg_pd,
34608c2ecf20Sopenharmony_ci			 rtw8822c_cck_pd_reg[bw][nrx].mask_pd,
34618c2ecf20Sopenharmony_ci			 pd);
34628c2ecf20Sopenharmony_ci	rtw_write32_mask(rtwdev,
34638c2ecf20Sopenharmony_ci			 rtw8822c_cck_pd_reg[bw][nrx].reg_cs,
34648c2ecf20Sopenharmony_ci			 rtw8822c_cck_pd_reg[bw][nrx].mask_cs,
34658c2ecf20Sopenharmony_ci			 cs);
34668c2ecf20Sopenharmony_ci}
34678c2ecf20Sopenharmony_ci
34688c2ecf20Sopenharmony_cistatic void rtw8822c_phy_cck_pd_set(struct rtw_dev *rtwdev, u8 new_lvl)
34698c2ecf20Sopenharmony_ci{
34708c2ecf20Sopenharmony_ci	struct rtw_dm_info *dm_info = &rtwdev->dm_info;
34718c2ecf20Sopenharmony_ci	s8 pd_lvl[CCK_PD_LV_MAX] = {0, 2, 4, 6, 8};
34728c2ecf20Sopenharmony_ci	s8 cs_lvl[CCK_PD_LV_MAX] = {0, 2, 2, 2, 4};
34738c2ecf20Sopenharmony_ci	u8 cur_lvl;
34748c2ecf20Sopenharmony_ci	u8 nrx, bw;
34758c2ecf20Sopenharmony_ci
34768c2ecf20Sopenharmony_ci	nrx = (u8)rtw_read32_mask(rtwdev, 0x1a2c, 0x60000);
34778c2ecf20Sopenharmony_ci	bw = (u8)rtw_read32_mask(rtwdev, 0x9b0, 0xc);
34788c2ecf20Sopenharmony_ci
34798c2ecf20Sopenharmony_ci	if (dm_info->cck_pd_lv[bw][nrx] == new_lvl)
34808c2ecf20Sopenharmony_ci		return;
34818c2ecf20Sopenharmony_ci
34828c2ecf20Sopenharmony_ci	cur_lvl = dm_info->cck_pd_lv[bw][nrx];
34838c2ecf20Sopenharmony_ci
34848c2ecf20Sopenharmony_ci	/* update cck pd info */
34858c2ecf20Sopenharmony_ci	dm_info->cck_fa_avg = CCK_FA_AVG_RESET;
34868c2ecf20Sopenharmony_ci
34878c2ecf20Sopenharmony_ci	rtw8822c_phy_cck_pd_set_reg(rtwdev,
34888c2ecf20Sopenharmony_ci				    pd_lvl[new_lvl] - pd_lvl[cur_lvl],
34898c2ecf20Sopenharmony_ci				    cs_lvl[new_lvl] - cs_lvl[cur_lvl],
34908c2ecf20Sopenharmony_ci				    bw, nrx);
34918c2ecf20Sopenharmony_ci	dm_info->cck_pd_lv[bw][nrx] = new_lvl;
34928c2ecf20Sopenharmony_ci}
34938c2ecf20Sopenharmony_ci
34948c2ecf20Sopenharmony_ci#define PWR_TRACK_MASK 0x7f
34958c2ecf20Sopenharmony_cistatic void rtw8822c_pwrtrack_set(struct rtw_dev *rtwdev, u8 rf_path)
34968c2ecf20Sopenharmony_ci{
34978c2ecf20Sopenharmony_ci	struct rtw_dm_info *dm_info = &rtwdev->dm_info;
34988c2ecf20Sopenharmony_ci
34998c2ecf20Sopenharmony_ci	switch (rf_path) {
35008c2ecf20Sopenharmony_ci	case RF_PATH_A:
35018c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, 0x18a0, PWR_TRACK_MASK,
35028c2ecf20Sopenharmony_ci				 dm_info->delta_power_index[rf_path]);
35038c2ecf20Sopenharmony_ci		break;
35048c2ecf20Sopenharmony_ci	case RF_PATH_B:
35058c2ecf20Sopenharmony_ci		rtw_write32_mask(rtwdev, 0x41a0, PWR_TRACK_MASK,
35068c2ecf20Sopenharmony_ci				 dm_info->delta_power_index[rf_path]);
35078c2ecf20Sopenharmony_ci		break;
35088c2ecf20Sopenharmony_ci	default:
35098c2ecf20Sopenharmony_ci		break;
35108c2ecf20Sopenharmony_ci	}
35118c2ecf20Sopenharmony_ci}
35128c2ecf20Sopenharmony_ci
35138c2ecf20Sopenharmony_cistatic void rtw8822c_pwr_track_stats(struct rtw_dev *rtwdev, u8 path)
35148c2ecf20Sopenharmony_ci{
35158c2ecf20Sopenharmony_ci	u8 thermal_value;
35168c2ecf20Sopenharmony_ci
35178c2ecf20Sopenharmony_ci	if (rtwdev->efuse.thermal_meter[path] == 0xff)
35188c2ecf20Sopenharmony_ci		return;
35198c2ecf20Sopenharmony_ci
35208c2ecf20Sopenharmony_ci	thermal_value = rtw_read_rf(rtwdev, path, RF_T_METER, 0x7e);
35218c2ecf20Sopenharmony_ci	rtw_phy_pwrtrack_avg(rtwdev, thermal_value, path);
35228c2ecf20Sopenharmony_ci}
35238c2ecf20Sopenharmony_ci
35248c2ecf20Sopenharmony_cistatic void rtw8822c_pwr_track_path(struct rtw_dev *rtwdev,
35258c2ecf20Sopenharmony_ci				    struct rtw_swing_table *swing_table,
35268c2ecf20Sopenharmony_ci				    u8 path)
35278c2ecf20Sopenharmony_ci{
35288c2ecf20Sopenharmony_ci	struct rtw_dm_info *dm_info = &rtwdev->dm_info;
35298c2ecf20Sopenharmony_ci	u8 delta;
35308c2ecf20Sopenharmony_ci
35318c2ecf20Sopenharmony_ci	delta = rtw_phy_pwrtrack_get_delta(rtwdev, path);
35328c2ecf20Sopenharmony_ci	dm_info->delta_power_index[path] =
35338c2ecf20Sopenharmony_ci		rtw_phy_pwrtrack_get_pwridx(rtwdev, swing_table, path, path,
35348c2ecf20Sopenharmony_ci					    delta);
35358c2ecf20Sopenharmony_ci	rtw8822c_pwrtrack_set(rtwdev, path);
35368c2ecf20Sopenharmony_ci}
35378c2ecf20Sopenharmony_ci
35388c2ecf20Sopenharmony_cistatic void __rtw8822c_pwr_track(struct rtw_dev *rtwdev)
35398c2ecf20Sopenharmony_ci{
35408c2ecf20Sopenharmony_ci	struct rtw_swing_table swing_table;
35418c2ecf20Sopenharmony_ci	u8 i;
35428c2ecf20Sopenharmony_ci
35438c2ecf20Sopenharmony_ci	rtw_phy_config_swing_table(rtwdev, &swing_table);
35448c2ecf20Sopenharmony_ci
35458c2ecf20Sopenharmony_ci	for (i = 0; i < rtwdev->hal.rf_path_num; i++)
35468c2ecf20Sopenharmony_ci		rtw8822c_pwr_track_stats(rtwdev, i);
35478c2ecf20Sopenharmony_ci	if (rtw_phy_pwrtrack_need_lck(rtwdev))
35488c2ecf20Sopenharmony_ci		rtw8822c_do_lck(rtwdev);
35498c2ecf20Sopenharmony_ci	for (i = 0; i < rtwdev->hal.rf_path_num; i++)
35508c2ecf20Sopenharmony_ci		rtw8822c_pwr_track_path(rtwdev, &swing_table, i);
35518c2ecf20Sopenharmony_ci}
35528c2ecf20Sopenharmony_ci
35538c2ecf20Sopenharmony_cistatic void rtw8822c_pwr_track(struct rtw_dev *rtwdev)
35548c2ecf20Sopenharmony_ci{
35558c2ecf20Sopenharmony_ci	struct rtw_efuse *efuse = &rtwdev->efuse;
35568c2ecf20Sopenharmony_ci	struct rtw_dm_info *dm_info = &rtwdev->dm_info;
35578c2ecf20Sopenharmony_ci
35588c2ecf20Sopenharmony_ci	if (efuse->power_track_type != 0)
35598c2ecf20Sopenharmony_ci		return;
35608c2ecf20Sopenharmony_ci
35618c2ecf20Sopenharmony_ci	if (!dm_info->pwr_trk_triggered) {
35628c2ecf20Sopenharmony_ci		rtw_write_rf(rtwdev, RF_PATH_A, RF_T_METER, BIT(19), 0x01);
35638c2ecf20Sopenharmony_ci		rtw_write_rf(rtwdev, RF_PATH_A, RF_T_METER, BIT(19), 0x00);
35648c2ecf20Sopenharmony_ci		rtw_write_rf(rtwdev, RF_PATH_A, RF_T_METER, BIT(19), 0x01);
35658c2ecf20Sopenharmony_ci
35668c2ecf20Sopenharmony_ci		rtw_write_rf(rtwdev, RF_PATH_B, RF_T_METER, BIT(19), 0x01);
35678c2ecf20Sopenharmony_ci		rtw_write_rf(rtwdev, RF_PATH_B, RF_T_METER, BIT(19), 0x00);
35688c2ecf20Sopenharmony_ci		rtw_write_rf(rtwdev, RF_PATH_B, RF_T_METER, BIT(19), 0x01);
35698c2ecf20Sopenharmony_ci
35708c2ecf20Sopenharmony_ci		dm_info->pwr_trk_triggered = true;
35718c2ecf20Sopenharmony_ci		return;
35728c2ecf20Sopenharmony_ci	}
35738c2ecf20Sopenharmony_ci
35748c2ecf20Sopenharmony_ci	__rtw8822c_pwr_track(rtwdev);
35758c2ecf20Sopenharmony_ci	dm_info->pwr_trk_triggered = false;
35768c2ecf20Sopenharmony_ci}
35778c2ecf20Sopenharmony_ci
35788c2ecf20Sopenharmony_cistatic const struct rtw_pwr_seq_cmd trans_carddis_to_cardemu_8822c[] = {
35798c2ecf20Sopenharmony_ci	{0x0086,
35808c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
35818c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_SDIO_MSK,
35828c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_SDIO,
35838c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_WRITE, BIT(0), 0},
35848c2ecf20Sopenharmony_ci	{0x0086,
35858c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
35868c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_SDIO_MSK,
35878c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_SDIO,
35888c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_POLLING, BIT(1), BIT(1)},
35898c2ecf20Sopenharmony_ci	{0x002E,
35908c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
35918c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_ALL_MSK,
35928c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_MAC,
35938c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_WRITE, BIT(2), BIT(2)},
35948c2ecf20Sopenharmony_ci	{0x002D,
35958c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
35968c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_ALL_MSK,
35978c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_MAC,
35988c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_WRITE, BIT(0), 0},
35998c2ecf20Sopenharmony_ci	{0x007F,
36008c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
36018c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_ALL_MSK,
36028c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_MAC,
36038c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_WRITE, BIT(7), 0},
36048c2ecf20Sopenharmony_ci	{0x004A,
36058c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
36068c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_USB_MSK,
36078c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_MAC,
36088c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_WRITE, BIT(0), 0},
36098c2ecf20Sopenharmony_ci	{0x0005,
36108c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
36118c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_ALL_MSK,
36128c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_MAC,
36138c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_WRITE, BIT(3) | BIT(4) | BIT(7), 0},
36148c2ecf20Sopenharmony_ci	{0xFFFF,
36158c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
36168c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_ALL_MSK,
36178c2ecf20Sopenharmony_ci	 0,
36188c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_END, 0, 0},
36198c2ecf20Sopenharmony_ci};
36208c2ecf20Sopenharmony_ci
36218c2ecf20Sopenharmony_cistatic const struct rtw_pwr_seq_cmd trans_cardemu_to_act_8822c[] = {
36228c2ecf20Sopenharmony_ci	{0x0000,
36238c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
36248c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_USB_MSK | RTW_PWR_INTF_SDIO_MSK,
36258c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_MAC,
36268c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_WRITE, BIT(5), 0},
36278c2ecf20Sopenharmony_ci	{0x0005,
36288c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
36298c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_ALL_MSK,
36308c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_MAC,
36318c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_WRITE, (BIT(4) | BIT(3) | BIT(2)), 0},
36328c2ecf20Sopenharmony_ci	{0x0075,
36338c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
36348c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_PCI_MSK,
36358c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_MAC,
36368c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_WRITE, BIT(0), BIT(0)},
36378c2ecf20Sopenharmony_ci	{0x0006,
36388c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
36398c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_ALL_MSK,
36408c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_MAC,
36418c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_POLLING, BIT(1), BIT(1)},
36428c2ecf20Sopenharmony_ci	{0x0075,
36438c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
36448c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_PCI_MSK,
36458c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_MAC,
36468c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_WRITE, BIT(0), 0},
36478c2ecf20Sopenharmony_ci	{0xFF1A,
36488c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
36498c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_USB_MSK,
36508c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_MAC,
36518c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_WRITE, 0xFF, 0},
36528c2ecf20Sopenharmony_ci	{0x002E,
36538c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
36548c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_ALL_MSK,
36558c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_MAC,
36568c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_WRITE, BIT(3), 0},
36578c2ecf20Sopenharmony_ci	{0x0006,
36588c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
36598c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_ALL_MSK,
36608c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_MAC,
36618c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_WRITE, BIT(0), BIT(0)},
36628c2ecf20Sopenharmony_ci	{0x0005,
36638c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
36648c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_ALL_MSK,
36658c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_MAC,
36668c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_WRITE, (BIT(4) | BIT(3)), 0},
36678c2ecf20Sopenharmony_ci	{0x1018,
36688c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
36698c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_ALL_MSK,
36708c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_MAC,
36718c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_WRITE, BIT(2), BIT(2)},
36728c2ecf20Sopenharmony_ci	{0x0005,
36738c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
36748c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_ALL_MSK,
36758c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_MAC,
36768c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_WRITE, BIT(0), BIT(0)},
36778c2ecf20Sopenharmony_ci	{0x0005,
36788c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
36798c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_ALL_MSK,
36808c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_MAC,
36818c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_POLLING, BIT(0), 0},
36828c2ecf20Sopenharmony_ci	{0x0074,
36838c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
36848c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_PCI_MSK,
36858c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_MAC,
36868c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_WRITE, BIT(5), BIT(5)},
36878c2ecf20Sopenharmony_ci	{0x0071,
36888c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
36898c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_PCI_MSK,
36908c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_MAC,
36918c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_WRITE, BIT(4), 0},
36928c2ecf20Sopenharmony_ci	{0x0062,
36938c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
36948c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_PCI_MSK,
36958c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_MAC,
36968c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_WRITE, (BIT(7) | BIT(6) | BIT(5)),
36978c2ecf20Sopenharmony_ci	 (BIT(7) | BIT(6) | BIT(5))},
36988c2ecf20Sopenharmony_ci	{0x0061,
36998c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
37008c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_PCI_MSK,
37018c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_MAC,
37028c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_WRITE, (BIT(7) | BIT(6) | BIT(5)), 0},
37038c2ecf20Sopenharmony_ci	{0x001F,
37048c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
37058c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_ALL_MSK,
37068c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_MAC,
37078c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_WRITE, (BIT(7) | BIT(6)), BIT(7)},
37088c2ecf20Sopenharmony_ci	{0x00EF,
37098c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
37108c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_ALL_MSK,
37118c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_MAC,
37128c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_WRITE, (BIT(7) | BIT(6)), BIT(7)},
37138c2ecf20Sopenharmony_ci	{0x1045,
37148c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
37158c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_ALL_MSK,
37168c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_MAC,
37178c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_WRITE, BIT(4), BIT(4)},
37188c2ecf20Sopenharmony_ci	{0x0010,
37198c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
37208c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_ALL_MSK,
37218c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_MAC,
37228c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_WRITE, BIT(2), BIT(2)},
37238c2ecf20Sopenharmony_ci	{0x1064,
37248c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
37258c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_ALL_MSK,
37268c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_MAC,
37278c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_WRITE, BIT(1), BIT(1)},
37288c2ecf20Sopenharmony_ci	{0xFFFF,
37298c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
37308c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_ALL_MSK,
37318c2ecf20Sopenharmony_ci	 0,
37328c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_END, 0, 0},
37338c2ecf20Sopenharmony_ci};
37348c2ecf20Sopenharmony_ci
37358c2ecf20Sopenharmony_cistatic const struct rtw_pwr_seq_cmd trans_act_to_cardemu_8822c[] = {
37368c2ecf20Sopenharmony_ci	{0x0093,
37378c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
37388c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_ALL_MSK,
37398c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_MAC,
37408c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_WRITE, BIT(3), 0},
37418c2ecf20Sopenharmony_ci	{0x001F,
37428c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
37438c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_ALL_MSK,
37448c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_MAC,
37458c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_WRITE, 0xFF, 0},
37468c2ecf20Sopenharmony_ci	{0x00EF,
37478c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
37488c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_ALL_MSK,
37498c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_MAC,
37508c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_WRITE, 0xFF, 0},
37518c2ecf20Sopenharmony_ci	{0x1045,
37528c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
37538c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_ALL_MSK,
37548c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_MAC,
37558c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_WRITE, BIT(4), 0},
37568c2ecf20Sopenharmony_ci	{0xFF1A,
37578c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
37588c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_USB_MSK,
37598c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_MAC,
37608c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_WRITE, 0xFF, 0x30},
37618c2ecf20Sopenharmony_ci	{0x0049,
37628c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
37638c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_ALL_MSK,
37648c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_MAC,
37658c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_WRITE, BIT(1), 0},
37668c2ecf20Sopenharmony_ci	{0x0006,
37678c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
37688c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_ALL_MSK,
37698c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_MAC,
37708c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_WRITE, BIT(0), BIT(0)},
37718c2ecf20Sopenharmony_ci	{0x0002,
37728c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
37738c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_ALL_MSK,
37748c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_MAC,
37758c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_WRITE, BIT(1), 0},
37768c2ecf20Sopenharmony_ci	{0x0005,
37778c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
37788c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_ALL_MSK,
37798c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_MAC,
37808c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_WRITE, BIT(1), BIT(1)},
37818c2ecf20Sopenharmony_ci	{0x0005,
37828c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
37838c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_ALL_MSK,
37848c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_MAC,
37858c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_POLLING, BIT(1), 0},
37868c2ecf20Sopenharmony_ci	{0x0000,
37878c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
37888c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_USB_MSK | RTW_PWR_INTF_SDIO_MSK,
37898c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_MAC,
37908c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_WRITE, BIT(5), BIT(5)},
37918c2ecf20Sopenharmony_ci	{0xFFFF,
37928c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
37938c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_ALL_MSK,
37948c2ecf20Sopenharmony_ci	 0,
37958c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_END, 0, 0},
37968c2ecf20Sopenharmony_ci};
37978c2ecf20Sopenharmony_ci
37988c2ecf20Sopenharmony_cistatic const struct rtw_pwr_seq_cmd trans_cardemu_to_carddis_8822c[] = {
37998c2ecf20Sopenharmony_ci	{0x0005,
38008c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
38018c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_SDIO_MSK,
38028c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_MAC,
38038c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_WRITE, BIT(7), BIT(7)},
38048c2ecf20Sopenharmony_ci	{0x0007,
38058c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
38068c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_USB_MSK | RTW_PWR_INTF_SDIO_MSK,
38078c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_MAC,
38088c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_WRITE, 0xFF, 0x00},
38098c2ecf20Sopenharmony_ci	{0x0067,
38108c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
38118c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_ALL_MSK,
38128c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_MAC,
38138c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_WRITE, BIT(5), 0},
38148c2ecf20Sopenharmony_ci	{0x004A,
38158c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
38168c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_USB_MSK,
38178c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_MAC,
38188c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_WRITE, BIT(0), 0},
38198c2ecf20Sopenharmony_ci	{0x0081,
38208c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
38218c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_ALL_MSK,
38228c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_MAC,
38238c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_WRITE, BIT(7) | BIT(6), 0},
38248c2ecf20Sopenharmony_ci	{0x0090,
38258c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
38268c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_ALL_MSK,
38278c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_MAC,
38288c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_WRITE, BIT(1), 0},
38298c2ecf20Sopenharmony_ci	{0x0092,
38308c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
38318c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_PCI_MSK,
38328c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_MAC,
38338c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_WRITE, 0xFF, 0x20},
38348c2ecf20Sopenharmony_ci	{0x0093,
38358c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
38368c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_PCI_MSK,
38378c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_MAC,
38388c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_WRITE, 0xFF, 0x04},
38398c2ecf20Sopenharmony_ci	{0x0005,
38408c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
38418c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_USB_MSK | RTW_PWR_INTF_SDIO_MSK,
38428c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_MAC,
38438c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_WRITE, BIT(3) | BIT(4), BIT(3)},
38448c2ecf20Sopenharmony_ci	{0x0005,
38458c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
38468c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_PCI_MSK,
38478c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_MAC,
38488c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_WRITE, BIT(2), BIT(2)},
38498c2ecf20Sopenharmony_ci	{0x0086,
38508c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
38518c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_SDIO_MSK,
38528c2ecf20Sopenharmony_ci	 RTW_PWR_ADDR_SDIO,
38538c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_WRITE, BIT(0), BIT(0)},
38548c2ecf20Sopenharmony_ci	{0xFFFF,
38558c2ecf20Sopenharmony_ci	 RTW_PWR_CUT_ALL_MSK,
38568c2ecf20Sopenharmony_ci	 RTW_PWR_INTF_ALL_MSK,
38578c2ecf20Sopenharmony_ci	 0,
38588c2ecf20Sopenharmony_ci	 RTW_PWR_CMD_END, 0, 0},
38598c2ecf20Sopenharmony_ci};
38608c2ecf20Sopenharmony_ci
38618c2ecf20Sopenharmony_cistatic const struct rtw_pwr_seq_cmd *card_enable_flow_8822c[] = {
38628c2ecf20Sopenharmony_ci	trans_carddis_to_cardemu_8822c,
38638c2ecf20Sopenharmony_ci	trans_cardemu_to_act_8822c,
38648c2ecf20Sopenharmony_ci	NULL
38658c2ecf20Sopenharmony_ci};
38668c2ecf20Sopenharmony_ci
38678c2ecf20Sopenharmony_cistatic const struct rtw_pwr_seq_cmd *card_disable_flow_8822c[] = {
38688c2ecf20Sopenharmony_ci	trans_act_to_cardemu_8822c,
38698c2ecf20Sopenharmony_ci	trans_cardemu_to_carddis_8822c,
38708c2ecf20Sopenharmony_ci	NULL
38718c2ecf20Sopenharmony_ci};
38728c2ecf20Sopenharmony_ci
38738c2ecf20Sopenharmony_cistatic const struct rtw_intf_phy_para usb2_param_8822c[] = {
38748c2ecf20Sopenharmony_ci	{0xFFFF, 0x00,
38758c2ecf20Sopenharmony_ci	 RTW_IP_SEL_PHY,
38768c2ecf20Sopenharmony_ci	 RTW_INTF_PHY_CUT_ALL,
38778c2ecf20Sopenharmony_ci	 RTW_INTF_PHY_PLATFORM_ALL},
38788c2ecf20Sopenharmony_ci};
38798c2ecf20Sopenharmony_ci
38808c2ecf20Sopenharmony_cistatic const struct rtw_intf_phy_para usb3_param_8822c[] = {
38818c2ecf20Sopenharmony_ci	{0xFFFF, 0x0000,
38828c2ecf20Sopenharmony_ci	 RTW_IP_SEL_PHY,
38838c2ecf20Sopenharmony_ci	 RTW_INTF_PHY_CUT_ALL,
38848c2ecf20Sopenharmony_ci	 RTW_INTF_PHY_PLATFORM_ALL},
38858c2ecf20Sopenharmony_ci};
38868c2ecf20Sopenharmony_ci
38878c2ecf20Sopenharmony_cistatic const struct rtw_intf_phy_para pcie_gen1_param_8822c[] = {
38888c2ecf20Sopenharmony_ci	{0xFFFF, 0x0000,
38898c2ecf20Sopenharmony_ci	 RTW_IP_SEL_PHY,
38908c2ecf20Sopenharmony_ci	 RTW_INTF_PHY_CUT_ALL,
38918c2ecf20Sopenharmony_ci	 RTW_INTF_PHY_PLATFORM_ALL},
38928c2ecf20Sopenharmony_ci};
38938c2ecf20Sopenharmony_ci
38948c2ecf20Sopenharmony_cistatic const struct rtw_intf_phy_para pcie_gen2_param_8822c[] = {
38958c2ecf20Sopenharmony_ci	{0xFFFF, 0x0000,
38968c2ecf20Sopenharmony_ci	 RTW_IP_SEL_PHY,
38978c2ecf20Sopenharmony_ci	 RTW_INTF_PHY_CUT_ALL,
38988c2ecf20Sopenharmony_ci	 RTW_INTF_PHY_PLATFORM_ALL},
38998c2ecf20Sopenharmony_ci};
39008c2ecf20Sopenharmony_ci
39018c2ecf20Sopenharmony_cistatic const struct rtw_intf_phy_para_table phy_para_table_8822c = {
39028c2ecf20Sopenharmony_ci	.usb2_para	= usb2_param_8822c,
39038c2ecf20Sopenharmony_ci	.usb3_para	= usb3_param_8822c,
39048c2ecf20Sopenharmony_ci	.gen1_para	= pcie_gen1_param_8822c,
39058c2ecf20Sopenharmony_ci	.gen2_para	= pcie_gen2_param_8822c,
39068c2ecf20Sopenharmony_ci	.n_usb2_para	= ARRAY_SIZE(usb2_param_8822c),
39078c2ecf20Sopenharmony_ci	.n_usb3_para	= ARRAY_SIZE(usb2_param_8822c),
39088c2ecf20Sopenharmony_ci	.n_gen1_para	= ARRAY_SIZE(pcie_gen1_param_8822c),
39098c2ecf20Sopenharmony_ci	.n_gen2_para	= ARRAY_SIZE(pcie_gen2_param_8822c),
39108c2ecf20Sopenharmony_ci};
39118c2ecf20Sopenharmony_ci
39128c2ecf20Sopenharmony_cistatic const struct rtw_rfe_def rtw8822c_rfe_defs[] = {
39138c2ecf20Sopenharmony_ci	[0] = RTW_DEF_RFE(8822c, 0, 0),
39148c2ecf20Sopenharmony_ci	[1] = RTW_DEF_RFE(8822c, 0, 0),
39158c2ecf20Sopenharmony_ci	[2] = RTW_DEF_RFE(8822c, 0, 0),
39168c2ecf20Sopenharmony_ci	[5] = RTW_DEF_RFE(8822c, 0, 5),
39178c2ecf20Sopenharmony_ci	[6] = RTW_DEF_RFE(8822c, 0, 0),
39188c2ecf20Sopenharmony_ci};
39198c2ecf20Sopenharmony_ci
39208c2ecf20Sopenharmony_cistatic const struct rtw_hw_reg rtw8822c_dig[] = {
39218c2ecf20Sopenharmony_ci	[0] = { .addr = 0x1d70, .mask = 0x7f },
39228c2ecf20Sopenharmony_ci	[1] = { .addr = 0x1d70, .mask = 0x7f00 },
39238c2ecf20Sopenharmony_ci};
39248c2ecf20Sopenharmony_ci
39258c2ecf20Sopenharmony_cistatic const struct rtw_ltecoex_addr rtw8822c_ltecoex_addr = {
39268c2ecf20Sopenharmony_ci	.ctrl = LTECOEX_ACCESS_CTRL,
39278c2ecf20Sopenharmony_ci	.wdata = LTECOEX_WRITE_DATA,
39288c2ecf20Sopenharmony_ci	.rdata = LTECOEX_READ_DATA,
39298c2ecf20Sopenharmony_ci};
39308c2ecf20Sopenharmony_ci
39318c2ecf20Sopenharmony_cistatic const struct rtw_page_table page_table_8822c[] = {
39328c2ecf20Sopenharmony_ci	{64, 64, 64, 64, 1},
39338c2ecf20Sopenharmony_ci	{64, 64, 64, 64, 1},
39348c2ecf20Sopenharmony_ci	{64, 64, 0, 0, 1},
39358c2ecf20Sopenharmony_ci	{64, 64, 64, 0, 1},
39368c2ecf20Sopenharmony_ci	{64, 64, 64, 64, 1},
39378c2ecf20Sopenharmony_ci};
39388c2ecf20Sopenharmony_ci
39398c2ecf20Sopenharmony_cistatic const struct rtw_rqpn rqpn_table_8822c[] = {
39408c2ecf20Sopenharmony_ci	{RTW_DMA_MAPPING_NORMAL, RTW_DMA_MAPPING_NORMAL,
39418c2ecf20Sopenharmony_ci	 RTW_DMA_MAPPING_LOW, RTW_DMA_MAPPING_LOW,
39428c2ecf20Sopenharmony_ci	 RTW_DMA_MAPPING_EXTRA, RTW_DMA_MAPPING_HIGH},
39438c2ecf20Sopenharmony_ci	{RTW_DMA_MAPPING_NORMAL, RTW_DMA_MAPPING_NORMAL,
39448c2ecf20Sopenharmony_ci	 RTW_DMA_MAPPING_LOW, RTW_DMA_MAPPING_LOW,
39458c2ecf20Sopenharmony_ci	 RTW_DMA_MAPPING_EXTRA, RTW_DMA_MAPPING_HIGH},
39468c2ecf20Sopenharmony_ci	{RTW_DMA_MAPPING_NORMAL, RTW_DMA_MAPPING_NORMAL,
39478c2ecf20Sopenharmony_ci	 RTW_DMA_MAPPING_NORMAL, RTW_DMA_MAPPING_HIGH,
39488c2ecf20Sopenharmony_ci	 RTW_DMA_MAPPING_HIGH, RTW_DMA_MAPPING_HIGH},
39498c2ecf20Sopenharmony_ci	{RTW_DMA_MAPPING_NORMAL, RTW_DMA_MAPPING_NORMAL,
39508c2ecf20Sopenharmony_ci	 RTW_DMA_MAPPING_LOW, RTW_DMA_MAPPING_LOW,
39518c2ecf20Sopenharmony_ci	 RTW_DMA_MAPPING_HIGH, RTW_DMA_MAPPING_HIGH},
39528c2ecf20Sopenharmony_ci	{RTW_DMA_MAPPING_NORMAL, RTW_DMA_MAPPING_NORMAL,
39538c2ecf20Sopenharmony_ci	 RTW_DMA_MAPPING_LOW, RTW_DMA_MAPPING_LOW,
39548c2ecf20Sopenharmony_ci	 RTW_DMA_MAPPING_EXTRA, RTW_DMA_MAPPING_HIGH},
39558c2ecf20Sopenharmony_ci};
39568c2ecf20Sopenharmony_ci
39578c2ecf20Sopenharmony_cistatic struct rtw_prioq_addrs prioq_addrs_8822c = {
39588c2ecf20Sopenharmony_ci	.prio[RTW_DMA_MAPPING_EXTRA] = {
39598c2ecf20Sopenharmony_ci		.rsvd = REG_FIFOPAGE_INFO_4, .avail = REG_FIFOPAGE_INFO_4 + 2,
39608c2ecf20Sopenharmony_ci	},
39618c2ecf20Sopenharmony_ci	.prio[RTW_DMA_MAPPING_LOW] = {
39628c2ecf20Sopenharmony_ci		.rsvd = REG_FIFOPAGE_INFO_2, .avail = REG_FIFOPAGE_INFO_2 + 2,
39638c2ecf20Sopenharmony_ci	},
39648c2ecf20Sopenharmony_ci	.prio[RTW_DMA_MAPPING_NORMAL] = {
39658c2ecf20Sopenharmony_ci		.rsvd = REG_FIFOPAGE_INFO_3, .avail = REG_FIFOPAGE_INFO_3 + 2,
39668c2ecf20Sopenharmony_ci	},
39678c2ecf20Sopenharmony_ci	.prio[RTW_DMA_MAPPING_HIGH] = {
39688c2ecf20Sopenharmony_ci		.rsvd = REG_FIFOPAGE_INFO_1, .avail = REG_FIFOPAGE_INFO_1 + 2,
39698c2ecf20Sopenharmony_ci	},
39708c2ecf20Sopenharmony_ci	.wsize = true,
39718c2ecf20Sopenharmony_ci};
39728c2ecf20Sopenharmony_ci
39738c2ecf20Sopenharmony_cistatic struct rtw_chip_ops rtw8822c_ops = {
39748c2ecf20Sopenharmony_ci	.phy_set_param		= rtw8822c_phy_set_param,
39758c2ecf20Sopenharmony_ci	.read_efuse		= rtw8822c_read_efuse,
39768c2ecf20Sopenharmony_ci	.query_rx_desc		= rtw8822c_query_rx_desc,
39778c2ecf20Sopenharmony_ci	.set_channel		= rtw8822c_set_channel,
39788c2ecf20Sopenharmony_ci	.mac_init		= rtw8822c_mac_init,
39798c2ecf20Sopenharmony_ci	.read_rf		= rtw_phy_read_rf,
39808c2ecf20Sopenharmony_ci	.write_rf		= rtw_phy_write_rf_reg_mix,
39818c2ecf20Sopenharmony_ci	.set_tx_power_index	= rtw8822c_set_tx_power_index,
39828c2ecf20Sopenharmony_ci	.set_antenna		= rtw8822c_set_antenna,
39838c2ecf20Sopenharmony_ci	.cfg_ldo25		= rtw8822c_cfg_ldo25,
39848c2ecf20Sopenharmony_ci	.false_alarm_statistics	= rtw8822c_false_alarm_statistics,
39858c2ecf20Sopenharmony_ci	.dpk_track		= rtw8822c_dpk_track,
39868c2ecf20Sopenharmony_ci	.phy_calibration	= rtw8822c_phy_calibration,
39878c2ecf20Sopenharmony_ci	.cck_pd_set		= rtw8822c_phy_cck_pd_set,
39888c2ecf20Sopenharmony_ci	.pwr_track		= rtw8822c_pwr_track,
39898c2ecf20Sopenharmony_ci	.config_bfee		= rtw8822c_bf_config_bfee,
39908c2ecf20Sopenharmony_ci	.set_gid_table		= rtw_bf_set_gid_table,
39918c2ecf20Sopenharmony_ci	.cfg_csi_rate		= rtw_bf_cfg_csi_rate,
39928c2ecf20Sopenharmony_ci
39938c2ecf20Sopenharmony_ci	.coex_set_init		= rtw8822c_coex_cfg_init,
39948c2ecf20Sopenharmony_ci	.coex_set_ant_switch	= NULL,
39958c2ecf20Sopenharmony_ci	.coex_set_gnt_fix	= rtw8822c_coex_cfg_gnt_fix,
39968c2ecf20Sopenharmony_ci	.coex_set_gnt_debug	= rtw8822c_coex_cfg_gnt_debug,
39978c2ecf20Sopenharmony_ci	.coex_set_rfe_type	= rtw8822c_coex_cfg_rfe_type,
39988c2ecf20Sopenharmony_ci	.coex_set_wl_tx_power	= rtw8822c_coex_cfg_wl_tx_power,
39998c2ecf20Sopenharmony_ci	.coex_set_wl_rx_gain	= rtw8822c_coex_cfg_wl_rx_gain,
40008c2ecf20Sopenharmony_ci};
40018c2ecf20Sopenharmony_ci
40028c2ecf20Sopenharmony_ci/* Shared-Antenna Coex Table */
40038c2ecf20Sopenharmony_cistatic const struct coex_table_para table_sant_8822c[] = {
40048c2ecf20Sopenharmony_ci	{0xffffffff, 0xffffffff}, /* case-0 */
40058c2ecf20Sopenharmony_ci	{0x55555555, 0x55555555},
40068c2ecf20Sopenharmony_ci	{0x66555555, 0x66555555},
40078c2ecf20Sopenharmony_ci	{0xaaaaaaaa, 0xaaaaaaaa},
40088c2ecf20Sopenharmony_ci	{0x5a5a5a5a, 0x5a5a5a5a},
40098c2ecf20Sopenharmony_ci	{0xfafafafa, 0xfafafafa}, /* case-5 */
40108c2ecf20Sopenharmony_ci	{0x6a5a6a5a, 0xaaaaaaaa},
40118c2ecf20Sopenharmony_ci	{0x6a5a56aa, 0x6a5a56aa},
40128c2ecf20Sopenharmony_ci	{0x6a5a5a5a, 0x6a5a5a5a},
40138c2ecf20Sopenharmony_ci	{0x66555555, 0x5a5a5a5a},
40148c2ecf20Sopenharmony_ci	{0x66555555, 0x6a5a5a5a}, /* case-10 */
40158c2ecf20Sopenharmony_ci	{0x66555555, 0xfafafafa},
40168c2ecf20Sopenharmony_ci	{0x66555555, 0x5a5a5aaa},
40178c2ecf20Sopenharmony_ci	{0x66555555, 0x5aaa5aaa},
40188c2ecf20Sopenharmony_ci	{0x66555555, 0xaaaa5aaa},
40198c2ecf20Sopenharmony_ci	{0x66555555, 0xaaaaaaaa}, /* case-15 */
40208c2ecf20Sopenharmony_ci	{0xffff55ff, 0xfafafafa},
40218c2ecf20Sopenharmony_ci	{0xffff55ff, 0x6afa5afa},
40228c2ecf20Sopenharmony_ci	{0xaaffffaa, 0xfafafafa},
40238c2ecf20Sopenharmony_ci	{0xaa5555aa, 0x5a5a5a5a},
40248c2ecf20Sopenharmony_ci	{0xaa5555aa, 0x6a5a5a5a}, /* case-20 */
40258c2ecf20Sopenharmony_ci	{0xaa5555aa, 0xaaaaaaaa},
40268c2ecf20Sopenharmony_ci	{0xffffffff, 0x5a5a5a5a},
40278c2ecf20Sopenharmony_ci	{0xffffffff, 0x6a5a5a5a},
40288c2ecf20Sopenharmony_ci	{0xffffffff, 0x55555555},
40298c2ecf20Sopenharmony_ci	{0xffffffff, 0x6a5a5aaa}, /* case-25 */
40308c2ecf20Sopenharmony_ci	{0x55555555, 0x5a5a5a5a},
40318c2ecf20Sopenharmony_ci	{0x55555555, 0xaaaaaaaa},
40328c2ecf20Sopenharmony_ci	{0x55555555, 0x6a5a6a5a},
40338c2ecf20Sopenharmony_ci	{0x66556655, 0x66556655}
40348c2ecf20Sopenharmony_ci};
40358c2ecf20Sopenharmony_ci
40368c2ecf20Sopenharmony_ci/* Non-Shared-Antenna Coex Table */
40378c2ecf20Sopenharmony_cistatic const struct coex_table_para table_nsant_8822c[] = {
40388c2ecf20Sopenharmony_ci	{0xffffffff, 0xffffffff}, /* case-100 */
40398c2ecf20Sopenharmony_ci	{0x55555555, 0x55555555},
40408c2ecf20Sopenharmony_ci	{0x66555555, 0x66555555},
40418c2ecf20Sopenharmony_ci	{0xaaaaaaaa, 0xaaaaaaaa},
40428c2ecf20Sopenharmony_ci	{0x5a5a5a5a, 0x5a5a5a5a},
40438c2ecf20Sopenharmony_ci	{0xfafafafa, 0xfafafafa}, /* case-105 */
40448c2ecf20Sopenharmony_ci	{0x5afa5afa, 0x5afa5afa},
40458c2ecf20Sopenharmony_ci	{0x55555555, 0xfafafafa},
40468c2ecf20Sopenharmony_ci	{0x66555555, 0xfafafafa},
40478c2ecf20Sopenharmony_ci	{0x66555555, 0x5a5a5a5a},
40488c2ecf20Sopenharmony_ci	{0x66555555, 0x6a5a5a5a}, /* case-110 */
40498c2ecf20Sopenharmony_ci	{0x66555555, 0xaaaaaaaa},
40508c2ecf20Sopenharmony_ci	{0xffff55ff, 0xfafafafa},
40518c2ecf20Sopenharmony_ci	{0xffff55ff, 0x5afa5afa},
40528c2ecf20Sopenharmony_ci	{0xffff55ff, 0xaaaaaaaa},
40538c2ecf20Sopenharmony_ci	{0xaaffffaa, 0xfafafafa}, /* case-115 */
40548c2ecf20Sopenharmony_ci	{0xaaffffaa, 0x5afa5afa},
40558c2ecf20Sopenharmony_ci	{0xaaffffaa, 0xaaaaaaaa},
40568c2ecf20Sopenharmony_ci	{0xffffffff, 0xfafafafa},
40578c2ecf20Sopenharmony_ci	{0xffffffff, 0x5afa5afa},
40588c2ecf20Sopenharmony_ci	{0xffffffff, 0xaaaaaaaa},/* case-120 */
40598c2ecf20Sopenharmony_ci	{0x55ff55ff, 0x5afa5afa},
40608c2ecf20Sopenharmony_ci	{0x55ff55ff, 0xaaaaaaaa},
40618c2ecf20Sopenharmony_ci	{0x55ff55ff, 0x55ff55ff}
40628c2ecf20Sopenharmony_ci};
40638c2ecf20Sopenharmony_ci
40648c2ecf20Sopenharmony_ci/* Shared-Antenna TDMA */
40658c2ecf20Sopenharmony_cistatic const struct coex_tdma_para tdma_sant_8822c[] = {
40668c2ecf20Sopenharmony_ci	{ {0x00, 0x00, 0x00, 0x00, 0x00} }, /* case-0 */
40678c2ecf20Sopenharmony_ci	{ {0x61, 0x45, 0x03, 0x11, 0x11} },
40688c2ecf20Sopenharmony_ci	{ {0x61, 0x3a, 0x03, 0x11, 0x11} },
40698c2ecf20Sopenharmony_ci	{ {0x61, 0x30, 0x03, 0x11, 0x11} },
40708c2ecf20Sopenharmony_ci	{ {0x61, 0x20, 0x03, 0x11, 0x11} },
40718c2ecf20Sopenharmony_ci	{ {0x61, 0x10, 0x03, 0x11, 0x11} }, /* case-5 */
40728c2ecf20Sopenharmony_ci	{ {0x61, 0x45, 0x03, 0x11, 0x10} },
40738c2ecf20Sopenharmony_ci	{ {0x61, 0x3a, 0x03, 0x11, 0x10} },
40748c2ecf20Sopenharmony_ci	{ {0x61, 0x30, 0x03, 0x11, 0x10} },
40758c2ecf20Sopenharmony_ci	{ {0x61, 0x20, 0x03, 0x11, 0x10} },
40768c2ecf20Sopenharmony_ci	{ {0x61, 0x10, 0x03, 0x11, 0x10} }, /* case-10 */
40778c2ecf20Sopenharmony_ci	{ {0x61, 0x08, 0x03, 0x11, 0x14} },
40788c2ecf20Sopenharmony_ci	{ {0x61, 0x08, 0x03, 0x10, 0x14} },
40798c2ecf20Sopenharmony_ci	{ {0x51, 0x08, 0x03, 0x10, 0x54} },
40808c2ecf20Sopenharmony_ci	{ {0x51, 0x08, 0x03, 0x10, 0x55} },
40818c2ecf20Sopenharmony_ci	{ {0x51, 0x08, 0x07, 0x10, 0x54} }, /* case-15 */
40828c2ecf20Sopenharmony_ci	{ {0x51, 0x45, 0x03, 0x10, 0x10} },
40838c2ecf20Sopenharmony_ci	{ {0x51, 0x3a, 0x03, 0x10, 0x50} },
40848c2ecf20Sopenharmony_ci	{ {0x51, 0x30, 0x03, 0x10, 0x50} },
40858c2ecf20Sopenharmony_ci	{ {0x51, 0x20, 0x03, 0x10, 0x50} },
40868c2ecf20Sopenharmony_ci	{ {0x51, 0x10, 0x03, 0x10, 0x50} }, /* case-20 */
40878c2ecf20Sopenharmony_ci	{ {0x51, 0x4a, 0x03, 0x10, 0x50} },
40888c2ecf20Sopenharmony_ci	{ {0x51, 0x0c, 0x03, 0x10, 0x54} },
40898c2ecf20Sopenharmony_ci	{ {0x55, 0x08, 0x03, 0x10, 0x54} },
40908c2ecf20Sopenharmony_ci	{ {0x65, 0x10, 0x03, 0x11, 0x11} },
40918c2ecf20Sopenharmony_ci	{ {0x51, 0x10, 0x03, 0x10, 0x51} }, /* case-25 */
40928c2ecf20Sopenharmony_ci	{ {0x51, 0x08, 0x03, 0x10, 0x50} },
40938c2ecf20Sopenharmony_ci	{ {0x61, 0x08, 0x03, 0x11, 0x11} }
40948c2ecf20Sopenharmony_ci};
40958c2ecf20Sopenharmony_ci
40968c2ecf20Sopenharmony_ci/* Non-Shared-Antenna TDMA */
40978c2ecf20Sopenharmony_cistatic const struct coex_tdma_para tdma_nsant_8822c[] = {
40988c2ecf20Sopenharmony_ci	{ {0x00, 0x00, 0x00, 0x00, 0x00} }, /* case-100 */
40998c2ecf20Sopenharmony_ci	{ {0x61, 0x45, 0x03, 0x11, 0x11} },
41008c2ecf20Sopenharmony_ci	{ {0x61, 0x3a, 0x03, 0x11, 0x11} },
41018c2ecf20Sopenharmony_ci	{ {0x61, 0x30, 0x03, 0x11, 0x11} },
41028c2ecf20Sopenharmony_ci	{ {0x61, 0x20, 0x03, 0x11, 0x11} },
41038c2ecf20Sopenharmony_ci	{ {0x61, 0x10, 0x03, 0x11, 0x11} }, /* case-105 */
41048c2ecf20Sopenharmony_ci	{ {0x61, 0x45, 0x03, 0x11, 0x10} },
41058c2ecf20Sopenharmony_ci	{ {0x61, 0x3a, 0x03, 0x11, 0x10} },
41068c2ecf20Sopenharmony_ci	{ {0x61, 0x30, 0x03, 0x11, 0x10} },
41078c2ecf20Sopenharmony_ci	{ {0x61, 0x20, 0x03, 0x11, 0x10} },
41088c2ecf20Sopenharmony_ci	{ {0x61, 0x10, 0x03, 0x11, 0x10} }, /* case-110 */
41098c2ecf20Sopenharmony_ci	{ {0x61, 0x08, 0x03, 0x11, 0x14} },
41108c2ecf20Sopenharmony_ci	{ {0x61, 0x08, 0x03, 0x10, 0x14} },
41118c2ecf20Sopenharmony_ci	{ {0x51, 0x08, 0x03, 0x10, 0x54} },
41128c2ecf20Sopenharmony_ci	{ {0x51, 0x08, 0x03, 0x10, 0x55} },
41138c2ecf20Sopenharmony_ci	{ {0x51, 0x08, 0x07, 0x10, 0x54} }, /* case-115 */
41148c2ecf20Sopenharmony_ci	{ {0x51, 0x45, 0x03, 0x10, 0x50} },
41158c2ecf20Sopenharmony_ci	{ {0x51, 0x3a, 0x03, 0x10, 0x50} },
41168c2ecf20Sopenharmony_ci	{ {0x51, 0x30, 0x03, 0x10, 0x50} },
41178c2ecf20Sopenharmony_ci	{ {0x51, 0x20, 0x03, 0x10, 0x50} },
41188c2ecf20Sopenharmony_ci	{ {0x51, 0x10, 0x03, 0x10, 0x50} }  /* case-120 */
41198c2ecf20Sopenharmony_ci};
41208c2ecf20Sopenharmony_ci
41218c2ecf20Sopenharmony_ci/* rssi in percentage % (dbm = % - 100) */
41228c2ecf20Sopenharmony_cistatic const u8 wl_rssi_step_8822c[] = {60, 50, 44, 30};
41238c2ecf20Sopenharmony_cistatic const u8 bt_rssi_step_8822c[] = {8, 15, 20, 25};
41248c2ecf20Sopenharmony_cistatic const struct coex_5g_afh_map afh_5g_8822c[] = { {0, 0, 0} };
41258c2ecf20Sopenharmony_ci
41268c2ecf20Sopenharmony_ci/* wl_tx_dec_power, bt_tx_dec_power, wl_rx_gain, bt_rx_lna_constrain */
41278c2ecf20Sopenharmony_cistatic const struct coex_rf_para rf_para_tx_8822c[] = {
41288c2ecf20Sopenharmony_ci	{0, 0, false, 7},  /* for normal */
41298c2ecf20Sopenharmony_ci	{0, 16, false, 7}, /* for WL-CPT */
41308c2ecf20Sopenharmony_ci	{8, 17, true, 4},
41318c2ecf20Sopenharmony_ci	{7, 18, true, 4},
41328c2ecf20Sopenharmony_ci	{6, 19, true, 4},
41338c2ecf20Sopenharmony_ci	{5, 20, true, 4}
41348c2ecf20Sopenharmony_ci};
41358c2ecf20Sopenharmony_ci
41368c2ecf20Sopenharmony_cistatic const struct coex_rf_para rf_para_rx_8822c[] = {
41378c2ecf20Sopenharmony_ci	{0, 0, false, 7},  /* for normal */
41388c2ecf20Sopenharmony_ci	{0, 16, false, 7}, /* for WL-CPT */
41398c2ecf20Sopenharmony_ci	{3, 24, true, 5},
41408c2ecf20Sopenharmony_ci	{2, 26, true, 5},
41418c2ecf20Sopenharmony_ci	{1, 27, true, 5},
41428c2ecf20Sopenharmony_ci	{0, 28, true, 5}
41438c2ecf20Sopenharmony_ci};
41448c2ecf20Sopenharmony_ci
41458c2ecf20Sopenharmony_cistatic_assert(ARRAY_SIZE(rf_para_tx_8822c) == ARRAY_SIZE(rf_para_rx_8822c));
41468c2ecf20Sopenharmony_ci
41478c2ecf20Sopenharmony_cistatic const u8
41488c2ecf20Sopenharmony_cirtw8822c_pwrtrk_5gb_n[RTW_PWR_TRK_5G_NUM][RTW_PWR_TRK_TBL_SZ] = {
41498c2ecf20Sopenharmony_ci	{ 0,  1,  2,  3,  5,  6,  7,  8,  9, 10,
41508c2ecf20Sopenharmony_ci	 11, 12, 13, 14, 15, 16, 18, 19, 20, 21,
41518c2ecf20Sopenharmony_ci	 22, 23, 24, 25, 26, 27, 28, 29, 30, 32 },
41528c2ecf20Sopenharmony_ci	{ 0,  1,  2,  3,  5,  6,  7,  8,  9, 10,
41538c2ecf20Sopenharmony_ci	 11, 12, 13, 14, 15, 16, 18, 19, 20, 21,
41548c2ecf20Sopenharmony_ci	 22, 23, 24, 25, 26, 27, 28, 29, 30, 32 },
41558c2ecf20Sopenharmony_ci	{ 0,  1,  2,  3,  5,  6,  7,  8,  9, 10,
41568c2ecf20Sopenharmony_ci	 11, 12, 13, 14, 15, 16, 18, 19, 20, 21,
41578c2ecf20Sopenharmony_ci	 22, 23, 24, 25, 26, 27, 28, 29, 30, 32 },
41588c2ecf20Sopenharmony_ci};
41598c2ecf20Sopenharmony_ci
41608c2ecf20Sopenharmony_cistatic const u8
41618c2ecf20Sopenharmony_cirtw8822c_pwrtrk_5gb_p[RTW_PWR_TRK_5G_NUM][RTW_PWR_TRK_TBL_SZ] = {
41628c2ecf20Sopenharmony_ci	{ 0,  1,  2,  3,  4,  5,  6,  7,  8,  9,
41638c2ecf20Sopenharmony_ci	 10, 10, 11, 12, 13, 14, 15, 16, 17, 18,
41648c2ecf20Sopenharmony_ci	 19, 20, 21, 22, 22, 23, 24, 25, 26, 27 },
41658c2ecf20Sopenharmony_ci	{ 0,  1,  2,  3,  4,  5,  6,  7,  8,  9,
41668c2ecf20Sopenharmony_ci	 10, 10, 11, 12, 13, 14, 15, 16, 17, 18,
41678c2ecf20Sopenharmony_ci	 19, 20, 21, 22, 22, 23, 24, 25, 26, 27 },
41688c2ecf20Sopenharmony_ci	{ 0,  1,  2,  3,  4,  5,  6,  7,  8,  9,
41698c2ecf20Sopenharmony_ci	 10, 10, 11, 12, 13, 14, 15, 16, 17, 18,
41708c2ecf20Sopenharmony_ci	 19, 20, 21, 22, 22, 23, 24, 25, 26, 27 },
41718c2ecf20Sopenharmony_ci};
41728c2ecf20Sopenharmony_ci
41738c2ecf20Sopenharmony_cistatic const u8
41748c2ecf20Sopenharmony_cirtw8822c_pwrtrk_5ga_n[RTW_PWR_TRK_5G_NUM][RTW_PWR_TRK_TBL_SZ] = {
41758c2ecf20Sopenharmony_ci	{ 0,  1,  2,  4,  5,  6,  7,  8,  9, 10,
41768c2ecf20Sopenharmony_ci	 11, 13, 14, 15, 16, 17, 18, 19, 20, 21,
41778c2ecf20Sopenharmony_ci	 23, 24, 25, 26, 27, 28, 29, 30, 31, 33 },
41788c2ecf20Sopenharmony_ci	{ 0,  1,  2,  4,  5,  6,  7,  8,  9, 10,
41798c2ecf20Sopenharmony_ci	 11, 13, 14, 15, 16, 17, 18, 19, 20, 21,
41808c2ecf20Sopenharmony_ci	 23, 24, 25, 26, 27, 28, 29, 30, 31, 33 },
41818c2ecf20Sopenharmony_ci	{ 0,  1,  2,  4,  5,  6,  7,  8,  9, 10,
41828c2ecf20Sopenharmony_ci	 11, 13, 14, 15, 16, 17, 18, 19, 20, 21,
41838c2ecf20Sopenharmony_ci	 23, 24, 25, 26, 27, 28, 29, 30, 31, 33 },
41848c2ecf20Sopenharmony_ci};
41858c2ecf20Sopenharmony_ci
41868c2ecf20Sopenharmony_cistatic const u8
41878c2ecf20Sopenharmony_cirtw8822c_pwrtrk_5ga_p[RTW_PWR_TRK_5G_NUM][RTW_PWR_TRK_TBL_SZ] = {
41888c2ecf20Sopenharmony_ci	{ 0,  1,  2,  3,  4,  5,  6,  7,  8,  9,
41898c2ecf20Sopenharmony_ci	 10, 11, 12, 13, 14, 15, 16, 17, 18, 20,
41908c2ecf20Sopenharmony_ci	 21, 22, 23, 24, 25, 26, 27, 28, 29, 30 },
41918c2ecf20Sopenharmony_ci	{ 0,  1,  2,  3,  4,  5,  6,  7,  8,  9,
41928c2ecf20Sopenharmony_ci	 10, 11, 12, 13, 14, 15, 16, 17, 18, 20,
41938c2ecf20Sopenharmony_ci	 21, 22, 23, 24, 25, 26, 27, 28, 29, 30 },
41948c2ecf20Sopenharmony_ci	{ 0,  1,  2,  3,  4,  5,  6,  7,  8,  9,
41958c2ecf20Sopenharmony_ci	 10, 11, 12, 13, 14, 15, 16, 17, 18, 20,
41968c2ecf20Sopenharmony_ci	 21, 22, 23, 24, 25, 26, 27, 28, 29, 30 },
41978c2ecf20Sopenharmony_ci};
41988c2ecf20Sopenharmony_ci
41998c2ecf20Sopenharmony_cistatic const u8 rtw8822c_pwrtrk_2gb_n[RTW_PWR_TRK_TBL_SZ] = {
42008c2ecf20Sopenharmony_ci	 0,  1,  2,  3,  4,  4,  5,  6,  7,  8,
42018c2ecf20Sopenharmony_ci	 9,  9, 10, 11, 12, 13, 14, 15, 15, 16,
42028c2ecf20Sopenharmony_ci	17, 18, 19, 20, 20, 21, 22, 23, 24, 25
42038c2ecf20Sopenharmony_ci};
42048c2ecf20Sopenharmony_ci
42058c2ecf20Sopenharmony_cistatic const u8 rtw8822c_pwrtrk_2gb_p[RTW_PWR_TRK_TBL_SZ] = {
42068c2ecf20Sopenharmony_ci	 0,  1,  2,  3,  4,  5,  6,  7,  8,  9,
42078c2ecf20Sopenharmony_ci	10, 11, 12, 13, 14, 14, 15, 16, 17, 18,
42088c2ecf20Sopenharmony_ci	19, 20, 21, 22, 23, 24, 25, 26, 27, 28
42098c2ecf20Sopenharmony_ci};
42108c2ecf20Sopenharmony_ci
42118c2ecf20Sopenharmony_cistatic const u8 rtw8822c_pwrtrk_2ga_n[RTW_PWR_TRK_TBL_SZ] = {
42128c2ecf20Sopenharmony_ci	 0,  1,  2,  2,  3,  4,  4,  5,  6,  6,
42138c2ecf20Sopenharmony_ci	 7,  8,  8,  9,  9, 10, 11, 11, 12, 13,
42148c2ecf20Sopenharmony_ci	13, 14, 15, 15, 16, 17, 17, 18, 19, 19
42158c2ecf20Sopenharmony_ci};
42168c2ecf20Sopenharmony_ci
42178c2ecf20Sopenharmony_cistatic const u8 rtw8822c_pwrtrk_2ga_p[RTW_PWR_TRK_TBL_SZ] = {
42188c2ecf20Sopenharmony_ci	 0,  1,  2,  3,  4,  5,  6,  7,  8,  9,
42198c2ecf20Sopenharmony_ci	10, 11, 11, 12, 13, 14, 15, 16, 17, 18,
42208c2ecf20Sopenharmony_ci	19, 20, 21, 22, 23, 24, 25, 25, 26, 27
42218c2ecf20Sopenharmony_ci};
42228c2ecf20Sopenharmony_ci
42238c2ecf20Sopenharmony_cistatic const u8 rtw8822c_pwrtrk_2g_cck_b_n[RTW_PWR_TRK_TBL_SZ] = {
42248c2ecf20Sopenharmony_ci	 0,  1,  2,  3,  4,  5,  5,  6,  7,  8,
42258c2ecf20Sopenharmony_ci	 9, 10, 11, 11, 12, 13, 14, 15, 16, 17,
42268c2ecf20Sopenharmony_ci	17, 18, 19, 20, 21, 22, 23, 23, 24, 25
42278c2ecf20Sopenharmony_ci};
42288c2ecf20Sopenharmony_ci
42298c2ecf20Sopenharmony_cistatic const u8 rtw8822c_pwrtrk_2g_cck_b_p[RTW_PWR_TRK_TBL_SZ] = {
42308c2ecf20Sopenharmony_ci	 0,  1,  2,  3,  4,  5,  6,  7,  8,  9,
42318c2ecf20Sopenharmony_ci	10, 11, 12, 13, 14, 15, 16, 17, 18, 19,
42328c2ecf20Sopenharmony_ci	20, 21, 22, 23, 24, 25, 26, 27, 28, 29
42338c2ecf20Sopenharmony_ci};
42348c2ecf20Sopenharmony_ci
42358c2ecf20Sopenharmony_cistatic const u8 rtw8822c_pwrtrk_2g_cck_a_n[RTW_PWR_TRK_TBL_SZ] = {
42368c2ecf20Sopenharmony_ci	 0,  1,  2,  3,  3,  4,  5,  6,  6,  7,
42378c2ecf20Sopenharmony_ci	 8,  9,  9, 10, 11, 12, 12, 13, 14, 15,
42388c2ecf20Sopenharmony_ci	15, 16, 17, 18, 18, 19, 20, 21, 21, 22
42398c2ecf20Sopenharmony_ci};
42408c2ecf20Sopenharmony_ci
42418c2ecf20Sopenharmony_cistatic const u8 rtw8822c_pwrtrk_2g_cck_a_p[RTW_PWR_TRK_TBL_SZ] = {
42428c2ecf20Sopenharmony_ci	 0,  1,  2,  3,  4,  5,  5,  6,  7,  8,
42438c2ecf20Sopenharmony_ci	 9, 10, 11, 11, 12, 13, 14, 15, 16, 17,
42448c2ecf20Sopenharmony_ci	18, 18, 19, 20, 21, 22, 23, 24, 24, 25
42458c2ecf20Sopenharmony_ci};
42468c2ecf20Sopenharmony_ci
42478c2ecf20Sopenharmony_cistatic const struct rtw_pwr_track_tbl rtw8822c_rtw_pwr_track_tbl = {
42488c2ecf20Sopenharmony_ci	.pwrtrk_5gb_n[RTW_PWR_TRK_5G_1] = rtw8822c_pwrtrk_5gb_n[RTW_PWR_TRK_5G_1],
42498c2ecf20Sopenharmony_ci	.pwrtrk_5gb_n[RTW_PWR_TRK_5G_2] = rtw8822c_pwrtrk_5gb_n[RTW_PWR_TRK_5G_2],
42508c2ecf20Sopenharmony_ci	.pwrtrk_5gb_n[RTW_PWR_TRK_5G_3] = rtw8822c_pwrtrk_5gb_n[RTW_PWR_TRK_5G_3],
42518c2ecf20Sopenharmony_ci	.pwrtrk_5gb_p[RTW_PWR_TRK_5G_1] = rtw8822c_pwrtrk_5gb_p[RTW_PWR_TRK_5G_1],
42528c2ecf20Sopenharmony_ci	.pwrtrk_5gb_p[RTW_PWR_TRK_5G_2] = rtw8822c_pwrtrk_5gb_p[RTW_PWR_TRK_5G_2],
42538c2ecf20Sopenharmony_ci	.pwrtrk_5gb_p[RTW_PWR_TRK_5G_3] = rtw8822c_pwrtrk_5gb_p[RTW_PWR_TRK_5G_3],
42548c2ecf20Sopenharmony_ci	.pwrtrk_5ga_n[RTW_PWR_TRK_5G_1] = rtw8822c_pwrtrk_5ga_n[RTW_PWR_TRK_5G_1],
42558c2ecf20Sopenharmony_ci	.pwrtrk_5ga_n[RTW_PWR_TRK_5G_2] = rtw8822c_pwrtrk_5ga_n[RTW_PWR_TRK_5G_2],
42568c2ecf20Sopenharmony_ci	.pwrtrk_5ga_n[RTW_PWR_TRK_5G_3] = rtw8822c_pwrtrk_5ga_n[RTW_PWR_TRK_5G_3],
42578c2ecf20Sopenharmony_ci	.pwrtrk_5ga_p[RTW_PWR_TRK_5G_1] = rtw8822c_pwrtrk_5ga_p[RTW_PWR_TRK_5G_1],
42588c2ecf20Sopenharmony_ci	.pwrtrk_5ga_p[RTW_PWR_TRK_5G_2] = rtw8822c_pwrtrk_5ga_p[RTW_PWR_TRK_5G_2],
42598c2ecf20Sopenharmony_ci	.pwrtrk_5ga_p[RTW_PWR_TRK_5G_3] = rtw8822c_pwrtrk_5ga_p[RTW_PWR_TRK_5G_3],
42608c2ecf20Sopenharmony_ci	.pwrtrk_2gb_n = rtw8822c_pwrtrk_2gb_n,
42618c2ecf20Sopenharmony_ci	.pwrtrk_2gb_p = rtw8822c_pwrtrk_2gb_p,
42628c2ecf20Sopenharmony_ci	.pwrtrk_2ga_n = rtw8822c_pwrtrk_2ga_n,
42638c2ecf20Sopenharmony_ci	.pwrtrk_2ga_p = rtw8822c_pwrtrk_2ga_p,
42648c2ecf20Sopenharmony_ci	.pwrtrk_2g_cckb_n = rtw8822c_pwrtrk_2g_cck_b_n,
42658c2ecf20Sopenharmony_ci	.pwrtrk_2g_cckb_p = rtw8822c_pwrtrk_2g_cck_b_p,
42668c2ecf20Sopenharmony_ci	.pwrtrk_2g_ccka_n = rtw8822c_pwrtrk_2g_cck_a_n,
42678c2ecf20Sopenharmony_ci	.pwrtrk_2g_ccka_p = rtw8822c_pwrtrk_2g_cck_a_p,
42688c2ecf20Sopenharmony_ci};
42698c2ecf20Sopenharmony_ci
42708c2ecf20Sopenharmony_ci#ifdef CONFIG_PM
42718c2ecf20Sopenharmony_cistatic const struct wiphy_wowlan_support rtw_wowlan_stub_8822c = {
42728c2ecf20Sopenharmony_ci	.flags = WIPHY_WOWLAN_MAGIC_PKT | WIPHY_WOWLAN_GTK_REKEY_FAILURE |
42738c2ecf20Sopenharmony_ci		 WIPHY_WOWLAN_DISCONNECT | WIPHY_WOWLAN_SUPPORTS_GTK_REKEY |
42748c2ecf20Sopenharmony_ci		 WIPHY_WOWLAN_NET_DETECT,
42758c2ecf20Sopenharmony_ci	.n_patterns = RTW_MAX_PATTERN_NUM,
42768c2ecf20Sopenharmony_ci	.pattern_max_len = RTW_MAX_PATTERN_SIZE,
42778c2ecf20Sopenharmony_ci	.pattern_min_len = 1,
42788c2ecf20Sopenharmony_ci	.max_nd_match_sets = 4,
42798c2ecf20Sopenharmony_ci};
42808c2ecf20Sopenharmony_ci#endif
42818c2ecf20Sopenharmony_ci
42828c2ecf20Sopenharmony_cistatic const struct rtw_reg_domain coex_info_hw_regs_8822c[] = {
42838c2ecf20Sopenharmony_ci	{0x1860, BIT(3), RTW_REG_DOMAIN_MAC8},
42848c2ecf20Sopenharmony_ci	{0x4160, BIT(3), RTW_REG_DOMAIN_MAC8},
42858c2ecf20Sopenharmony_ci	{0x1c32, BIT(6), RTW_REG_DOMAIN_MAC8},
42868c2ecf20Sopenharmony_ci	{0x1c38, BIT(28), RTW_REG_DOMAIN_MAC32},
42878c2ecf20Sopenharmony_ci	{0, 0, RTW_REG_DOMAIN_NL},
42888c2ecf20Sopenharmony_ci	{0x430, MASKDWORD, RTW_REG_DOMAIN_MAC32},
42898c2ecf20Sopenharmony_ci	{0x434, MASKDWORD, RTW_REG_DOMAIN_MAC32},
42908c2ecf20Sopenharmony_ci	{0x42a, MASKLWORD, RTW_REG_DOMAIN_MAC16},
42918c2ecf20Sopenharmony_ci	{0x426, MASKBYTE0, RTW_REG_DOMAIN_MAC8},
42928c2ecf20Sopenharmony_ci	{0x45e, BIT(3), RTW_REG_DOMAIN_MAC8},
42938c2ecf20Sopenharmony_ci	{0x454, MASKLWORD, RTW_REG_DOMAIN_MAC16},
42948c2ecf20Sopenharmony_ci	{0, 0, RTW_REG_DOMAIN_NL},
42958c2ecf20Sopenharmony_ci	{0x4c, BIT(24) | BIT(23), RTW_REG_DOMAIN_MAC32},
42968c2ecf20Sopenharmony_ci	{0x64, BIT(0), RTW_REG_DOMAIN_MAC8},
42978c2ecf20Sopenharmony_ci	{0x4c6, BIT(4), RTW_REG_DOMAIN_MAC8},
42988c2ecf20Sopenharmony_ci	{0x40, BIT(5), RTW_REG_DOMAIN_MAC8},
42998c2ecf20Sopenharmony_ci	{0x1, RFREG_MASK, RTW_REG_DOMAIN_RF_B},
43008c2ecf20Sopenharmony_ci	{0, 0, RTW_REG_DOMAIN_NL},
43018c2ecf20Sopenharmony_ci	{0x550, MASKDWORD, RTW_REG_DOMAIN_MAC32},
43028c2ecf20Sopenharmony_ci	{0x522, MASKBYTE0, RTW_REG_DOMAIN_MAC8},
43038c2ecf20Sopenharmony_ci	{0x953, BIT(1), RTW_REG_DOMAIN_MAC8},
43048c2ecf20Sopenharmony_ci	{0xc50, MASKBYTE0, RTW_REG_DOMAIN_MAC8},
43058c2ecf20Sopenharmony_ci};
43068c2ecf20Sopenharmony_ci
43078c2ecf20Sopenharmony_cistruct rtw_chip_info rtw8822c_hw_spec = {
43088c2ecf20Sopenharmony_ci	.ops = &rtw8822c_ops,
43098c2ecf20Sopenharmony_ci	.id = RTW_CHIP_TYPE_8822C,
43108c2ecf20Sopenharmony_ci	.fw_name = "rtw88/rtw8822c_fw.bin",
43118c2ecf20Sopenharmony_ci	.wlan_cpu = RTW_WCPU_11AC,
43128c2ecf20Sopenharmony_ci	.tx_pkt_desc_sz = 48,
43138c2ecf20Sopenharmony_ci	.tx_buf_desc_sz = 16,
43148c2ecf20Sopenharmony_ci	.rx_pkt_desc_sz = 24,
43158c2ecf20Sopenharmony_ci	.rx_buf_desc_sz = 8,
43168c2ecf20Sopenharmony_ci	.phy_efuse_size = 512,
43178c2ecf20Sopenharmony_ci	.log_efuse_size = 768,
43188c2ecf20Sopenharmony_ci	.ptct_efuse_size = 124,
43198c2ecf20Sopenharmony_ci	.txff_size = 262144,
43208c2ecf20Sopenharmony_ci	.rxff_size = 24576,
43218c2ecf20Sopenharmony_ci	.fw_rxff_size = 12288,
43228c2ecf20Sopenharmony_ci	.txgi_factor = 2,
43238c2ecf20Sopenharmony_ci	.is_pwr_by_rate_dec = false,
43248c2ecf20Sopenharmony_ci	.max_power_index = 0x7f,
43258c2ecf20Sopenharmony_ci	.csi_buf_pg_num = 50,
43268c2ecf20Sopenharmony_ci	.band = RTW_BAND_2G | RTW_BAND_5G,
43278c2ecf20Sopenharmony_ci	.page_size = 128,
43288c2ecf20Sopenharmony_ci	.dig_min = 0x20,
43298c2ecf20Sopenharmony_ci	.ht_supported = true,
43308c2ecf20Sopenharmony_ci	.vht_supported = true,
43318c2ecf20Sopenharmony_ci	.lps_deep_mode_supported = BIT(LPS_DEEP_MODE_LCLK) | BIT(LPS_DEEP_MODE_PG),
43328c2ecf20Sopenharmony_ci	.sys_func_en = 0xD8,
43338c2ecf20Sopenharmony_ci	.pwr_on_seq = card_enable_flow_8822c,
43348c2ecf20Sopenharmony_ci	.pwr_off_seq = card_disable_flow_8822c,
43358c2ecf20Sopenharmony_ci	.page_table = page_table_8822c,
43368c2ecf20Sopenharmony_ci	.rqpn_table = rqpn_table_8822c,
43378c2ecf20Sopenharmony_ci	.prioq_addrs = &prioq_addrs_8822c,
43388c2ecf20Sopenharmony_ci	.intf_table = &phy_para_table_8822c,
43398c2ecf20Sopenharmony_ci	.dig = rtw8822c_dig,
43408c2ecf20Sopenharmony_ci	.dig_cck = NULL,
43418c2ecf20Sopenharmony_ci	.rf_base_addr = {0x3c00, 0x4c00},
43428c2ecf20Sopenharmony_ci	.rf_sipi_addr = {0x1808, 0x4108},
43438c2ecf20Sopenharmony_ci	.ltecoex_addr = &rtw8822c_ltecoex_addr,
43448c2ecf20Sopenharmony_ci	.mac_tbl = &rtw8822c_mac_tbl,
43458c2ecf20Sopenharmony_ci	.agc_tbl = &rtw8822c_agc_tbl,
43468c2ecf20Sopenharmony_ci	.bb_tbl = &rtw8822c_bb_tbl,
43478c2ecf20Sopenharmony_ci	.rfk_init_tbl = &rtw8822c_array_mp_cal_init_tbl,
43488c2ecf20Sopenharmony_ci	.rf_tbl = {&rtw8822c_rf_b_tbl, &rtw8822c_rf_a_tbl},
43498c2ecf20Sopenharmony_ci	.rfe_defs = rtw8822c_rfe_defs,
43508c2ecf20Sopenharmony_ci	.rfe_defs_size = ARRAY_SIZE(rtw8822c_rfe_defs),
43518c2ecf20Sopenharmony_ci	.en_dis_dpd = true,
43528c2ecf20Sopenharmony_ci	.dpd_ratemask = DIS_DPD_RATEALL,
43538c2ecf20Sopenharmony_ci	.pwr_track_tbl = &rtw8822c_rtw_pwr_track_tbl,
43548c2ecf20Sopenharmony_ci	.iqk_threshold = 8,
43558c2ecf20Sopenharmony_ci	.lck_threshold = 8,
43568c2ecf20Sopenharmony_ci	.bfer_su_max_num = 2,
43578c2ecf20Sopenharmony_ci	.bfer_mu_max_num = 1,
43588c2ecf20Sopenharmony_ci	.rx_ldpc = true,
43598c2ecf20Sopenharmony_ci
43608c2ecf20Sopenharmony_ci#ifdef CONFIG_PM
43618c2ecf20Sopenharmony_ci	.wow_fw_name = "rtw88/rtw8822c_wow_fw.bin",
43628c2ecf20Sopenharmony_ci	.wowlan_stub = &rtw_wowlan_stub_8822c,
43638c2ecf20Sopenharmony_ci	.max_sched_scan_ssids = 4,
43648c2ecf20Sopenharmony_ci#endif
43658c2ecf20Sopenharmony_ci	.coex_para_ver = 0x20070217,
43668c2ecf20Sopenharmony_ci	.bt_desired_ver = 0x17,
43678c2ecf20Sopenharmony_ci	.scbd_support = true,
43688c2ecf20Sopenharmony_ci	.new_scbd10_def = true,
43698c2ecf20Sopenharmony_ci	.pstdma_type = COEX_PSTDMA_FORCE_LPSOFF,
43708c2ecf20Sopenharmony_ci	.bt_rssi_type = COEX_BTRSSI_DBM,
43718c2ecf20Sopenharmony_ci	.ant_isolation = 15,
43728c2ecf20Sopenharmony_ci	.rssi_tolerance = 2,
43738c2ecf20Sopenharmony_ci	.wl_rssi_step = wl_rssi_step_8822c,
43748c2ecf20Sopenharmony_ci	.bt_rssi_step = bt_rssi_step_8822c,
43758c2ecf20Sopenharmony_ci	.table_sant_num = ARRAY_SIZE(table_sant_8822c),
43768c2ecf20Sopenharmony_ci	.table_sant = table_sant_8822c,
43778c2ecf20Sopenharmony_ci	.table_nsant_num = ARRAY_SIZE(table_nsant_8822c),
43788c2ecf20Sopenharmony_ci	.table_nsant = table_nsant_8822c,
43798c2ecf20Sopenharmony_ci	.tdma_sant_num = ARRAY_SIZE(tdma_sant_8822c),
43808c2ecf20Sopenharmony_ci	.tdma_sant = tdma_sant_8822c,
43818c2ecf20Sopenharmony_ci	.tdma_nsant_num = ARRAY_SIZE(tdma_nsant_8822c),
43828c2ecf20Sopenharmony_ci	.tdma_nsant = tdma_nsant_8822c,
43838c2ecf20Sopenharmony_ci	.wl_rf_para_num = ARRAY_SIZE(rf_para_tx_8822c),
43848c2ecf20Sopenharmony_ci	.wl_rf_para_tx = rf_para_tx_8822c,
43858c2ecf20Sopenharmony_ci	.wl_rf_para_rx = rf_para_rx_8822c,
43868c2ecf20Sopenharmony_ci	.bt_afh_span_bw20 = 0x24,
43878c2ecf20Sopenharmony_ci	.bt_afh_span_bw40 = 0x36,
43888c2ecf20Sopenharmony_ci	.afh_5g_num = ARRAY_SIZE(afh_5g_8822c),
43898c2ecf20Sopenharmony_ci	.afh_5g = afh_5g_8822c,
43908c2ecf20Sopenharmony_ci
43918c2ecf20Sopenharmony_ci	.coex_info_hw_regs_num = ARRAY_SIZE(coex_info_hw_regs_8822c),
43928c2ecf20Sopenharmony_ci	.coex_info_hw_regs = coex_info_hw_regs_8822c,
43938c2ecf20Sopenharmony_ci
43948c2ecf20Sopenharmony_ci	.fw_fifo_addr = {0x780, 0x700, 0x780, 0x660, 0x650, 0x680},
43958c2ecf20Sopenharmony_ci};
43968c2ecf20Sopenharmony_ciEXPORT_SYMBOL(rtw8822c_hw_spec);
43978c2ecf20Sopenharmony_ci
43988c2ecf20Sopenharmony_ciMODULE_FIRMWARE("rtw88/rtw8822c_fw.bin");
43998c2ecf20Sopenharmony_ciMODULE_FIRMWARE("rtw88/rtw8822c_wow_fw.bin");
44008c2ecf20Sopenharmony_ci
44018c2ecf20Sopenharmony_ciMODULE_AUTHOR("Realtek Corporation");
44028c2ecf20Sopenharmony_ciMODULE_DESCRIPTION("Realtek 802.11ac wireless 8822c driver");
44038c2ecf20Sopenharmony_ciMODULE_LICENSE("Dual BSD/GPL");
4404