Orange Pi5 kernel

Deprecated Linux kernel 5.10.110 for OrangePi 5/5B/5+ boards

3 Commits   0 Branches   0 Tags
/******************************************************************************
 *
 * Copyright(c) 2007 - 2017  Realtek Corporation.
 *
 * This program is free software; you can redistribute it and/or modify it
 * under the terms of version 2 of the GNU General Public License as
 * published by the Free Software Foundation.
 *
 * This program is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
 * more details.
 *
 * The full GNU General Public License is included in this distribution in the
 * file called LICENSE.
 *
 * Contact Information:
 * wlanfae <wlanfae@realtek.com>
 * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
 * Hsinchu 300, Taiwan.
 *
 * Larry Finger <Larry.Finger@lwfinger.net>
 *
 *****************************************************************************/

/*************************************************************
 * include files
 ************************************************************/

#include "mp_precomp.h"
#include "phydm_precomp.h"

#ifdef PHYDM_SUPPORT_CCKPD

void phydm_write_cck_cca_th_new_cs_ratio(void *dm_void, u8 cca_th,
					 u8 cca_th_aaa)
{
	struct dm_struct *dm = (struct dm_struct *)dm_void;
	struct phydm_cckpd_struct *cckpd_t = &dm->dm_cckpd_table;

	PHYDM_DBG(dm, DBG_CCKPD, "%s ======>\n", __func__);
	PHYDM_DBG(dm, DBG_CCKPD, "[New] pd_th=0x%x, cs_ratio=0x%x\n\n", cca_th,
		  cca_th_aaa);

	if (cckpd_t->cur_cck_cca_thres != cca_th) {
		cckpd_t->cur_cck_cca_thres = cca_th;
		odm_set_bb_reg(dm, R_0xa08, 0xf0000, cca_th);
		cckpd_t->cck_fa_ma = CCK_FA_MA_RESET;
	}

	if (cckpd_t->cck_cca_th_aaa != cca_th_aaa) {
		cckpd_t->cck_cca_th_aaa = cca_th_aaa;
		odm_set_bb_reg(dm, R_0xaa8, 0x1f0000, cca_th_aaa);
		cckpd_t->cck_fa_ma = CCK_FA_MA_RESET;
	}
}

void phydm_write_cck_cca_th_92f(void *dm_void, u8 cca_pd_th, u8 cca_cs_ratio,
				u8 type)
{
	struct dm_struct *dm = (struct dm_struct *)dm_void;
	struct phydm_cckpd_struct *cckpd_t = &dm->dm_cckpd_table;

	PHYDM_DBG(dm, DBG_CCKPD, "%s ======>\n", __func__);
	PHYDM_DBG(dm, DBG_CCKPD,
		  "[92F] pd_th=0x%x, cs_ratio=0x%x, type=0x%x\n\n", cca_pd_th,
		  cca_cs_ratio, type);
#if 0
	type=0:  regAc8[7:0]      r_PD_lim_RFBW20_1R
	type=1:  regAc8[15:8]	  r_PD_lim_RFBW20_2R
	type=2:  regAcc[7:0]       r_PD_lim_RFBW40_1R
	type=3:  regAcc[15:8]	  r_PD_lim_RFBW40_2R

	type=0:  Ad0[4:0]	       r_CS_ratio_RFBW20_1R[4:0]
	type=1:  Ad0[9:5]	       r_CS_ratio_RFBW20_2R[4:0]
	type=2:  Ad0[24:20]	r_CS_ratio_RFBW40_1R[4:0]
	type=3:  Ad0[29:25]	r_CS_ratio_RFBW40_2R[4:0]
#endif
	switch (type) {
	case 0: /*RFBW20_1R*/
	{
		if (cckpd_t->cur_cck_pd_20m_1r != cca_pd_th) {
			cckpd_t->cur_cck_pd_20m_1r = cca_pd_th;
			odm_set_bb_reg(dm, R_0xac8, 0xff, cca_pd_th);
			cckpd_t->cck_fa_ma = CCK_FA_MA_RESET;
		}
		if (cckpd_t->cur_cck_cs_ratio_20m_1r != cca_cs_ratio) {
			cckpd_t->cur_cck_cs_ratio_20m_1r = cca_cs_ratio;
			odm_set_bb_reg(dm, R_0xad0, 0x1f, cca_cs_ratio);
			cckpd_t->cck_fa_ma = CCK_FA_MA_RESET;
		}
	} break;
	case 1: /*RFBW20_2R*/
	{
		if (cckpd_t->cur_cck_pd_20m_2r != cca_pd_th) {
			cckpd_t->cur_cck_pd_20m_2r = cca_pd_th;
			odm_set_bb_reg(dm, R_0xac8, 0xff00, cca_pd_th);
			cckpd_t->cck_fa_ma = CCK_FA_MA_RESET;
		}
		if (cckpd_t->cur_cck_cs_ratio_20m_2r != cca_cs_ratio) {
			cckpd_t->cur_cck_cs_ratio_20m_2r = cca_cs_ratio;
			odm_set_bb_reg(dm, R_0xad0, 0x3e0, cca_cs_ratio);
			cckpd_t->cck_fa_ma = CCK_FA_MA_RESET;
		}

	} break;
	case 2: /*RFBW40_1R*/
	{
		if (cckpd_t->cur_cck_pd_40m_1r != cca_pd_th) {
			cckpd_t->cur_cck_pd_40m_1r = cca_pd_th;
			odm_set_bb_reg(dm, R_0xacc, 0xff, cca_pd_th);
			cckpd_t->cck_fa_ma = CCK_FA_MA_RESET;
		}
		if (cckpd_t->cur_cck_cs_ratio_40m_1r != cca_cs_ratio) {
			cckpd_t->cur_cck_cs_ratio_40m_1r = cca_cs_ratio;
			odm_set_bb_reg(dm, R_0xad0, 0x1f00000, cca_cs_ratio);
			cckpd_t->cck_fa_ma = CCK_FA_MA_RESET;
		}

	} break;
	case 3: /*RFBW40_2R*/
	{
		if (cckpd_t->cur_cck_pd_40m_2r != cca_pd_th) {
			cckpd_t->cur_cck_pd_40m_2r = cca_pd_th;
			odm_set_bb_reg(dm, R_0xacc, 0xff00, cca_pd_th);
			cckpd_t->cck_fa_ma = CCK_FA_MA_RESET;
		}
		if (cckpd_t->cur_cck_cs_ratio_40m_2r != cca_cs_ratio) {
			cckpd_t->cur_cck_cs_ratio_40m_2r = cca_cs_ratio;
			odm_set_bb_reg(dm, R_0xad0, 0x3e000000, cca_cs_ratio);
			cckpd_t->cck_fa_ma = CCK_FA_MA_RESET;
		}

	} break;

	default:
		break;
	}
}

void phydm_write_cck_cca_th(void *dm_void, u8 cca_th)
{
	struct dm_struct *dm = (struct dm_struct *)dm_void;
	struct phydm_cckpd_struct *cckpd_t = &dm->dm_cckpd_table;

	PHYDM_DBG(dm, DBG_CCKPD, "%s ======>\n", __func__);
	PHYDM_DBG(dm, DBG_CCKPD, "New cck_cca_th=((0x%x))\n\n", cca_th);

	if (cckpd_t->cur_cck_cca_thres != cca_th) {
		odm_write_1byte(dm, ODM_REG(CCK_CCA, dm), cca_th);
		cckpd_t->cck_fa_ma = CCK_FA_MA_RESET;
	}
	cckpd_t->cur_cck_cca_thres = cca_th;
}

void phydm_set_cckpd_val(void *dm_void, u32 *val_buf, u8 val_len)
{
	struct dm_struct *dm = (struct dm_struct *)dm_void;
	u8 val_0 = 0, val_1 = 0;
	u8 en_2rcca;
	u8 en_bw40m;
	if (val_len != 2) {
		PHYDM_DBG(dm, ODM_COMP_API, "[Error][CCKPD]Need val_len=2\n");
		return;
	}

	/*val_buf[0]: 0xa0a*/
	/*val_buf[1]: 0xaaa*/
	val_0 = (u8)val_buf[0];
	val_1 = (u8)val_buf[1];

	if (dm->support_ic_type & EXTEND_CCK_CCATH_AAA_IC)
		phydm_write_cck_cca_th_new_cs_ratio(dm, val_0, val_1);
	else if (dm->support_ic_type & EXTEND_CCK_CCATH_92F_IC) {
		en_2rcca = (u8)(odm_get_bb_reg(dm, R_0xa2c, BIT(17)));
		en_bw40m = (u8)(odm_get_bb_reg(dm, R_0x800, BIT(0)));
		if (en_2rcca == 0) {
			if (en_bw40m == 0)
				phydm_write_cck_cca_th_92f(dm, val_0, val_1, 0);
			else
				phydm_write_cck_cca_th_92f(dm, val_0, val_1, 2);
		} else {
			if (en_bw40m == 0)
				phydm_write_cck_cca_th_92f(dm, val_0, val_1, 1);
			else
				phydm_write_cck_cca_th_92f(dm, val_0, val_1, 3);
		}
	}
	else
		phydm_write_cck_cca_th(dm, val_0);
}

boolean
phydm_stop_cck_pd_th(void *dm_void)
{
	struct dm_struct *dm = (struct dm_struct *)dm_void;

	if (!(dm->support_ability & (ODM_BB_CCK_PD | ODM_BB_FA_CNT))) {
		PHYDM_DBG(dm, DBG_CCKPD, "Not Support\n");

		#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
		#ifdef MCR_WIRELESS_EXTEND
		phydm_write_cck_cca_th(dm, 0x43);
		#endif
		#endif

		return true;
	}

	if (dm->pause_ability & ODM_BB_CCK_PD) {
		PHYDM_DBG(dm, DBG_CCKPD, "Return: Pause CCKPD in LV=%d\n",
			  dm->pause_lv_table.lv_cckpd);
		return true;
	}

	#if 0 /*(DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))*/
	if (dm->ext_lna)
		return true;
	#endif

	return false;
}

void phydm_cckpd(void *dm_void)
{
	struct dm_struct *dm = (struct dm_struct *)dm_void;
	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
	struct phydm_cckpd_struct *cckpd_t = &dm->dm_cckpd_table;
	u8 cur_cck_cca_th = cckpd_t->cur_cck_cca_thres;

	if (dm->is_linked) {
#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))

		/*Add hp_hw_id condition due to 22B LPS power consumption issue
		 *and [PCIE-1596]
		 */
		if (dm->hp_hw_id && dm->traffic_load == TRAFFIC_ULTRA_LOW) {
			cur_cck_cca_th = 0x40;
		} else if (dm->rssi_min > 60) {
			cur_cck_cca_th = 0xdd;
		} else if (dm->rssi_min > 35) {
			cur_cck_cca_th = 0xcd;
		} else if (dm->rssi_min > 20) {
			if (cckpd_t->cck_fa_ma > 500)
				cur_cck_cca_th = 0xcd;
			else if (cckpd_t->cck_fa_ma < 250)
				cur_cck_cca_th = 0x83;

		} else {
			if ((dm->p_advance_ota & PHYDM_ASUS_OTA_SETTING) &&
			    cckpd_t->cck_fa_ma > 200)
				cur_cck_cca_th = 0xc3; /*for ASUS OTA test*/
			else
				cur_cck_cca_th = 0x83;
		}

#else /*ODM_AP*/
		if (dig_t->cur_ig_value > 0x32)
			cur_cck_cca_th = 0xed;
		else if (dig_t->cur_ig_value > 0x2a)
			cur_cck_cca_th = 0xdd;
		else if (dig_t->cur_ig_value > 0x24)
			cur_cck_cca_th = 0xcd;
		else
			cur_cck_cca_th = 0x83;

#endif
	} else {
		if (cckpd_t->cck_fa_ma > 1000)
			cur_cck_cca_th = 0x83;
		else if (cckpd_t->cck_fa_ma < 500)
			cur_cck_cca_th = 0x40;
	}

	phydm_write_cck_cca_th(dm, cur_cck_cca_th);
	PHYDM_DBG(dm, DBG_CCKPD, "New cck_cca_th=((0x%x)), IGI=((0x%x))\n",
		  cur_cck_cca_th, dig_t->cur_ig_value);
}

void phydm_cckpd_new_cs_ratio(void *dm_void)
{
	struct dm_struct *dm = (struct dm_struct *)dm_void;
	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
	struct phydm_cckpd_struct *cckpd_t = &dm->dm_cckpd_table;
	u8 pd_th = 0, cs_ratio = 0, cs_2r_offset = 0;
	u8 igi_curr = dig_t->cur_ig_value;
	u8 en_2rcca;
	boolean is_update = true;

	PHYDM_DBG(dm, DBG_CCKPD, "%s ======>\n", __func__);

	en_2rcca = (u8)(odm_get_bb_reg(dm, R_0xa2c, BIT(18)) &&
			odm_get_bb_reg(dm, R_0xa2c, BIT(22)));

	if (dm->is_linked) {
		if (igi_curr > 0x38 && dm->rssi_min > 32) {
			cs_ratio = dig_t->aaa_default + AAA_BASE + AAA_STEP * 2;
			cs_2r_offset = 5;
			pd_th = 0xd;
		} else if ((igi_curr > 0x2a) && (dm->rssi_min > 32)) {
			cs_ratio = dig_t->aaa_default + AAA_BASE + AAA_STEP;
			cs_2r_offset = 4;
			pd_th = 0xd;
		} else if ((igi_curr > 0x24) ||
			   (dm->rssi_min > 24 && dm->rssi_min <= 30)) {
			cs_ratio = dig_t->aaa_default + AAA_BASE;
			cs_2r_offset = 3;
			pd_th = 0xd;
		} else if ((igi_curr <= 0x24) || (dm->rssi_min < 22)) {
			if (cckpd_t->cck_fa_ma > 1000) {
				cs_ratio = dig_t->aaa_default + AAA_STEP;
				cs_2r_offset = 1;
				pd_th = 0x7;
			} else if (cckpd_t->cck_fa_ma < 500) {
				cs_ratio = dig_t->aaa_default;
				pd_th = 0x3;
			} else {
				is_update = false;
				cs_ratio = cckpd_t->cck_cca_th_aaa;
				pd_th = cckpd_t->cur_cck_cca_thres;
			}
		}
	} else {
		if (cckpd_t->cck_fa_ma > 1000) {
			cs_ratio = dig_t->aaa_default + AAA_STEP;
			cs_2r_offset = 1;
			pd_th = 0x7;
		} else if (cckpd_t->cck_fa_ma < 500) {
			cs_ratio = dig_t->aaa_default;
			pd_th = 0x3;
		} else {
			is_update = false;
			cs_ratio = cckpd_t->cck_cca_th_aaa;
			pd_th = cckpd_t->cur_cck_cca_thres;
		}
	}

	if (en_2rcca) {
		if (cs_ratio >= cs_2r_offset)
			cs_ratio = cs_ratio - cs_2r_offset;
		else
			cs_ratio = 0;
	}

	PHYDM_DBG(dm, DBG_CCKPD, "[New] cs_ratio=0x%x, pd_th=0x%x\n", cs_ratio,
		  pd_th);

	if (is_update) {
		cckpd_t->cur_cck_cca_thres = pd_th;
		cckpd_t->cck_cca_th_aaa = cs_ratio;
		odm_set_bb_reg(dm, R_0xa08, 0xf0000, pd_th);
		odm_set_bb_reg(dm, R_0xaa8, 0x1f0000, cs_ratio);
	}

	/*phydm_write_cck_cca_th_new_cs_ratio(dm, pd_th, cs_ratio);*/
}

#if (RTL8192F_SUPPORT == 1)

void phydm_cckpd_92f_1r_linked(
	void *dm_void)
{
	struct dm_struct *dm = (struct dm_struct *)dm_void;
	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
	struct phydm_cckpd_struct *cckpd_t = &dm->dm_cckpd_table;
	u8 pd_th_20m_1r = 0, cs_ratio_20m_1r = 0;
	u8 pd_th_40m_1r = 0, cs_ratio_40m_1r = 0;
	u8 igi_curr = dig_t->cur_ig_value;

	if (igi_curr > 0x38 && dm->rssi_min > 32) {
		pd_th_20m_1r = dig_t->cck_pd_20m_1r + 4;
		pd_th_40m_1r = dig_t->cck_pd_40m_1r + 4;
		cs_ratio_20m_1r = dig_t->cck_cs_ratio_20m_1r + 3;
		cs_ratio_40m_1r = dig_t->cck_cs_ratio_40m_1r + 3;
	} else if ((igi_curr > 0x2a) && (dm->rssi_min > 32)) {
		pd_th_20m_1r = dig_t->cck_pd_20m_1r + 3;
		pd_th_40m_1r = dig_t->cck_pd_40m_1r + 3;
		cs_ratio_20m_1r = dig_t->cck_cs_ratio_20m_1r + 2;
		cs_ratio_40m_1r = dig_t->cck_cs_ratio_40m_1r + 2;
	} else if ((igi_curr > 0x24) ||
		   (dm->rssi_min > 24 && dm->rssi_min <= 30)) {
		pd_th_20m_1r = dig_t->cck_pd_20m_1r + 2;
		pd_th_40m_1r = dig_t->cck_pd_40m_1r + 2;
		cs_ratio_20m_1r = dig_t->cck_cs_ratio_20m_1r + 1;
		cs_ratio_40m_1r = dig_t->cck_cs_ratio_40m_1r + 1;

	} else if ((igi_curr <= 0x24) || (dm->rssi_min < 22)) {
		if (cckpd_t->cck_fa_ma > 1000) {
			pd_th_20m_1r = dig_t->cck_pd_20m_1r + 1;
			pd_th_40m_1r = dig_t->cck_pd_40m_1r + 1;
			cs_ratio_20m_1r = dig_t->cck_cs_ratio_20m_1r + 1;
			cs_ratio_40m_1r = dig_t->cck_cs_ratio_40m_1r + 1;
		} else if (cckpd_t->cck_fa_ma < 500) {
			pd_th_20m_1r = dig_t->cck_pd_20m_1r;
			pd_th_40m_1r = dig_t->cck_pd_40m_1r;
			cs_ratio_20m_1r = dig_t->cck_cs_ratio_20m_1r;
			cs_ratio_40m_1r = dig_t->cck_cs_ratio_40m_1r;
		} else {
			pd_th_20m_1r = cckpd_t->cur_cck_pd_20m_1r;
			pd_th_40m_1r = cckpd_t->cur_cck_pd_40m_1r;
			cs_ratio_20m_1r = cckpd_t->cur_cck_cs_ratio_20m_1r;
			cs_ratio_40m_1r = cckpd_t->cur_cck_cs_ratio_40m_1r;
		}
	}
	cckpd_t->cur_cck_pd_20m_1r = pd_th_20m_1r;
	cckpd_t->cur_cck_pd_40m_1r = pd_th_40m_1r;
	cckpd_t->cur_cck_cs_ratio_20m_1r = cs_ratio_20m_1r;
	cckpd_t->cur_cck_cs_ratio_40m_1r = cs_ratio_40m_1r;
	PHYDM_DBG(dm, DBG_CCKPD,
		  "[92F 1R linked] pd_th_20m_1r=0x%x, pd_th_40m_1r=0x%x, cs_ratio_20m_1r=0x%x, cs_ratio_40m_1r=0x%x\n",
		  pd_th_20m_1r, pd_th_40m_1r, cs_ratio_20m_1r, cs_ratio_40m_1r);
	/*1R 20M*/
	/*phydm_write_cck_cca_th_92f(p_dm, pd_th_20m_1r, cs_ratio_20m_1r,0);*/
	odm_set_bb_reg(dm, R_0xac8, 0xff, pd_th_20m_1r);
	odm_set_bb_reg(dm, R_0xad0, 0x1f, cs_ratio_20m_1r);
	/*1R 40M*/
	/*phydm_write_cck_cca_th_92f(p_dm, pd_th_40m_1r, cs_ratio_40m_1r,2);*/
	odm_set_bb_reg(dm, R_0xacc, 0xff, pd_th_40m_1r);
	odm_set_bb_reg(dm, R_0xad0, 0x1f00000, cs_ratio_40m_1r);
}

void phydm_cckpd_92f_1r(
	void *dm_void)
{
	struct dm_struct *dm = (struct dm_struct *)dm_void;
	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
	struct phydm_cckpd_struct *cckpd_t = &dm->dm_cckpd_table;
	u8 pd_th_20m_1r = 0, cs_ratio_20m_1r = 0;
	u8 pd_th_40m_1r = 0, cs_ratio_40m_1r = 0;
	u8 igi_curr = dig_t->cur_ig_value;

	if (dm->is_linked) {
		phydm_cckpd_92f_1r_linked(dm);
	} else {
		if (cckpd_t->cck_fa_ma > 1000) {
			pd_th_20m_1r = dig_t->cck_pd_20m_1r + 1;
			pd_th_40m_1r = dig_t->cck_pd_40m_1r + 1;
			cs_ratio_20m_1r = dig_t->cck_cs_ratio_20m_1r + 1;
			cs_ratio_40m_1r = dig_t->cck_cs_ratio_40m_1r + 1;
		} else if (cckpd_t->cck_fa_ma < 500) {
			pd_th_20m_1r = dig_t->cck_pd_20m_1r;
			pd_th_40m_1r = dig_t->cck_pd_40m_1r;
			cs_ratio_20m_1r = dig_t->cck_cs_ratio_20m_1r;
			cs_ratio_40m_1r = dig_t->cck_cs_ratio_40m_1r;
		} else {
			pd_th_20m_1r = cckpd_t->cur_cck_pd_20m_1r;
			pd_th_40m_1r = cckpd_t->cur_cck_pd_40m_1r;
			cs_ratio_20m_1r = cckpd_t->cur_cck_cs_ratio_20m_1r;
			cs_ratio_40m_1r = cckpd_t->cur_cck_cs_ratio_40m_1r;
		}
		cckpd_t->cur_cck_pd_20m_1r = pd_th_20m_1r;
		cckpd_t->cur_cck_pd_40m_1r = pd_th_40m_1r;
		cckpd_t->cur_cck_cs_ratio_20m_1r = cs_ratio_20m_1r;
		cckpd_t->cur_cck_cs_ratio_40m_1r = cs_ratio_40m_1r;
		PHYDM_DBG(dm, DBG_CCKPD,
		"[92F 1R unlink] pd_th_20m_1r=0x%x, pd_th_40m_1r=0x%x, cs_ratio_20m_1r=0x%x, cs_ratio_40m_1r=0x%x\n",
		pd_th_20m_1r, pd_th_40m_1r, cs_ratio_20m_1r, cs_ratio_40m_1r);
		/*1R 20M*/
		/*phydm_write_cck_cca_th_92f(p_dm, pd_th_20m_1r, cs_ratio_20m_1r,0);*/
		odm_set_bb_reg(dm, R_0xac8, 0xff, pd_th_20m_1r);
		odm_set_bb_reg(dm, R_0xad0, 0x1f, cs_ratio_20m_1r);
		/*1R 40M*/
		/*phydm_write_cck_cca_th_92f(p_dm, pd_th_40m_1r, cs_ratio_40m_1r,2);*/
		odm_set_bb_reg(dm, R_0xacc, 0xff, pd_th_40m_1r);
		odm_set_bb_reg(dm, R_0xad0, 0x1f00000, cs_ratio_40m_1r);
	}
}

void phydm_cckpd_92f_2r_linked(
	void *dm_void)
{
	struct dm_struct *dm = (struct dm_struct *)dm_void;
	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
	struct phydm_cckpd_struct *cckpd_t = &dm->dm_cckpd_table;
	u8 pd_th_20m_2r = 0, cs_ratio_20m_2r = 0;
	u8 pd_th_40m_2r = 0, cs_ratio_40m_2r = 0;
	u8 igi_curr = dig_t->cur_ig_value;

	if (igi_curr > 0x38 && dm->rssi_min > 32) {
		pd_th_20m_2r = dig_t->cck_pd_20m_2r + 4;
		pd_th_40m_2r = dig_t->cck_pd_40m_2r + 4;
		cs_ratio_20m_2r = dig_t->cck_cs_ratio_20m_2r + 2;
		cs_ratio_40m_2r = dig_t->cck_cs_ratio_40m_2r + 2;
	} else if ((igi_curr > 0x2a) && (dm->rssi_min > 32)) {
		pd_th_20m_2r = dig_t->cck_pd_20m_2r + 3;
		pd_th_40m_2r = dig_t->cck_pd_40m_2r + 3;
		cs_ratio_20m_2r = dig_t->cck_cs_ratio_20m_2r + 1;
		cs_ratio_40m_2r = dig_t->cck_cs_ratio_40m_2r + 1;
	} else if ((igi_curr > 0x24) ||
		   (dm->rssi_min > 24 && dm->rssi_min <= 30)) {
		pd_th_20m_2r = dig_t->cck_pd_20m_2r + 2;
		pd_th_40m_2r = dig_t->cck_pd_40m_2r + 2;
		cs_ratio_20m_2r = dig_t->cck_cs_ratio_20m_2r + 1;
		cs_ratio_40m_2r = dig_t->cck_cs_ratio_40m_2r + 1;
	} else if ((igi_curr <= 0x24) || (dm->rssi_min < 22)) {
		if (cckpd_t->cck_fa_ma > 1000) {
			pd_th_20m_2r = dig_t->cck_pd_20m_2r + 1;
			pd_th_40m_2r = dig_t->cck_pd_40m_2r + 1;
			cs_ratio_20m_2r = dig_t->cck_cs_ratio_20m_2r + 1;
			cs_ratio_40m_2r = dig_t->cck_cs_ratio_40m_2r + 1;
		} else if (cckpd_t->cck_fa_ma < 500) {
			pd_th_20m_2r = dig_t->cck_pd_20m_2r;
			pd_th_40m_2r = dig_t->cck_pd_40m_2r;
			cs_ratio_20m_2r = dig_t->cck_cs_ratio_20m_2r;
			cs_ratio_40m_2r = dig_t->cck_cs_ratio_40m_2r;
		} else {
			pd_th_20m_2r = cckpd_t->cur_cck_pd_20m_2r;
			pd_th_40m_2r = cckpd_t->cur_cck_pd_40m_2r;
			cs_ratio_20m_2r = cckpd_t->cur_cck_cs_ratio_20m_2r;
			cs_ratio_40m_2r = cckpd_t->cur_cck_cs_ratio_40m_2r;
		}
	}
	cckpd_t->cur_cck_pd_20m_2r = pd_th_20m_2r;
	cckpd_t->cur_cck_pd_40m_2r = pd_th_40m_2r;
	cckpd_t->cur_cck_cs_ratio_20m_2r = cs_ratio_20m_2r;
	cckpd_t->cur_cck_cs_ratio_40m_2r = cs_ratio_40m_2r;
	PHYDM_DBG(dm, DBG_CCKPD,
		  "[92F 2R linked] pd_th_20m_2r=0x%x, pd_th_40m_2r=0x%x, cs_ratio_20m_2r=0x%x, cs_ratio_40m_2r=0x%x\n",
		  pd_th_20m_2r, pd_th_40m_2r, cs_ratio_20m_2r, cs_ratio_40m_2r);

	/*2R 20M*/
	/*phydm_write_cck_cca_th_92f(p_dm, pd_th_20m_2r, cs_ratio_20m_2r,1);*/
	odm_set_bb_reg(dm, R_0xac8, 0xff00, pd_th_20m_2r);
	odm_set_bb_reg(dm, R_0xad0, 0x3e0, cs_ratio_20m_2r);

	/*2R 40M*/
	/*phydm_write_cck_cca_th_92f(p_dm, pd_th_40m_2r, cs_ratio_40m_2r,3);*/
	odm_set_bb_reg(dm, R_0xacc, 0xff00, pd_th_40m_2r);
	odm_set_bb_reg(dm, R_0xad0, 0x3e000000, cs_ratio_40m_2r);
}

void phydm_cckpd_92f_2r(
	void *dm_void)
{
	struct dm_struct *dm = (struct dm_struct *)dm_void;
	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
	struct phydm_cckpd_struct *cckpd_t = &dm->dm_cckpd_table;
	u8 pd_th_20m_2r = 0, cs_ratio_20m_2r = 0;
	u8 pd_th_40m_2r = 0, cs_ratio_40m_2r = 0;
	u8 igi_curr = dig_t->cur_ig_value;

	if (dm->is_linked) {
		phydm_cckpd_92f_2r_linked(dm);
	} else {
		if (cckpd_t->cck_fa_ma > 1000) {
			pd_th_20m_2r = dig_t->cck_pd_20m_2r + 1;
			pd_th_40m_2r = dig_t->cck_pd_40m_2r + 1;
			cs_ratio_20m_2r = dig_t->cck_cs_ratio_20m_2r + 1;
			cs_ratio_40m_2r = dig_t->cck_cs_ratio_40m_2r + 1;
		} else if (cckpd_t->cck_fa_ma < 500) {
			pd_th_20m_2r = dig_t->cck_pd_20m_2r;
			pd_th_40m_2r = dig_t->cck_pd_40m_2r;
			cs_ratio_20m_2r = dig_t->cck_cs_ratio_20m_2r;
			cs_ratio_40m_2r = dig_t->cck_cs_ratio_40m_2r;
		} else {
			pd_th_20m_2r = cckpd_t->cur_cck_pd_20m_2r;
			pd_th_40m_2r = cckpd_t->cur_cck_pd_40m_2r;
			cs_ratio_20m_2r = cckpd_t->cur_cck_cs_ratio_20m_2r;
			cs_ratio_40m_2r = cckpd_t->cur_cck_cs_ratio_40m_2r;
		}
		cckpd_t->cur_cck_pd_20m_2r = pd_th_20m_2r;
		cckpd_t->cur_cck_pd_40m_2r = pd_th_40m_2r;
		cckpd_t->cur_cck_cs_ratio_20m_2r = cs_ratio_20m_2r;
		cckpd_t->cur_cck_cs_ratio_40m_2r = cs_ratio_40m_2r;
		PHYDM_DBG(dm, DBG_CCKPD,
			  "[92F 2R unlink] pd_th_20m_2r=0x%x, pd_th_40m_2r=0x%x, cs_ratio_20m_2r=0x%x, cs_ratio_40m_2r=0x%x\n",
			  pd_th_20m_2r, pd_th_40m_2r, cs_ratio_20m_2r, cs_ratio_40m_2r);
		
		/*2R 20M*/
		/*phydm_write_cck_cca_th_92f(p_dm, pd_th_20m_2r, cs_ratio_20m_2r,1);*/
		odm_set_bb_reg(dm, R_0xac8, 0xff00, pd_th_20m_2r);
		odm_set_bb_reg(dm, R_0xad0, 0x3e0, cs_ratio_20m_2r);
		
		/*2R 40M*/
		/*phydm_write_cck_cca_th_92f(p_dm, pd_th_40m_2r, cs_ratio_40m_2r,3);*/
		odm_set_bb_reg(dm, R_0xacc, 0xff00, pd_th_40m_2r);
		odm_set_bb_reg(dm, R_0xad0, 0x3e000000, cs_ratio_40m_2r);
	}
}

void phydm_cckpd_92f(
	void *dm_void)
{
	struct dm_struct *dm = (struct dm_struct *)dm_void;
	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
	struct phydm_cckpd_struct *cckpd_t = &dm->dm_cckpd_table;
	u32 en_2rcca = 0;

	PHYDM_DBG(dm, DBG_CCKPD, "%s ======>\n", __func__);

	if (dm->support_ic_type & ODM_RTL8192F) {
		en_2rcca = odm_get_bb_reg(dm, R_0xa2c, BIT(17));
	} else {
		en_2rcca = odm_get_bb_reg(dm, R_0xa2c, BIT(18)) &&
		   odm_get_bb_reg(dm, R_0xa2c, BIT(22));
	}

	if (en_2rcca == 0)
		phydm_cckpd_92f_1r(dm);
	else
		phydm_cckpd_92f_2r(dm);

}

void phydm_cck_pd_init_92f(void *dm_void)
{
	struct dm_struct *dm = (struct dm_struct *)dm_void;
	struct phydm_cckpd_struct *cckpd_t = &dm->dm_cckpd_table;
	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;

	u32 reg_tmp = 0;
	/*
	 *type = 0 :  regAc8[7:0]		r_PD_lim_RFBW20_1R
	 *type = 1 :  regAc8[15:8]	r_PD_lim_RFBW20_2R
	 *type = 2 :  regAcc[7:0]		r_PD_lim_RFBW40_1R
	 *type = 3 :  regAcc[15:8]	r_PD_lim_RFBW40_2R

	 *type = 0 :  Ad0[4:0]		r_CS_ratio_RFBW20_1R[4:0]
	 *type = 1 :  Ad0[9:5]		r_CS_ratio_RFBW20_2R[4:0]
	 *type = 2 :  Ad0[24:20]		r_CS_ratio_RFBW40_1R[4:0]
	 *type = 3 :  Ad0[29:25]		r_CS_ratio_RFBW40_2R[4:0]
	 */
	dig_t->cck_pd_20m_1r = (u8)odm_get_bb_reg(dm, R_0xac8, 0xff);
	dig_t->cck_pd_20m_2r = (u8)odm_get_bb_reg(dm, R_0xac8, 0xff00);
	dig_t->cck_pd_40m_1r = (u8)odm_get_bb_reg(dm, R_0xacc, 0xff);
	dig_t->cck_pd_40m_2r = (u8)odm_get_bb_reg(dm, R_0xacc, 0xff00);

	reg_tmp = odm_get_bb_reg(dm, R_0xad0, MASKDWORD);
	dig_t->cck_cs_ratio_20m_1r = (u8)(reg_tmp & 0x1f);
	dig_t->cck_cs_ratio_20m_2r = (u8)((reg_tmp & 0x3e0) >> 5);
	dig_t->cck_cs_ratio_40m_1r = (u8)((reg_tmp & 0x1f00000) >> 20);
	dig_t->cck_cs_ratio_40m_2r = (u8)((reg_tmp & 0x3e000000) >> 25);

	cckpd_t->cur_cck_pd_20m_1r = (u8)odm_get_bb_reg(dm, R_0xac8, 0xff);
	cckpd_t->cur_cck_pd_20m_2r = (u8)odm_get_bb_reg(dm, R_0xac8, 0xff00);
	cckpd_t->cur_cck_pd_40m_1r = (u8)odm_get_bb_reg(dm, R_0xacc, 0xff);
	cckpd_t->cur_cck_pd_40m_2r = (u8)odm_get_bb_reg(dm, R_0xacc, 0xff00);

	cckpd_t->cur_cck_cs_ratio_20m_1r = (u8)(reg_tmp & 0x1f);
	cckpd_t->cur_cck_cs_ratio_20m_2r = (u8)((reg_tmp & 0x3e0) >> 5);
	cckpd_t->cur_cck_cs_ratio_40m_1r = (u8)((reg_tmp & 0x1f00000) >> 20);
	cckpd_t->cur_cck_cs_ratio_40m_2r = (u8)((reg_tmp & 0x3e000000) >> 25);

}

#endif

#endif

void phydm_cck_pd_th(void *dm_void)
{
#ifdef PHYDM_SUPPORT_CCKPD
	struct dm_struct *dm = (struct dm_struct *)dm_void;
	struct phydm_fa_struct *fa_t = &dm->false_alm_cnt;
	struct phydm_cckpd_struct *cckpd_t = &dm->dm_cckpd_table;
	u32 fail_tmp = fa_t->cnt_cck_fail;
	#ifdef PHYDM_TDMA_DIG_SUPPORT
	struct phydm_fa_acc_struct *fa_acc_t = &dm->false_alm_cnt_acc;
	#endif

	PHYDM_DBG(dm, DBG_CCKPD, "%s ======>\n", __func__);

	if (phydm_stop_cck_pd_th(dm) == true)
		return;

#ifdef PHYDM_TDMA_DIG_SUPPORT
	if (dm->original_dig_restore)
		fail_tmp = fa_t->cnt_cck_fail;
	else
		fail_tmp = fa_acc_t->cnt_cck_fail_1sec;
#endif

	if (cckpd_t->cck_fa_ma == CCK_FA_MA_RESET)
		cckpd_t->cck_fa_ma = fail_tmp;
	else
		cckpd_t->cck_fa_ma = (cckpd_t->cck_fa_ma * 3 + fail_tmp) >> 2;

	PHYDM_DBG(dm, DBG_CCKPD, "CCK FA=%d\n", cckpd_t->cck_fa_ma);

	if (dm->support_ic_type & EXTEND_CCK_CCATH_AAA_IC)
		phydm_cckpd_new_cs_ratio(dm);
	#if (RTL8192F_SUPPORT == 1)
	else if (dm->support_ic_type & EXTEND_CCK_CCATH_92F_IC)
		phydm_cckpd_92f(dm);
	#endif
	else
		phydm_cckpd(dm);

#endif
}

void odm_pause_cck_packet_detection(void *dm_void, enum phydm_pause_type type,
				    enum phydm_pause_level lv,
				    u8 cck_pd_th_input)
{
#ifdef PHYDM_SUPPORT_CCKPD
	struct dm_struct *dm = (struct dm_struct *)dm_void;
	struct phydm_cckpd_struct *cckpd_t = &dm->dm_cckpd_table;
	u8 rpt = false;
	u32 val_buf[2] = {0};

	val_buf[0] = (u32)cck_pd_th_input;
	val_buf[1] = (u32)cckpd_t->cck_cca_th_aaa;

if (dm->support_ic_type & EXTEND_CCK_CCATH_92F_IC) {
	if (cck_pd_th_input == 0x40) {
		val_buf[0] = (u32)0x00;
		val_buf[1] = (u32)0x0C;
	} else if (cck_pd_th_input == 0x83) {
		val_buf[0] = (u32)0x08;
		val_buf[1] = (u32)0x10;
	} else if (cck_pd_th_input == 0xcd) {
		val_buf[0] = (u32)0x08;
		val_buf[1] = (u32)0x12;
	} else if (cck_pd_th_input == 0x0) {
		val_buf[0] = (u32)0x00;
		val_buf[1] = (u32)0x0c;
	} else {
		val_buf[0] = (u32)0x08;
		val_buf[1] = (u32)0x10;
	}
}

	PHYDM_DBG(dm, DBG_CCKPD,
		  "[%s] type = %s, LV = %d, cck_pd_th_input = 0x%x\n", __func__,
		  ((type == PHYDM_PAUSE) ? "Pause" :
		  ((type == PHYDM_RESUME) ? "Resume" : "PauseNoSet")), lv,
		  cck_pd_th_input);

	switch (type) {
	case PHYDM_PAUSE:
	case PHYDM_PAUSE_NO_SET: {
		rpt = phydm_pause_func(dm, F05_CCK_PD, PHYDM_PAUSE,
				       lv, 2, &val_buf[0]);
		break;
	}
	case PHYDM_RESUME: {
		rpt = phydm_pause_func(dm, F05_CCK_PD, PHYDM_RESUME,
				       lv, 2, &val_buf[0]);
		break;
	}
	default:
		PHYDM_DBG(dm, DBG_CCKPD, "Wrong type\n");
		break;
	}

	PHYDM_DBG(dm, DBG_CCKPD, "pause_result=%d\n", rpt);
#endif
}

void phydm_cck_pd_init(void *dm_void)
{
#ifdef PHYDM_SUPPORT_CCKPD
	struct dm_struct *dm = (struct dm_struct *)dm_void;
	struct phydm_cckpd_struct *cckpd_t = &dm->dm_cckpd_table;
	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;

	cckpd_t->cur_cck_cca_thres = 0;
	cckpd_t->cck_cca_th_aaa = 0;

	if (dm->support_ic_type & EXTEND_CCK_CCATH_AAA_IC) {
		dig_t->aaa_default = odm_read_1byte(dm, 0xaaa) & 0x1f;
		dig_t->a0a_default = (u8)odm_get_bb_reg(dm, R_0xa08, 0xff0000);
		cckpd_t->cck_cca_th_aaa = dig_t->aaa_default;
		cckpd_t->cur_cck_cca_thres = dig_t->a0a_default;
	#if (RTL8192F_SUPPORT == 1)
	} else if (dm->support_ic_type & EXTEND_CCK_CCATH_92F_IC) {
		phydm_cck_pd_init_92f(dm);
	#endif
	} else {
		dig_t->a0a_default = (u8)odm_get_bb_reg(dm, R_0xa08, 0xff0000);
		cckpd_t->cur_cck_cca_thres = dig_t->a0a_default;
	}
#endif
}