xref: /OK3568_Linux_fs/external/rkwifibt/drivers/rtl8189fs/hal/hal_mp.c (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun /******************************************************************************
2*4882a593Smuzhiyun  *
3*4882a593Smuzhiyun  * Copyright(c) 2007 - 2017 Realtek Corporation.
4*4882a593Smuzhiyun  *
5*4882a593Smuzhiyun  * This program is free software; you can redistribute it and/or modify it
6*4882a593Smuzhiyun  * under the terms of version 2 of the GNU General Public License as
7*4882a593Smuzhiyun  * published by the Free Software Foundation.
8*4882a593Smuzhiyun  *
9*4882a593Smuzhiyun  * This program is distributed in the hope that it will be useful, but WITHOUT
10*4882a593Smuzhiyun  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11*4882a593Smuzhiyun  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
12*4882a593Smuzhiyun  * more details.
13*4882a593Smuzhiyun  *
14*4882a593Smuzhiyun  *****************************************************************************/
15*4882a593Smuzhiyun #define _HAL_MP_C_
16*4882a593Smuzhiyun 
17*4882a593Smuzhiyun #include <drv_types.h>
18*4882a593Smuzhiyun 
19*4882a593Smuzhiyun #ifdef CONFIG_MP_INCLUDED
20*4882a593Smuzhiyun 
21*4882a593Smuzhiyun #ifdef RTW_HALMAC
22*4882a593Smuzhiyun 	#include <hal_data.h>		/* struct HAL_DATA_TYPE, RF register definition and etc. */
23*4882a593Smuzhiyun #else /* !RTW_HALMAC */
24*4882a593Smuzhiyun 	#ifdef CONFIG_RTL8188E
25*4882a593Smuzhiyun 		#include <rtl8188e_hal.h>
26*4882a593Smuzhiyun 	#endif
27*4882a593Smuzhiyun 	#ifdef CONFIG_RTL8723B
28*4882a593Smuzhiyun 		#include <rtl8723b_hal.h>
29*4882a593Smuzhiyun 	#endif
30*4882a593Smuzhiyun 	#ifdef CONFIG_RTL8192E
31*4882a593Smuzhiyun 		#include <rtl8192e_hal.h>
32*4882a593Smuzhiyun 	#endif
33*4882a593Smuzhiyun 	#ifdef CONFIG_RTL8814A
34*4882a593Smuzhiyun 		#include <rtl8814a_hal.h>
35*4882a593Smuzhiyun 	#endif
36*4882a593Smuzhiyun 	#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A)
37*4882a593Smuzhiyun 		#include <rtl8812a_hal.h>
38*4882a593Smuzhiyun 	#endif
39*4882a593Smuzhiyun 	#ifdef CONFIG_RTL8703B
40*4882a593Smuzhiyun 		#include <rtl8703b_hal.h>
41*4882a593Smuzhiyun 	#endif
42*4882a593Smuzhiyun 	#ifdef CONFIG_RTL8723D
43*4882a593Smuzhiyun 		#include <rtl8723d_hal.h>
44*4882a593Smuzhiyun 	#endif
45*4882a593Smuzhiyun 	#ifdef CONFIG_RTL8710B
46*4882a593Smuzhiyun 		#include <rtl8710b_hal.h>
47*4882a593Smuzhiyun 	#endif
48*4882a593Smuzhiyun 	#ifdef CONFIG_RTL8188F
49*4882a593Smuzhiyun 		#include <rtl8188f_hal.h>
50*4882a593Smuzhiyun 	#endif
51*4882a593Smuzhiyun 	#ifdef CONFIG_RTL8188GTV
52*4882a593Smuzhiyun 		#include <rtl8188gtv_hal.h>
53*4882a593Smuzhiyun 	#endif
54*4882a593Smuzhiyun 	#ifdef CONFIG_RTL8192F
55*4882a593Smuzhiyun 		#include <rtl8192f_hal.h>
56*4882a593Smuzhiyun 	#endif
57*4882a593Smuzhiyun #endif /* !RTW_HALMAC */
58*4882a593Smuzhiyun 
59*4882a593Smuzhiyun 
MgntQuery_NssTxRate(u16 Rate)60*4882a593Smuzhiyun u8 MgntQuery_NssTxRate(u16 Rate)
61*4882a593Smuzhiyun {
62*4882a593Smuzhiyun 	u8	NssNum = RF_TX_NUM_NONIMPLEMENT;
63*4882a593Smuzhiyun 
64*4882a593Smuzhiyun 	if ((Rate >= MGN_MCS8 && Rate <= MGN_MCS15) ||
65*4882a593Smuzhiyun 	    (Rate >= MGN_VHT2SS_MCS0 && Rate <= MGN_VHT2SS_MCS9))
66*4882a593Smuzhiyun 		NssNum = RF_2TX;
67*4882a593Smuzhiyun 	else if ((Rate >= MGN_MCS16 && Rate <= MGN_MCS23) ||
68*4882a593Smuzhiyun 		 (Rate >= MGN_VHT3SS_MCS0 && Rate <= MGN_VHT3SS_MCS9))
69*4882a593Smuzhiyun 		NssNum = RF_3TX;
70*4882a593Smuzhiyun 	else if ((Rate >= MGN_MCS24 && Rate <= MGN_MCS31) ||
71*4882a593Smuzhiyun 		 (Rate >= MGN_VHT4SS_MCS0 && Rate <= MGN_VHT4SS_MCS9))
72*4882a593Smuzhiyun 		NssNum = RF_4TX;
73*4882a593Smuzhiyun 	else
74*4882a593Smuzhiyun 		NssNum = RF_1TX;
75*4882a593Smuzhiyun 
76*4882a593Smuzhiyun 	return NssNum;
77*4882a593Smuzhiyun }
78*4882a593Smuzhiyun 
hal_mpt_SwitchRfSetting(PADAPTER pAdapter)79*4882a593Smuzhiyun void hal_mpt_SwitchRfSetting(PADAPTER	pAdapter)
80*4882a593Smuzhiyun {
81*4882a593Smuzhiyun 	PMPT_CONTEXT		pMptCtx = &(pAdapter->mppriv.mpt_ctx);
82*4882a593Smuzhiyun 	u8				ChannelToSw = pMptCtx->MptChannelToSw;
83*4882a593Smuzhiyun 	u32				ulRateIdx = pMptCtx->mpt_rate_index;
84*4882a593Smuzhiyun 	u32				ulbandwidth = pMptCtx->MptBandWidth;
85*4882a593Smuzhiyun 
86*4882a593Smuzhiyun 	/* <20120525, Kordan> Dynamic mechanism for APK, asked by Dennis.*/
87*4882a593Smuzhiyun 	if (IS_HARDWARE_TYPE_8188ES(pAdapter) && (1 <= ChannelToSw && ChannelToSw <= 11) &&
88*4882a593Smuzhiyun 	    (ulRateIdx == MPT_RATE_MCS0 || ulRateIdx == MPT_RATE_1M || ulRateIdx == MPT_RATE_6M)) {
89*4882a593Smuzhiyun 		pMptCtx->backup0x52_RF_A = (u8)phy_query_rf_reg(pAdapter, RF_PATH_A, RF_0x52, 0x000F0);
90*4882a593Smuzhiyun 		pMptCtx->backup0x52_RF_B = (u8)phy_query_rf_reg(pAdapter, RF_PATH_B, RF_0x52, 0x000F0);
91*4882a593Smuzhiyun 
92*4882a593Smuzhiyun 		if ((PlatformEFIORead4Byte(pAdapter, 0xF4) & BIT29) == BIT29) {
93*4882a593Smuzhiyun 			phy_set_rf_reg(pAdapter, RF_PATH_A, RF_0x52, 0x000F0, 0xB);
94*4882a593Smuzhiyun 			phy_set_rf_reg(pAdapter, RF_PATH_B, RF_0x52, 0x000F0, 0xB);
95*4882a593Smuzhiyun 		} else {
96*4882a593Smuzhiyun 			phy_set_rf_reg(pAdapter, RF_PATH_A, RF_0x52, 0x000F0, 0xD);
97*4882a593Smuzhiyun 			phy_set_rf_reg(pAdapter, RF_PATH_B, RF_0x52, 0x000F0, 0xD);
98*4882a593Smuzhiyun 		}
99*4882a593Smuzhiyun 	} else if (IS_HARDWARE_TYPE_8188EE(pAdapter)) { /* <20140903, VincentL> Asked by RF Eason and Edlu*/
100*4882a593Smuzhiyun 		if (ChannelToSw == 3 && ulbandwidth == MPT_BW_40MHZ) {
101*4882a593Smuzhiyun 			phy_set_rf_reg(pAdapter, RF_PATH_A, RF_0x52, 0x000F0, 0xB); /*RF 0x52 = 0x0007E4BD*/
102*4882a593Smuzhiyun 			phy_set_rf_reg(pAdapter, RF_PATH_B, RF_0x52, 0x000F0, 0xB); /*RF 0x52 = 0x0007E4BD*/
103*4882a593Smuzhiyun 		} else {
104*4882a593Smuzhiyun 			phy_set_rf_reg(pAdapter, RF_PATH_A, RF_0x52, 0x000F0, 0x9); /*RF 0x52 = 0x0007E49D*/
105*4882a593Smuzhiyun 			phy_set_rf_reg(pAdapter, RF_PATH_B, RF_0x52, 0x000F0, 0x9); /*RF 0x52 = 0x0007E49D*/
106*4882a593Smuzhiyun 		}
107*4882a593Smuzhiyun 	} else if (IS_HARDWARE_TYPE_8188E(pAdapter)) {
108*4882a593Smuzhiyun 		phy_set_rf_reg(pAdapter, RF_PATH_A, RF_0x52, 0x000F0, pMptCtx->backup0x52_RF_A);
109*4882a593Smuzhiyun 		phy_set_rf_reg(pAdapter, RF_PATH_B, RF_0x52, 0x000F0, pMptCtx->backup0x52_RF_B);
110*4882a593Smuzhiyun 	}
111*4882a593Smuzhiyun }
112*4882a593Smuzhiyun 
hal_mpt_SetPowerTracking(PADAPTER padapter,u8 enable)113*4882a593Smuzhiyun s32 hal_mpt_SetPowerTracking(PADAPTER padapter, u8 enable)
114*4882a593Smuzhiyun {
115*4882a593Smuzhiyun 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
116*4882a593Smuzhiyun 	struct dm_struct		*pDM_Odm = &(pHalData->odmpriv);
117*4882a593Smuzhiyun 
118*4882a593Smuzhiyun 
119*4882a593Smuzhiyun 	if (!netif_running(padapter->pnetdev)) {
120*4882a593Smuzhiyun 		return _FAIL;
121*4882a593Smuzhiyun 	}
122*4882a593Smuzhiyun 
123*4882a593Smuzhiyun 	if (check_fwstate(&padapter->mlmepriv, WIFI_MP_STATE) == _FALSE) {
124*4882a593Smuzhiyun 		return _FAIL;
125*4882a593Smuzhiyun 	}
126*4882a593Smuzhiyun 	if (enable)
127*4882a593Smuzhiyun 		pDM_Odm->rf_calibrate_info.txpowertrack_control = _TRUE;
128*4882a593Smuzhiyun 	else
129*4882a593Smuzhiyun 		pDM_Odm->rf_calibrate_info.txpowertrack_control = _FALSE;
130*4882a593Smuzhiyun 
131*4882a593Smuzhiyun 	return _SUCCESS;
132*4882a593Smuzhiyun }
133*4882a593Smuzhiyun 
hal_mpt_GetPowerTracking(PADAPTER padapter,u8 * enable)134*4882a593Smuzhiyun void hal_mpt_GetPowerTracking(PADAPTER padapter, u8 *enable)
135*4882a593Smuzhiyun {
136*4882a593Smuzhiyun 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
137*4882a593Smuzhiyun 	struct dm_struct		*pDM_Odm = &(pHalData->odmpriv);
138*4882a593Smuzhiyun 
139*4882a593Smuzhiyun 
140*4882a593Smuzhiyun 	*enable = pDM_Odm->rf_calibrate_info.txpowertrack_control;
141*4882a593Smuzhiyun }
142*4882a593Smuzhiyun 
143*4882a593Smuzhiyun 
hal_mpt_CCKTxPowerAdjust(PADAPTER Adapter,BOOLEAN bInCH14)144*4882a593Smuzhiyun void hal_mpt_CCKTxPowerAdjust(PADAPTER Adapter, BOOLEAN bInCH14)
145*4882a593Smuzhiyun {
146*4882a593Smuzhiyun 	u32		TempVal = 0, TempVal2 = 0, TempVal3 = 0;
147*4882a593Smuzhiyun 	u32		CurrCCKSwingVal = 0, CCKSwingIndex = 12;
148*4882a593Smuzhiyun 	u8		i;
149*4882a593Smuzhiyun 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
150*4882a593Smuzhiyun 	PMPT_CONTEXT		pMptCtx = &(Adapter->mppriv.mpt_ctx);
151*4882a593Smuzhiyun 	u8				u1Channel = pHalData->current_channel;
152*4882a593Smuzhiyun 	u32				ulRateIdx = pMptCtx->mpt_rate_index;
153*4882a593Smuzhiyun 	u8				DataRate = 0xFF;
154*4882a593Smuzhiyun 
155*4882a593Smuzhiyun 	/* Do not modify CCK TX filter parameters for 8822B*/
156*4882a593Smuzhiyun 	if(IS_HARDWARE_TYPE_8822B(Adapter) || IS_HARDWARE_TYPE_8821C(Adapter) ||
157*4882a593Smuzhiyun 		IS_HARDWARE_TYPE_8723D(Adapter) || IS_HARDWARE_TYPE_8192F(Adapter) || IS_HARDWARE_TYPE_8822C(Adapter))
158*4882a593Smuzhiyun 		return;
159*4882a593Smuzhiyun 
160*4882a593Smuzhiyun 	DataRate = mpt_to_mgnt_rate(ulRateIdx);
161*4882a593Smuzhiyun 
162*4882a593Smuzhiyun 	if (u1Channel == 14 && IS_CCK_RATE(DataRate))
163*4882a593Smuzhiyun 		pHalData->bCCKinCH14 = TRUE;
164*4882a593Smuzhiyun 	else
165*4882a593Smuzhiyun 		pHalData->bCCKinCH14 = FALSE;
166*4882a593Smuzhiyun 
167*4882a593Smuzhiyun 	if (IS_HARDWARE_TYPE_8703B(Adapter)) {
168*4882a593Smuzhiyun 		if ((u1Channel == 14) && IS_CCK_RATE(DataRate)) {
169*4882a593Smuzhiyun 			/* Channel 14 in CCK, need to set 0xA26~0xA29 to 0 for 8703B */
170*4882a593Smuzhiyun 			phy_set_bb_reg(Adapter, rCCK0_TxFilter2, bMaskHWord, 0);
171*4882a593Smuzhiyun 			phy_set_bb_reg(Adapter, rCCK0_DebugPort, bMaskLWord, 0);
172*4882a593Smuzhiyun 
173*4882a593Smuzhiyun 		} else {
174*4882a593Smuzhiyun 			/* Normal setting for 8703B, just recover to the default setting. */
175*4882a593Smuzhiyun 			/* This hardcore values reference from the parameter which BB team gave. */
176*4882a593Smuzhiyun 			for (i = 0 ; i < 2 ; ++i)
177*4882a593Smuzhiyun 				phy_set_bb_reg(Adapter, pHalData->RegForRecover[i].offset, bMaskDWord, pHalData->RegForRecover[i].value);
178*4882a593Smuzhiyun 
179*4882a593Smuzhiyun 		}
180*4882a593Smuzhiyun 	} else if (IS_HARDWARE_TYPE_8723D(Adapter)) {
181*4882a593Smuzhiyun 		/* 2.4G CCK TX DFIR */
182*4882a593Smuzhiyun 		/* 2016.01.20 Suggest from RS BB mingzhi*/
183*4882a593Smuzhiyun 		if ((u1Channel == 14)) {
184*4882a593Smuzhiyun 			phy_set_bb_reg(Adapter, rCCK0_TxFilter2, bMaskDWord, 0x0000B81C);
185*4882a593Smuzhiyun 			phy_set_bb_reg(Adapter, rCCK0_DebugPort, bMaskDWord, 0x00000000);
186*4882a593Smuzhiyun 			phy_set_bb_reg(Adapter, 0xAAC, bMaskDWord, 0x00003667);
187*4882a593Smuzhiyun 		} else {
188*4882a593Smuzhiyun 			for (i = 0 ; i < 3 ; ++i) {
189*4882a593Smuzhiyun 				phy_set_bb_reg(Adapter,
190*4882a593Smuzhiyun 					     pHalData->RegForRecover[i].offset,
191*4882a593Smuzhiyun 					     bMaskDWord,
192*4882a593Smuzhiyun 					     pHalData->RegForRecover[i].value);
193*4882a593Smuzhiyun 			}
194*4882a593Smuzhiyun 		}
195*4882a593Smuzhiyun 	} else if (IS_HARDWARE_TYPE_8188F(Adapter) || IS_HARDWARE_TYPE_8188GTV(Adapter)) {
196*4882a593Smuzhiyun 		/* get current cck swing value and check 0xa22 & 0xa23 later to match the table.*/
197*4882a593Smuzhiyun 		CurrCCKSwingVal = read_bbreg(Adapter, rCCK0_TxFilter1, bMaskHWord);
198*4882a593Smuzhiyun 		CCKSwingIndex = 20; /* default index */
199*4882a593Smuzhiyun 
200*4882a593Smuzhiyun 		if (!pHalData->bCCKinCH14) {
201*4882a593Smuzhiyun 			/* Readback the current bb cck swing value and compare with the table to */
202*4882a593Smuzhiyun 			/* get the current swing index */
203*4882a593Smuzhiyun 			for (i = 0; i < CCK_TABLE_SIZE_88F; i++) {
204*4882a593Smuzhiyun 				if (((CurrCCKSwingVal & 0xff) == (u32)cck_swing_table_ch1_ch13_88f[i][0]) &&
205*4882a593Smuzhiyun 				    (((CurrCCKSwingVal & 0xff00) >> 8) == (u32)cck_swing_table_ch1_ch13_88f[i][1])) {
206*4882a593Smuzhiyun 					CCKSwingIndex = i;
207*4882a593Smuzhiyun 					break;
208*4882a593Smuzhiyun 				}
209*4882a593Smuzhiyun 			}
210*4882a593Smuzhiyun 			write_bbreg(Adapter, 0xa22, bMaskByte0, cck_swing_table_ch1_ch13_88f[CCKSwingIndex][0]);
211*4882a593Smuzhiyun 			write_bbreg(Adapter, 0xa23, bMaskByte0, cck_swing_table_ch1_ch13_88f[CCKSwingIndex][1]);
212*4882a593Smuzhiyun 			write_bbreg(Adapter, 0xa24, bMaskByte0, cck_swing_table_ch1_ch13_88f[CCKSwingIndex][2]);
213*4882a593Smuzhiyun 			write_bbreg(Adapter, 0xa25, bMaskByte0, cck_swing_table_ch1_ch13_88f[CCKSwingIndex][3]);
214*4882a593Smuzhiyun 			write_bbreg(Adapter, 0xa26, bMaskByte0, cck_swing_table_ch1_ch13_88f[CCKSwingIndex][4]);
215*4882a593Smuzhiyun 			write_bbreg(Adapter, 0xa27, bMaskByte0, cck_swing_table_ch1_ch13_88f[CCKSwingIndex][5]);
216*4882a593Smuzhiyun 			write_bbreg(Adapter, 0xa28, bMaskByte0, cck_swing_table_ch1_ch13_88f[CCKSwingIndex][6]);
217*4882a593Smuzhiyun 			write_bbreg(Adapter, 0xa29, bMaskByte0, cck_swing_table_ch1_ch13_88f[CCKSwingIndex][7]);
218*4882a593Smuzhiyun 			write_bbreg(Adapter, 0xa9a, bMaskByte0, cck_swing_table_ch1_ch13_88f[CCKSwingIndex][8]);
219*4882a593Smuzhiyun 			write_bbreg(Adapter, 0xa9b, bMaskByte0, cck_swing_table_ch1_ch13_88f[CCKSwingIndex][9]);
220*4882a593Smuzhiyun 			write_bbreg(Adapter, 0xa9c, bMaskByte0, cck_swing_table_ch1_ch13_88f[CCKSwingIndex][10]);
221*4882a593Smuzhiyun 			write_bbreg(Adapter, 0xa9d, bMaskByte0, cck_swing_table_ch1_ch13_88f[CCKSwingIndex][11]);
222*4882a593Smuzhiyun 			write_bbreg(Adapter, 0xaa0, bMaskByte0, cck_swing_table_ch1_ch13_88f[CCKSwingIndex][12]);
223*4882a593Smuzhiyun 			write_bbreg(Adapter, 0xaa1, bMaskByte0, cck_swing_table_ch1_ch13_88f[CCKSwingIndex][13]);
224*4882a593Smuzhiyun 			write_bbreg(Adapter, 0xaa2, bMaskByte0, cck_swing_table_ch1_ch13_88f[CCKSwingIndex][14]);
225*4882a593Smuzhiyun 			write_bbreg(Adapter, 0xaa3, bMaskByte0, cck_swing_table_ch1_ch13_88f[CCKSwingIndex][15]);
226*4882a593Smuzhiyun 			RTW_INFO("%s , cck_swing_table_ch1_ch13_88f[%d]\n", __func__, CCKSwingIndex);
227*4882a593Smuzhiyun 		}  else {
228*4882a593Smuzhiyun 			for (i = 0; i < CCK_TABLE_SIZE_88F; i++) {
229*4882a593Smuzhiyun 				if (((CurrCCKSwingVal & 0xff) == (u32)cck_swing_table_ch14_88f[i][0]) &&
230*4882a593Smuzhiyun 				    (((CurrCCKSwingVal & 0xff00) >> 8) == (u32)cck_swing_table_ch14_88f[i][1])) {
231*4882a593Smuzhiyun 					CCKSwingIndex = i;
232*4882a593Smuzhiyun 					break;
233*4882a593Smuzhiyun 				}
234*4882a593Smuzhiyun 			}
235*4882a593Smuzhiyun 			write_bbreg(Adapter, 0xa22, bMaskByte0, cck_swing_table_ch14_88f[CCKSwingIndex][0]);
236*4882a593Smuzhiyun 			write_bbreg(Adapter, 0xa23, bMaskByte0, cck_swing_table_ch14_88f[CCKSwingIndex][1]);
237*4882a593Smuzhiyun 			write_bbreg(Adapter, 0xa24, bMaskByte0, cck_swing_table_ch14_88f[CCKSwingIndex][2]);
238*4882a593Smuzhiyun 			write_bbreg(Adapter, 0xa25, bMaskByte0, cck_swing_table_ch14_88f[CCKSwingIndex][3]);
239*4882a593Smuzhiyun 			write_bbreg(Adapter, 0xa26, bMaskByte0, cck_swing_table_ch14_88f[CCKSwingIndex][4]);
240*4882a593Smuzhiyun 			write_bbreg(Adapter, 0xa27, bMaskByte0, cck_swing_table_ch14_88f[CCKSwingIndex][5]);
241*4882a593Smuzhiyun 			write_bbreg(Adapter, 0xa28, bMaskByte0, cck_swing_table_ch14_88f[CCKSwingIndex][6]);
242*4882a593Smuzhiyun 			write_bbreg(Adapter, 0xa29, bMaskByte0, cck_swing_table_ch14_88f[CCKSwingIndex][7]);
243*4882a593Smuzhiyun 			write_bbreg(Adapter, 0xa9a, bMaskByte0, cck_swing_table_ch14_88f[CCKSwingIndex][8]);
244*4882a593Smuzhiyun 			write_bbreg(Adapter, 0xa9b, bMaskByte0, cck_swing_table_ch14_88f[CCKSwingIndex][9]);
245*4882a593Smuzhiyun 			write_bbreg(Adapter, 0xa9c, bMaskByte0, cck_swing_table_ch14_88f[CCKSwingIndex][10]);
246*4882a593Smuzhiyun 			write_bbreg(Adapter, 0xa9d, bMaskByte0, cck_swing_table_ch14_88f[CCKSwingIndex][11]);
247*4882a593Smuzhiyun 			write_bbreg(Adapter, 0xaa0, bMaskByte0, cck_swing_table_ch14_88f[CCKSwingIndex][12]);
248*4882a593Smuzhiyun 			write_bbreg(Adapter, 0xaa1, bMaskByte0, cck_swing_table_ch14_88f[CCKSwingIndex][13]);
249*4882a593Smuzhiyun 			write_bbreg(Adapter, 0xaa2, bMaskByte0, cck_swing_table_ch14_88f[CCKSwingIndex][14]);
250*4882a593Smuzhiyun 			write_bbreg(Adapter, 0xaa3, bMaskByte0, cck_swing_table_ch14_88f[CCKSwingIndex][15]);
251*4882a593Smuzhiyun 			RTW_INFO("%s , cck_swing_table_ch14_88f[%d]\n", __func__, CCKSwingIndex);
252*4882a593Smuzhiyun 		}
253*4882a593Smuzhiyun 	} else {
254*4882a593Smuzhiyun 
255*4882a593Smuzhiyun 		/* get current cck swing value and check 0xa22 & 0xa23 later to match the table.*/
256*4882a593Smuzhiyun 		CurrCCKSwingVal = read_bbreg(Adapter, rCCK0_TxFilter1, bMaskHWord);
257*4882a593Smuzhiyun 
258*4882a593Smuzhiyun 		if (!pHalData->bCCKinCH14) {
259*4882a593Smuzhiyun 			/* Readback the current bb cck swing value and compare with the table to */
260*4882a593Smuzhiyun 			/* get the current swing index */
261*4882a593Smuzhiyun 			for (i = 0; i < CCK_TABLE_SIZE; i++) {
262*4882a593Smuzhiyun 				if (((CurrCCKSwingVal & 0xff) == (u32)cck_swing_table_ch1_ch13[i][0]) &&
263*4882a593Smuzhiyun 				    (((CurrCCKSwingVal & 0xff00) >> 8) == (u32)cck_swing_table_ch1_ch13[i][1])) {
264*4882a593Smuzhiyun 					CCKSwingIndex = i;
265*4882a593Smuzhiyun 					break;
266*4882a593Smuzhiyun 				}
267*4882a593Smuzhiyun 			}
268*4882a593Smuzhiyun 
269*4882a593Smuzhiyun 			/*Write 0xa22 0xa23*/
270*4882a593Smuzhiyun 			TempVal = cck_swing_table_ch1_ch13[CCKSwingIndex][0] +
271*4882a593Smuzhiyun 				(cck_swing_table_ch1_ch13[CCKSwingIndex][1] << 8);
272*4882a593Smuzhiyun 
273*4882a593Smuzhiyun 
274*4882a593Smuzhiyun 			/*Write 0xa24 ~ 0xa27*/
275*4882a593Smuzhiyun 			TempVal2 = 0;
276*4882a593Smuzhiyun 			TempVal2 = cck_swing_table_ch1_ch13[CCKSwingIndex][2] +
277*4882a593Smuzhiyun 				(cck_swing_table_ch1_ch13[CCKSwingIndex][3] << 8) +
278*4882a593Smuzhiyun 				(cck_swing_table_ch1_ch13[CCKSwingIndex][4] << 16) +
279*4882a593Smuzhiyun 				(cck_swing_table_ch1_ch13[CCKSwingIndex][5] << 24);
280*4882a593Smuzhiyun 
281*4882a593Smuzhiyun 			/*Write 0xa28  0xa29*/
282*4882a593Smuzhiyun 			TempVal3 = 0;
283*4882a593Smuzhiyun 			TempVal3 = cck_swing_table_ch1_ch13[CCKSwingIndex][6] +
284*4882a593Smuzhiyun 				(cck_swing_table_ch1_ch13[CCKSwingIndex][7] << 8);
285*4882a593Smuzhiyun 		}  else {
286*4882a593Smuzhiyun 			for (i = 0; i < CCK_TABLE_SIZE; i++) {
287*4882a593Smuzhiyun 				if (((CurrCCKSwingVal & 0xff) == (u32)cck_swing_table_ch14[i][0]) &&
288*4882a593Smuzhiyun 				    (((CurrCCKSwingVal & 0xff00) >> 8) == (u32)cck_swing_table_ch14[i][1])) {
289*4882a593Smuzhiyun 					CCKSwingIndex = i;
290*4882a593Smuzhiyun 					break;
291*4882a593Smuzhiyun 				}
292*4882a593Smuzhiyun 			}
293*4882a593Smuzhiyun 
294*4882a593Smuzhiyun 			/*Write 0xa22 0xa23*/
295*4882a593Smuzhiyun 			TempVal = cck_swing_table_ch14[CCKSwingIndex][0] +
296*4882a593Smuzhiyun 				  (cck_swing_table_ch14[CCKSwingIndex][1] << 8);
297*4882a593Smuzhiyun 
298*4882a593Smuzhiyun 			/*Write 0xa24 ~ 0xa27*/
299*4882a593Smuzhiyun 			TempVal2 = 0;
300*4882a593Smuzhiyun 			TempVal2 = cck_swing_table_ch14[CCKSwingIndex][2] +
301*4882a593Smuzhiyun 				   (cck_swing_table_ch14[CCKSwingIndex][3] << 8) +
302*4882a593Smuzhiyun 				(cck_swing_table_ch14[CCKSwingIndex][4] << 16) +
303*4882a593Smuzhiyun 				   (cck_swing_table_ch14[CCKSwingIndex][5] << 24);
304*4882a593Smuzhiyun 
305*4882a593Smuzhiyun 			/*Write 0xa28  0xa29*/
306*4882a593Smuzhiyun 			TempVal3 = 0;
307*4882a593Smuzhiyun 			TempVal3 = cck_swing_table_ch14[CCKSwingIndex][6] +
308*4882a593Smuzhiyun 				   (cck_swing_table_ch14[CCKSwingIndex][7] << 8);
309*4882a593Smuzhiyun 		}
310*4882a593Smuzhiyun 
311*4882a593Smuzhiyun 		write_bbreg(Adapter, rCCK0_TxFilter1, bMaskHWord, TempVal);
312*4882a593Smuzhiyun 		write_bbreg(Adapter, rCCK0_TxFilter2, bMaskDWord, TempVal2);
313*4882a593Smuzhiyun 		write_bbreg(Adapter, rCCK0_DebugPort, bMaskLWord, TempVal3);
314*4882a593Smuzhiyun 	}
315*4882a593Smuzhiyun 
316*4882a593Smuzhiyun }
317*4882a593Smuzhiyun 
hal_mpt_SetChannel(PADAPTER pAdapter)318*4882a593Smuzhiyun void hal_mpt_SetChannel(PADAPTER pAdapter)
319*4882a593Smuzhiyun {
320*4882a593Smuzhiyun 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
321*4882a593Smuzhiyun 	struct mp_priv	*pmp = &pAdapter->mppriv;
322*4882a593Smuzhiyun 	u8		channel = pmp->channel;
323*4882a593Smuzhiyun 	u8		bandwidth = pmp->bandwidth;
324*4882a593Smuzhiyun 
325*4882a593Smuzhiyun 	hal_mpt_SwitchRfSetting(pAdapter);
326*4882a593Smuzhiyun 
327*4882a593Smuzhiyun 	pHalData->bSwChnl = _TRUE;
328*4882a593Smuzhiyun 	pHalData->bSetChnlBW = _TRUE;
329*4882a593Smuzhiyun 
330*4882a593Smuzhiyun 	if (bandwidth == 2) {
331*4882a593Smuzhiyun 		rtw_hal_set_chnl_bw(pAdapter, channel, bandwidth, HAL_PRIME_CHNL_OFFSET_LOWER, HAL_PRIME_CHNL_OFFSET_UPPER);
332*4882a593Smuzhiyun 	} else if (bandwidth == 1) {
333*4882a593Smuzhiyun 		rtw_hal_set_chnl_bw(pAdapter, channel, bandwidth, HAL_PRIME_CHNL_OFFSET_UPPER, 0);
334*4882a593Smuzhiyun 	} else
335*4882a593Smuzhiyun 		rtw_hal_set_chnl_bw(pAdapter, channel, bandwidth, pmp->prime_channel_offset, 0);
336*4882a593Smuzhiyun 
337*4882a593Smuzhiyun 	hal_mpt_CCKTxPowerAdjust(pAdapter, pHalData->bCCKinCH14);
338*4882a593Smuzhiyun 	rtw_btcoex_wifionly_scan_notify(pAdapter);
339*4882a593Smuzhiyun 
340*4882a593Smuzhiyun }
341*4882a593Smuzhiyun 
342*4882a593Smuzhiyun /*
343*4882a593Smuzhiyun  * Notice
344*4882a593Smuzhiyun  *	Switch bandwitdth may change center frequency(channel)
345*4882a593Smuzhiyun  */
hal_mpt_SetBandwidth(PADAPTER pAdapter)346*4882a593Smuzhiyun void hal_mpt_SetBandwidth(PADAPTER pAdapter)
347*4882a593Smuzhiyun {
348*4882a593Smuzhiyun 	struct mp_priv *pmp = &pAdapter->mppriv;
349*4882a593Smuzhiyun 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
350*4882a593Smuzhiyun 
351*4882a593Smuzhiyun 	u8		channel = pmp->channel;
352*4882a593Smuzhiyun 	u8		bandwidth = pmp->bandwidth;
353*4882a593Smuzhiyun 
354*4882a593Smuzhiyun 	pHalData->bSwChnl = _TRUE;
355*4882a593Smuzhiyun 	pHalData->bSetChnlBW = _TRUE;
356*4882a593Smuzhiyun 
357*4882a593Smuzhiyun 	if (bandwidth == 2) {
358*4882a593Smuzhiyun 		rtw_hal_set_chnl_bw(pAdapter, channel, bandwidth, HAL_PRIME_CHNL_OFFSET_LOWER, HAL_PRIME_CHNL_OFFSET_UPPER);
359*4882a593Smuzhiyun 	} else if (bandwidth == 1) {
360*4882a593Smuzhiyun 		rtw_hal_set_chnl_bw(pAdapter, channel, bandwidth, HAL_PRIME_CHNL_OFFSET_UPPER, 0);
361*4882a593Smuzhiyun 	} else
362*4882a593Smuzhiyun 		rtw_hal_set_chnl_bw(pAdapter, channel, bandwidth, pmp->prime_channel_offset, 0);
363*4882a593Smuzhiyun 
364*4882a593Smuzhiyun 	hal_mpt_SwitchRfSetting(pAdapter);
365*4882a593Smuzhiyun 	rtw_btcoex_wifionly_scan_notify(pAdapter);
366*4882a593Smuzhiyun 
367*4882a593Smuzhiyun }
368*4882a593Smuzhiyun 
mpt_SetTxPower_Old(PADAPTER pAdapter,MPT_TXPWR_DEF Rate,u8 * pTxPower)369*4882a593Smuzhiyun void mpt_SetTxPower_Old(PADAPTER pAdapter, MPT_TXPWR_DEF Rate, u8 *pTxPower)
370*4882a593Smuzhiyun {
371*4882a593Smuzhiyun 	switch (Rate) {
372*4882a593Smuzhiyun 	case MPT_CCK: {
373*4882a593Smuzhiyun 		u32	TxAGC = 0, pwr = 0;
374*4882a593Smuzhiyun 
375*4882a593Smuzhiyun 		pwr = pTxPower[RF_PATH_A];
376*4882a593Smuzhiyun 		if (pwr < 0x3f) {
377*4882a593Smuzhiyun 			TxAGC = (pwr << 16) | (pwr << 8) | (pwr);
378*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rTxAGC_A_CCK1_Mcs32, bMaskByte1, pTxPower[RF_PATH_A]);
379*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rTxAGC_B_CCK11_A_CCK2_11, 0xffffff00, TxAGC);
380*4882a593Smuzhiyun 		}
381*4882a593Smuzhiyun 		pwr = pTxPower[RF_PATH_B];
382*4882a593Smuzhiyun 		if (pwr < 0x3f) {
383*4882a593Smuzhiyun 			TxAGC = (pwr << 16) | (pwr << 8) | (pwr);
384*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rTxAGC_B_CCK11_A_CCK2_11, bMaskByte0, pTxPower[RF_PATH_B]);
385*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rTxAGC_B_CCK1_55_Mcs32, 0xffffff00, TxAGC);
386*4882a593Smuzhiyun 		}
387*4882a593Smuzhiyun 	}
388*4882a593Smuzhiyun 	break;
389*4882a593Smuzhiyun 
390*4882a593Smuzhiyun 	case MPT_OFDM_AND_HT: {
391*4882a593Smuzhiyun 		u32	TxAGC = 0;
392*4882a593Smuzhiyun 		u8	pwr = 0;
393*4882a593Smuzhiyun 
394*4882a593Smuzhiyun 		pwr = pTxPower[0];
395*4882a593Smuzhiyun 		if (pwr < 0x3f) {
396*4882a593Smuzhiyun 			TxAGC |= ((pwr << 24) | (pwr << 16) | (pwr << 8) | pwr);
397*4882a593Smuzhiyun 			RTW_INFO("HT Tx-rf(A) Power = 0x%x\n", TxAGC);
398*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rTxAGC_A_Rate18_06, bMaskDWord, TxAGC);
399*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rTxAGC_A_Rate54_24, bMaskDWord, TxAGC);
400*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rTxAGC_A_Mcs03_Mcs00, bMaskDWord, TxAGC);
401*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rTxAGC_A_Mcs07_Mcs04, bMaskDWord, TxAGC);
402*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rTxAGC_A_Mcs11_Mcs08, bMaskDWord, TxAGC);
403*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rTxAGC_A_Mcs15_Mcs12, bMaskDWord, TxAGC);
404*4882a593Smuzhiyun 		}
405*4882a593Smuzhiyun 		TxAGC = 0;
406*4882a593Smuzhiyun 		pwr = pTxPower[1];
407*4882a593Smuzhiyun 		if (pwr < 0x3f) {
408*4882a593Smuzhiyun 			TxAGC |= ((pwr << 24) | (pwr << 16) | (pwr << 8) | pwr);
409*4882a593Smuzhiyun 			RTW_INFO("HT Tx-rf(B) Power = 0x%x\n", TxAGC);
410*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rTxAGC_B_Rate18_06, bMaskDWord, TxAGC);
411*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rTxAGC_B_Rate54_24, bMaskDWord, TxAGC);
412*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rTxAGC_B_Mcs03_Mcs00, bMaskDWord, TxAGC);
413*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rTxAGC_B_Mcs07_Mcs04, bMaskDWord, TxAGC);
414*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rTxAGC_B_Mcs11_Mcs08, bMaskDWord, TxAGC);
415*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rTxAGC_B_Mcs15_Mcs12, bMaskDWord, TxAGC);
416*4882a593Smuzhiyun 		}
417*4882a593Smuzhiyun 	}
418*4882a593Smuzhiyun 	break;
419*4882a593Smuzhiyun 
420*4882a593Smuzhiyun 	default:
421*4882a593Smuzhiyun 		break;
422*4882a593Smuzhiyun 	}
423*4882a593Smuzhiyun 	RTW_INFO("<===mpt_SetTxPower_Old()\n");
424*4882a593Smuzhiyun }
425*4882a593Smuzhiyun 
426*4882a593Smuzhiyun void
mpt_SetTxPower(PADAPTER pAdapter,MPT_TXPWR_DEF Rate,u8 * pTxPower)427*4882a593Smuzhiyun mpt_SetTxPower(
428*4882a593Smuzhiyun 	PADAPTER		pAdapter,
429*4882a593Smuzhiyun 	MPT_TXPWR_DEF	Rate,
430*4882a593Smuzhiyun 	u8 *pTxPower
431*4882a593Smuzhiyun )
432*4882a593Smuzhiyun {
433*4882a593Smuzhiyun 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
434*4882a593Smuzhiyun 
435*4882a593Smuzhiyun 	u8 path = 0 , i = 0, MaxRate = MGN_6M;
436*4882a593Smuzhiyun 	u8 StartPath = RF_PATH_A, EndPath = RF_PATH_B;
437*4882a593Smuzhiyun 
438*4882a593Smuzhiyun 	if (IS_HARDWARE_TYPE_8814A(pAdapter) || IS_HARDWARE_TYPE_8814B(pAdapter))
439*4882a593Smuzhiyun 		EndPath = RF_PATH_D;
440*4882a593Smuzhiyun 	else if (IS_HARDWARE_TYPE_8188F(pAdapter) || IS_HARDWARE_TYPE_8188GTV(pAdapter)
441*4882a593Smuzhiyun 		|| IS_HARDWARE_TYPE_8723D(pAdapter) || IS_HARDWARE_TYPE_8821C(pAdapter))
442*4882a593Smuzhiyun 		EndPath = RF_PATH_A;
443*4882a593Smuzhiyun 
444*4882a593Smuzhiyun 	switch (Rate) {
445*4882a593Smuzhiyun 	case MPT_CCK: {
446*4882a593Smuzhiyun 		u8 rate[] = {MGN_1M, MGN_2M, MGN_5_5M, MGN_11M};
447*4882a593Smuzhiyun 
448*4882a593Smuzhiyun 		for (path = StartPath; path <= EndPath; path++)
449*4882a593Smuzhiyun 			for (i = 0; i < sizeof(rate); ++i)
450*4882a593Smuzhiyun 				PHY_SetTxPowerIndex(pAdapter, pTxPower[path], path, rate[i]);
451*4882a593Smuzhiyun 	}
452*4882a593Smuzhiyun 	break;
453*4882a593Smuzhiyun 	case MPT_OFDM: {
454*4882a593Smuzhiyun 		u8 rate[] = {
455*4882a593Smuzhiyun 			MGN_6M, MGN_9M, MGN_12M, MGN_18M,
456*4882a593Smuzhiyun 			MGN_24M, MGN_36M, MGN_48M, MGN_54M,
457*4882a593Smuzhiyun 		};
458*4882a593Smuzhiyun 
459*4882a593Smuzhiyun 		for (path = StartPath; path <= EndPath; path++)
460*4882a593Smuzhiyun 			for (i = 0; i < sizeof(rate); ++i)
461*4882a593Smuzhiyun 				PHY_SetTxPowerIndex(pAdapter, pTxPower[path], path, rate[i]);
462*4882a593Smuzhiyun 	}
463*4882a593Smuzhiyun 	break;
464*4882a593Smuzhiyun 	case MPT_HT: {
465*4882a593Smuzhiyun 		u8 rate[] = {
466*4882a593Smuzhiyun 			MGN_MCS0, MGN_MCS1, MGN_MCS2, MGN_MCS3, MGN_MCS4,
467*4882a593Smuzhiyun 			MGN_MCS5, MGN_MCS6, MGN_MCS7, MGN_MCS8, MGN_MCS9,
468*4882a593Smuzhiyun 			MGN_MCS10, MGN_MCS11, MGN_MCS12, MGN_MCS13, MGN_MCS14,
469*4882a593Smuzhiyun 			MGN_MCS15, MGN_MCS16, MGN_MCS17, MGN_MCS18, MGN_MCS19,
470*4882a593Smuzhiyun 			MGN_MCS20, MGN_MCS21, MGN_MCS22, MGN_MCS23, MGN_MCS24,
471*4882a593Smuzhiyun 			MGN_MCS25, MGN_MCS26, MGN_MCS27, MGN_MCS28, MGN_MCS29,
472*4882a593Smuzhiyun 			MGN_MCS30, MGN_MCS31,
473*4882a593Smuzhiyun 		};
474*4882a593Smuzhiyun 		if (pHalData->rf_type == RF_4T4R)
475*4882a593Smuzhiyun 			MaxRate = MGN_MCS31;
476*4882a593Smuzhiyun 		else if (pHalData->rf_type == RF_3T3R)
477*4882a593Smuzhiyun 			MaxRate = MGN_MCS23;
478*4882a593Smuzhiyun 		else if (pHalData->rf_type == RF_2T2R)
479*4882a593Smuzhiyun 			MaxRate = MGN_MCS15;
480*4882a593Smuzhiyun 		else
481*4882a593Smuzhiyun 			MaxRate = MGN_MCS7;
482*4882a593Smuzhiyun 		for (path = StartPath; path <= EndPath; path++) {
483*4882a593Smuzhiyun 			for (i = 0; i < sizeof(rate); ++i) {
484*4882a593Smuzhiyun 				if (rate[i] > MaxRate)
485*4882a593Smuzhiyun 					break;
486*4882a593Smuzhiyun 				PHY_SetTxPowerIndex(pAdapter, pTxPower[path], path, rate[i]);
487*4882a593Smuzhiyun 			}
488*4882a593Smuzhiyun 		}
489*4882a593Smuzhiyun 	}
490*4882a593Smuzhiyun 	break;
491*4882a593Smuzhiyun 	case MPT_VHT: {
492*4882a593Smuzhiyun 		u8 rate[] = {
493*4882a593Smuzhiyun 			MGN_VHT1SS_MCS0, MGN_VHT1SS_MCS1, MGN_VHT1SS_MCS2, MGN_VHT1SS_MCS3, MGN_VHT1SS_MCS4,
494*4882a593Smuzhiyun 			MGN_VHT1SS_MCS5, MGN_VHT1SS_MCS6, MGN_VHT1SS_MCS7, MGN_VHT1SS_MCS8, MGN_VHT1SS_MCS9,
495*4882a593Smuzhiyun 			MGN_VHT2SS_MCS0, MGN_VHT2SS_MCS1, MGN_VHT2SS_MCS2, MGN_VHT2SS_MCS3, MGN_VHT2SS_MCS4,
496*4882a593Smuzhiyun 			MGN_VHT2SS_MCS5, MGN_VHT2SS_MCS6, MGN_VHT2SS_MCS7, MGN_VHT2SS_MCS8, MGN_VHT2SS_MCS9,
497*4882a593Smuzhiyun 			MGN_VHT3SS_MCS0, MGN_VHT3SS_MCS1, MGN_VHT3SS_MCS2, MGN_VHT3SS_MCS3, MGN_VHT3SS_MCS4,
498*4882a593Smuzhiyun 			MGN_VHT3SS_MCS5, MGN_VHT3SS_MCS6, MGN_VHT3SS_MCS7, MGN_VHT3SS_MCS8, MGN_VHT3SS_MCS9,
499*4882a593Smuzhiyun 			MGN_VHT4SS_MCS0, MGN_VHT4SS_MCS1, MGN_VHT4SS_MCS2, MGN_VHT4SS_MCS3, MGN_VHT4SS_MCS4,
500*4882a593Smuzhiyun 			MGN_VHT4SS_MCS5, MGN_VHT4SS_MCS6, MGN_VHT4SS_MCS7, MGN_VHT4SS_MCS8, MGN_VHT4SS_MCS9,
501*4882a593Smuzhiyun 		};
502*4882a593Smuzhiyun 		if (pHalData->rf_type == RF_4T4R)
503*4882a593Smuzhiyun 			MaxRate = MGN_VHT4SS_MCS9;
504*4882a593Smuzhiyun 		else if (pHalData->rf_type == RF_3T3R)
505*4882a593Smuzhiyun 			MaxRate = MGN_VHT3SS_MCS9;
506*4882a593Smuzhiyun 		else if (pHalData->rf_type == RF_2T2R || pHalData->rf_type == RF_2T4R)
507*4882a593Smuzhiyun 			MaxRate = MGN_VHT2SS_MCS9;
508*4882a593Smuzhiyun 		else
509*4882a593Smuzhiyun 			MaxRate = MGN_VHT1SS_MCS9;
510*4882a593Smuzhiyun 
511*4882a593Smuzhiyun 		for (path = StartPath; path <= EndPath; path++) {
512*4882a593Smuzhiyun 			for (i = 0; i < sizeof(rate); ++i) {
513*4882a593Smuzhiyun 				if (rate[i] > MaxRate)
514*4882a593Smuzhiyun 					break;
515*4882a593Smuzhiyun 				PHY_SetTxPowerIndex(pAdapter, pTxPower[path], path, rate[i]);
516*4882a593Smuzhiyun 			}
517*4882a593Smuzhiyun 		}
518*4882a593Smuzhiyun 	}
519*4882a593Smuzhiyun 	break;
520*4882a593Smuzhiyun 	default:
521*4882a593Smuzhiyun 		RTW_INFO("<===mpt_SetTxPower: Illegal channel!!\n");
522*4882a593Smuzhiyun 		break;
523*4882a593Smuzhiyun 	}
524*4882a593Smuzhiyun }
525*4882a593Smuzhiyun 
hal_mpt_SetTxPower(PADAPTER pAdapter)526*4882a593Smuzhiyun void hal_mpt_SetTxPower(PADAPTER pAdapter)
527*4882a593Smuzhiyun {
528*4882a593Smuzhiyun 	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
529*4882a593Smuzhiyun 	PMPT_CONTEXT		pMptCtx = &(pAdapter->mppriv.mpt_ctx);
530*4882a593Smuzhiyun 	struct dm_struct		*pDM_Odm = &pHalData->odmpriv;
531*4882a593Smuzhiyun 
532*4882a593Smuzhiyun 	if (pHalData->rf_chip < RF_CHIP_MAX) {
533*4882a593Smuzhiyun 		if (IS_HARDWARE_TYPE_8188E(pAdapter) ||
534*4882a593Smuzhiyun 		    IS_HARDWARE_TYPE_8723B(pAdapter) ||
535*4882a593Smuzhiyun 		    IS_HARDWARE_TYPE_8192E(pAdapter) ||
536*4882a593Smuzhiyun 		    IS_HARDWARE_TYPE_8703B(pAdapter) ||
537*4882a593Smuzhiyun 		    IS_HARDWARE_TYPE_8188F(pAdapter) ||
538*4882a593Smuzhiyun 		    IS_HARDWARE_TYPE_8188GTV(pAdapter)
539*4882a593Smuzhiyun 		) {
540*4882a593Smuzhiyun 
541*4882a593Smuzhiyun 			RTW_INFO("===> MPT_ProSetTxPower: Old\n");
542*4882a593Smuzhiyun 
543*4882a593Smuzhiyun 			mpt_SetTxPower_Old(pAdapter, MPT_CCK, pMptCtx->TxPwrLevel);
544*4882a593Smuzhiyun 			mpt_SetTxPower_Old(pAdapter, MPT_OFDM_AND_HT, pMptCtx->TxPwrLevel);
545*4882a593Smuzhiyun 
546*4882a593Smuzhiyun 		} else {
547*4882a593Smuzhiyun 
548*4882a593Smuzhiyun 			mpt_SetTxPower(pAdapter, MPT_CCK, pMptCtx->TxPwrLevel);
549*4882a593Smuzhiyun 			mpt_SetTxPower(pAdapter, MPT_OFDM, pMptCtx->TxPwrLevel);
550*4882a593Smuzhiyun 			mpt_SetTxPower(pAdapter, MPT_HT, pMptCtx->TxPwrLevel);
551*4882a593Smuzhiyun 			if(IS_HARDWARE_TYPE_JAGUAR_ALL(pAdapter)) {
552*4882a593Smuzhiyun 				RTW_INFO("===> MPT_ProSetTxPower: Jaguar/Jaguar2\n");
553*4882a593Smuzhiyun 				mpt_SetTxPower(pAdapter, MPT_VHT, pMptCtx->TxPwrLevel);
554*4882a593Smuzhiyun 			}
555*4882a593Smuzhiyun 		}
556*4882a593Smuzhiyun 
557*4882a593Smuzhiyun 		rtw_hal_set_txpwr_done(pAdapter);
558*4882a593Smuzhiyun 	} else
559*4882a593Smuzhiyun 		RTW_INFO("RFChipID < RF_CHIP_MAX, the RF chip is not supported - %d\n", pHalData->rf_chip);
560*4882a593Smuzhiyun 
561*4882a593Smuzhiyun 	odm_clear_txpowertracking_state(pDM_Odm);
562*4882a593Smuzhiyun }
563*4882a593Smuzhiyun 
hal_mpt_SetDataRate(PADAPTER pAdapter)564*4882a593Smuzhiyun void hal_mpt_SetDataRate(PADAPTER pAdapter)
565*4882a593Smuzhiyun {
566*4882a593Smuzhiyun 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
567*4882a593Smuzhiyun 	PMPT_CONTEXT		pMptCtx = &(pAdapter->mppriv.mpt_ctx);
568*4882a593Smuzhiyun 	u32 DataRate;
569*4882a593Smuzhiyun 
570*4882a593Smuzhiyun 	DataRate = mpt_to_mgnt_rate(pMptCtx->mpt_rate_index);
571*4882a593Smuzhiyun 
572*4882a593Smuzhiyun 	hal_mpt_SwitchRfSetting(pAdapter);
573*4882a593Smuzhiyun 
574*4882a593Smuzhiyun 	hal_mpt_CCKTxPowerAdjust(pAdapter, pHalData->bCCKinCH14);
575*4882a593Smuzhiyun #ifdef CONFIG_RTL8723B
576*4882a593Smuzhiyun 	if (IS_HARDWARE_TYPE_8723B(pAdapter)) {
577*4882a593Smuzhiyun 		if (IS_CCK_RATE(DataRate)) {
578*4882a593Smuzhiyun 			if (pMptCtx->mpt_rf_path == RF_PATH_A)
579*4882a593Smuzhiyun 				phy_set_rf_reg(pAdapter, RF_PATH_A, 0x51, 0xF, 0x6);
580*4882a593Smuzhiyun 			else
581*4882a593Smuzhiyun 				phy_set_rf_reg(pAdapter, RF_PATH_A, 0x71, 0xF, 0x6);
582*4882a593Smuzhiyun 		} else {
583*4882a593Smuzhiyun 			if (pMptCtx->mpt_rf_path == RF_PATH_A)
584*4882a593Smuzhiyun 				phy_set_rf_reg(pAdapter, RF_PATH_A, 0x51, 0xF, 0xE);
585*4882a593Smuzhiyun 			else
586*4882a593Smuzhiyun 				phy_set_rf_reg(pAdapter, RF_PATH_A, 0x71, 0xF, 0xE);
587*4882a593Smuzhiyun 		}
588*4882a593Smuzhiyun 	}
589*4882a593Smuzhiyun 
590*4882a593Smuzhiyun 	if ((IS_HARDWARE_TYPE_8723BS(pAdapter) &&
591*4882a593Smuzhiyun 	     ((pHalData->PackageType == PACKAGE_TFBGA79) || (pHalData->PackageType == PACKAGE_TFBGA90)))) {
592*4882a593Smuzhiyun 		if (pMptCtx->mpt_rf_path == RF_PATH_A)
593*4882a593Smuzhiyun 			phy_set_rf_reg(pAdapter, RF_PATH_A, 0x51, 0xF, 0xE);
594*4882a593Smuzhiyun 		else
595*4882a593Smuzhiyun 			phy_set_rf_reg(pAdapter, RF_PATH_A, 0x71, 0xF, 0xE);
596*4882a593Smuzhiyun 	}
597*4882a593Smuzhiyun #endif
598*4882a593Smuzhiyun }
599*4882a593Smuzhiyun 
600*4882a593Smuzhiyun #define RF_PATH_AB	22
601*4882a593Smuzhiyun 
602*4882a593Smuzhiyun #ifdef CONFIG_RTL8814A
mpt_ToggleIG_8814A(PADAPTER pAdapter)603*4882a593Smuzhiyun void mpt_ToggleIG_8814A(PADAPTER	pAdapter)
604*4882a593Smuzhiyun {
605*4882a593Smuzhiyun 	u8 Path;
606*4882a593Smuzhiyun 	u32 IGReg = rA_IGI_Jaguar, IGvalue = 0;
607*4882a593Smuzhiyun 
608*4882a593Smuzhiyun 	for (Path = 0; Path <= RF_PATH_D; Path++) {
609*4882a593Smuzhiyun 		switch (Path) {
610*4882a593Smuzhiyun 		case RF_PATH_B:
611*4882a593Smuzhiyun 			IGReg = rB_IGI_Jaguar;
612*4882a593Smuzhiyun 			break;
613*4882a593Smuzhiyun 		case RF_PATH_C:
614*4882a593Smuzhiyun 			IGReg = rC_IGI_Jaguar2;
615*4882a593Smuzhiyun 			break;
616*4882a593Smuzhiyun 		case RF_PATH_D:
617*4882a593Smuzhiyun 			IGReg = rD_IGI_Jaguar2;
618*4882a593Smuzhiyun 			break;
619*4882a593Smuzhiyun 		default:
620*4882a593Smuzhiyun 			IGReg = rA_IGI_Jaguar;
621*4882a593Smuzhiyun 			break;
622*4882a593Smuzhiyun 		}
623*4882a593Smuzhiyun 
624*4882a593Smuzhiyun 		IGvalue = phy_query_bb_reg(pAdapter, IGReg, bMaskByte0);
625*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, IGReg, bMaskByte0, IGvalue + 2);
626*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, IGReg, bMaskByte0, IGvalue);
627*4882a593Smuzhiyun 	}
628*4882a593Smuzhiyun }
629*4882a593Smuzhiyun 
mpt_SetRFPath_8814A(PADAPTER pAdapter)630*4882a593Smuzhiyun void mpt_SetRFPath_8814A(PADAPTER	pAdapter)
631*4882a593Smuzhiyun {
632*4882a593Smuzhiyun 
633*4882a593Smuzhiyun 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
634*4882a593Smuzhiyun 	PMPT_CONTEXT	pMptCtx = &pAdapter->mppriv.mpt_ctx;
635*4882a593Smuzhiyun 	R_ANTENNA_SELECT_OFDM	*p_ofdm_tx;	/* OFDM Tx register */
636*4882a593Smuzhiyun 	R_ANTENNA_SELECT_CCK	*p_cck_txrx;
637*4882a593Smuzhiyun 	u8	ForcedDataRate = mpt_to_mgnt_rate(pMptCtx->mpt_rate_index);
638*4882a593Smuzhiyun 	/*/PRT_HIGH_THROUGHPUT		pHTInfo = GET_HT_INFO(pMgntInfo);*/
639*4882a593Smuzhiyun 	/*/PRT_VERY_HIGH_THROUGHPUT	pVHTInfo = GET_VHT_INFO(pMgntInfo);*/
640*4882a593Smuzhiyun 
641*4882a593Smuzhiyun 	u32	ulAntennaTx = pHalData->antenna_tx_path;
642*4882a593Smuzhiyun 	u32	ulAntennaRx = pHalData->AntennaRxPath;
643*4882a593Smuzhiyun 	u8	NssforRate = MgntQuery_NssTxRate(ForcedDataRate);
644*4882a593Smuzhiyun 
645*4882a593Smuzhiyun 	if (NssforRate == RF_3TX) {
646*4882a593Smuzhiyun 		RTW_INFO("===> SetAntenna 3T Rate ForcedDataRate %d NssforRate %d AntennaTx %d\n", ForcedDataRate, NssforRate, ulAntennaTx);
647*4882a593Smuzhiyun 
648*4882a593Smuzhiyun 		switch (ulAntennaTx) {
649*4882a593Smuzhiyun 		case ANTENNA_BCD:
650*4882a593Smuzhiyun 			pMptCtx->mpt_rf_path = RF_PATH_BCD;
651*4882a593Smuzhiyun 			/*pHalData->ValidTxPath = 0x0e;*/
652*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rTxAnt_23Nsts_Jaguar2, 0x0fff0000, 0x90e);	/*/ 0x940[27:16]=12'b0010_0100_0111*/
653*4882a593Smuzhiyun 			break;
654*4882a593Smuzhiyun 
655*4882a593Smuzhiyun 		case ANTENNA_ABC:
656*4882a593Smuzhiyun 		default:
657*4882a593Smuzhiyun 			pMptCtx->mpt_rf_path = RF_PATH_ABC;
658*4882a593Smuzhiyun 			/*pHalData->ValidTxPath = 0x0d;*/
659*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rTxAnt_23Nsts_Jaguar2, 0x0fff0000, 0x247);	/*/ 0x940[27:16]=12'b0010_0100_0111*/
660*4882a593Smuzhiyun 			break;
661*4882a593Smuzhiyun 		}
662*4882a593Smuzhiyun 
663*4882a593Smuzhiyun 	} else { /*/if(NssforRate == RF_1TX)*/
664*4882a593Smuzhiyun 		RTW_INFO("===> SetAntenna for 1T/2T Rate, ForcedDataRate %d NssforRate %d AntennaTx %d\n", ForcedDataRate, NssforRate, ulAntennaTx);
665*4882a593Smuzhiyun 		switch (ulAntennaTx) {
666*4882a593Smuzhiyun 		case ANTENNA_BCD:
667*4882a593Smuzhiyun 			pMptCtx->mpt_rf_path = RF_PATH_BCD;
668*4882a593Smuzhiyun 			/*pHalData->ValidTxPath = 0x0e;*/
669*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, 0xf0000000, 0x7);
670*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rTxAnt_1Nsts_Jaguar2, 0x000f00000, 0xe);
671*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rTxPath_Jaguar, 0xf0, 0xe);
672*4882a593Smuzhiyun 			break;
673*4882a593Smuzhiyun 
674*4882a593Smuzhiyun 		case ANTENNA_BC:
675*4882a593Smuzhiyun 			pMptCtx->mpt_rf_path = RF_PATH_BC;
676*4882a593Smuzhiyun 			/*pHalData->ValidTxPath = 0x06;*/
677*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, 0xf0000000, 0x6);
678*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rTxAnt_1Nsts_Jaguar2, 0x000f00000, 0x6);
679*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rTxPath_Jaguar, 0xf0, 0x6);
680*4882a593Smuzhiyun 			break;
681*4882a593Smuzhiyun 		case ANTENNA_B:
682*4882a593Smuzhiyun 			pMptCtx->mpt_rf_path = RF_PATH_B;
683*4882a593Smuzhiyun 			/*pHalData->ValidTxPath = 0x02;*/
684*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, 0xf0000000, 0x4);			/*/ 0xa07[7:4] = 4'b0100*/
685*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rTxAnt_1Nsts_Jaguar2, 0xfff00000, 0x002);	/*/ 0x93C[31:20]=12'b0000_0000_0010*/
686*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rTxPath_Jaguar, 0xf0, 0x2);					/* 0x80C[7:4] = 4'b0010*/
687*4882a593Smuzhiyun 			break;
688*4882a593Smuzhiyun 
689*4882a593Smuzhiyun 		case ANTENNA_C:
690*4882a593Smuzhiyun 			pMptCtx->mpt_rf_path = RF_PATH_C;
691*4882a593Smuzhiyun 			/*pHalData->ValidTxPath = 0x04;*/
692*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, 0xf0000000, 0x2);			/*/ 0xa07[7:4] = 4'b0010*/
693*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rTxAnt_1Nsts_Jaguar2, 0xfff00000, 0x004);	/*/ 0x93C[31:20]=12'b0000_0000_0100*/
694*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rTxPath_Jaguar, 0xf0, 0x4);					/*/ 0x80C[7:4] = 4'b0100*/
695*4882a593Smuzhiyun 			break;
696*4882a593Smuzhiyun 
697*4882a593Smuzhiyun 		case ANTENNA_D:
698*4882a593Smuzhiyun 			pMptCtx->mpt_rf_path = RF_PATH_D;
699*4882a593Smuzhiyun 			/*pHalData->ValidTxPath = 0x08;*/
700*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, 0xf0000000, 0x1);			/*/ 0xa07[7:4] = 4'b0001*/
701*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rTxAnt_1Nsts_Jaguar2, 0xfff00000, 0x008);	/*/ 0x93C[31:20]=12'b0000_0000_1000*/
702*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rTxPath_Jaguar, 0xf0, 0x8);					/*/ 0x80C[7:4] = 4'b1000*/
703*4882a593Smuzhiyun 			break;
704*4882a593Smuzhiyun 
705*4882a593Smuzhiyun 		case ANTENNA_A:
706*4882a593Smuzhiyun 		default:
707*4882a593Smuzhiyun 			pMptCtx->mpt_rf_path = RF_PATH_A;
708*4882a593Smuzhiyun 			/*pHalData->ValidTxPath = 0x01;*/
709*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, 0xf0000000, 0x8);			/*/ 0xa07[7:4] = 4'b1000*/
710*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rTxAnt_1Nsts_Jaguar2, 0xfff00000, 0x001);	/*/ 0x93C[31:20]=12'b0000_0000_0001*/
711*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rTxPath_Jaguar, 0xf0, 0x1);					/*/ 0x80C[7:4] = 4'b0001*/
712*4882a593Smuzhiyun 			break;
713*4882a593Smuzhiyun 		}
714*4882a593Smuzhiyun 	}
715*4882a593Smuzhiyun 
716*4882a593Smuzhiyun 	switch (ulAntennaRx) {
717*4882a593Smuzhiyun 	case ANTENNA_A:
718*4882a593Smuzhiyun 		/*pHalData->ValidRxPath = 0x01;*/
719*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x1);
720*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, 0x1000, bMaskByte2, 0x2);
721*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rRxPath_Jaguar, bMaskByte0, 0x11);
722*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, 0x1000, bMaskByte2, 0x3);
723*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x0);
724*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, 0x0C000000, 0x0);
725*4882a593Smuzhiyun 		phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_A_0x0[19:16] = 3, RX mode*/
726*4882a593Smuzhiyun 		phy_set_rf_reg(pAdapter, RF_PATH_B, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_B_0x0[19:16] = 1, Standby mode*/
727*4882a593Smuzhiyun 		phy_set_rf_reg(pAdapter, RF_PATH_C, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_C_0x0[19:16] = 1, Standby mode*/
728*4882a593Smuzhiyun 		phy_set_rf_reg(pAdapter, RF_PATH_D, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_D_0x0[19:16] = 1, Standby mode*/
729*4882a593Smuzhiyun 		/*/ CCA related PD_delay_th*/
730*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rAGC_table_Jaguar, 0x0F000000, 0x5);
731*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rPwed_TH_Jaguar, 0x0000000F, 0xA);
732*4882a593Smuzhiyun 		break;
733*4882a593Smuzhiyun 
734*4882a593Smuzhiyun 	case ANTENNA_B:
735*4882a593Smuzhiyun 		/*pHalData->ValidRxPath = 0x02;*/
736*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x1);
737*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, 0x1000, bMaskByte2, 0x2);
738*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rRxPath_Jaguar, bMaskByte0, 0x22);
739*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, 0x1000, bMaskByte2, 0x3);
740*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x0);
741*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, 0x0C000000, 0x1);
742*4882a593Smuzhiyun 		phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_A_0x0[19:16] = 1, Standby mode*/
743*4882a593Smuzhiyun 		phy_set_rf_reg(pAdapter, RF_PATH_B, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_B_0x0[19:16] = 3, RX mode*/
744*4882a593Smuzhiyun 		phy_set_rf_reg(pAdapter, RF_PATH_C, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_C_0x0[19:16] = 1, Standby mode*/
745*4882a593Smuzhiyun 		phy_set_rf_reg(pAdapter, RF_PATH_D, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_D_0x0[19:16] = 1, Standby mode*/
746*4882a593Smuzhiyun 		/*/ CCA related PD_delay_th*/
747*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rAGC_table_Jaguar, 0x0F000000, 0x5);
748*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rPwed_TH_Jaguar, 0x0000000F, 0xA);
749*4882a593Smuzhiyun 		break;
750*4882a593Smuzhiyun 
751*4882a593Smuzhiyun 	case ANTENNA_C:
752*4882a593Smuzhiyun 		/*pHalData->ValidRxPath = 0x04;*/
753*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x1);
754*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, 0x1000, bMaskByte2, 0x2);
755*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rRxPath_Jaguar, bMaskByte0, 0x44);
756*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, 0x1000, bMaskByte2, 0x3);
757*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x0);
758*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, 0x0C000000, 0x2);
759*4882a593Smuzhiyun 		phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_A_0x0[19:16] = 1, Standby mode*/
760*4882a593Smuzhiyun 		phy_set_rf_reg(pAdapter, RF_PATH_B, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_B_0x0[19:16] = 1, Standby mode*/
761*4882a593Smuzhiyun 		phy_set_rf_reg(pAdapter, RF_PATH_C, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_C_0x0[19:16] = 3, RX mode*/
762*4882a593Smuzhiyun 		phy_set_rf_reg(pAdapter, RF_PATH_D, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_D_0x0[19:16] = 1, Standby mode*/
763*4882a593Smuzhiyun 		/*/ CCA related PD_delay_th*/
764*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rAGC_table_Jaguar, 0x0F000000, 0x5);
765*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rPwed_TH_Jaguar, 0x0000000F, 0xA);
766*4882a593Smuzhiyun 		break;
767*4882a593Smuzhiyun 
768*4882a593Smuzhiyun 	case ANTENNA_D:
769*4882a593Smuzhiyun 		/*pHalData->ValidRxPath = 0x08;*/
770*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x1);
771*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, 0x1000, bMaskByte2, 0x2);
772*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rRxPath_Jaguar, bMaskByte0, 0x88);
773*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, 0x1000, bMaskByte2, 0x3);
774*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x0);
775*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, 0x0C000000, 0x3);
776*4882a593Smuzhiyun 		phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_A_0x0[19:16] = 1, Standby mode*/
777*4882a593Smuzhiyun 		phy_set_rf_reg(pAdapter, RF_PATH_B, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_B_0x0[19:16] = 1, Standby mode*/
778*4882a593Smuzhiyun 		phy_set_rf_reg(pAdapter, RF_PATH_C, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_C_0x0[19:16] = 1, Standby mode*/
779*4882a593Smuzhiyun 		phy_set_rf_reg(pAdapter, RF_PATH_D, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_D_0x0[19:16] = 3, RX mode*/
780*4882a593Smuzhiyun 		/*/ CCA related PD_delay_th*/
781*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rAGC_table_Jaguar, 0x0F000000, 0x5);
782*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rPwed_TH_Jaguar, 0x0000000F, 0xA);
783*4882a593Smuzhiyun 		break;
784*4882a593Smuzhiyun 
785*4882a593Smuzhiyun 	case ANTENNA_BC:
786*4882a593Smuzhiyun 		/*pHalData->ValidRxPath = 0x06;*/
787*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x1);
788*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, 0x1000, bMaskByte2, 0x2);
789*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rRxPath_Jaguar, bMaskByte0, 0x66);
790*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, 0x1000, bMaskByte2, 0x3);
791*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x0);
792*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, 0x0f000000, 0x6);
793*4882a593Smuzhiyun 		phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_A_0x0[19:16] = 1, Standby mode*/
794*4882a593Smuzhiyun 		phy_set_rf_reg(pAdapter, RF_PATH_B, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_B_0x0[19:16] = 3, RX mode*/
795*4882a593Smuzhiyun 		phy_set_rf_reg(pAdapter, RF_PATH_C, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_C_0x0[19:16] = 3, Rx mode*/
796*4882a593Smuzhiyun 		phy_set_rf_reg(pAdapter, RF_PATH_D, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_D_0x0[19:16] = 1, Standby mode*/
797*4882a593Smuzhiyun 		/*/ CCA related PD_delay_th*/
798*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rAGC_table_Jaguar, 0x0F000000, 0x5);
799*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rPwed_TH_Jaguar, 0x0000000F, 0xA);
800*4882a593Smuzhiyun 		break;
801*4882a593Smuzhiyun 
802*4882a593Smuzhiyun 	case ANTENNA_CD:
803*4882a593Smuzhiyun 		/*pHalData->ValidRxPath = 0x0C;*/
804*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x1);
805*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, 0x1000, bMaskByte2, 0x2);
806*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rRxPath_Jaguar, bMaskByte0, 0xcc);
807*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, 0x1000, bMaskByte2, 0x3);
808*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x0);
809*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, 0x0f000000, 0xB);
810*4882a593Smuzhiyun 		phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_A_0x0[19:16] = 1, Standby mode*/
811*4882a593Smuzhiyun 		phy_set_rf_reg(pAdapter, RF_PATH_B, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_B_0x0[19:16] = 1, Standby mode*/
812*4882a593Smuzhiyun 		phy_set_rf_reg(pAdapter, RF_PATH_C, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_C_0x0[19:16] = 3, Rx mode*/
813*4882a593Smuzhiyun 		phy_set_rf_reg(pAdapter, RF_PATH_D, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_D_0x0[19:16] = 3, RX mode*/
814*4882a593Smuzhiyun 		/*/ CCA related PD_delay_th*/
815*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rAGC_table_Jaguar, 0x0F000000, 0x5);
816*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rPwed_TH_Jaguar, 0x0000000F, 0xA);
817*4882a593Smuzhiyun 		break;
818*4882a593Smuzhiyun 
819*4882a593Smuzhiyun 	case ANTENNA_BCD:
820*4882a593Smuzhiyun 		/*pHalData->ValidRxPath = 0x0e;*/
821*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x1);
822*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, 0x1000, bMaskByte2, 0x2);
823*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rRxPath_Jaguar, bMaskByte0, 0xee);
824*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, 0x1000, bMaskByte2, 0x3);
825*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x0);
826*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, 0x0f000000, 0x6);
827*4882a593Smuzhiyun 		phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_A_0x0[19:16] = 1, Standby mode*/
828*4882a593Smuzhiyun 		phy_set_rf_reg(pAdapter, RF_PATH_B, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_B_0x0[19:16] = 3, RX mode*/
829*4882a593Smuzhiyun 		phy_set_rf_reg(pAdapter, RF_PATH_C, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_C_0x0[19:16] = 3, RX mode*/
830*4882a593Smuzhiyun 		phy_set_rf_reg(pAdapter, RF_PATH_D, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_D_0x0[19:16] = 3, Rx mode*/
831*4882a593Smuzhiyun 		/*/ CCA related PD_delay_th*/
832*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rAGC_table_Jaguar, 0x0F000000, 0x3);
833*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rPwed_TH_Jaguar, 0x0000000F, 0x8);
834*4882a593Smuzhiyun 		break;
835*4882a593Smuzhiyun 
836*4882a593Smuzhiyun 	case ANTENNA_ABCD:
837*4882a593Smuzhiyun 		/*pHalData->ValidRxPath = 0x0f;*/
838*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x1);
839*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, 0x1000, bMaskByte2, 0x2);
840*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rRxPath_Jaguar, bMaskByte0, 0xff);
841*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, 0x1000, bMaskByte2, 0x3);
842*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x0);
843*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, 0x0f000000, 0x1);
844*4882a593Smuzhiyun 		phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_A_0x0[19:16] = 3, RX mode*/
845*4882a593Smuzhiyun 		phy_set_rf_reg(pAdapter, RF_PATH_B, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_B_0x0[19:16] = 3, RX mode*/
846*4882a593Smuzhiyun 		phy_set_rf_reg(pAdapter, RF_PATH_C, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_C_0x0[19:16] = 3, RX mode*/
847*4882a593Smuzhiyun 		phy_set_rf_reg(pAdapter, RF_PATH_D, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_D_0x0[19:16] = 3, RX mode*/
848*4882a593Smuzhiyun 		/*/ CCA related PD_delay_th*/
849*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rAGC_table_Jaguar, 0x0F000000, 0x3);
850*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rPwed_TH_Jaguar, 0x0000000F, 0x8);
851*4882a593Smuzhiyun 		break;
852*4882a593Smuzhiyun 
853*4882a593Smuzhiyun 	default:
854*4882a593Smuzhiyun 		break;
855*4882a593Smuzhiyun 	}
856*4882a593Smuzhiyun 
857*4882a593Smuzhiyun 	PHY_Set_SecCCATH_by_RXANT_8814A(pAdapter, ulAntennaRx);
858*4882a593Smuzhiyun 
859*4882a593Smuzhiyun 	mpt_ToggleIG_8814A(pAdapter);
860*4882a593Smuzhiyun }
861*4882a593Smuzhiyun 
862*4882a593Smuzhiyun #endif /* CONFIG_RTL8814A */
863*4882a593Smuzhiyun #if defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C)  || defined(CONFIG_RTL8822C) || defined(CONFIG_RTL8814B)
864*4882a593Smuzhiyun void
mpt_SetSingleTone_8814A(PADAPTER pAdapter,BOOLEAN bSingleTone,BOOLEAN bEnPMacTx)865*4882a593Smuzhiyun mpt_SetSingleTone_8814A(
866*4882a593Smuzhiyun 		PADAPTER	pAdapter,
867*4882a593Smuzhiyun 		BOOLEAN	bSingleTone,
868*4882a593Smuzhiyun 		BOOLEAN	bEnPMacTx)
869*4882a593Smuzhiyun {
870*4882a593Smuzhiyun 
871*4882a593Smuzhiyun 	PMPT_CONTEXT	pMptCtx = &(pAdapter->mppriv.mpt_ctx);
872*4882a593Smuzhiyun 	u8 StartPath = RF_PATH_A,  EndPath = RF_PATH_A, path;
873*4882a593Smuzhiyun 	static u32		regIG0 = 0, regIG1 = 0, regIG2 = 0, regIG3 = 0;
874*4882a593Smuzhiyun 
875*4882a593Smuzhiyun 	if (bSingleTone) {
876*4882a593Smuzhiyun 		regIG0 = phy_query_bb_reg(pAdapter, rA_TxScale_Jaguar, bMaskDWord);		/*/ 0xC1C[31:21]*/
877*4882a593Smuzhiyun 		regIG1 = phy_query_bb_reg(pAdapter, rB_TxScale_Jaguar, bMaskDWord);		/*/ 0xE1C[31:21]*/
878*4882a593Smuzhiyun 		regIG2 = phy_query_bb_reg(pAdapter, rC_TxScale_Jaguar2, bMaskDWord);	/*/ 0x181C[31:21]*/
879*4882a593Smuzhiyun 		regIG3 = phy_query_bb_reg(pAdapter, rD_TxScale_Jaguar2, bMaskDWord);	/*/ 0x1A1C[31:21]*/
880*4882a593Smuzhiyun 
881*4882a593Smuzhiyun 		switch (pMptCtx->mpt_rf_path) {
882*4882a593Smuzhiyun 		case RF_PATH_A:
883*4882a593Smuzhiyun 		case RF_PATH_B:
884*4882a593Smuzhiyun 		case RF_PATH_C:
885*4882a593Smuzhiyun 		case RF_PATH_D:
886*4882a593Smuzhiyun 			StartPath = pMptCtx->mpt_rf_path;
887*4882a593Smuzhiyun 			EndPath = pMptCtx->mpt_rf_path;
888*4882a593Smuzhiyun 			break;
889*4882a593Smuzhiyun 		case RF_PATH_AB:
890*4882a593Smuzhiyun 			EndPath = RF_PATH_B;
891*4882a593Smuzhiyun 			break;
892*4882a593Smuzhiyun 		case RF_PATH_BC:
893*4882a593Smuzhiyun 			StartPath = RF_PATH_B;
894*4882a593Smuzhiyun 			EndPath = RF_PATH_C;
895*4882a593Smuzhiyun 			break;
896*4882a593Smuzhiyun 		case RF_PATH_ABC:
897*4882a593Smuzhiyun 			EndPath = RF_PATH_C;
898*4882a593Smuzhiyun 			break;
899*4882a593Smuzhiyun 		case RF_PATH_BCD:
900*4882a593Smuzhiyun 			StartPath = RF_PATH_B;
901*4882a593Smuzhiyun 			EndPath = RF_PATH_D;
902*4882a593Smuzhiyun 			break;
903*4882a593Smuzhiyun 		case RF_PATH_ABCD:
904*4882a593Smuzhiyun 			EndPath = RF_PATH_D;
905*4882a593Smuzhiyun 			break;
906*4882a593Smuzhiyun 		}
907*4882a593Smuzhiyun 
908*4882a593Smuzhiyun 		if (bEnPMacTx == FALSE) {
909*4882a593Smuzhiyun 			hal_mpt_SetContinuousTx(pAdapter, _TRUE);
910*4882a593Smuzhiyun 			issue_nulldata(pAdapter, NULL, 1, 3, 500);
911*4882a593Smuzhiyun 		}
912*4882a593Smuzhiyun 
913*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x1); /*/ Disable CCA*/
914*4882a593Smuzhiyun 
915*4882a593Smuzhiyun 		for (path = StartPath; path <= EndPath; path++) {
916*4882a593Smuzhiyun 			phy_set_rf_reg(pAdapter, path, RF_AC_Jaguar, 0xF0000, 0x2); /*/ Tx mode: RF0x00[19:16]=4'b0010 */
917*4882a593Smuzhiyun 			phy_set_rf_reg(pAdapter, path, RF_AC_Jaguar, 0x1F, 0x0); /*/ Lowest RF gain index: RF_0x0[4:0] = 0*/
918*4882a593Smuzhiyun 
919*4882a593Smuzhiyun 			phy_set_rf_reg(pAdapter, path, lna_low_gain_3, BIT1, 0x1); /*/ RF LO enabled*/
920*4882a593Smuzhiyun 		}
921*4882a593Smuzhiyun 
922*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rA_TxScale_Jaguar, 0xFFE00000, 0); /*/ 0xC1C[31:21]*/
923*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rB_TxScale_Jaguar, 0xFFE00000, 0); /*/ 0xE1C[31:21]*/
924*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rC_TxScale_Jaguar2, 0xFFE00000, 0); /*/ 0x181C[31:21]*/
925*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rD_TxScale_Jaguar2, 0xFFE00000, 0); /*/ 0x1A1C[31:21]*/
926*4882a593Smuzhiyun 	} else {
927*4882a593Smuzhiyun 		switch (pMptCtx->mpt_rf_path) {
928*4882a593Smuzhiyun 		case RF_PATH_A:
929*4882a593Smuzhiyun 		case RF_PATH_B:
930*4882a593Smuzhiyun 		case RF_PATH_C:
931*4882a593Smuzhiyun 		case RF_PATH_D:
932*4882a593Smuzhiyun 			StartPath = pMptCtx->mpt_rf_path;
933*4882a593Smuzhiyun 			EndPath = pMptCtx->mpt_rf_path;
934*4882a593Smuzhiyun 			break;
935*4882a593Smuzhiyun 		case RF_PATH_AB:
936*4882a593Smuzhiyun 			EndPath = RF_PATH_B;
937*4882a593Smuzhiyun 			break;
938*4882a593Smuzhiyun 		case RF_PATH_BC:
939*4882a593Smuzhiyun 			StartPath = RF_PATH_B;
940*4882a593Smuzhiyun 			EndPath = RF_PATH_C;
941*4882a593Smuzhiyun 			break;
942*4882a593Smuzhiyun 		case RF_PATH_ABC:
943*4882a593Smuzhiyun 			EndPath = RF_PATH_C;
944*4882a593Smuzhiyun 			break;
945*4882a593Smuzhiyun 		case RF_PATH_BCD:
946*4882a593Smuzhiyun 			StartPath = RF_PATH_B;
947*4882a593Smuzhiyun 			EndPath = RF_PATH_D;
948*4882a593Smuzhiyun 			break;
949*4882a593Smuzhiyun 		case RF_PATH_ABCD:
950*4882a593Smuzhiyun 			EndPath = RF_PATH_D;
951*4882a593Smuzhiyun 			break;
952*4882a593Smuzhiyun 		}
953*4882a593Smuzhiyun 		for (path = StartPath; path <= EndPath; path++)
954*4882a593Smuzhiyun 			phy_set_rf_reg(pAdapter, path, lna_low_gain_3, BIT1, 0x0); /* RF LO disabled */
955*4882a593Smuzhiyun 
956*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x0); /* Enable CCA*/
957*4882a593Smuzhiyun 
958*4882a593Smuzhiyun 		if (bEnPMacTx == FALSE) {
959*4882a593Smuzhiyun 			if(IS_HARDWARE_TYPE_JAGUAR3(pAdapter)) {
960*4882a593Smuzhiyun #ifdef	PHYDM_MP_SUPPORT
961*4882a593Smuzhiyun 					phydm_stop_ofdm_cont_tx(pAdapter);
962*4882a593Smuzhiyun 					pMptCtx->bCckContTx = FALSE;
963*4882a593Smuzhiyun 					pMptCtx->bOfdmContTx = FALSE;
964*4882a593Smuzhiyun #endif
965*4882a593Smuzhiyun 			} else
966*4882a593Smuzhiyun 					hal_mpt_SetContinuousTx(pAdapter, _FALSE);
967*4882a593Smuzhiyun 		}
968*4882a593Smuzhiyun 
969*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rA_TxScale_Jaguar, bMaskDWord, regIG0); /* 0xC1C[31:21]*/
970*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rB_TxScale_Jaguar, bMaskDWord, regIG1); /* 0xE1C[31:21]*/
971*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rC_TxScale_Jaguar2, bMaskDWord, regIG2); /* 0x181C[31:21]*/
972*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rD_TxScale_Jaguar2, bMaskDWord, regIG3); /* 0x1A1C[31:21]*/
973*4882a593Smuzhiyun 	}
974*4882a593Smuzhiyun }
975*4882a593Smuzhiyun 
976*4882a593Smuzhiyun #endif
977*4882a593Smuzhiyun 
978*4882a593Smuzhiyun #if	defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A)
mpt_SetRFPath_8812A(PADAPTER pAdapter)979*4882a593Smuzhiyun void mpt_SetRFPath_8812A(PADAPTER pAdapter)
980*4882a593Smuzhiyun {
981*4882a593Smuzhiyun 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
982*4882a593Smuzhiyun 	PMPT_CONTEXT	pMptCtx = &pAdapter->mppriv.mpt_ctx;
983*4882a593Smuzhiyun 	struct mp_priv *pmp = &pAdapter->mppriv;
984*4882a593Smuzhiyun 	u8		channel = pmp->channel;
985*4882a593Smuzhiyun 	u8		bandwidth = pmp->bandwidth;
986*4882a593Smuzhiyun 	u8		eLNA_2g = pHalData->ExternalLNA_2G;
987*4882a593Smuzhiyun 	u32		ulAntennaTx, ulAntennaRx;
988*4882a593Smuzhiyun 	u32 reg0xC50 = 0;
989*4882a593Smuzhiyun 
990*4882a593Smuzhiyun 	ulAntennaTx = pHalData->antenna_tx_path;
991*4882a593Smuzhiyun 	ulAntennaRx = pHalData->AntennaRxPath;
992*4882a593Smuzhiyun 
993*4882a593Smuzhiyun 	switch (ulAntennaTx) {
994*4882a593Smuzhiyun 	case ANTENNA_A:
995*4882a593Smuzhiyun 		pMptCtx->mpt_rf_path = RF_PATH_A;
996*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rTxPath_Jaguar, bMaskLWord, 0x1111);
997*4882a593Smuzhiyun 		if (pHalData->rfe_type == 3 && IS_HARDWARE_TYPE_8812(pAdapter))
998*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, r_ANTSEL_SW_Jaguar, bMask_AntselPathFollow_Jaguar, 0x0);
999*4882a593Smuzhiyun 		break;
1000*4882a593Smuzhiyun 	case ANTENNA_B:
1001*4882a593Smuzhiyun 		pMptCtx->mpt_rf_path = RF_PATH_B;
1002*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rTxPath_Jaguar, bMaskLWord, 0x2222);
1003*4882a593Smuzhiyun 		if (pHalData->rfe_type == 3 && IS_HARDWARE_TYPE_8812(pAdapter))
1004*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter,	r_ANTSEL_SW_Jaguar, bMask_AntselPathFollow_Jaguar, 0x1);
1005*4882a593Smuzhiyun 		break;
1006*4882a593Smuzhiyun 	case ANTENNA_AB:
1007*4882a593Smuzhiyun 		pMptCtx->mpt_rf_path = RF_PATH_AB;
1008*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rTxPath_Jaguar, bMaskLWord, 0x3333);
1009*4882a593Smuzhiyun 		if (pHalData->rfe_type == 3 && IS_HARDWARE_TYPE_8812(pAdapter))
1010*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, r_ANTSEL_SW_Jaguar, bMask_AntselPathFollow_Jaguar, 0x0);
1011*4882a593Smuzhiyun 		break;
1012*4882a593Smuzhiyun 	default:
1013*4882a593Smuzhiyun 		pMptCtx->mpt_rf_path = RF_PATH_AB;
1014*4882a593Smuzhiyun 		RTW_INFO("Unknown Tx antenna.\n");
1015*4882a593Smuzhiyun 		break;
1016*4882a593Smuzhiyun 	}
1017*4882a593Smuzhiyun 
1018*4882a593Smuzhiyun 	switch (ulAntennaRx) {
1019*4882a593Smuzhiyun 	case ANTENNA_A:
1020*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rRxPath_Jaguar, bMaskByte0, 0x11);
1021*4882a593Smuzhiyun 		phy_set_rf_reg(pAdapter, RF_PATH_B, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_B_0x0[19:16] = 1, Standby mode*/
1022*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, bCCK_RX_Jaguar, 0x0);
1023*4882a593Smuzhiyun 		phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC_Jaguar, BIT19 | BIT18 | BIT17 | BIT16, 0x3);
1024*4882a593Smuzhiyun 
1025*4882a593Smuzhiyun 		/*/ <20121101, Kordan> To prevent gain table from not switched, asked by Ynlin.*/
1026*4882a593Smuzhiyun 		reg0xC50 = phy_query_bb_reg(pAdapter, rA_IGI_Jaguar, bMaskByte0);
1027*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rA_IGI_Jaguar, bMaskByte0, reg0xC50 + 2);
1028*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rA_IGI_Jaguar, bMaskByte0, reg0xC50);
1029*4882a593Smuzhiyun 
1030*4882a593Smuzhiyun 		/* set PWED_TH for BB Yn user guide R29 */
1031*4882a593Smuzhiyun 		if (IS_HARDWARE_TYPE_8812(pAdapter)) {
1032*4882a593Smuzhiyun 			if (channel <= 14) { /* 2.4G */
1033*4882a593Smuzhiyun 				if (bandwidth == CHANNEL_WIDTH_20
1034*4882a593Smuzhiyun 				    && eLNA_2g == 0) {
1035*4882a593Smuzhiyun 					/* 0x830[3:1]=3'b010 */
1036*4882a593Smuzhiyun 					phy_set_bb_reg(pAdapter, rPwed_TH_Jaguar, BIT1 | BIT2 | BIT3, 0x02);
1037*4882a593Smuzhiyun 				} else
1038*4882a593Smuzhiyun 					/* 0x830[3:1]=3'b100 */
1039*4882a593Smuzhiyun 					phy_set_bb_reg(pAdapter, rPwed_TH_Jaguar, BIT1 | BIT2 | BIT3, 0x04);
1040*4882a593Smuzhiyun 			} else
1041*4882a593Smuzhiyun 				/* 0x830[3:1]=3'b100 for 5G */
1042*4882a593Smuzhiyun 				phy_set_bb_reg(pAdapter, rPwed_TH_Jaguar, BIT1 | BIT2 | BIT3, 0x04);
1043*4882a593Smuzhiyun 		}
1044*4882a593Smuzhiyun 		break;
1045*4882a593Smuzhiyun 	case ANTENNA_B:
1046*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rRxPath_Jaguar, bMaskByte0, 0x22);
1047*4882a593Smuzhiyun 		phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC_Jaguar, 0xF0000, 0x1);/*/ RF_A_0x0[19:16] = 1, Standby mode */
1048*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, bCCK_RX_Jaguar, 0x1);
1049*4882a593Smuzhiyun 		phy_set_rf_reg(pAdapter, RF_PATH_B, RF_AC_Jaguar, BIT19 | BIT18 | BIT17 | BIT16, 0x3);
1050*4882a593Smuzhiyun 
1051*4882a593Smuzhiyun 		/*/ <20121101, Kordan> To prevent gain table from not switched, asked by Ynlin.*/
1052*4882a593Smuzhiyun 		reg0xC50 = phy_query_bb_reg(pAdapter, rB_IGI_Jaguar, bMaskByte0);
1053*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rB_IGI_Jaguar, bMaskByte0, reg0xC50 + 2);
1054*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rB_IGI_Jaguar, bMaskByte0, reg0xC50);
1055*4882a593Smuzhiyun 
1056*4882a593Smuzhiyun 		/* set PWED_TH for BB Yn user guide R29 */
1057*4882a593Smuzhiyun 		if (IS_HARDWARE_TYPE_8812(pAdapter)) {
1058*4882a593Smuzhiyun 			if (channel <= 14) {
1059*4882a593Smuzhiyun 				if (bandwidth == CHANNEL_WIDTH_20
1060*4882a593Smuzhiyun 				    && eLNA_2g == 0) {
1061*4882a593Smuzhiyun 					/* 0x830[3:1]=3'b010 */
1062*4882a593Smuzhiyun 					phy_set_bb_reg(pAdapter, rPwed_TH_Jaguar, BIT1 | BIT2 | BIT3, 0x02);
1063*4882a593Smuzhiyun 				} else
1064*4882a593Smuzhiyun 					/* 0x830[3:1]=3'b100 */
1065*4882a593Smuzhiyun 					phy_set_bb_reg(pAdapter, rPwed_TH_Jaguar, BIT1 | BIT2 | BIT3, 0x04);
1066*4882a593Smuzhiyun 			} else
1067*4882a593Smuzhiyun 				/* 0x830[3:1]=3'b100 for 5G */
1068*4882a593Smuzhiyun 				phy_set_bb_reg(pAdapter, rPwed_TH_Jaguar, BIT1 | BIT2 | BIT3, 0x04);
1069*4882a593Smuzhiyun 		}
1070*4882a593Smuzhiyun 		break;
1071*4882a593Smuzhiyun 	case ANTENNA_AB:
1072*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rRxPath_Jaguar, bMaskByte0, 0x33);
1073*4882a593Smuzhiyun 		phy_set_rf_reg(pAdapter, RF_PATH_B, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_B_0x0[19:16] = 3, Rx mode*/
1074*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, bCCK_RX_Jaguar, 0x0);
1075*4882a593Smuzhiyun 		/* set PWED_TH for BB Yn user guide R29 */
1076*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rPwed_TH_Jaguar, BIT1 | BIT2 | BIT3, 0x04);
1077*4882a593Smuzhiyun 		break;
1078*4882a593Smuzhiyun 	default:
1079*4882a593Smuzhiyun 		RTW_INFO("Unknown Rx antenna.\n");
1080*4882a593Smuzhiyun 		break;
1081*4882a593Smuzhiyun 	}
1082*4882a593Smuzhiyun 
1083*4882a593Smuzhiyun 	if (pHalData->rfe_type == 5 || pHalData->rfe_type == 1) {
1084*4882a593Smuzhiyun 		if (ulAntennaTx == ANTENNA_A || ulAntennaTx == ANTENNA_AB) {
1085*4882a593Smuzhiyun 			/* WiFi */
1086*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, r_ANTSEL_SW_Jaguar, BIT(1) | BIT(0), 0x2);
1087*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, r_ANTSEL_SW_Jaguar, BIT(9) | BIT(8), 0x3);
1088*4882a593Smuzhiyun 		} else {
1089*4882a593Smuzhiyun 			/* BT */
1090*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, r_ANTSEL_SW_Jaguar, BIT(1) | BIT(0), 0x1);
1091*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, r_ANTSEL_SW_Jaguar, BIT(9) | BIT(8), 0x3);
1092*4882a593Smuzhiyun 		}
1093*4882a593Smuzhiyun 	}
1094*4882a593Smuzhiyun }
1095*4882a593Smuzhiyun #endif
1096*4882a593Smuzhiyun 
1097*4882a593Smuzhiyun #ifdef CONFIG_RTL8723B
mpt_SetRFPath_8723B(PADAPTER pAdapter)1098*4882a593Smuzhiyun void mpt_SetRFPath_8723B(PADAPTER pAdapter)
1099*4882a593Smuzhiyun {
1100*4882a593Smuzhiyun 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
1101*4882a593Smuzhiyun 	u32		ulAntennaTx, ulAntennaRx;
1102*4882a593Smuzhiyun 	PMPT_CONTEXT	pMptCtx = &(pAdapter->mppriv.mpt_ctx);
1103*4882a593Smuzhiyun 	struct dm_struct	*pDM_Odm = &pHalData->odmpriv;
1104*4882a593Smuzhiyun 	struct dm_rf_calibration_struct	*pRFCalibrateInfo = &(pDM_Odm->rf_calibrate_info);
1105*4882a593Smuzhiyun 	u8 i;
1106*4882a593Smuzhiyun 
1107*4882a593Smuzhiyun 	ulAntennaTx = pHalData->antenna_tx_path;
1108*4882a593Smuzhiyun 	ulAntennaRx = pHalData->AntennaRxPath;
1109*4882a593Smuzhiyun 
1110*4882a593Smuzhiyun 	if (pHalData->rf_chip >= RF_CHIP_MAX) {
1111*4882a593Smuzhiyun 		RTW_INFO("This RF chip ID is not supported\n");
1112*4882a593Smuzhiyun 		return;
1113*4882a593Smuzhiyun 	}
1114*4882a593Smuzhiyun 
1115*4882a593Smuzhiyun 	switch (pAdapter->mppriv.antenna_tx) {
1116*4882a593Smuzhiyun 	case ANTENNA_A: { /*/ Actually path S1  (Wi-Fi)*/
1117*4882a593Smuzhiyun 		pMptCtx->mpt_rf_path = RF_PATH_A;
1118*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rS0S1_PathSwitch, BIT9 | BIT8 | BIT7, 0x0);
1119*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, 0xB2C, BIT31, 0x0); /* AGC Table Sel*/
1120*4882a593Smuzhiyun 
1121*4882a593Smuzhiyun 		for (i = 0; i < 3; ++i) {
1122*4882a593Smuzhiyun 			u32 offset = pRFCalibrateInfo->tx_iqc_8723b[RF_PATH_A][i][0];
1123*4882a593Smuzhiyun 			u32 data = pRFCalibrateInfo->tx_iqc_8723b[RF_PATH_A][i][1];
1124*4882a593Smuzhiyun 
1125*4882a593Smuzhiyun 			if (offset != 0) {
1126*4882a593Smuzhiyun 				phy_set_bb_reg(pAdapter, offset, bMaskDWord, data);
1127*4882a593Smuzhiyun 				RTW_INFO("Switch to S1 TxIQC(offset, data) = (0x%X, 0x%X)\n", offset, data);
1128*4882a593Smuzhiyun 			}
1129*4882a593Smuzhiyun 		}
1130*4882a593Smuzhiyun 		for (i = 0; i < 2; ++i) {
1131*4882a593Smuzhiyun 			u32 offset = pRFCalibrateInfo->rx_iqc_8723b[RF_PATH_A][i][0];
1132*4882a593Smuzhiyun 			u32 data = pRFCalibrateInfo->rx_iqc_8723b[RF_PATH_A][i][1];
1133*4882a593Smuzhiyun 
1134*4882a593Smuzhiyun 			if (offset != 0) {
1135*4882a593Smuzhiyun 				phy_set_bb_reg(pAdapter, offset, bMaskDWord, data);
1136*4882a593Smuzhiyun 				RTW_INFO("Switch to S1 RxIQC (offset, data) = (0x%X, 0x%X)\n", offset, data);
1137*4882a593Smuzhiyun 			}
1138*4882a593Smuzhiyun 		}
1139*4882a593Smuzhiyun 	}
1140*4882a593Smuzhiyun 	break;
1141*4882a593Smuzhiyun 	case ANTENNA_B: { /*/ Actually path S0 (BT)*/
1142*4882a593Smuzhiyun 		u32 offset;
1143*4882a593Smuzhiyun 		u32 data;
1144*4882a593Smuzhiyun 
1145*4882a593Smuzhiyun 		pMptCtx->mpt_rf_path = RF_PATH_B;
1146*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rS0S1_PathSwitch, BIT9 | BIT8 | BIT7, 0x5);
1147*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, 0xB2C, BIT31, 0x1); /*/ AGC Table Sel.*/
1148*4882a593Smuzhiyun 
1149*4882a593Smuzhiyun 		for (i = 0; i < 3; ++i) {
1150*4882a593Smuzhiyun 			/*/ <20130603, Kordan> Because BB suppors only 1T1R, we restore IQC  to S1 instead of S0.*/
1151*4882a593Smuzhiyun 			offset = pRFCalibrateInfo->tx_iqc_8723b[RF_PATH_A][i][0];
1152*4882a593Smuzhiyun 			data = pRFCalibrateInfo->tx_iqc_8723b[RF_PATH_B][i][1];
1153*4882a593Smuzhiyun 			if (pRFCalibrateInfo->tx_iqc_8723b[RF_PATH_B][i][0] != 0) {
1154*4882a593Smuzhiyun 				phy_set_bb_reg(pAdapter, offset, bMaskDWord, data);
1155*4882a593Smuzhiyun 				RTW_INFO("Switch to S0 TxIQC (offset, data) = (0x%X, 0x%X)\n", offset, data);
1156*4882a593Smuzhiyun 			}
1157*4882a593Smuzhiyun 		}
1158*4882a593Smuzhiyun 		/*/ <20130603, Kordan> Because BB suppors only 1T1R, we restore IQC to S1 instead of S0.*/
1159*4882a593Smuzhiyun 		for (i = 0; i < 2; ++i) {
1160*4882a593Smuzhiyun 			offset = pRFCalibrateInfo->rx_iqc_8723b[RF_PATH_A][i][0];
1161*4882a593Smuzhiyun 			data = pRFCalibrateInfo->rx_iqc_8723b[RF_PATH_B][i][1];
1162*4882a593Smuzhiyun 			if (pRFCalibrateInfo->rx_iqc_8723b[RF_PATH_B][i][0] != 0) {
1163*4882a593Smuzhiyun 				phy_set_bb_reg(pAdapter, offset, bMaskDWord, data);
1164*4882a593Smuzhiyun 				RTW_INFO("Switch to S0 RxIQC (offset, data) = (0x%X, 0x%X)\n", offset, data);
1165*4882a593Smuzhiyun 			}
1166*4882a593Smuzhiyun 		}
1167*4882a593Smuzhiyun 	}
1168*4882a593Smuzhiyun 	break;
1169*4882a593Smuzhiyun 	default:
1170*4882a593Smuzhiyun 		pMptCtx->mpt_rf_path = RF_PATH_AB;
1171*4882a593Smuzhiyun 		break;
1172*4882a593Smuzhiyun 	}
1173*4882a593Smuzhiyun }
1174*4882a593Smuzhiyun #endif
1175*4882a593Smuzhiyun 
1176*4882a593Smuzhiyun #ifdef CONFIG_RTL8703B
mpt_SetRFPath_8703B(PADAPTER pAdapter)1177*4882a593Smuzhiyun void mpt_SetRFPath_8703B(PADAPTER pAdapter)
1178*4882a593Smuzhiyun {
1179*4882a593Smuzhiyun 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
1180*4882a593Smuzhiyun 	u32					ulAntennaTx, ulAntennaRx;
1181*4882a593Smuzhiyun 	PMPT_CONTEXT		pMptCtx = &(pAdapter->mppriv.mpt_ctx);
1182*4882a593Smuzhiyun 	struct dm_struct		*pDM_Odm = &pHalData->odmpriv;
1183*4882a593Smuzhiyun 	struct dm_rf_calibration_struct			*pRFCalibrateInfo = &(pDM_Odm->rf_calibrate_info);
1184*4882a593Smuzhiyun 	u8 i;
1185*4882a593Smuzhiyun 
1186*4882a593Smuzhiyun 	ulAntennaTx = pHalData->antenna_tx_path;
1187*4882a593Smuzhiyun 	ulAntennaRx = pHalData->AntennaRxPath;
1188*4882a593Smuzhiyun 
1189*4882a593Smuzhiyun 	if (pHalData->rf_chip >= RF_CHIP_MAX) {
1190*4882a593Smuzhiyun 		RTW_INFO("This RF chip ID is not supported\n");
1191*4882a593Smuzhiyun 		return;
1192*4882a593Smuzhiyun 	}
1193*4882a593Smuzhiyun 
1194*4882a593Smuzhiyun 	switch (pAdapter->mppriv.antenna_tx) {
1195*4882a593Smuzhiyun 	case ANTENNA_A: { /* Actually path S1  (Wi-Fi) */
1196*4882a593Smuzhiyun 		pMptCtx->mpt_rf_path = RF_PATH_A;
1197*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rS0S1_PathSwitch, BIT9 | BIT8 | BIT7, 0x0);
1198*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, 0xB2C, BIT31, 0x0); /* AGC Table Sel*/
1199*4882a593Smuzhiyun 
1200*4882a593Smuzhiyun 		for (i = 0; i < 3; ++i) {
1201*4882a593Smuzhiyun 			u32 offset = pRFCalibrateInfo->tx_iqc_8703b[i][0];
1202*4882a593Smuzhiyun 			u32 data = pRFCalibrateInfo->tx_iqc_8703b[i][1];
1203*4882a593Smuzhiyun 
1204*4882a593Smuzhiyun 			if (offset != 0) {
1205*4882a593Smuzhiyun 				phy_set_bb_reg(pAdapter, offset, bMaskDWord, data);
1206*4882a593Smuzhiyun 				RTW_INFO("Switch to S1 TxIQC(offset, data) = (0x%X, 0x%X)\n", offset, data);
1207*4882a593Smuzhiyun 			}
1208*4882a593Smuzhiyun 
1209*4882a593Smuzhiyun 		}
1210*4882a593Smuzhiyun 		for (i = 0; i < 2; ++i) {
1211*4882a593Smuzhiyun 			u32 offset = pRFCalibrateInfo->rx_iqc_8703b[i][0];
1212*4882a593Smuzhiyun 			u32 data = pRFCalibrateInfo->rx_iqc_8703b[i][1];
1213*4882a593Smuzhiyun 
1214*4882a593Smuzhiyun 			if (offset != 0) {
1215*4882a593Smuzhiyun 				phy_set_bb_reg(pAdapter, offset, bMaskDWord, data);
1216*4882a593Smuzhiyun 				RTW_INFO("Switch to S1 RxIQC (offset, data) = (0x%X, 0x%X)\n", offset, data);
1217*4882a593Smuzhiyun 			}
1218*4882a593Smuzhiyun 		}
1219*4882a593Smuzhiyun 	}
1220*4882a593Smuzhiyun 	break;
1221*4882a593Smuzhiyun 	case ANTENNA_B: { /* Actually path S0 (BT)*/
1222*4882a593Smuzhiyun 		pMptCtx->mpt_rf_path = RF_PATH_B;
1223*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rS0S1_PathSwitch, BIT9 | BIT8 | BIT7, 0x5);
1224*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, 0xB2C, BIT31, 0x1); /* AGC Table Sel */
1225*4882a593Smuzhiyun 
1226*4882a593Smuzhiyun 		for (i = 0; i < 3; ++i) {
1227*4882a593Smuzhiyun 			u32 offset = pRFCalibrateInfo->tx_iqc_8703b[i][0];
1228*4882a593Smuzhiyun 			u32 data = pRFCalibrateInfo->tx_iqc_8703b[i][1];
1229*4882a593Smuzhiyun 
1230*4882a593Smuzhiyun 			if (pRFCalibrateInfo->tx_iqc_8703b[i][0] != 0) {
1231*4882a593Smuzhiyun 				phy_set_bb_reg(pAdapter, offset, bMaskDWord, data);
1232*4882a593Smuzhiyun 				RTW_INFO("Switch to S0 TxIQC (offset, data) = (0x%X, 0x%X)\n", offset, data);
1233*4882a593Smuzhiyun 			}
1234*4882a593Smuzhiyun 		}
1235*4882a593Smuzhiyun 		for (i = 0; i < 2; ++i) {
1236*4882a593Smuzhiyun 			u32 offset = pRFCalibrateInfo->rx_iqc_8703b[i][0];
1237*4882a593Smuzhiyun 			u32 data = pRFCalibrateInfo->rx_iqc_8703b[i][1];
1238*4882a593Smuzhiyun 
1239*4882a593Smuzhiyun 			if (pRFCalibrateInfo->rx_iqc_8703b[i][0] != 0) {
1240*4882a593Smuzhiyun 				phy_set_bb_reg(pAdapter, offset, bMaskDWord, data);
1241*4882a593Smuzhiyun 				RTW_INFO("Switch to S0 RxIQC (offset, data) = (0x%X, 0x%X)\n", offset, data);
1242*4882a593Smuzhiyun 			}
1243*4882a593Smuzhiyun 		}
1244*4882a593Smuzhiyun 	}
1245*4882a593Smuzhiyun 	break;
1246*4882a593Smuzhiyun 	default:
1247*4882a593Smuzhiyun 		pMptCtx->mpt_rf_path = RF_PATH_AB;
1248*4882a593Smuzhiyun 		break;
1249*4882a593Smuzhiyun 	}
1250*4882a593Smuzhiyun 
1251*4882a593Smuzhiyun }
1252*4882a593Smuzhiyun #endif
1253*4882a593Smuzhiyun 
1254*4882a593Smuzhiyun #ifdef CONFIG_RTL8723D
mpt_SetRFPath_8723D(PADAPTER pAdapter)1255*4882a593Smuzhiyun void mpt_SetRFPath_8723D(PADAPTER pAdapter)
1256*4882a593Smuzhiyun {
1257*4882a593Smuzhiyun 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
1258*4882a593Smuzhiyun 	u8	p = 0, i = 0;
1259*4882a593Smuzhiyun 	u32	ulAntennaTx, ulAntennaRx, offset = 0, data = 0, val32 = 0;
1260*4882a593Smuzhiyun 	PMPT_CONTEXT	pMptCtx = &(pAdapter->mppriv.mpt_ctx);
1261*4882a593Smuzhiyun 	struct dm_struct	*pDM_Odm = &pHalData->odmpriv;
1262*4882a593Smuzhiyun 	struct dm_rf_calibration_struct	*pRFCalibrateInfo = &(pDM_Odm->rf_calibrate_info);
1263*4882a593Smuzhiyun 
1264*4882a593Smuzhiyun 	ulAntennaTx = pHalData->antenna_tx_path;
1265*4882a593Smuzhiyun 	ulAntennaRx = pHalData->AntennaRxPath;
1266*4882a593Smuzhiyun 
1267*4882a593Smuzhiyun 	if (pHalData->rf_chip >= RF_CHIP_MAX) {
1268*4882a593Smuzhiyun 		RTW_INFO("This RF chip ID is not supported\n");
1269*4882a593Smuzhiyun 		return;
1270*4882a593Smuzhiyun 	}
1271*4882a593Smuzhiyun 
1272*4882a593Smuzhiyun 	switch (pAdapter->mppriv.antenna_tx) {
1273*4882a593Smuzhiyun 	/* Actually path S1  (Wi-Fi) */
1274*4882a593Smuzhiyun 	case ANTENNA_A: {
1275*4882a593Smuzhiyun 		pMptCtx->mpt_rf_path = RF_PATH_A;
1276*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rS0S1_PathSwitch, BIT9|BIT8|BIT7|BIT6, 0);
1277*4882a593Smuzhiyun 	}
1278*4882a593Smuzhiyun 	break;
1279*4882a593Smuzhiyun 	/* Actually path S0 (BT) */
1280*4882a593Smuzhiyun 	case ANTENNA_B: {
1281*4882a593Smuzhiyun 		pMptCtx->mpt_rf_path = RF_PATH_B;
1282*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rS0S1_PathSwitch, BIT9|BIT8|BIT7|BIT6, 0xA);
1283*4882a593Smuzhiyun 
1284*4882a593Smuzhiyun 	}
1285*4882a593Smuzhiyun 	break;
1286*4882a593Smuzhiyun 	default:
1287*4882a593Smuzhiyun 		pMptCtx->mpt_rf_path = RF_PATH_AB;
1288*4882a593Smuzhiyun 		break;
1289*4882a593Smuzhiyun 	}
1290*4882a593Smuzhiyun }
1291*4882a593Smuzhiyun #endif
1292*4882a593Smuzhiyun 
mpt_SetRFPath_819X(PADAPTER pAdapter)1293*4882a593Smuzhiyun void mpt_SetRFPath_819X(PADAPTER	pAdapter)
1294*4882a593Smuzhiyun {
1295*4882a593Smuzhiyun 	HAL_DATA_TYPE			*pHalData	= GET_HAL_DATA(pAdapter);
1296*4882a593Smuzhiyun 	PMPT_CONTEXT		pMptCtx = &(pAdapter->mppriv.mpt_ctx);
1297*4882a593Smuzhiyun 	u32			ulAntennaTx, ulAntennaRx;
1298*4882a593Smuzhiyun 	R_ANTENNA_SELECT_OFDM	*p_ofdm_tx;	/* OFDM Tx register */
1299*4882a593Smuzhiyun 	R_ANTENNA_SELECT_CCK	*p_cck_txrx;
1300*4882a593Smuzhiyun 	u8		r_rx_antenna_ofdm = 0, r_ant_select_cck_val = 0;
1301*4882a593Smuzhiyun 	u8		chgTx = 0, chgRx = 0;
1302*4882a593Smuzhiyun 	u32		r_ant_sel_cck_val = 0, r_ant_select_ofdm_val = 0, r_ofdm_tx_en_val = 0;
1303*4882a593Smuzhiyun 
1304*4882a593Smuzhiyun 	ulAntennaTx = pHalData->antenna_tx_path;
1305*4882a593Smuzhiyun 	ulAntennaRx = pHalData->AntennaRxPath;
1306*4882a593Smuzhiyun 
1307*4882a593Smuzhiyun 	p_ofdm_tx = (R_ANTENNA_SELECT_OFDM *)&r_ant_select_ofdm_val;
1308*4882a593Smuzhiyun 	p_cck_txrx = (R_ANTENNA_SELECT_CCK *)&r_ant_select_cck_val;
1309*4882a593Smuzhiyun 
1310*4882a593Smuzhiyun 	p_ofdm_tx->r_ant_ht1			= 0x1;
1311*4882a593Smuzhiyun 	p_ofdm_tx->r_ant_ht2			= 0x2;/*Second TX RF path is A*/
1312*4882a593Smuzhiyun 	p_ofdm_tx->r_ant_non_ht			= 0x3;/*/ 0x1+0x2=0x3 */
1313*4882a593Smuzhiyun 
1314*4882a593Smuzhiyun 	switch (ulAntennaTx) {
1315*4882a593Smuzhiyun 	case ANTENNA_A:
1316*4882a593Smuzhiyun 		p_ofdm_tx->r_tx_antenna		= 0x1;
1317*4882a593Smuzhiyun 		r_ofdm_tx_en_val		= 0x1;
1318*4882a593Smuzhiyun 		p_ofdm_tx->r_ant_l		= 0x1;
1319*4882a593Smuzhiyun 		p_ofdm_tx->r_ant_ht_s1		= 0x1;
1320*4882a593Smuzhiyun 		p_ofdm_tx->r_ant_non_ht_s1	= 0x1;
1321*4882a593Smuzhiyun 		p_cck_txrx->r_ccktx_enable	= 0x8;
1322*4882a593Smuzhiyun 		chgTx = 1;
1323*4882a593Smuzhiyun 		/*/ From SD3 Willis suggestion !!! Set RF A=TX and B as standby*/
1324*4882a593Smuzhiyun 		/*/if (IS_HARDWARE_TYPE_8192S(pAdapter))*/
1325*4882a593Smuzhiyun 		{
1326*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rFPGA0_XA_HSSIParameter2, 0xe, 2);
1327*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rFPGA0_XB_HSSIParameter2, 0xe, 1);
1328*4882a593Smuzhiyun 			r_ofdm_tx_en_val			= 0x3;
1329*4882a593Smuzhiyun 			/*/ Power save*/
1330*4882a593Smuzhiyun 			/*/cosa r_ant_select_ofdm_val = 0x11111111;*/
1331*4882a593Smuzhiyun 			/*/ We need to close RFB by SW control*/
1332*4882a593Smuzhiyun 			if (pHalData->rf_type == RF_2T2R) {
1333*4882a593Smuzhiyun 				phy_set_bb_reg(pAdapter, rFPGA0_XAB_RFInterfaceSW, BIT10, 0);
1334*4882a593Smuzhiyun 				phy_set_bb_reg(pAdapter, rFPGA0_XAB_RFInterfaceSW, BIT26, 1);
1335*4882a593Smuzhiyun 				phy_set_bb_reg(pAdapter, rFPGA0_XB_RFInterfaceOE, BIT10, 0);
1336*4882a593Smuzhiyun 				phy_set_bb_reg(pAdapter, rFPGA0_XAB_RFParameter, BIT1, 1);
1337*4882a593Smuzhiyun 				phy_set_bb_reg(pAdapter, rFPGA0_XAB_RFParameter, BIT17, 0);
1338*4882a593Smuzhiyun 			}
1339*4882a593Smuzhiyun 		}
1340*4882a593Smuzhiyun 		pMptCtx->mpt_rf_path = RF_PATH_A;
1341*4882a593Smuzhiyun 		break;
1342*4882a593Smuzhiyun 	case ANTENNA_B:
1343*4882a593Smuzhiyun 		p_ofdm_tx->r_tx_antenna		= 0x2;
1344*4882a593Smuzhiyun 		r_ofdm_tx_en_val		= 0x2;
1345*4882a593Smuzhiyun 		p_ofdm_tx->r_ant_l		= 0x2;
1346*4882a593Smuzhiyun 		p_ofdm_tx->r_ant_ht_s1		= 0x2;
1347*4882a593Smuzhiyun 		p_ofdm_tx->r_ant_non_ht_s1	= 0x2;
1348*4882a593Smuzhiyun 		p_cck_txrx->r_ccktx_enable	= 0x4;
1349*4882a593Smuzhiyun 		chgTx = 1;
1350*4882a593Smuzhiyun 		/*/ From SD3 Willis suggestion !!! Set RF A as standby*/
1351*4882a593Smuzhiyun 		/*/if (IS_HARDWARE_TYPE_8192S(pAdapter))*/
1352*4882a593Smuzhiyun 		{
1353*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rFPGA0_XA_HSSIParameter2, 0xe, 1);
1354*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rFPGA0_XB_HSSIParameter2, 0xe, 2);
1355*4882a593Smuzhiyun 
1356*4882a593Smuzhiyun 			/*/ 2008/10/31 MH From SD3 Willi's suggestion. We must read RF 1T table.*/
1357*4882a593Smuzhiyun 			/*/ 2009/01/08 MH From Sd3 Willis. We need to close RFA by SW control*/
1358*4882a593Smuzhiyun 			if (pHalData->rf_type == RF_2T2R || pHalData->rf_type == RF_1T2R) {
1359*4882a593Smuzhiyun 				phy_set_bb_reg(pAdapter, rFPGA0_XAB_RFInterfaceSW, BIT10, 1);
1360*4882a593Smuzhiyun 				phy_set_bb_reg(pAdapter, rFPGA0_XA_RFInterfaceOE, BIT10, 0);
1361*4882a593Smuzhiyun 				phy_set_bb_reg(pAdapter, rFPGA0_XAB_RFInterfaceSW, BIT26, 0);
1362*4882a593Smuzhiyun 				/*/phy_set_bb_reg(pAdapter, rFPGA0_XB_RFInterfaceOE, BIT10, 0);*/
1363*4882a593Smuzhiyun 				phy_set_bb_reg(pAdapter, rFPGA0_XAB_RFParameter, BIT1, 0);
1364*4882a593Smuzhiyun 				phy_set_bb_reg(pAdapter, rFPGA0_XAB_RFParameter, BIT17, 1);
1365*4882a593Smuzhiyun 			}
1366*4882a593Smuzhiyun 		}
1367*4882a593Smuzhiyun 		pMptCtx->mpt_rf_path = RF_PATH_B;
1368*4882a593Smuzhiyun 		break;
1369*4882a593Smuzhiyun 	case ANTENNA_AB:/*/ For 8192S*/
1370*4882a593Smuzhiyun 		p_ofdm_tx->r_tx_antenna		= 0x3;
1371*4882a593Smuzhiyun 		r_ofdm_tx_en_val		= 0x3;
1372*4882a593Smuzhiyun 		p_ofdm_tx->r_ant_l		= 0x3;
1373*4882a593Smuzhiyun 		p_ofdm_tx->r_ant_ht_s1		= 0x3;
1374*4882a593Smuzhiyun 		p_ofdm_tx->r_ant_non_ht_s1	= 0x3;
1375*4882a593Smuzhiyun 		p_cck_txrx->r_ccktx_enable	= 0xC;
1376*4882a593Smuzhiyun 		chgTx = 1;
1377*4882a593Smuzhiyun 		/*/ From SD3Willis suggestion !!! Set RF B as standby*/
1378*4882a593Smuzhiyun 		/*/if (IS_HARDWARE_TYPE_8192S(pAdapter))*/
1379*4882a593Smuzhiyun 		{
1380*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rFPGA0_XA_HSSIParameter2, 0xe, 2);
1381*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rFPGA0_XB_HSSIParameter2, 0xe, 2);
1382*4882a593Smuzhiyun 			/* Disable Power save*/
1383*4882a593Smuzhiyun 			/*cosa r_ant_select_ofdm_val = 0x3321333;*/
1384*4882a593Smuzhiyun 			/* 2009/01/08 MH From Sd3 Willis. We need to enable RFA/B by SW control*/
1385*4882a593Smuzhiyun 			if (pHalData->rf_type == RF_2T2R) {
1386*4882a593Smuzhiyun 				phy_set_bb_reg(pAdapter, rFPGA0_XAB_RFInterfaceSW, BIT10, 0);
1387*4882a593Smuzhiyun 
1388*4882a593Smuzhiyun 				phy_set_bb_reg(pAdapter, rFPGA0_XAB_RFInterfaceSW, BIT26, 0);
1389*4882a593Smuzhiyun 				/*/phy_set_bb_reg(pAdapter, rFPGA0_XB_RFInterfaceOE, BIT10, 0);*/
1390*4882a593Smuzhiyun 				phy_set_bb_reg(pAdapter, rFPGA0_XAB_RFParameter, BIT1, 1);
1391*4882a593Smuzhiyun 				phy_set_bb_reg(pAdapter, rFPGA0_XAB_RFParameter, BIT17, 1);
1392*4882a593Smuzhiyun 			}
1393*4882a593Smuzhiyun 		}
1394*4882a593Smuzhiyun 		pMptCtx->mpt_rf_path = RF_PATH_AB;
1395*4882a593Smuzhiyun 		break;
1396*4882a593Smuzhiyun 	default:
1397*4882a593Smuzhiyun 		break;
1398*4882a593Smuzhiyun 	}
1399*4882a593Smuzhiyun #if 0
1400*4882a593Smuzhiyun 	/*  r_rx_antenna_ofdm, bit0=A, bit1=B, bit2=C, bit3=D */
1401*4882a593Smuzhiyun 	/*  r_cckrx_enable : CCK default, 0=A, 1=B, 2=C, 3=D */
1402*4882a593Smuzhiyun 	/* r_cckrx_enable_2 : CCK option, 0=A, 1=B, 2=C, 3=D	 */
1403*4882a593Smuzhiyun #endif
1404*4882a593Smuzhiyun 	switch (ulAntennaRx) {
1405*4882a593Smuzhiyun 	case ANTENNA_A:
1406*4882a593Smuzhiyun 		r_rx_antenna_ofdm		= 0x1;	/* A*/
1407*4882a593Smuzhiyun 		p_cck_txrx->r_cckrx_enable	= 0x0;	/* default: A*/
1408*4882a593Smuzhiyun 		p_cck_txrx->r_cckrx_enable_2	= 0x0;	/* option: A*/
1409*4882a593Smuzhiyun 		chgRx = 1;
1410*4882a593Smuzhiyun 		break;
1411*4882a593Smuzhiyun 	case ANTENNA_B:
1412*4882a593Smuzhiyun 		r_rx_antenna_ofdm			= 0x2;	/*/ B*/
1413*4882a593Smuzhiyun 		p_cck_txrx->r_cckrx_enable	= 0x1;	/*/ default: B*/
1414*4882a593Smuzhiyun 		p_cck_txrx->r_cckrx_enable_2	= 0x1;	/*/ option: B*/
1415*4882a593Smuzhiyun 		chgRx = 1;
1416*4882a593Smuzhiyun 		break;
1417*4882a593Smuzhiyun 	case ANTENNA_AB:/*/ For 8192S and 8192E/U...*/
1418*4882a593Smuzhiyun 		r_rx_antenna_ofdm		= 0x3;/*/ AB*/
1419*4882a593Smuzhiyun 		p_cck_txrx->r_cckrx_enable	= 0x0;/*/ default:A*/
1420*4882a593Smuzhiyun 		p_cck_txrx->r_cckrx_enable_2	= 0x1;/*/ option:B*/
1421*4882a593Smuzhiyun 		chgRx = 1;
1422*4882a593Smuzhiyun 		break;
1423*4882a593Smuzhiyun 	default:
1424*4882a593Smuzhiyun 		break;
1425*4882a593Smuzhiyun 	}
1426*4882a593Smuzhiyun 
1427*4882a593Smuzhiyun 
1428*4882a593Smuzhiyun 	if (chgTx && chgRx) {
1429*4882a593Smuzhiyun 		switch (pHalData->rf_chip) {
1430*4882a593Smuzhiyun 		case RF_8225:
1431*4882a593Smuzhiyun 		case RF_8256:
1432*4882a593Smuzhiyun 		case RF_6052:
1433*4882a593Smuzhiyun 			/*/r_ant_sel_cck_val = r_ant_select_cck_val;*/
1434*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rFPGA1_TxInfo, 0x7fffffff, r_ant_select_ofdm_val);		/*/OFDM Tx*/
1435*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rFPGA0_TxInfo, 0x0000000f, r_ofdm_tx_en_val);		/*/OFDM Tx*/
1436*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rOFDM0_TRxPathEnable, 0x0000000f, r_rx_antenna_ofdm);	/*/OFDM Rx*/
1437*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rOFDM1_TRxPathEnable, 0x0000000f, r_rx_antenna_ofdm);	/*/OFDM Rx*/
1438*4882a593Smuzhiyun 			if (IS_HARDWARE_TYPE_8192E(pAdapter)) {
1439*4882a593Smuzhiyun 				phy_set_bb_reg(pAdapter, rOFDM0_TRxPathEnable, 0x000000F0, r_rx_antenna_ofdm);	/*/OFDM Rx*/
1440*4882a593Smuzhiyun 				phy_set_bb_reg(pAdapter, rOFDM1_TRxPathEnable, 0x000000F0, r_rx_antenna_ofdm);	/*/OFDM Rx*/
1441*4882a593Smuzhiyun 			}
1442*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rCCK0_AFESetting, bMaskByte3, r_ant_select_cck_val);/*/r_ant_sel_cck_val); /CCK TxRx*/
1443*4882a593Smuzhiyun 			break;
1444*4882a593Smuzhiyun 
1445*4882a593Smuzhiyun 		default:
1446*4882a593Smuzhiyun 			RTW_INFO("Unsupported RFChipID for switching antenna.\n");
1447*4882a593Smuzhiyun 			break;
1448*4882a593Smuzhiyun 		}
1449*4882a593Smuzhiyun 	}
1450*4882a593Smuzhiyun }	/* MPT_ProSetRFPath */
1451*4882a593Smuzhiyun 
1452*4882a593Smuzhiyun #ifdef CONFIG_RTL8192F
1453*4882a593Smuzhiyun 
mpt_set_rfpath_8192f(PADAPTER pAdapter)1454*4882a593Smuzhiyun void mpt_set_rfpath_8192f(PADAPTER	pAdapter)
1455*4882a593Smuzhiyun {
1456*4882a593Smuzhiyun 	HAL_DATA_TYPE			*pHalData	= GET_HAL_DATA(pAdapter);
1457*4882a593Smuzhiyun 	PMPT_CONTEXT		pMptCtx = &(pAdapter->mppriv.mpt_ctx);
1458*4882a593Smuzhiyun 
1459*4882a593Smuzhiyun 	u16		ForcedDataRate = mpt_to_mgnt_rate(pMptCtx->mpt_rate_index);
1460*4882a593Smuzhiyun 	u8				NssforRate, odmNssforRate;
1461*4882a593Smuzhiyun 	u32				ulAntennaTx, ulAntennaRx;
1462*4882a593Smuzhiyun 	enum bb_path	RxAntToPhyDm;
1463*4882a593Smuzhiyun 	enum bb_path	TxAntToPhyDm;
1464*4882a593Smuzhiyun 
1465*4882a593Smuzhiyun 	ulAntennaTx = pHalData->antenna_tx_path;
1466*4882a593Smuzhiyun 	ulAntennaRx = pHalData->AntennaRxPath;
1467*4882a593Smuzhiyun 	NssforRate = MgntQuery_NssTxRate(ForcedDataRate);
1468*4882a593Smuzhiyun 
1469*4882a593Smuzhiyun 	if (pHalData->rf_chip >= RF_TYPE_MAX)
1470*4882a593Smuzhiyun 		RTW_INFO("This RF chip ID is not supported\n");
1471*4882a593Smuzhiyun 
1472*4882a593Smuzhiyun 	switch (ulAntennaTx) {
1473*4882a593Smuzhiyun 	case ANTENNA_A:
1474*4882a593Smuzhiyun 			pMptCtx->mpt_rf_path = RF_PATH_A;
1475*4882a593Smuzhiyun 			TxAntToPhyDm = BB_PATH_A;
1476*4882a593Smuzhiyun 			break;
1477*4882a593Smuzhiyun 	case ANTENNA_B:
1478*4882a593Smuzhiyun 			pMptCtx->mpt_rf_path = RF_PATH_B;
1479*4882a593Smuzhiyun 			TxAntToPhyDm = BB_PATH_B;
1480*4882a593Smuzhiyun 			break;
1481*4882a593Smuzhiyun 	case ANTENNA_AB:
1482*4882a593Smuzhiyun 			pMptCtx->mpt_rf_path = RF_PATH_AB;
1483*4882a593Smuzhiyun 			TxAntToPhyDm = (BB_PATH_A|BB_PATH_B);
1484*4882a593Smuzhiyun 			break;
1485*4882a593Smuzhiyun 	default:
1486*4882a593Smuzhiyun 			pMptCtx->mpt_rf_path = RF_PATH_AB;
1487*4882a593Smuzhiyun 			TxAntToPhyDm = (BB_PATH_A|BB_PATH_B);
1488*4882a593Smuzhiyun 			break;
1489*4882a593Smuzhiyun 	}
1490*4882a593Smuzhiyun 
1491*4882a593Smuzhiyun 	switch (ulAntennaRx) {
1492*4882a593Smuzhiyun 	case ANTENNA_A:
1493*4882a593Smuzhiyun 			RxAntToPhyDm = BB_PATH_A;
1494*4882a593Smuzhiyun 			break;
1495*4882a593Smuzhiyun 	case ANTENNA_B:
1496*4882a593Smuzhiyun 			RxAntToPhyDm = BB_PATH_B;
1497*4882a593Smuzhiyun 			break;
1498*4882a593Smuzhiyun 	case ANTENNA_AB:
1499*4882a593Smuzhiyun 			RxAntToPhyDm = (BB_PATH_A|BB_PATH_B);
1500*4882a593Smuzhiyun 			break;
1501*4882a593Smuzhiyun 	default:
1502*4882a593Smuzhiyun 			RxAntToPhyDm = (BB_PATH_A|BB_PATH_B);
1503*4882a593Smuzhiyun 			break;
1504*4882a593Smuzhiyun 	}
1505*4882a593Smuzhiyun 
1506*4882a593Smuzhiyun 	phydm_api_trx_mode(GET_PDM_ODM(pAdapter), TxAntToPhyDm, RxAntToPhyDm, TxAntToPhyDm);
1507*4882a593Smuzhiyun 
1508*4882a593Smuzhiyun }
1509*4882a593Smuzhiyun 
1510*4882a593Smuzhiyun #endif
1511*4882a593Smuzhiyun 
hal_mpt_SetAntenna(PADAPTER pAdapter)1512*4882a593Smuzhiyun void hal_mpt_SetAntenna(PADAPTER	pAdapter)
1513*4882a593Smuzhiyun {
1514*4882a593Smuzhiyun 	PHAL_DATA_TYPE hal;
1515*4882a593Smuzhiyun 	ANTENNA_PATH anttx;
1516*4882a593Smuzhiyun 	enum bb_path bb_tx = 0;
1517*4882a593Smuzhiyun 
1518*4882a593Smuzhiyun 
1519*4882a593Smuzhiyun 	hal = GET_HAL_DATA(pAdapter);
1520*4882a593Smuzhiyun 	anttx = hal->antenna_tx_path;
1521*4882a593Smuzhiyun 
1522*4882a593Smuzhiyun 	switch (anttx) {
1523*4882a593Smuzhiyun 	case ANTENNA_A:
1524*4882a593Smuzhiyun 		bb_tx = BB_PATH_A;
1525*4882a593Smuzhiyun 		break;
1526*4882a593Smuzhiyun 	case ANTENNA_B:
1527*4882a593Smuzhiyun 		bb_tx = BB_PATH_B;
1528*4882a593Smuzhiyun 		break;
1529*4882a593Smuzhiyun 	case ANTENNA_C:
1530*4882a593Smuzhiyun 		bb_tx = BB_PATH_C;
1531*4882a593Smuzhiyun 		break;
1532*4882a593Smuzhiyun 	case ANTENNA_D:
1533*4882a593Smuzhiyun 		bb_tx = BB_PATH_D;
1534*4882a593Smuzhiyun 		break;
1535*4882a593Smuzhiyun 	case ANTENNA_AB:
1536*4882a593Smuzhiyun 		bb_tx = BB_PATH_AB;
1537*4882a593Smuzhiyun 		break;
1538*4882a593Smuzhiyun 	case ANTENNA_AC:
1539*4882a593Smuzhiyun 		bb_tx = BB_PATH_AC;
1540*4882a593Smuzhiyun 		break;
1541*4882a593Smuzhiyun 	case ANTENNA_AD:
1542*4882a593Smuzhiyun 		bb_tx = BB_PATH_AD;
1543*4882a593Smuzhiyun 		break;
1544*4882a593Smuzhiyun 	case ANTENNA_BC:
1545*4882a593Smuzhiyun 		bb_tx = BB_PATH_BC;
1546*4882a593Smuzhiyun 		break;
1547*4882a593Smuzhiyun 	case ANTENNA_BD:
1548*4882a593Smuzhiyun 		bb_tx = BB_PATH_BD;
1549*4882a593Smuzhiyun 		break;
1550*4882a593Smuzhiyun 	case ANTENNA_CD:
1551*4882a593Smuzhiyun 		bb_tx = BB_PATH_CD;
1552*4882a593Smuzhiyun 		break;
1553*4882a593Smuzhiyun 	case ANTENNA_ABC:
1554*4882a593Smuzhiyun 		bb_tx = BB_PATH_ABC;
1555*4882a593Smuzhiyun 		break;
1556*4882a593Smuzhiyun 	case ANTENNA_BCD:
1557*4882a593Smuzhiyun 		bb_tx = BB_PATH_BCD;
1558*4882a593Smuzhiyun 		break;
1559*4882a593Smuzhiyun 	case ANTENNA_ABD:
1560*4882a593Smuzhiyun 		bb_tx = BB_PATH_ABD;
1561*4882a593Smuzhiyun 		break;
1562*4882a593Smuzhiyun 	case ANTENNA_ACD:
1563*4882a593Smuzhiyun 		bb_tx = BB_PATH_ACD;
1564*4882a593Smuzhiyun 		break;
1565*4882a593Smuzhiyun 	case ANTENNA_ABCD:
1566*4882a593Smuzhiyun 		bb_tx = BB_PATH_ABCD;
1567*4882a593Smuzhiyun 		break;
1568*4882a593Smuzhiyun 	default:
1569*4882a593Smuzhiyun 		bb_tx = BB_PATH_A;
1570*4882a593Smuzhiyun 		break;
1571*4882a593Smuzhiyun 	}
1572*4882a593Smuzhiyun 	tx_path_nss_set_full_tx(hal->txpath_nss, hal->txpath_num_nss, bb_tx);
1573*4882a593Smuzhiyun 	RTW_INFO("%s ,ant idx %d, tx path_num_nss = %d\n", __func__, anttx, hal->txpath_num_nss[0]);
1574*4882a593Smuzhiyun 
1575*4882a593Smuzhiyun #ifdef CONFIG_RTL8822C
1576*4882a593Smuzhiyun 	if (IS_HARDWARE_TYPE_8822C(pAdapter)) {
1577*4882a593Smuzhiyun 		rtl8822c_mp_config_rfpath(pAdapter);
1578*4882a593Smuzhiyun 		return;
1579*4882a593Smuzhiyun 	}
1580*4882a593Smuzhiyun #endif
1581*4882a593Smuzhiyun #ifdef CONFIG_RTL8814A
1582*4882a593Smuzhiyun 	if (IS_HARDWARE_TYPE_8814A(pAdapter)) {
1583*4882a593Smuzhiyun 		mpt_SetRFPath_8814A(pAdapter);
1584*4882a593Smuzhiyun 		return;
1585*4882a593Smuzhiyun 	}
1586*4882a593Smuzhiyun #endif
1587*4882a593Smuzhiyun #ifdef CONFIG_RTL8822B
1588*4882a593Smuzhiyun 	if (IS_HARDWARE_TYPE_8822B(pAdapter)) {
1589*4882a593Smuzhiyun 		rtl8822b_mp_config_rfpath(pAdapter);
1590*4882a593Smuzhiyun 		return;
1591*4882a593Smuzhiyun 	}
1592*4882a593Smuzhiyun #endif
1593*4882a593Smuzhiyun #ifdef CONFIG_RTL8821C
1594*4882a593Smuzhiyun 	if (IS_HARDWARE_TYPE_8821C(pAdapter)) {
1595*4882a593Smuzhiyun 		rtl8821c_mp_config_rfpath(pAdapter);
1596*4882a593Smuzhiyun 		return;
1597*4882a593Smuzhiyun 	}
1598*4882a593Smuzhiyun #endif
1599*4882a593Smuzhiyun #if	defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A)
1600*4882a593Smuzhiyun 	if (IS_HARDWARE_TYPE_JAGUAR(pAdapter)) {
1601*4882a593Smuzhiyun 		mpt_SetRFPath_8812A(pAdapter);
1602*4882a593Smuzhiyun 		return;
1603*4882a593Smuzhiyun 	}
1604*4882a593Smuzhiyun #endif
1605*4882a593Smuzhiyun #ifdef CONFIG_RTL8723B
1606*4882a593Smuzhiyun 	if (IS_HARDWARE_TYPE_8723B(pAdapter)) {
1607*4882a593Smuzhiyun 		mpt_SetRFPath_8723B(pAdapter);
1608*4882a593Smuzhiyun 		return;
1609*4882a593Smuzhiyun 	}
1610*4882a593Smuzhiyun #endif
1611*4882a593Smuzhiyun 
1612*4882a593Smuzhiyun #ifdef CONFIG_RTL8703B
1613*4882a593Smuzhiyun 	if (IS_HARDWARE_TYPE_8703B(pAdapter)) {
1614*4882a593Smuzhiyun 		mpt_SetRFPath_8703B(pAdapter);
1615*4882a593Smuzhiyun 		return;
1616*4882a593Smuzhiyun 	}
1617*4882a593Smuzhiyun #endif
1618*4882a593Smuzhiyun 
1619*4882a593Smuzhiyun #ifdef CONFIG_RTL8723D
1620*4882a593Smuzhiyun 	if (IS_HARDWARE_TYPE_8723D(pAdapter)) {
1621*4882a593Smuzhiyun 		mpt_SetRFPath_8723D(pAdapter);
1622*4882a593Smuzhiyun 		return;
1623*4882a593Smuzhiyun 	}
1624*4882a593Smuzhiyun #endif
1625*4882a593Smuzhiyun 
1626*4882a593Smuzhiyun #ifdef CONFIG_RTL8192F
1627*4882a593Smuzhiyun 		if (IS_HARDWARE_TYPE_8192F(pAdapter)) {
1628*4882a593Smuzhiyun 			mpt_set_rfpath_8192f(pAdapter);
1629*4882a593Smuzhiyun 			return;
1630*4882a593Smuzhiyun 		}
1631*4882a593Smuzhiyun #endif
1632*4882a593Smuzhiyun 
1633*4882a593Smuzhiyun #ifdef CONFIG_RTL8814B
1634*4882a593Smuzhiyun 	if (IS_HARDWARE_TYPE_8814B(pAdapter)) {
1635*4882a593Smuzhiyun 		rtl8814b_mp_config_rfpath(pAdapter);
1636*4882a593Smuzhiyun 		return;
1637*4882a593Smuzhiyun 	}
1638*4882a593Smuzhiyun #endif
1639*4882a593Smuzhiyun 
1640*4882a593Smuzhiyun 	/*	else if (IS_HARDWARE_TYPE_8821B(pAdapter))
1641*4882a593Smuzhiyun 			mpt_SetRFPath_8821B(pAdapter);
1642*4882a593Smuzhiyun 		Prepare for 8822B
1643*4882a593Smuzhiyun 		else if (IS_HARDWARE_TYPE_8822B(Context))
1644*4882a593Smuzhiyun 			mpt_SetRFPath_8822B(Context);
1645*4882a593Smuzhiyun 	*/
1646*4882a593Smuzhiyun 	mpt_SetRFPath_819X(pAdapter);
1647*4882a593Smuzhiyun 	RTW_INFO("mpt_SetRFPath_819X Do %s\n", __func__);
1648*4882a593Smuzhiyun }
1649*4882a593Smuzhiyun 
hal_mpt_SetThermalMeter(PADAPTER pAdapter,u8 target_ther)1650*4882a593Smuzhiyun s32 hal_mpt_SetThermalMeter(PADAPTER pAdapter, u8 target_ther)
1651*4882a593Smuzhiyun {
1652*4882a593Smuzhiyun 	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
1653*4882a593Smuzhiyun 
1654*4882a593Smuzhiyun 	if (!netif_running(pAdapter->pnetdev)) {
1655*4882a593Smuzhiyun 		return _FAIL;
1656*4882a593Smuzhiyun 	}
1657*4882a593Smuzhiyun 
1658*4882a593Smuzhiyun 
1659*4882a593Smuzhiyun 	if (check_fwstate(&pAdapter->mlmepriv, WIFI_MP_STATE) == _FALSE) {
1660*4882a593Smuzhiyun 		return _FAIL;
1661*4882a593Smuzhiyun 	}
1662*4882a593Smuzhiyun 
1663*4882a593Smuzhiyun 	target_ther &= 0xff;
1664*4882a593Smuzhiyun 
1665*4882a593Smuzhiyun 	pHalData->eeprom_thermal_meter = target_ther;
1666*4882a593Smuzhiyun 
1667*4882a593Smuzhiyun 	return _SUCCESS;
1668*4882a593Smuzhiyun }
1669*4882a593Smuzhiyun 
1670*4882a593Smuzhiyun 
hal_mpt_TriggerRFThermalMeter(PADAPTER pAdapter)1671*4882a593Smuzhiyun void hal_mpt_TriggerRFThermalMeter(PADAPTER pAdapter)
1672*4882a593Smuzhiyun {
1673*4882a593Smuzhiyun 	if (IS_HARDWARE_TYPE_JAGUAR3(pAdapter)) {
1674*4882a593Smuzhiyun 		phy_set_rf_reg(pAdapter, RF_PATH_A, 0x42, BIT19, 0x1);
1675*4882a593Smuzhiyun 		phy_set_rf_reg(pAdapter, RF_PATH_A, 0x42, BIT19, 0x0);
1676*4882a593Smuzhiyun 		phy_set_rf_reg(pAdapter, RF_PATH_A, 0x42, BIT19, 0x1);
1677*4882a593Smuzhiyun 	} else
1678*4882a593Smuzhiyun 		phy_set_rf_reg(pAdapter, RF_PATH_A, 0x42, BIT17 | BIT16, 0x03);
1679*4882a593Smuzhiyun 
1680*4882a593Smuzhiyun }
1681*4882a593Smuzhiyun 
1682*4882a593Smuzhiyun 
hal_mpt_ReadRFThermalMeter(PADAPTER pAdapter,u8 rf_path)1683*4882a593Smuzhiyun u8 hal_mpt_ReadRFThermalMeter(PADAPTER pAdapter, u8 rf_path)
1684*4882a593Smuzhiyun 
1685*4882a593Smuzhiyun {
1686*4882a593Smuzhiyun 	struct dm_struct *p_dm_odm = adapter_to_phydm(pAdapter);
1687*4882a593Smuzhiyun 
1688*4882a593Smuzhiyun 	u32 ThermalValue = 0;
1689*4882a593Smuzhiyun 	s32 thermal_value_temp = 0;
1690*4882a593Smuzhiyun 	s8 thermal_offset = 0;
1691*4882a593Smuzhiyun 	u32 thermal_reg_mask = 0;
1692*4882a593Smuzhiyun 
1693*4882a593Smuzhiyun 	if (IS_8822C_SERIES(GET_HAL_DATA(pAdapter)->version_id))
1694*4882a593Smuzhiyun 			thermal_reg_mask = 0x007e; 	/*0x42: RF Reg[6:1], 35332(themal K  & bias k & power trim) & 35325(tssi )*/
1695*4882a593Smuzhiyun 	else
1696*4882a593Smuzhiyun 			thermal_reg_mask = 0xfc00;	/*0x42: RF Reg[15:10]*/
1697*4882a593Smuzhiyun 
1698*4882a593Smuzhiyun 	ThermalValue = (u8)phy_query_rf_reg(pAdapter, rf_path, 0x42, thermal_reg_mask);
1699*4882a593Smuzhiyun 
1700*4882a593Smuzhiyun 	thermal_offset = phydm_get_thermal_offset(p_dm_odm);
1701*4882a593Smuzhiyun 
1702*4882a593Smuzhiyun 	thermal_value_temp = ThermalValue + thermal_offset;
1703*4882a593Smuzhiyun 
1704*4882a593Smuzhiyun 	if (thermal_value_temp > 63)
1705*4882a593Smuzhiyun 		ThermalValue = 63;
1706*4882a593Smuzhiyun 	else if (thermal_value_temp < 0)
1707*4882a593Smuzhiyun 		ThermalValue = 0;
1708*4882a593Smuzhiyun 	else
1709*4882a593Smuzhiyun 		ThermalValue = thermal_value_temp;
1710*4882a593Smuzhiyun 
1711*4882a593Smuzhiyun 	return (u8)ThermalValue;
1712*4882a593Smuzhiyun }
1713*4882a593Smuzhiyun 
1714*4882a593Smuzhiyun 
hal_mpt_GetThermalMeter(PADAPTER pAdapter,u8 rfpath,u8 * value)1715*4882a593Smuzhiyun void hal_mpt_GetThermalMeter(PADAPTER pAdapter, u8 rfpath, u8 *value)
1716*4882a593Smuzhiyun {
1717*4882a593Smuzhiyun #if 0
1718*4882a593Smuzhiyun 	fw_cmd(pAdapter, IOCMD_GET_THERMAL_METER);
1719*4882a593Smuzhiyun 	rtw_msleep_os(1000);
1720*4882a593Smuzhiyun 	fw_cmd_data(pAdapter, value, 1);
1721*4882a593Smuzhiyun 	*value &= 0xFF;
1722*4882a593Smuzhiyun #else
1723*4882a593Smuzhiyun 	hal_mpt_TriggerRFThermalMeter(pAdapter);
1724*4882a593Smuzhiyun 	rtw_msleep_os(1000);
1725*4882a593Smuzhiyun 	*value = hal_mpt_ReadRFThermalMeter(pAdapter, rfpath);
1726*4882a593Smuzhiyun #endif
1727*4882a593Smuzhiyun 
1728*4882a593Smuzhiyun }
1729*4882a593Smuzhiyun 
1730*4882a593Smuzhiyun 
hal_mpt_SetSingleCarrierTx(PADAPTER pAdapter,u8 bStart)1731*4882a593Smuzhiyun void hal_mpt_SetSingleCarrierTx(PADAPTER pAdapter, u8 bStart)
1732*4882a593Smuzhiyun {
1733*4882a593Smuzhiyun 	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
1734*4882a593Smuzhiyun 
1735*4882a593Smuzhiyun 	pAdapter->mppriv.mpt_ctx.bSingleCarrier = bStart;
1736*4882a593Smuzhiyun 
1737*4882a593Smuzhiyun 	if (bStart) {/*/ Start Single Carrier.*/
1738*4882a593Smuzhiyun 		/*/ Start Single Carrier.*/
1739*4882a593Smuzhiyun 		/*/ 1. if OFDM block on?*/
1740*4882a593Smuzhiyun 		if (!phy_query_bb_reg(pAdapter, rFPGA0_RFMOD, bOFDMEn))
1741*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rFPGA0_RFMOD, bOFDMEn, 1); /*set OFDM block on*/
1742*4882a593Smuzhiyun 
1743*4882a593Smuzhiyun 		/*/ 2. set CCK test mode off, set to CCK normal mode*/
1744*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rCCK0_System, bCCKBBMode, 0);
1745*4882a593Smuzhiyun 
1746*4882a593Smuzhiyun 		/*/ 3. turn on scramble setting*/
1747*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rCCK0_System, bCCKScramble, 1);
1748*4882a593Smuzhiyun 
1749*4882a593Smuzhiyun 		/*/ 4. Turn On Continue Tx and turn off the other test modes.*/
1750*4882a593Smuzhiyun #if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A) || defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C)
1751*4882a593Smuzhiyun 		if (IS_HARDWARE_TYPE_JAGUAR_ALL(pAdapter))
1752*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rSingleTone_ContTx_Jaguar, BIT18 | BIT17 | BIT16, OFDM_SingleCarrier);
1753*4882a593Smuzhiyun 		else
1754*4882a593Smuzhiyun #endif /* CONFIG_RTL8812A || CONFIG_RTL8821A || CONFIG_RTL8814A || CONFIG_RTL8822B || CONFIG_RTL8821C */
1755*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rOFDM1_LSTF, BIT30 | BIT29 | BIT28, OFDM_SingleCarrier);
1756*4882a593Smuzhiyun 
1757*4882a593Smuzhiyun 	} else {
1758*4882a593Smuzhiyun 		/*/ Stop Single Carrier.*/
1759*4882a593Smuzhiyun 		/*/ Stop Single Carrier.*/
1760*4882a593Smuzhiyun 		/*/ Turn off all test modes.*/
1761*4882a593Smuzhiyun #if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A) || defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C)
1762*4882a593Smuzhiyun 		if (IS_HARDWARE_TYPE_JAGUAR_ALL(pAdapter))
1763*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rSingleTone_ContTx_Jaguar, BIT18 | BIT17 | BIT16, OFDM_ALL_OFF);
1764*4882a593Smuzhiyun 		else
1765*4882a593Smuzhiyun #endif /* CONFIG_RTL8812A || CONFIG_RTL8821A || CONFIG_RTL8814A || CONFIG_RTL8822B || CONFIG_RTL8821C */
1766*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rOFDM1_LSTF, BIT30 | BIT29 | BIT28, OFDM_ALL_OFF);
1767*4882a593Smuzhiyun 
1768*4882a593Smuzhiyun 		rtw_msleep_os(10);
1769*4882a593Smuzhiyun 		/*/BB Reset*/
1770*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rPMAC_Reset, bBBResetB, 0x0);
1771*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rPMAC_Reset, bBBResetB, 0x1);
1772*4882a593Smuzhiyun 	}
1773*4882a593Smuzhiyun }
1774*4882a593Smuzhiyun 
1775*4882a593Smuzhiyun 
hal_mpt_SetSingleToneTx(PADAPTER pAdapter,u8 bStart)1776*4882a593Smuzhiyun void hal_mpt_SetSingleToneTx(PADAPTER pAdapter, u8 bStart)
1777*4882a593Smuzhiyun {
1778*4882a593Smuzhiyun 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
1779*4882a593Smuzhiyun 	PMPT_CONTEXT		pMptCtx = &(pAdapter->mppriv.mpt_ctx);
1780*4882a593Smuzhiyun 	struct dm_struct		*pDM_Odm = &pHalData->odmpriv;
1781*4882a593Smuzhiyun 	u32			ulAntennaTx = pHalData->antenna_tx_path;
1782*4882a593Smuzhiyun 	static u32		regRF = 0, regBB0 = 0, regBB1 = 0, regBB2 = 0, regBB3 = 0;
1783*4882a593Smuzhiyun 	u8 rfPath;
1784*4882a593Smuzhiyun 
1785*4882a593Smuzhiyun 	if (IS_HARDWARE_TYPE_JAGUAR3(pAdapter)) {
1786*4882a593Smuzhiyun #ifdef	PHYDM_MP_SUPPORT
1787*4882a593Smuzhiyun #ifdef CONFIG_RTL8814B
1788*4882a593Smuzhiyun 		if(pHalData->current_channel_bw == CHANNEL_WIDTH_80_80)
1789*4882a593Smuzhiyun 		{
1790*4882a593Smuzhiyun 			/* @Tx mode: RF0x00[19:16]=4'b0010 */
1791*4882a593Smuzhiyun 			config_phydm_write_rf_syn_8814b(pDM_Odm, RF_SYN0, RF_0x0, 0xF0000, 0x2);
1792*4882a593Smuzhiyun 			/* @Lowest RF gain index: RF_0x0[4:0] = 0*/
1793*4882a593Smuzhiyun 			config_phydm_write_rf_syn_8814b(pDM_Odm, RF_SYN0, RF_0x0, 0x1F, 0x0);
1794*4882a593Smuzhiyun 			/* @RF LO enabled */
1795*4882a593Smuzhiyun 			config_phydm_write_rf_syn_8814b(pDM_Odm, RF_SYN0, RF_0x58, BIT(1), 0x1);
1796*4882a593Smuzhiyun 			/* @SYN1 */
1797*4882a593Smuzhiyun 			config_phydm_write_rf_syn_8814b(pDM_Odm, RF_SYN1, RF_0x0, 0xF0000, 0x2);
1798*4882a593Smuzhiyun 			config_phydm_write_rf_syn_8814b(pDM_Odm, RF_SYN1, RF_0x0, 0x1F, 0x0);
1799*4882a593Smuzhiyun 			config_phydm_write_rf_syn_8814b(pDM_Odm, RF_SYN1, RF_0x58, BIT(1), 0x1);
1800*4882a593Smuzhiyun 		}
1801*4882a593Smuzhiyun #endif
1802*4882a593Smuzhiyun 		phydm_mp_set_single_tone(pDM_Odm, bStart, pMptCtx->mpt_rf_path);
1803*4882a593Smuzhiyun #endif
1804*4882a593Smuzhiyun 		return;
1805*4882a593Smuzhiyun 	}
1806*4882a593Smuzhiyun 
1807*4882a593Smuzhiyun 	switch (ulAntennaTx) {
1808*4882a593Smuzhiyun 	case ANTENNA_B:
1809*4882a593Smuzhiyun 		rfPath = RF_PATH_B;
1810*4882a593Smuzhiyun 		break;
1811*4882a593Smuzhiyun 	case ANTENNA_C:
1812*4882a593Smuzhiyun 		rfPath = RF_PATH_C;
1813*4882a593Smuzhiyun 		break;
1814*4882a593Smuzhiyun 	case ANTENNA_D:
1815*4882a593Smuzhiyun 		rfPath = RF_PATH_D;
1816*4882a593Smuzhiyun 		break;
1817*4882a593Smuzhiyun 	case ANTENNA_A:
1818*4882a593Smuzhiyun 	default:
1819*4882a593Smuzhiyun 		rfPath = RF_PATH_A;
1820*4882a593Smuzhiyun 		break;
1821*4882a593Smuzhiyun 	}
1822*4882a593Smuzhiyun 
1823*4882a593Smuzhiyun 	pAdapter->mppriv.mpt_ctx.is_single_tone = bStart;
1824*4882a593Smuzhiyun 	if (bStart) {
1825*4882a593Smuzhiyun 		/*/ Start Single Tone.*/
1826*4882a593Smuzhiyun 		/*/ <20120326, Kordan> To amplify the power of tone for Xtal calibration. (asked by Edlu)*/
1827*4882a593Smuzhiyun 		if (IS_HARDWARE_TYPE_8188E(pAdapter)) {
1828*4882a593Smuzhiyun 			regRF = phy_query_rf_reg(pAdapter, rfPath, lna_low_gain_3, bRFRegOffsetMask);
1829*4882a593Smuzhiyun 			phy_set_rf_reg(pAdapter, RF_PATH_A, lna_low_gain_3, BIT1, 0x1); /*/ RF LO enabled*/
1830*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rFPGA0_RFMOD, bCCKEn, 0x0);
1831*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rFPGA0_RFMOD, bOFDMEn, 0x0);
1832*4882a593Smuzhiyun 		} else if (IS_HARDWARE_TYPE_8192E(pAdapter)) { /*/ USB need to do RF LO disable first, PCIE isn't required to follow this order.*/
1833*4882a593Smuzhiyun 			/*/Set MAC REG 88C: Prevent SingleTone Fail*/
1834*4882a593Smuzhiyun 			phy_set_mac_reg(pAdapter, 0x88C, 0xF00000, 0xF);
1835*4882a593Smuzhiyun 			phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, lna_low_gain_3, BIT1, 0x1); /*/ RF LO disabled*/
1836*4882a593Smuzhiyun 			phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, RF_AC, 0xF0000, 0x2); /*/ Tx mode*/
1837*4882a593Smuzhiyun 		}	else if (IS_HARDWARE_TYPE_8192F(pAdapter)) { /* USB need to do RF LO disable first, PCIE isn't required to follow this order.*/
1838*4882a593Smuzhiyun  #ifdef CONFIG_RTL8192F
1839*4882a593Smuzhiyun 			phy_set_mac_reg(pAdapter, REG_LEDCFG0_8192F, BIT23, 0x1);
1840*4882a593Smuzhiyun 			phy_set_mac_reg(pAdapter, REG_LEDCFG0_8192F, BIT26, 0x1);
1841*4882a593Smuzhiyun 			phy_set_mac_reg(pAdapter, REG_PAD_CTRL1_8192F, BIT7, 0x1);
1842*4882a593Smuzhiyun 			phy_set_mac_reg(pAdapter, REG_PAD_CTRL1_8192F, BIT1, 0x1);
1843*4882a593Smuzhiyun 			phy_set_mac_reg(pAdapter, REG_PAD_CTRL1_8192F, BIT0, 0x1);
1844*4882a593Smuzhiyun 			phy_set_mac_reg(pAdapter, REG_AFE_CTRL_4_8192F, BIT16, 0x1);
1845*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, 0x88C, 0xF00000, 0xF);
1846*4882a593Smuzhiyun 			phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, 0x57, BIT1, 0x1); /* RF LO disabled*/
1847*4882a593Smuzhiyun 			phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, RF_AC, 0xF0000, 0x2); /* Tx mode*/
1848*4882a593Smuzhiyun #endif
1849*4882a593Smuzhiyun 		} else if (IS_HARDWARE_TYPE_8723B(pAdapter)) {
1850*4882a593Smuzhiyun 			if (pMptCtx->mpt_rf_path == RF_PATH_A) {
1851*4882a593Smuzhiyun 				phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC, 0xF0000, 0x2); /*/ Tx mode*/
1852*4882a593Smuzhiyun 				phy_set_rf_reg(pAdapter, RF_PATH_A, 0x56, 0xF, 0x1); /*/ RF LO enabled*/
1853*4882a593Smuzhiyun 			} else {
1854*4882a593Smuzhiyun 				/*/ S0/S1 both use PATH A to configure*/
1855*4882a593Smuzhiyun 				phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC, 0xF0000, 0x2); /*/ Tx mode*/
1856*4882a593Smuzhiyun 				phy_set_rf_reg(pAdapter, RF_PATH_A, 0x76, 0xF, 0x1); /*/ RF LO enabled*/
1857*4882a593Smuzhiyun 			}
1858*4882a593Smuzhiyun 		} else if (IS_HARDWARE_TYPE_8703B(pAdapter)) {
1859*4882a593Smuzhiyun 			if (pMptCtx->mpt_rf_path == RF_PATH_A) {
1860*4882a593Smuzhiyun 				phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC, 0xF0000, 0x2); /* Tx mode */
1861*4882a593Smuzhiyun 				phy_set_rf_reg(pAdapter, RF_PATH_A, 0x53, 0xF000, 0x1); /* RF LO enabled */
1862*4882a593Smuzhiyun 			}
1863*4882a593Smuzhiyun 		} else if (IS_HARDWARE_TYPE_8188F(pAdapter) || IS_HARDWARE_TYPE_8188GTV(pAdapter)) {
1864*4882a593Smuzhiyun 			/*Set BB REG 88C: Prevent SingleTone Fail*/
1865*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rFPGA0_AnalogParameter4, 0xF00000, 0xF);
1866*4882a593Smuzhiyun 			phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, lna_low_gain_3, BIT1, 0x1);
1867*4882a593Smuzhiyun 			phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, RF_AC, 0xF0000, 0x2);
1868*4882a593Smuzhiyun 
1869*4882a593Smuzhiyun 		} else if (IS_HARDWARE_TYPE_8723D(pAdapter)) {
1870*4882a593Smuzhiyun 			if (pMptCtx->mpt_rf_path == RF_PATH_A) {
1871*4882a593Smuzhiyun 				phy_set_bb_reg(pAdapter, rFPGA0_RFMOD, bCCKEn|bOFDMEn, 0);
1872*4882a593Smuzhiyun 				phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC, BIT16, 0x0);
1873*4882a593Smuzhiyun 				phy_set_rf_reg(pAdapter, RF_PATH_A, 0x53, BIT0, 0x1);
1874*4882a593Smuzhiyun 			} else {/* S0/S1 both use PATH A to configure */
1875*4882a593Smuzhiyun 				phy_set_bb_reg(pAdapter, rFPGA0_RFMOD, bCCKEn|bOFDMEn, 0);
1876*4882a593Smuzhiyun 				phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC, BIT16, 0x0);
1877*4882a593Smuzhiyun 				phy_set_rf_reg(pAdapter, RF_PATH_A, 0x63, BIT0, 0x1);
1878*4882a593Smuzhiyun 			}
1879*4882a593Smuzhiyun 		} else if (IS_HARDWARE_TYPE_JAGUAR(pAdapter) || IS_HARDWARE_TYPE_8822B(pAdapter) || IS_HARDWARE_TYPE_8821C(pAdapter)) {
1880*4882a593Smuzhiyun #if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A) || defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C)
1881*4882a593Smuzhiyun 			u8 p = RF_PATH_A;
1882*4882a593Smuzhiyun 
1883*4882a593Smuzhiyun 			regRF = phy_query_rf_reg(pAdapter, RF_PATH_A, RF_AC_Jaguar, bRFRegOffsetMask);
1884*4882a593Smuzhiyun 			regBB0 = phy_query_bb_reg(pAdapter, rA_RFE_Pinmux_Jaguar, bMaskDWord);
1885*4882a593Smuzhiyun 			regBB1 = phy_query_bb_reg(pAdapter, rB_RFE_Pinmux_Jaguar, bMaskDWord);
1886*4882a593Smuzhiyun 			regBB2 = phy_query_bb_reg(pAdapter, rA_RFE_Pinmux_Jaguar + 4, bMaskDWord);
1887*4882a593Smuzhiyun 			regBB3 = phy_query_bb_reg(pAdapter, rB_RFE_Pinmux_Jaguar + 4, bMaskDWord);
1888*4882a593Smuzhiyun 
1889*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rOFDMCCKEN_Jaguar, BIT29 | BIT28, 0x0); /*/ Disable CCK and OFDM*/
1890*4882a593Smuzhiyun 
1891*4882a593Smuzhiyun 			if (pMptCtx->mpt_rf_path == RF_PATH_AB) {
1892*4882a593Smuzhiyun 				for (p = RF_PATH_A; p <= RF_PATH_B; ++p) {
1893*4882a593Smuzhiyun 					phy_set_rf_reg(pAdapter, p, RF_AC_Jaguar, 0xF0000, 0x2); /*/ Tx mode: RF0x00[19:16]=4'b0010 */
1894*4882a593Smuzhiyun 					phy_set_rf_reg(pAdapter, p, RF_AC_Jaguar, 0x1F, 0x0); /*/ Lowest RF gain index: RF_0x0[4:0] = 0*/
1895*4882a593Smuzhiyun 					phy_set_rf_reg(pAdapter, p, lna_low_gain_3, BIT1, 0x1); /*/ RF LO enabled*/
1896*4882a593Smuzhiyun 				}
1897*4882a593Smuzhiyun 			} else {
1898*4882a593Smuzhiyun 				phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, RF_AC_Jaguar, 0xF0000, 0x2); /*/ Tx mode: RF0x00[19:16]=4'b0010 */
1899*4882a593Smuzhiyun 				phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, RF_AC_Jaguar, 0x1F, 0x0); /*/ Lowest RF gain index: RF_0x0[4:0] = 0*/
1900*4882a593Smuzhiyun #ifdef CONFIG_RTL8821C
1901*4882a593Smuzhiyun 				if (IS_HARDWARE_TYPE_8821C(pAdapter) && pDM_Odm->current_rf_set_8821c == SWITCH_TO_BTG)
1902*4882a593Smuzhiyun 					phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, 0x75, BIT16, 0x1); /* RF LO (for BTG) enabled */
1903*4882a593Smuzhiyun 				else
1904*4882a593Smuzhiyun #endif
1905*4882a593Smuzhiyun 					phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, lna_low_gain_3, BIT1, 0x1); /*/ RF LO enabled*/
1906*4882a593Smuzhiyun 			}
1907*4882a593Smuzhiyun 			if (IS_HARDWARE_TYPE_8822B(pAdapter)) {
1908*4882a593Smuzhiyun 					phy_set_bb_reg(pAdapter, rA_RFE_Pinmux_Jaguar, bMaskDWord, 0x77777777);  /* 0xCB0=0x77777777*/
1909*4882a593Smuzhiyun 					phy_set_bb_reg(pAdapter, rB_RFE_Pinmux_Jaguar, bMaskDWord, 0x77777777);  /* 0xEB0=0x77777777*/
1910*4882a593Smuzhiyun 					phy_set_bb_reg(pAdapter, rA_RFE_Pinmux_Jaguar + 4, bMaskLWord, 0x7777);  /* 0xCB4[15:0] = 0x7777*/
1911*4882a593Smuzhiyun 					phy_set_bb_reg(pAdapter, rB_RFE_Pinmux_Jaguar + 4, bMaskLWord, 0x7777);  /* 0xEB4[15:0] = 0x7777*/
1912*4882a593Smuzhiyun 					phy_set_bb_reg(pAdapter, rA_RFE_Inverse_Jaguar, 0xFFF, 0xb); /* 0xCBC[23:16] = 0x12*/
1913*4882a593Smuzhiyun 					phy_set_bb_reg(pAdapter, rB_RFE_Inverse_Jaguar, 0xFFF, 0x830); /* 0xEBC[23:16] = 0x12*/
1914*4882a593Smuzhiyun 			} else if (IS_HARDWARE_TYPE_8821C(pAdapter)) {
1915*4882a593Smuzhiyun 				phy_set_bb_reg(pAdapter, rA_RFE_Pinmux_Jaguar, 0xF0F0, 0x707);  /* 0xCB0[[15:12, 7:4] = 0x707*/
1916*4882a593Smuzhiyun 
1917*4882a593Smuzhiyun 				if (pHalData->external_pa_5g)
1918*4882a593Smuzhiyun 				{
1919*4882a593Smuzhiyun 					phy_set_bb_reg(pAdapter, rA_RFE_Pinmux_Jaguar + 4, 0xA00000, 0x1); /* 0xCB4[23, 21] = 0x1*/
1920*4882a593Smuzhiyun 				}
1921*4882a593Smuzhiyun 				else if (pHalData->ExternalPA_2G)
1922*4882a593Smuzhiyun 				{
1923*4882a593Smuzhiyun 					phy_set_bb_reg(pAdapter, rA_RFE_Pinmux_Jaguar + 4, 0xA00000, 0x1); /* 0xCB4[23, 21] = 0x1*/
1924*4882a593Smuzhiyun 				}
1925*4882a593Smuzhiyun 			} else {
1926*4882a593Smuzhiyun 				phy_set_bb_reg(pAdapter, rA_RFE_Pinmux_Jaguar, 0xFF00F0, 0x77007);  /*/ 0xCB0[[23:16, 7:4] = 0x77007*/
1927*4882a593Smuzhiyun 				phy_set_bb_reg(pAdapter, rB_RFE_Pinmux_Jaguar, 0xFF00F0, 0x77007);  /*/ 0xCB0[[23:16, 7:4] = 0x77007*/
1928*4882a593Smuzhiyun 
1929*4882a593Smuzhiyun 				if (pHalData->external_pa_5g) {
1930*4882a593Smuzhiyun 					phy_set_bb_reg(pAdapter, rA_RFE_Pinmux_Jaguar + 4, 0xFF00000, 0x12); /*/ 0xCB4[23:16] = 0x12*/
1931*4882a593Smuzhiyun 					phy_set_bb_reg(pAdapter, rB_RFE_Pinmux_Jaguar + 4, 0xFF00000, 0x12); /*/ 0xEB4[23:16] = 0x12*/
1932*4882a593Smuzhiyun 				} else if (pHalData->ExternalPA_2G) {
1933*4882a593Smuzhiyun 					phy_set_bb_reg(pAdapter, rA_RFE_Pinmux_Jaguar + 4, 0xFF00000, 0x11); /*/ 0xCB4[23:16] = 0x11*/
1934*4882a593Smuzhiyun 					phy_set_bb_reg(pAdapter, rB_RFE_Pinmux_Jaguar + 4, 0xFF00000, 0x11); /*/ 0xEB4[23:16] = 0x11*/
1935*4882a593Smuzhiyun 				}
1936*4882a593Smuzhiyun 			}
1937*4882a593Smuzhiyun #endif
1938*4882a593Smuzhiyun 		}
1939*4882a593Smuzhiyun #if defined(CONFIG_RTL8814A)
1940*4882a593Smuzhiyun 				else if (IS_HARDWARE_TYPE_8814A(pAdapter))
1941*4882a593Smuzhiyun 						mpt_SetSingleTone_8814A(pAdapter, TRUE, FALSE);
1942*4882a593Smuzhiyun #endif
1943*4882a593Smuzhiyun 		else	/*/ Turn On SingleTone and turn off the other test modes.*/
1944*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rOFDM1_LSTF, BIT30 | BIT29 | BIT28, OFDM_SingleTone);
1945*4882a593Smuzhiyun 
1946*4882a593Smuzhiyun 		write_bbreg(pAdapter, rFPGA0_XA_HSSIParameter1, bMaskDWord, 0x01000500);
1947*4882a593Smuzhiyun 		write_bbreg(pAdapter, rFPGA0_XB_HSSIParameter1, bMaskDWord, 0x01000500);
1948*4882a593Smuzhiyun 
1949*4882a593Smuzhiyun 	} else {/*/ Stop Single Ton e.*/
1950*4882a593Smuzhiyun 
1951*4882a593Smuzhiyun 		if (IS_HARDWARE_TYPE_8188E(pAdapter)) {
1952*4882a593Smuzhiyun 			phy_set_rf_reg(pAdapter, RF_PATH_A, lna_low_gain_3, bRFRegOffsetMask, regRF);
1953*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rFPGA0_RFMOD, bCCKEn, 0x1);
1954*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rFPGA0_RFMOD, bOFDMEn, 0x1);
1955*4882a593Smuzhiyun 		} else if (IS_HARDWARE_TYPE_8192E(pAdapter)) {
1956*4882a593Smuzhiyun 			phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, RF_AC, 0xF0000, 0x3);/*/ Tx mode*/
1957*4882a593Smuzhiyun 			phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, lna_low_gain_3, BIT1, 0x0);/*/ RF LO disabled */
1958*4882a593Smuzhiyun 			/*/ RESTORE MAC REG 88C: Enable RF Functions*/
1959*4882a593Smuzhiyun 			phy_set_mac_reg(pAdapter, 0x88C, 0xF00000, 0x0);
1960*4882a593Smuzhiyun 		} else if (IS_HARDWARE_TYPE_8192F(pAdapter)){
1961*4882a593Smuzhiyun #ifdef CONFIG_RTL8192F
1962*4882a593Smuzhiyun 			phy_set_mac_reg(pAdapter, REG_LEDCFG0_8192F, BIT23, 0x0);
1963*4882a593Smuzhiyun 			phy_set_mac_reg(pAdapter, REG_LEDCFG0_8192F, BIT26, 0x0);
1964*4882a593Smuzhiyun 			phy_set_mac_reg(pAdapter, REG_PAD_CTRL1_8192F, BIT7, 0x0);
1965*4882a593Smuzhiyun 			phy_set_mac_reg(pAdapter, REG_PAD_CTRL1_8192F, BIT1, 0x0);
1966*4882a593Smuzhiyun 			phy_set_mac_reg(pAdapter, REG_PAD_CTRL1_8192F, BIT0, 0x0);
1967*4882a593Smuzhiyun 			phy_set_mac_reg(pAdapter, REG_AFE_CTRL_4_8192F, BIT16, 0x0);
1968*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, 0x88C, 0xF00000, 0x0);
1969*4882a593Smuzhiyun 			phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, 0x57, BIT1, 0x0); /* RF LO disabled*/
1970*4882a593Smuzhiyun 			phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, RF_AC, 0xF0000, 0x3); /* Rx mode*/
1971*4882a593Smuzhiyun #endif
1972*4882a593Smuzhiyun 		} else if (IS_HARDWARE_TYPE_8723B(pAdapter)) {
1973*4882a593Smuzhiyun 			if (pMptCtx->mpt_rf_path == RF_PATH_A) {
1974*4882a593Smuzhiyun 				phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC, 0xF0000, 0x3); /*/ Rx mode*/
1975*4882a593Smuzhiyun 				phy_set_rf_reg(pAdapter, RF_PATH_A, 0x56, 0xF, 0x0); /*/ RF LO disabled*/
1976*4882a593Smuzhiyun 			} else {
1977*4882a593Smuzhiyun 				/*/ S0/S1 both use PATH A to configure*/
1978*4882a593Smuzhiyun 				phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC, 0xF0000, 0x3); /*/ Rx mode*/
1979*4882a593Smuzhiyun 				phy_set_rf_reg(pAdapter, RF_PATH_A, 0x76, 0xF, 0x0); /*/ RF LO disabled*/
1980*4882a593Smuzhiyun 			}
1981*4882a593Smuzhiyun 		} else if (IS_HARDWARE_TYPE_8703B(pAdapter)) {
1982*4882a593Smuzhiyun 			if (pMptCtx->mpt_rf_path == RF_PATH_A) {
1983*4882a593Smuzhiyun 				phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC, 0xF0000, 0x3); /* Rx mode */
1984*4882a593Smuzhiyun 				phy_set_rf_reg(pAdapter, RF_PATH_A, 0x53, 0xF000, 0x0); /* RF LO disabled */
1985*4882a593Smuzhiyun 			}
1986*4882a593Smuzhiyun 		} else if (IS_HARDWARE_TYPE_8188F(pAdapter) || IS_HARDWARE_TYPE_8188GTV(pAdapter)) {
1987*4882a593Smuzhiyun 			phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, RF_AC, 0xF0000, 0x3); /*Tx mode*/
1988*4882a593Smuzhiyun 			phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, lna_low_gain_3, BIT1, 0x0); /*RF LO disabled*/
1989*4882a593Smuzhiyun 			/*Set BB REG 88C: Prevent SingleTone Fail*/
1990*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rFPGA0_AnalogParameter4, 0xF00000, 0xc);
1991*4882a593Smuzhiyun 		} else if (IS_HARDWARE_TYPE_8723D(pAdapter)) {
1992*4882a593Smuzhiyun 			if (pMptCtx->mpt_rf_path == RF_PATH_A) {
1993*4882a593Smuzhiyun 				phy_set_bb_reg(pAdapter, rFPGA0_RFMOD, bCCKEn|bOFDMEn, 0x3);
1994*4882a593Smuzhiyun 				phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC, BIT16, 0x1);
1995*4882a593Smuzhiyun 				phy_set_rf_reg(pAdapter, RF_PATH_A, 0x53, BIT0, 0x0);
1996*4882a593Smuzhiyun 			} else {	/* S0/S1 both use PATH A to configure */
1997*4882a593Smuzhiyun 				phy_set_bb_reg(pAdapter, rFPGA0_RFMOD, bCCKEn|bOFDMEn, 0x3);
1998*4882a593Smuzhiyun 				phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC, BIT16, 0x1);
1999*4882a593Smuzhiyun 				phy_set_rf_reg(pAdapter, RF_PATH_A, 0x63, BIT0, 0x0);
2000*4882a593Smuzhiyun 			}
2001*4882a593Smuzhiyun 		} else if (IS_HARDWARE_TYPE_JAGUAR(pAdapter) || IS_HARDWARE_TYPE_8822B(pAdapter) || IS_HARDWARE_TYPE_8821C(pAdapter)) {
2002*4882a593Smuzhiyun #if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A) || defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C)
2003*4882a593Smuzhiyun 			u8 p = RF_PATH_A;
2004*4882a593Smuzhiyun 
2005*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rOFDMCCKEN_Jaguar, BIT29 | BIT28, 0x3); /*/ Disable CCK and OFDM*/
2006*4882a593Smuzhiyun 
2007*4882a593Smuzhiyun 			if (pMptCtx->mpt_rf_path == RF_PATH_AB) {
2008*4882a593Smuzhiyun 				for (p = RF_PATH_A; p <= RF_PATH_B; ++p) {
2009*4882a593Smuzhiyun 					phy_set_rf_reg(pAdapter, p, RF_AC_Jaguar, bRFRegOffsetMask, regRF);
2010*4882a593Smuzhiyun 					phy_set_rf_reg(pAdapter, p, lna_low_gain_3, BIT1, 0x0); /*/ RF LO disabled*/
2011*4882a593Smuzhiyun 				}
2012*4882a593Smuzhiyun 			} else {
2013*4882a593Smuzhiyun 				p = pMptCtx->mpt_rf_path;
2014*4882a593Smuzhiyun 				phy_set_rf_reg(pAdapter, p, RF_AC_Jaguar, bRFRegOffsetMask, regRF);
2015*4882a593Smuzhiyun 
2016*4882a593Smuzhiyun 				if (IS_HARDWARE_TYPE_8821C(pAdapter))
2017*4882a593Smuzhiyun 					phy_set_rf_reg(pAdapter, p, 0x75, BIT16, 0x0); /* RF LO (for BTG) disabled */
2018*4882a593Smuzhiyun 
2019*4882a593Smuzhiyun 				phy_set_rf_reg(pAdapter, p, lna_low_gain_3, BIT1, 0x0); /*/ RF LO disabled*/
2020*4882a593Smuzhiyun 			}
2021*4882a593Smuzhiyun 
2022*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rA_RFE_Pinmux_Jaguar, bMaskDWord, regBB0);
2023*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rB_RFE_Pinmux_Jaguar, bMaskDWord, regBB1);
2024*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rA_RFE_Pinmux_Jaguar + 4, bMaskDWord, regBB2);
2025*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rB_RFE_Pinmux_Jaguar + 4, bMaskDWord, regBB3);
2026*4882a593Smuzhiyun 
2027*4882a593Smuzhiyun 			if (IS_HARDWARE_TYPE_8822B(pAdapter)) {
2028*4882a593Smuzhiyun 				RTW_INFO("Restore RFE control Pin cbc\n");
2029*4882a593Smuzhiyun 				phy_set_bb_reg(pAdapter, rA_RFE_Inverse_Jaguar, 0xfff, 0x0);
2030*4882a593Smuzhiyun 				phy_set_bb_reg(pAdapter, rB_RFE_Inverse_Jaguar, 0xfff, 0x0);
2031*4882a593Smuzhiyun 			}
2032*4882a593Smuzhiyun #endif
2033*4882a593Smuzhiyun 		}
2034*4882a593Smuzhiyun #if defined(CONFIG_RTL8814A)
2035*4882a593Smuzhiyun 		else if (IS_HARDWARE_TYPE_8814A(pAdapter))
2036*4882a593Smuzhiyun 			mpt_SetSingleTone_8814A(pAdapter, FALSE, FALSE);
2037*4882a593Smuzhiyun 
2038*4882a593Smuzhiyun 		else/*/ Turn off all test modes.*/
2039*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, rSingleTone_ContTx_Jaguar, BIT18 | BIT17 | BIT16, OFDM_ALL_OFF);
2040*4882a593Smuzhiyun #endif
2041*4882a593Smuzhiyun 		write_bbreg(pAdapter, rFPGA0_XA_HSSIParameter1, bMaskDWord, 0x01000100);
2042*4882a593Smuzhiyun 		write_bbreg(pAdapter, rFPGA0_XB_HSSIParameter1, bMaskDWord, 0x01000100);
2043*4882a593Smuzhiyun 
2044*4882a593Smuzhiyun 	}
2045*4882a593Smuzhiyun }
2046*4882a593Smuzhiyun 
hal_mpt_SetCarrierSuppressionTx(PADAPTER pAdapter,u8 bStart)2047*4882a593Smuzhiyun void hal_mpt_SetCarrierSuppressionTx(PADAPTER pAdapter, u8 bStart)
2048*4882a593Smuzhiyun {
2049*4882a593Smuzhiyun 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
2050*4882a593Smuzhiyun 	struct dm_struct		*pdm_odm = &pHalData->odmpriv;
2051*4882a593Smuzhiyun 	u8 Rate;
2052*4882a593Smuzhiyun 
2053*4882a593Smuzhiyun 	pAdapter->mppriv.mpt_ctx.is_carrier_suppression = bStart;
2054*4882a593Smuzhiyun 
2055*4882a593Smuzhiyun 	if (IS_HARDWARE_TYPE_JAGUAR3(pAdapter)) {
2056*4882a593Smuzhiyun #ifdef PHYDM_MP_SUPPORT
2057*4882a593Smuzhiyun 		phydm_mp_set_carrier_supp(pdm_odm, bStart, pAdapter->mppriv.rateidx);
2058*4882a593Smuzhiyun #endif
2059*4882a593Smuzhiyun 		return;
2060*4882a593Smuzhiyun 	}
2061*4882a593Smuzhiyun 
2062*4882a593Smuzhiyun 	Rate = HwRateToMPTRate(pAdapter->mppriv.rateidx);
2063*4882a593Smuzhiyun 	if (bStart) {/* Start Carrier Suppression.*/
2064*4882a593Smuzhiyun 		if (Rate <= MPT_RATE_11M) {
2065*4882a593Smuzhiyun 			/*/ 1. if CCK block on?*/
2066*4882a593Smuzhiyun 			if (!read_bbreg(pAdapter, rFPGA0_RFMOD, bCCKEn))
2067*4882a593Smuzhiyun 				write_bbreg(pAdapter, rFPGA0_RFMOD, bCCKEn, bEnable);/*set CCK block on*/
2068*4882a593Smuzhiyun 
2069*4882a593Smuzhiyun 			/*/Turn Off All Test Mode*/
2070*4882a593Smuzhiyun 			if (IS_HARDWARE_TYPE_JAGUAR_ALL(pAdapter))
2071*4882a593Smuzhiyun 				phy_set_bb_reg(pAdapter, 0x914, BIT18 | BIT17 | BIT16, OFDM_ALL_OFF); /* rSingleTone_ContTx_Jaguar*/
2072*4882a593Smuzhiyun 			else
2073*4882a593Smuzhiyun 				phy_set_bb_reg(pAdapter, rOFDM1_LSTF, BIT30 | BIT29 | BIT28, OFDM_ALL_OFF);
2074*4882a593Smuzhiyun 
2075*4882a593Smuzhiyun 			write_bbreg(pAdapter, rCCK0_System, bCCKBBMode, 0x2);    /*/transmit mode*/
2076*4882a593Smuzhiyun 			write_bbreg(pAdapter, rCCK0_System, bCCKScramble, 0x0);  /*/turn off scramble setting*/
2077*4882a593Smuzhiyun 
2078*4882a593Smuzhiyun 			/*/Set CCK Tx Test Rate*/
2079*4882a593Smuzhiyun 			write_bbreg(pAdapter, rCCK0_System, bCCKTxRate, 0x0);    /*/Set FTxRate to 1Mbps*/
2080*4882a593Smuzhiyun 		}
2081*4882a593Smuzhiyun 
2082*4882a593Smuzhiyun 		/*Set for dynamic set Power index*/
2083*4882a593Smuzhiyun 		write_bbreg(pAdapter, rFPGA0_XA_HSSIParameter1, bMaskDWord, 0x01000500);
2084*4882a593Smuzhiyun 		write_bbreg(pAdapter, rFPGA0_XB_HSSIParameter1, bMaskDWord, 0x01000500);
2085*4882a593Smuzhiyun 
2086*4882a593Smuzhiyun 	} else {/* Stop Carrier Suppression.*/
2087*4882a593Smuzhiyun 
2088*4882a593Smuzhiyun 		if (Rate <= MPT_RATE_11M) {
2089*4882a593Smuzhiyun 			write_bbreg(pAdapter, rCCK0_System, bCCKBBMode, 0x0);    /*normal mode*/
2090*4882a593Smuzhiyun 			write_bbreg(pAdapter, rCCK0_System, bCCKScramble, 0x1);  /*turn on scramble setting*/
2091*4882a593Smuzhiyun 
2092*4882a593Smuzhiyun 			/*BB Reset*/
2093*4882a593Smuzhiyun 			write_bbreg(pAdapter, rPMAC_Reset, bBBResetB, 0x0);
2094*4882a593Smuzhiyun 			write_bbreg(pAdapter, rPMAC_Reset, bBBResetB, 0x1);
2095*4882a593Smuzhiyun 		}
2096*4882a593Smuzhiyun 		/*Stop for dynamic set Power index*/
2097*4882a593Smuzhiyun 		write_bbreg(pAdapter, rFPGA0_XA_HSSIParameter1, bMaskDWord, 0x01000100);
2098*4882a593Smuzhiyun 		write_bbreg(pAdapter, rFPGA0_XB_HSSIParameter1, bMaskDWord, 0x01000100);
2099*4882a593Smuzhiyun 	}
2100*4882a593Smuzhiyun 	RTW_INFO("\n MPT_ProSetCarrierSupp() is finished.\n");
2101*4882a593Smuzhiyun }
2102*4882a593Smuzhiyun 
hal_mpt_query_phytxok(PADAPTER pAdapter)2103*4882a593Smuzhiyun u32 hal_mpt_query_phytxok(PADAPTER	pAdapter)
2104*4882a593Smuzhiyun {
2105*4882a593Smuzhiyun 	PMPT_CONTEXT pMptCtx = &(pAdapter->mppriv.mpt_ctx);
2106*4882a593Smuzhiyun 	RT_PMAC_TX_INFO PMacTxInfo = pMptCtx->PMacTxInfo;
2107*4882a593Smuzhiyun 	HAL_DATA_TYPE			*pHalData	= GET_HAL_DATA(pAdapter);
2108*4882a593Smuzhiyun 	u16 count = 0;
2109*4882a593Smuzhiyun 
2110*4882a593Smuzhiyun #ifdef PHYDM_MP_SUPPORT
2111*4882a593Smuzhiyun 	struct dm_struct *dm = (struct dm_struct *)&pHalData->odmpriv;
2112*4882a593Smuzhiyun 	struct phydm_mp *mp = &dm->dm_mp_table;
2113*4882a593Smuzhiyun 
2114*4882a593Smuzhiyun 	if (IS_HARDWARE_TYPE_JAGUAR3(pAdapter)) {
2115*4882a593Smuzhiyun 		phydm_mp_get_tx_ok(&pHalData->odmpriv, pAdapter->mppriv.rateidx);
2116*4882a593Smuzhiyun 		count = mp->tx_phy_ok_cnt;
2117*4882a593Smuzhiyun 
2118*4882a593Smuzhiyun 	} else
2119*4882a593Smuzhiyun #endif
2120*4882a593Smuzhiyun 	{
2121*4882a593Smuzhiyun 
2122*4882a593Smuzhiyun 	if (IS_MPT_CCK_RATE(PMacTxInfo.TX_RATE))
2123*4882a593Smuzhiyun 		count = phy_query_bb_reg(pAdapter, 0xF50, bMaskLWord); /* [15:0]*/
2124*4882a593Smuzhiyun 	else
2125*4882a593Smuzhiyun 		count = phy_query_bb_reg(pAdapter, 0xF50, bMaskHWord); /* [31:16]*/
2126*4882a593Smuzhiyun 	}
2127*4882a593Smuzhiyun 
2128*4882a593Smuzhiyun 	if (count > 50000) {
2129*4882a593Smuzhiyun 		rtw_reset_phy_trx_ok_counters(pAdapter);
2130*4882a593Smuzhiyun 		pAdapter->mppriv.tx.sended += count;
2131*4882a593Smuzhiyun 		count = 0;
2132*4882a593Smuzhiyun 	}
2133*4882a593Smuzhiyun 
2134*4882a593Smuzhiyun 	return pAdapter->mppriv.tx.sended + count;
2135*4882a593Smuzhiyun 
2136*4882a593Smuzhiyun }
2137*4882a593Smuzhiyun 
mpt_StopCckContTx(PADAPTER pAdapter)2138*4882a593Smuzhiyun static	void mpt_StopCckContTx(
2139*4882a593Smuzhiyun 	PADAPTER	pAdapter
2140*4882a593Smuzhiyun )
2141*4882a593Smuzhiyun {
2142*4882a593Smuzhiyun 	HAL_DATA_TYPE	*pHalData	= GET_HAL_DATA(pAdapter);
2143*4882a593Smuzhiyun 	PMPT_CONTEXT	pMptCtx = &(pAdapter->mppriv.mpt_ctx);
2144*4882a593Smuzhiyun 	u8			u1bReg;
2145*4882a593Smuzhiyun 
2146*4882a593Smuzhiyun 	pMptCtx->bCckContTx = FALSE;
2147*4882a593Smuzhiyun 	pMptCtx->bOfdmContTx = FALSE;
2148*4882a593Smuzhiyun 
2149*4882a593Smuzhiyun 	phy_set_bb_reg(pAdapter, rCCK0_System, bCCKBBMode, 0x0);	/*normal mode*/
2150*4882a593Smuzhiyun 	phy_set_bb_reg(pAdapter, rCCK0_System, bCCKScramble, 0x1);	/*turn on scramble setting*/
2151*4882a593Smuzhiyun 
2152*4882a593Smuzhiyun 	if (!IS_HARDWARE_TYPE_JAGUAR_ALL(pAdapter)) {
2153*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, 0xa14, 0x300, 0x0);			/* 0xa15[1:0] = 2b00*/
2154*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rOFDM0_TRMuxPar, 0x10000, 0x0);		/* 0xc08[16] = 0*/
2155*4882a593Smuzhiyun 
2156*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rFPGA0_XA_HSSIParameter2, BIT14, 0);
2157*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rFPGA0_XB_HSSIParameter2, BIT14, 0);
2158*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, 0x0B34, BIT14, 0);
2159*4882a593Smuzhiyun 	}
2160*4882a593Smuzhiyun 
2161*4882a593Smuzhiyun 	/*BB Reset*/
2162*4882a593Smuzhiyun 	phy_set_bb_reg(pAdapter, rPMAC_Reset, bBBResetB, 0x0);
2163*4882a593Smuzhiyun 	phy_set_bb_reg(pAdapter, rPMAC_Reset, bBBResetB, 0x1);
2164*4882a593Smuzhiyun 
2165*4882a593Smuzhiyun 	if (!IS_HARDWARE_TYPE_JAGUAR_ALL(pAdapter)
2166*4882a593Smuzhiyun 		&& !IS_HARDWARE_TYPE_8723D(pAdapter) && !IS_HARDWARE_TYPE_8192F(pAdapter)
2167*4882a593Smuzhiyun 		&& !IS_HARDWARE_TYPE_8188F(pAdapter)) {
2168*4882a593Smuzhiyun 	phy_set_bb_reg(pAdapter, rFPGA0_XA_HSSIParameter1, bMaskDWord, 0x01000100);
2169*4882a593Smuzhiyun 	phy_set_bb_reg(pAdapter, rFPGA0_XB_HSSIParameter1, bMaskDWord, 0x01000100);
2170*4882a593Smuzhiyun 	}
2171*4882a593Smuzhiyun 
2172*4882a593Smuzhiyun 	if (IS_HARDWARE_TYPE_8188E(pAdapter) || IS_HARDWARE_TYPE_8723B(pAdapter) ||
2173*4882a593Smuzhiyun 		IS_HARDWARE_TYPE_8703B(pAdapter) || IS_HARDWARE_TYPE_8188F(pAdapter) ||
2174*4882a593Smuzhiyun 		IS_HARDWARE_TYPE_8723D(pAdapter) || IS_HARDWARE_TYPE_8192F(pAdapter) ||
2175*4882a593Smuzhiyun 		IS_HARDWARE_TYPE_8821C(pAdapter) || IS_HARDWARE_TYPE_8188GTV(pAdapter)) {
2176*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, 0xA70, BIT(14), bDisable);/* patch Count CCK adjust Rate*/
2177*4882a593Smuzhiyun 	}
2178*4882a593Smuzhiyun 
2179*4882a593Smuzhiyun }	/* mpt_StopCckContTx */
2180*4882a593Smuzhiyun 
2181*4882a593Smuzhiyun 
mpt_StopOfdmContTx(PADAPTER pAdapter)2182*4882a593Smuzhiyun static	void mpt_StopOfdmContTx(
2183*4882a593Smuzhiyun 	PADAPTER	pAdapter
2184*4882a593Smuzhiyun )
2185*4882a593Smuzhiyun {
2186*4882a593Smuzhiyun 	HAL_DATA_TYPE	*pHalData	= GET_HAL_DATA(pAdapter);
2187*4882a593Smuzhiyun 	PMPT_CONTEXT	pMptCtx = &(pAdapter->mppriv.mpt_ctx);
2188*4882a593Smuzhiyun 	u8			u1bReg;
2189*4882a593Smuzhiyun 	u32			data;
2190*4882a593Smuzhiyun 
2191*4882a593Smuzhiyun 	pMptCtx->bCckContTx = FALSE;
2192*4882a593Smuzhiyun 	pMptCtx->bOfdmContTx = FALSE;
2193*4882a593Smuzhiyun 
2194*4882a593Smuzhiyun 	if (IS_HARDWARE_TYPE_JAGUAR_ALL(pAdapter))
2195*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, 0x914, BIT18 | BIT17 | BIT16, OFDM_ALL_OFF);
2196*4882a593Smuzhiyun 	else
2197*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rOFDM1_LSTF, BIT30 | BIT29 | BIT28, OFDM_ALL_OFF);
2198*4882a593Smuzhiyun 
2199*4882a593Smuzhiyun 	rtw_mdelay_os(10);
2200*4882a593Smuzhiyun 
2201*4882a593Smuzhiyun 	if (!IS_HARDWARE_TYPE_JAGUAR_ALL(pAdapter)){
2202*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, 0xa14, 0x300, 0x0);			/* 0xa15[1:0] = 0*/
2203*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rOFDM0_TRMuxPar, 0x10000, 0x0);		/* 0xc08[16] = 0*/
2204*4882a593Smuzhiyun 	}
2205*4882a593Smuzhiyun 
2206*4882a593Smuzhiyun 	/*BB Reset*/
2207*4882a593Smuzhiyun 	phy_set_bb_reg(pAdapter, rPMAC_Reset, bBBResetB, 0x0);
2208*4882a593Smuzhiyun 	phy_set_bb_reg(pAdapter, rPMAC_Reset, bBBResetB, 0x1);
2209*4882a593Smuzhiyun 
2210*4882a593Smuzhiyun 	if (!IS_HARDWARE_TYPE_JAGUAR_ALL(pAdapter)
2211*4882a593Smuzhiyun 		&& !IS_HARDWARE_TYPE_8723D(pAdapter) && !IS_HARDWARE_TYPE_8192F(pAdapter)
2212*4882a593Smuzhiyun 		&& !IS_HARDWARE_TYPE_8188F(pAdapter)) {
2213*4882a593Smuzhiyun 	phy_set_bb_reg(pAdapter, rFPGA0_XA_HSSIParameter1, bMaskDWord, 0x01000100);
2214*4882a593Smuzhiyun 	phy_set_bb_reg(pAdapter, rFPGA0_XB_HSSIParameter1, bMaskDWord, 0x01000100);
2215*4882a593Smuzhiyun 	}
2216*4882a593Smuzhiyun }	/* mpt_StopOfdmContTx */
2217*4882a593Smuzhiyun 
2218*4882a593Smuzhiyun 
mpt_StartCckContTx(PADAPTER pAdapter)2219*4882a593Smuzhiyun static	void mpt_StartCckContTx(
2220*4882a593Smuzhiyun 	PADAPTER		pAdapter
2221*4882a593Smuzhiyun )
2222*4882a593Smuzhiyun {
2223*4882a593Smuzhiyun 	HAL_DATA_TYPE	*pHalData	= GET_HAL_DATA(pAdapter);
2224*4882a593Smuzhiyun 	PMPT_CONTEXT	pMptCtx = &(pAdapter->mppriv.mpt_ctx);
2225*4882a593Smuzhiyun 	u32			cckrate;
2226*4882a593Smuzhiyun 
2227*4882a593Smuzhiyun 	/* 1. if CCK block on */
2228*4882a593Smuzhiyun 	if (!phy_query_bb_reg(pAdapter, rFPGA0_RFMOD, bCCKEn))
2229*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rFPGA0_RFMOD, bCCKEn, 1);/*set CCK block on*/
2230*4882a593Smuzhiyun 
2231*4882a593Smuzhiyun 	/*Turn Off All Test Mode*/
2232*4882a593Smuzhiyun 	if (IS_HARDWARE_TYPE_JAGUAR_ALL(pAdapter))
2233*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, 0x914, BIT18 | BIT17 | BIT16, OFDM_ALL_OFF);
2234*4882a593Smuzhiyun 	else
2235*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rOFDM1_LSTF, BIT30 | BIT29 | BIT28, OFDM_ALL_OFF);
2236*4882a593Smuzhiyun 
2237*4882a593Smuzhiyun 	cckrate  = pAdapter->mppriv.rateidx;
2238*4882a593Smuzhiyun 
2239*4882a593Smuzhiyun 	phy_set_bb_reg(pAdapter, rCCK0_System, bCCKTxRate, cckrate);
2240*4882a593Smuzhiyun 
2241*4882a593Smuzhiyun 	phy_set_bb_reg(pAdapter, rCCK0_System, bCCKBBMode, 0x2);	/*transmit mode*/
2242*4882a593Smuzhiyun 	phy_set_bb_reg(pAdapter, rCCK0_System, bCCKScramble, 0x1);	/*turn on scramble setting*/
2243*4882a593Smuzhiyun 
2244*4882a593Smuzhiyun 	if (!IS_HARDWARE_TYPE_JAGUAR_ALL(pAdapter)) {
2245*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, 0xa14, 0x300, 0x3);			/* 0xa15[1:0] = 11 force cck rxiq = 0*/
2246*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rOFDM0_TRMuxPar, 0x10000, 0x1);		/* 0xc08[16] = 1 force ofdm rxiq = ofdm txiq*/
2247*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rFPGA0_XA_HSSIParameter2, BIT14, 1);
2248*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rFPGA0_XB_HSSIParameter2, BIT14, 1);
2249*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, 0x0B34, BIT14, 1);
2250*4882a593Smuzhiyun 	}
2251*4882a593Smuzhiyun 
2252*4882a593Smuzhiyun 	if (!IS_HARDWARE_TYPE_JAGUAR_ALL(pAdapter)
2253*4882a593Smuzhiyun 		&& !IS_HARDWARE_TYPE_8723D(pAdapter) && !IS_HARDWARE_TYPE_8192F(pAdapter)
2254*4882a593Smuzhiyun 		&& !IS_HARDWARE_TYPE_8188F(pAdapter)) {
2255*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rFPGA0_XA_HSSIParameter1, bMaskDWord, 0x01000500);
2256*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rFPGA0_XB_HSSIParameter1, bMaskDWord, 0x01000500);
2257*4882a593Smuzhiyun 	}
2258*4882a593Smuzhiyun 
2259*4882a593Smuzhiyun 	if (IS_HARDWARE_TYPE_8188E(pAdapter) || IS_HARDWARE_TYPE_8723B(pAdapter) ||
2260*4882a593Smuzhiyun 		IS_HARDWARE_TYPE_8703B(pAdapter) || IS_HARDWARE_TYPE_8188F(pAdapter) ||
2261*4882a593Smuzhiyun 		IS_HARDWARE_TYPE_8723D(pAdapter) || IS_HARDWARE_TYPE_8192F(pAdapter) ||
2262*4882a593Smuzhiyun 		IS_HARDWARE_TYPE_8821C(pAdapter) || IS_HARDWARE_TYPE_8188GTV(pAdapter)) {
2263*4882a593Smuzhiyun 		if (pAdapter->mppriv.rateidx == MPT_RATE_1M) /* patch Count CCK adjust Rate*/
2264*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, 0xA70, BIT(14), bDisable);
2265*4882a593Smuzhiyun 		else
2266*4882a593Smuzhiyun 			phy_set_bb_reg(pAdapter, 0xA70, BIT(14), bEnable);
2267*4882a593Smuzhiyun 	}
2268*4882a593Smuzhiyun 
2269*4882a593Smuzhiyun 	pMptCtx->bCckContTx = TRUE;
2270*4882a593Smuzhiyun 	pMptCtx->bOfdmContTx = FALSE;
2271*4882a593Smuzhiyun 
2272*4882a593Smuzhiyun }	/* mpt_StartCckContTx */
2273*4882a593Smuzhiyun 
2274*4882a593Smuzhiyun 
mpt_StartOfdmContTx(PADAPTER pAdapter)2275*4882a593Smuzhiyun static	void mpt_StartOfdmContTx(
2276*4882a593Smuzhiyun 	PADAPTER		pAdapter
2277*4882a593Smuzhiyun )
2278*4882a593Smuzhiyun {
2279*4882a593Smuzhiyun 	HAL_DATA_TYPE	*pHalData	= GET_HAL_DATA(pAdapter);
2280*4882a593Smuzhiyun 	PMPT_CONTEXT	pMptCtx = &(pAdapter->mppriv.mpt_ctx);
2281*4882a593Smuzhiyun 
2282*4882a593Smuzhiyun 	/* 1. if OFDM block on?*/
2283*4882a593Smuzhiyun 	if (!phy_query_bb_reg(pAdapter, rFPGA0_RFMOD, bOFDMEn))
2284*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rFPGA0_RFMOD, bOFDMEn, 1);/*set OFDM block on*/
2285*4882a593Smuzhiyun 
2286*4882a593Smuzhiyun 	/* 2. set CCK test mode off, set to CCK normal mode*/
2287*4882a593Smuzhiyun 	phy_set_bb_reg(pAdapter, rCCK0_System, bCCKBBMode, 0);
2288*4882a593Smuzhiyun 
2289*4882a593Smuzhiyun 	/* 3. turn on scramble setting*/
2290*4882a593Smuzhiyun 	phy_set_bb_reg(pAdapter, rCCK0_System, bCCKScramble, 1);
2291*4882a593Smuzhiyun 
2292*4882a593Smuzhiyun 	if (!IS_HARDWARE_TYPE_JAGUAR_ALL(pAdapter)) {
2293*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, 0xa14, 0x300, 0x3);			/* 0xa15[1:0] = 2b'11*/
2294*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rOFDM0_TRMuxPar, 0x10000, 0x1);		/* 0xc08[16] = 1*/
2295*4882a593Smuzhiyun 	}
2296*4882a593Smuzhiyun 
2297*4882a593Smuzhiyun 	/* 4. Turn On Continue Tx and turn off the other test modes.*/
2298*4882a593Smuzhiyun 	if (IS_HARDWARE_TYPE_JAGUAR_ALL(pAdapter))
2299*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, 0x914, BIT18 | BIT17 | BIT16, OFDM_ContinuousTx);
2300*4882a593Smuzhiyun 	else
2301*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rOFDM1_LSTF, BIT30 | BIT29 | BIT28, OFDM_ContinuousTx);
2302*4882a593Smuzhiyun 
2303*4882a593Smuzhiyun 	if (!IS_HARDWARE_TYPE_JAGUAR_ALL(pAdapter)
2304*4882a593Smuzhiyun 		&& !IS_HARDWARE_TYPE_8723D(pAdapter) && !IS_HARDWARE_TYPE_8192F(pAdapter)
2305*4882a593Smuzhiyun 		&& !IS_HARDWARE_TYPE_8188F(pAdapter)) {
2306*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rFPGA0_XA_HSSIParameter1, bMaskDWord, 0x01000500);
2307*4882a593Smuzhiyun 		phy_set_bb_reg(pAdapter, rFPGA0_XB_HSSIParameter1, bMaskDWord, 0x01000500);
2308*4882a593Smuzhiyun 	}
2309*4882a593Smuzhiyun 
2310*4882a593Smuzhiyun 	pMptCtx->bCckContTx = FALSE;
2311*4882a593Smuzhiyun 	pMptCtx->bOfdmContTx = TRUE;
2312*4882a593Smuzhiyun }	/* mpt_StartOfdmContTx */
2313*4882a593Smuzhiyun 
2314*4882a593Smuzhiyun #if defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8821B) || defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C)  || defined(CONFIG_RTL8822C) || defined(CONFIG_RTL8814B)
2315*4882a593Smuzhiyun #ifdef PHYDM_PMAC_TX_SETTING_SUPPORT
mpt_convert_phydm_txinfo_for_jaguar3(RT_PMAC_TX_INFO * pMacTxInfo,struct phydm_pmac_info * phydmtxinfo)2316*4882a593Smuzhiyun static void mpt_convert_phydm_txinfo_for_jaguar3(
2317*4882a593Smuzhiyun 	RT_PMAC_TX_INFO	*pMacTxInfo, struct phydm_pmac_info *phydmtxinfo)
2318*4882a593Smuzhiyun {
2319*4882a593Smuzhiyun 	phydmtxinfo->en_pmac_tx = pMacTxInfo->bEnPMacTx;
2320*4882a593Smuzhiyun 	phydmtxinfo->mode = pMacTxInfo->Mode;
2321*4882a593Smuzhiyun 	phydmtxinfo->tx_rate = MRateToHwRate(mpt_to_mgnt_rate(pMacTxInfo->TX_RATE));
2322*4882a593Smuzhiyun 	phydmtxinfo->tx_sc = pMacTxInfo->TX_SC;
2323*4882a593Smuzhiyun 	phydmtxinfo->is_short_preamble = pMacTxInfo->bSPreamble;
2324*4882a593Smuzhiyun 	phydmtxinfo->ndp_sound = pMacTxInfo->NDP_sound;
2325*4882a593Smuzhiyun 	phydmtxinfo->bw = pMacTxInfo->BandWidth;
2326*4882a593Smuzhiyun 	phydmtxinfo->m_stbc = pMacTxInfo->m_STBC;
2327*4882a593Smuzhiyun 	phydmtxinfo->packet_period = pMacTxInfo->PacketPeriod;
2328*4882a593Smuzhiyun 	phydmtxinfo->packet_count = pMacTxInfo->PacketCount;
2329*4882a593Smuzhiyun 	phydmtxinfo->packet_pattern = pMacTxInfo->PacketPattern;
2330*4882a593Smuzhiyun 	phydmtxinfo->sfd = pMacTxInfo->SFD;
2331*4882a593Smuzhiyun 	phydmtxinfo->signal_field = pMacTxInfo->SignalField;
2332*4882a593Smuzhiyun 	phydmtxinfo->service_field = pMacTxInfo->ServiceField;
2333*4882a593Smuzhiyun 	phydmtxinfo->length = pMacTxInfo->LENGTH;
2334*4882a593Smuzhiyun 	_rtw_memcpy(&phydmtxinfo->crc16,pMacTxInfo->CRC16, 2);
2335*4882a593Smuzhiyun 	_rtw_memcpy(&phydmtxinfo->lsig , pMacTxInfo->LSIG,3);
2336*4882a593Smuzhiyun 	_rtw_memcpy(&phydmtxinfo->ht_sig , pMacTxInfo->HT_SIG,6);
2337*4882a593Smuzhiyun 	_rtw_memcpy(&phydmtxinfo->vht_sig_a , pMacTxInfo->VHT_SIG_A,6);
2338*4882a593Smuzhiyun 	_rtw_memcpy(&phydmtxinfo->vht_sig_b , pMacTxInfo->VHT_SIG_B,4);
2339*4882a593Smuzhiyun 	phydmtxinfo->vht_sig_b_crc = pMacTxInfo->VHT_SIG_B_CRC;
2340*4882a593Smuzhiyun 	_rtw_memcpy(&phydmtxinfo->vht_delimiter,pMacTxInfo->VHT_Delimiter,4);
2341*4882a593Smuzhiyun }
2342*4882a593Smuzhiyun #endif
2343*4882a593Smuzhiyun 
2344*4882a593Smuzhiyun /* for HW TX mode */
mpt_ProSetPMacTx(PADAPTER Adapter)2345*4882a593Smuzhiyun u8 mpt_ProSetPMacTx(PADAPTER	Adapter)
2346*4882a593Smuzhiyun {
2347*4882a593Smuzhiyun 	HAL_DATA_TYPE	*pHalData	= GET_HAL_DATA(Adapter);
2348*4882a593Smuzhiyun 	PMPT_CONTEXT	pMptCtx		=	&(Adapter->mppriv.mpt_ctx);
2349*4882a593Smuzhiyun 	struct mp_priv *pmppriv = &Adapter->mppriv;
2350*4882a593Smuzhiyun 	struct hal_spec_t *hal_spec = GET_HAL_SPEC(Adapter);
2351*4882a593Smuzhiyun 	RT_PMAC_TX_INFO	PMacTxInfo	=	pMptCtx->PMacTxInfo;
2352*4882a593Smuzhiyun 	struct dm_struct *p_dm_odm;
2353*4882a593Smuzhiyun 	u32			u4bTmp;
2354*4882a593Smuzhiyun 	u8 status = _TRUE;
2355*4882a593Smuzhiyun 
2356*4882a593Smuzhiyun 	p_dm_odm = &pHalData->odmpriv;
2357*4882a593Smuzhiyun 
2358*4882a593Smuzhiyun #if 0
2359*4882a593Smuzhiyun 	PRINT_DATA("LSIG ", PMacTxInfo.LSIG, 3);
2360*4882a593Smuzhiyun 	PRINT_DATA("HT_SIG", PMacTxInfo.HT_SIG, 6);
2361*4882a593Smuzhiyun 	PRINT_DATA("VHT_SIG_A", PMacTxInfo.VHT_SIG_A, 6);
2362*4882a593Smuzhiyun 	PRINT_DATA("VHT_SIG_B", PMacTxInfo.VHT_SIG_B, 4);
2363*4882a593Smuzhiyun 	dbg_print("VHT_SIG_B_CRC %x\n", PMacTxInfo.VHT_SIG_B_CRC);
2364*4882a593Smuzhiyun 	PRINT_DATA("VHT_Delimiter", PMacTxInfo.VHT_Delimiter, 4);
2365*4882a593Smuzhiyun 
2366*4882a593Smuzhiyun 	PRINT_DATA("Src Address", Adapter->mac_addr, ETH_ALEN);
2367*4882a593Smuzhiyun 	PRINT_DATA("Dest Address", PMacTxInfo.MacAddress, ETH_ALEN);
2368*4882a593Smuzhiyun #endif
2369*4882a593Smuzhiyun 	if (pmppriv->pktInterval != 0)
2370*4882a593Smuzhiyun 		PMacTxInfo.PacketPeriod = pmppriv->pktInterval;
2371*4882a593Smuzhiyun 
2372*4882a593Smuzhiyun     	if (pmppriv->tx.count != 0)
2373*4882a593Smuzhiyun         	PMacTxInfo.PacketCount = pmppriv->tx.count;
2374*4882a593Smuzhiyun 
2375*4882a593Smuzhiyun 	RTW_INFO("SGI %d bSPreamble %d bSTBC %d bLDPC %d NDP_sound %d\n", PMacTxInfo.bSGI, PMacTxInfo.bSPreamble, PMacTxInfo.bSTBC, PMacTxInfo.bLDPC, PMacTxInfo.NDP_sound);
2376*4882a593Smuzhiyun 	RTW_INFO("TXSC %d BandWidth %d PacketPeriod %d PacketCount %d PacketLength %d PacketPattern %d\n", PMacTxInfo.TX_SC, PMacTxInfo.BandWidth, PMacTxInfo.PacketPeriod, PMacTxInfo.PacketCount,
2377*4882a593Smuzhiyun 		 PMacTxInfo.PacketLength, PMacTxInfo.PacketPattern);
2378*4882a593Smuzhiyun 
2379*4882a593Smuzhiyun 	if (hal_spec->tx_nss_num < 2 && MPT_IS_2SS_RATE(PMacTxInfo.TX_RATE))
2380*4882a593Smuzhiyun 		return _FALSE;
2381*4882a593Smuzhiyun 	if (hal_spec->tx_nss_num < 3 && MPT_IS_3SS_RATE(PMacTxInfo.TX_RATE))
2382*4882a593Smuzhiyun 		return _FALSE;
2383*4882a593Smuzhiyun 	if (hal_spec->tx_nss_num < 4 && MPT_IS_4SS_RATE(PMacTxInfo.TX_RATE))
2384*4882a593Smuzhiyun 		return _FALSE;
2385*4882a593Smuzhiyun 	if (!is_supported_vht(Adapter->registrypriv.wireless_mode) && MPT_IS_VHT_RATE(PMacTxInfo.TX_RATE))
2386*4882a593Smuzhiyun 		return _FALSE;
2387*4882a593Smuzhiyun 	if (!is_supported_ht(Adapter->registrypriv.wireless_mode) && MPT_IS_HT_RATE(PMacTxInfo.TX_RATE))
2388*4882a593Smuzhiyun 		return _FALSE;
2389*4882a593Smuzhiyun 
2390*4882a593Smuzhiyun 	if (PMacTxInfo.BandWidth == 1 && hal_chk_bw_cap(Adapter, BW_CAP_40M))
2391*4882a593Smuzhiyun 		PMacTxInfo.BandWidth = CHANNEL_WIDTH_40;
2392*4882a593Smuzhiyun 	else if (PMacTxInfo.BandWidth == 2 && hal_chk_bw_cap(Adapter, BW_CAP_80M))
2393*4882a593Smuzhiyun 		PMacTxInfo.BandWidth = CHANNEL_WIDTH_80;
2394*4882a593Smuzhiyun 	else
2395*4882a593Smuzhiyun 		PMacTxInfo.BandWidth = CHANNEL_WIDTH_20;
2396*4882a593Smuzhiyun 
2397*4882a593Smuzhiyun 	if (IS_HARDWARE_TYPE_JAGUAR3(Adapter)) {
2398*4882a593Smuzhiyun #ifdef PHYDM_PMAC_TX_SETTING_SUPPORT
2399*4882a593Smuzhiyun 		struct phydm_pmac_info phydm_mactxinfo;
2400*4882a593Smuzhiyun 
2401*4882a593Smuzhiyun 		if (PMacTxInfo.bEnPMacTx == TRUE) {
2402*4882a593Smuzhiyun 			pMptCtx->HWTxmode = PMacTxInfo.Mode;
2403*4882a593Smuzhiyun 			pMptCtx->mpt_rate_index = PMacTxInfo.TX_RATE;
2404*4882a593Smuzhiyun 			if (PMacTxInfo.Mode == CONTINUOUS_TX)
2405*4882a593Smuzhiyun 				hal_mpt_SetTxPower(Adapter);
2406*4882a593Smuzhiyun 		} else {
2407*4882a593Smuzhiyun 			PMacTxInfo.Mode = pMptCtx->HWTxmode;
2408*4882a593Smuzhiyun 			PMacTxInfo.TX_RATE = pMptCtx->mpt_rate_index;
2409*4882a593Smuzhiyun 			pMptCtx->HWTxmode = TEST_NONE;
2410*4882a593Smuzhiyun 		}
2411*4882a593Smuzhiyun 		mpt_convert_phydm_txinfo_for_jaguar3(&PMacTxInfo, &phydm_mactxinfo);
2412*4882a593Smuzhiyun 		phydm_set_pmac_tx(p_dm_odm, &phydm_mactxinfo, pMptCtx->mpt_rf_path);
2413*4882a593Smuzhiyun #endif
2414*4882a593Smuzhiyun 		return status;
2415*4882a593Smuzhiyun 	}
2416*4882a593Smuzhiyun 
2417*4882a593Smuzhiyun 	if (PMacTxInfo.bEnPMacTx == FALSE) {
2418*4882a593Smuzhiyun 		if (pMptCtx->HWTxmode == CONTINUOUS_TX) {
2419*4882a593Smuzhiyun 			phy_set_bb_reg(Adapter, 0xb04, 0xf, 2);			/*	TX Stop*/
2420*4882a593Smuzhiyun 			if (IS_MPT_CCK_RATE(pMptCtx->mpt_rate_index))
2421*4882a593Smuzhiyun 				mpt_StopCckContTx(Adapter);
2422*4882a593Smuzhiyun 			else
2423*4882a593Smuzhiyun 				mpt_StopOfdmContTx(Adapter);
2424*4882a593Smuzhiyun 		} else if (IS_MPT_CCK_RATE(pMptCtx->mpt_rate_index)) {
2425*4882a593Smuzhiyun 			u4bTmp = phy_query_bb_reg(Adapter, 0xf50, bMaskLWord);
2426*4882a593Smuzhiyun 			phy_set_bb_reg(Adapter, 0xb1c, bMaskLWord, u4bTmp + 50);
2427*4882a593Smuzhiyun 			phy_set_bb_reg(Adapter, 0xb04, 0xf, 2);		/*TX Stop*/
2428*4882a593Smuzhiyun 		} else
2429*4882a593Smuzhiyun 			phy_set_bb_reg(Adapter, 0xb04, 0xf, 2);		/*	TX Stop*/
2430*4882a593Smuzhiyun 
2431*4882a593Smuzhiyun 		if (pMptCtx->HWTxmode == OFDM_Single_Tone_TX) {
2432*4882a593Smuzhiyun 			/* Stop HW TX -> Stop Continuous TX -> Stop RF Setting*/
2433*4882a593Smuzhiyun 			if (IS_MPT_CCK_RATE(pMptCtx->mpt_rate_index))
2434*4882a593Smuzhiyun 				mpt_StopCckContTx(Adapter);
2435*4882a593Smuzhiyun 			else
2436*4882a593Smuzhiyun 				mpt_StopOfdmContTx(Adapter);
2437*4882a593Smuzhiyun 
2438*4882a593Smuzhiyun 			mpt_SetSingleTone_8814A(Adapter, FALSE, TRUE);
2439*4882a593Smuzhiyun 		}
2440*4882a593Smuzhiyun 		pMptCtx->HWTxmode = TEST_NONE;
2441*4882a593Smuzhiyun 		return status;
2442*4882a593Smuzhiyun 	}
2443*4882a593Smuzhiyun 
2444*4882a593Smuzhiyun     	pMptCtx->mpt_rate_index = PMacTxInfo.TX_RATE;
2445*4882a593Smuzhiyun 
2446*4882a593Smuzhiyun 	if (PMacTxInfo.Mode == CONTINUOUS_TX) {
2447*4882a593Smuzhiyun 		pMptCtx->HWTxmode = CONTINUOUS_TX;
2448*4882a593Smuzhiyun 		PMacTxInfo.PacketCount = 1;
2449*4882a593Smuzhiyun 
2450*4882a593Smuzhiyun         	hal_mpt_SetTxPower(Adapter);
2451*4882a593Smuzhiyun 
2452*4882a593Smuzhiyun 		if (IS_MPT_CCK_RATE(PMacTxInfo.TX_RATE))
2453*4882a593Smuzhiyun 			mpt_StartCckContTx(Adapter);
2454*4882a593Smuzhiyun 		else
2455*4882a593Smuzhiyun 			mpt_StartOfdmContTx(Adapter);
2456*4882a593Smuzhiyun 	} else if (PMacTxInfo.Mode == OFDM_Single_Tone_TX) {
2457*4882a593Smuzhiyun 		/* Continuous TX -> HW TX -> RF Setting */
2458*4882a593Smuzhiyun 		pMptCtx->HWTxmode = OFDM_Single_Tone_TX;
2459*4882a593Smuzhiyun 		PMacTxInfo.PacketCount = 1;
2460*4882a593Smuzhiyun 
2461*4882a593Smuzhiyun 		if (IS_MPT_CCK_RATE(PMacTxInfo.TX_RATE))
2462*4882a593Smuzhiyun 			mpt_StartCckContTx(Adapter);
2463*4882a593Smuzhiyun 		else
2464*4882a593Smuzhiyun 			mpt_StartOfdmContTx(Adapter);
2465*4882a593Smuzhiyun 	} else if (PMacTxInfo.Mode == PACKETS_TX) {
2466*4882a593Smuzhiyun 		pMptCtx->HWTxmode = PACKETS_TX;
2467*4882a593Smuzhiyun 		if (IS_MPT_CCK_RATE(PMacTxInfo.TX_RATE) && PMacTxInfo.PacketCount == 0)
2468*4882a593Smuzhiyun 			PMacTxInfo.PacketCount = 0xffff;
2469*4882a593Smuzhiyun 	}
2470*4882a593Smuzhiyun 
2471*4882a593Smuzhiyun 	if (IS_MPT_CCK_RATE(PMacTxInfo.TX_RATE)) {
2472*4882a593Smuzhiyun 		/* 0xb1c[0:15] TX packet count 0xb1C[31:16]	SFD*/
2473*4882a593Smuzhiyun 		u4bTmp = PMacTxInfo.PacketCount | (PMacTxInfo.SFD << 16);
2474*4882a593Smuzhiyun 		phy_set_bb_reg(Adapter, 0xb1c, bMaskDWord, u4bTmp);
2475*4882a593Smuzhiyun 		/* 0xb40 7:0 SIGNAL	15:8 SERVICE	31:16 LENGTH*/
2476*4882a593Smuzhiyun 		u4bTmp = PMacTxInfo.SignalField | (PMacTxInfo.ServiceField << 8) | (PMacTxInfo.LENGTH << 16);
2477*4882a593Smuzhiyun 		phy_set_bb_reg(Adapter, 0xb40, bMaskDWord, u4bTmp);
2478*4882a593Smuzhiyun 		u4bTmp = PMacTxInfo.CRC16[0] | (PMacTxInfo.CRC16[1] << 8);
2479*4882a593Smuzhiyun 		phy_set_bb_reg(Adapter, 0xb44, bMaskLWord, u4bTmp);
2480*4882a593Smuzhiyun 
2481*4882a593Smuzhiyun 		if (PMacTxInfo.bSPreamble)
2482*4882a593Smuzhiyun 			phy_set_bb_reg(Adapter, 0xb0c, BIT27, 0);
2483*4882a593Smuzhiyun 		else
2484*4882a593Smuzhiyun 			phy_set_bb_reg(Adapter, 0xb0c, BIT27, 1);
2485*4882a593Smuzhiyun 	} else {
2486*4882a593Smuzhiyun 		phy_set_bb_reg(Adapter, 0xb18, 0xfffff, PMacTxInfo.PacketCount);
2487*4882a593Smuzhiyun 
2488*4882a593Smuzhiyun 		u4bTmp = PMacTxInfo.LSIG[0] | ((PMacTxInfo.LSIG[1]) << 8) | ((PMacTxInfo.LSIG[2]) << 16) | ((PMacTxInfo.PacketPattern) << 24);
2489*4882a593Smuzhiyun 		phy_set_bb_reg(Adapter, 0xb08, bMaskDWord, u4bTmp);	/*	Set 0xb08[23:0] = LSIG, 0xb08[31:24] =  Data init octet*/
2490*4882a593Smuzhiyun 
2491*4882a593Smuzhiyun 		if (PMacTxInfo.PacketPattern == 0x12)
2492*4882a593Smuzhiyun 			u4bTmp = 0x3000000;
2493*4882a593Smuzhiyun 		else
2494*4882a593Smuzhiyun 			u4bTmp = 0;
2495*4882a593Smuzhiyun 	}
2496*4882a593Smuzhiyun 
2497*4882a593Smuzhiyun 	if (IS_MPT_HT_RATE(PMacTxInfo.TX_RATE)) {
2498*4882a593Smuzhiyun 		u4bTmp |= PMacTxInfo.HT_SIG[0] | ((PMacTxInfo.HT_SIG[1]) << 8) | ((PMacTxInfo.HT_SIG[2]) << 16);
2499*4882a593Smuzhiyun 		phy_set_bb_reg(Adapter, 0xb0c, bMaskDWord, u4bTmp);
2500*4882a593Smuzhiyun 		u4bTmp = PMacTxInfo.HT_SIG[3] | ((PMacTxInfo.HT_SIG[4]) << 8) | ((PMacTxInfo.HT_SIG[5]) << 16);
2501*4882a593Smuzhiyun 		phy_set_bb_reg(Adapter, 0xb10, 0xffffff, u4bTmp);
2502*4882a593Smuzhiyun 	} else if (IS_MPT_VHT_RATE(PMacTxInfo.TX_RATE)) {
2503*4882a593Smuzhiyun 		u4bTmp |= PMacTxInfo.VHT_SIG_A[0] | ((PMacTxInfo.VHT_SIG_A[1]) << 8) | ((PMacTxInfo.VHT_SIG_A[2]) << 16);
2504*4882a593Smuzhiyun 		phy_set_bb_reg(Adapter, 0xb0c, bMaskDWord, u4bTmp);
2505*4882a593Smuzhiyun 		u4bTmp = PMacTxInfo.VHT_SIG_A[3] | ((PMacTxInfo.VHT_SIG_A[4]) << 8) | ((PMacTxInfo.VHT_SIG_A[5]) << 16);
2506*4882a593Smuzhiyun 		phy_set_bb_reg(Adapter, 0xb10, 0xffffff, u4bTmp);
2507*4882a593Smuzhiyun 
2508*4882a593Smuzhiyun 		_rtw_memcpy(&u4bTmp, PMacTxInfo.VHT_SIG_B, 4);
2509*4882a593Smuzhiyun 		phy_set_bb_reg(Adapter, 0xb14, bMaskDWord, u4bTmp);
2510*4882a593Smuzhiyun 	}
2511*4882a593Smuzhiyun 
2512*4882a593Smuzhiyun 	if (IS_MPT_VHT_RATE(PMacTxInfo.TX_RATE)) {
2513*4882a593Smuzhiyun 		u4bTmp = (PMacTxInfo.VHT_SIG_B_CRC << 24) | PMacTxInfo.PacketPeriod;	/* for TX interval */
2514*4882a593Smuzhiyun 		phy_set_bb_reg(Adapter, 0xb20, bMaskDWord, u4bTmp);
2515*4882a593Smuzhiyun 
2516*4882a593Smuzhiyun 		_rtw_memcpy(&u4bTmp, PMacTxInfo.VHT_Delimiter, 4);
2517*4882a593Smuzhiyun 		phy_set_bb_reg(Adapter, 0xb24, bMaskDWord, u4bTmp);
2518*4882a593Smuzhiyun 
2519*4882a593Smuzhiyun 		/* 0xb28 - 0xb34 24 byte Probe Request MAC Header*/
2520*4882a593Smuzhiyun 		/*& Duration & Frame control*/
2521*4882a593Smuzhiyun 		phy_set_bb_reg(Adapter, 0xb28, bMaskDWord, 0x00000040);
2522*4882a593Smuzhiyun 
2523*4882a593Smuzhiyun 		/* Address1 [0:3]*/
2524*4882a593Smuzhiyun 		u4bTmp = PMacTxInfo.MacAddress[0] | (PMacTxInfo.MacAddress[1] << 8) | (PMacTxInfo.MacAddress[2] << 16) | (PMacTxInfo.MacAddress[3] << 24);
2525*4882a593Smuzhiyun 		phy_set_bb_reg(Adapter, 0xb2C, bMaskDWord, u4bTmp);
2526*4882a593Smuzhiyun 
2527*4882a593Smuzhiyun 		/* Address3 [3:0]*/
2528*4882a593Smuzhiyun 		phy_set_bb_reg(Adapter, 0xb38, bMaskDWord, u4bTmp);
2529*4882a593Smuzhiyun 
2530*4882a593Smuzhiyun 		/* Address2[0:1] & Address1 [5:4]*/
2531*4882a593Smuzhiyun 		u4bTmp = PMacTxInfo.MacAddress[4] | (PMacTxInfo.MacAddress[5] << 8) | (Adapter->mac_addr[0] << 16) | (Adapter->mac_addr[1] << 24);
2532*4882a593Smuzhiyun 		phy_set_bb_reg(Adapter, 0xb30, bMaskDWord, u4bTmp);
2533*4882a593Smuzhiyun 
2534*4882a593Smuzhiyun 		/* Address2 [5:2]*/
2535*4882a593Smuzhiyun 		u4bTmp = Adapter->mac_addr[2] | (Adapter->mac_addr[3] << 8) | (Adapter->mac_addr[4] << 16) | (Adapter->mac_addr[5] << 24);
2536*4882a593Smuzhiyun 		phy_set_bb_reg(Adapter, 0xb34, bMaskDWord, u4bTmp);
2537*4882a593Smuzhiyun 
2538*4882a593Smuzhiyun 		/* Sequence Control & Address3 [5:4]*/
2539*4882a593Smuzhiyun 		/*u4bTmp = PMacTxInfo.MacAddress[4]|(PMacTxInfo.MacAddress[5] << 8) ;*/
2540*4882a593Smuzhiyun 		/*phy_set_bb_reg(Adapter, 0xb38, bMaskDWord, u4bTmp);*/
2541*4882a593Smuzhiyun 	} else {
2542*4882a593Smuzhiyun 		phy_set_bb_reg(Adapter, 0xb20, bMaskDWord, PMacTxInfo.PacketPeriod);	/* for TX interval*/
2543*4882a593Smuzhiyun 		/* & Duration & Frame control */
2544*4882a593Smuzhiyun 		phy_set_bb_reg(Adapter, 0xb24, bMaskDWord, 0x00000040);
2545*4882a593Smuzhiyun 
2546*4882a593Smuzhiyun 		/* 0xb24 - 0xb38 24 byte Probe Request MAC Header*/
2547*4882a593Smuzhiyun 		/* Address1 [0:3]*/
2548*4882a593Smuzhiyun 		u4bTmp = PMacTxInfo.MacAddress[0] | (PMacTxInfo.MacAddress[1] << 8) | (PMacTxInfo.MacAddress[2] << 16) | (PMacTxInfo.MacAddress[3] << 24);
2549*4882a593Smuzhiyun 		phy_set_bb_reg(Adapter, 0xb28, bMaskDWord, u4bTmp);
2550*4882a593Smuzhiyun 
2551*4882a593Smuzhiyun 		/* Address3 [3:0]*/
2552*4882a593Smuzhiyun 		phy_set_bb_reg(Adapter, 0xb34, bMaskDWord, u4bTmp);
2553*4882a593Smuzhiyun 
2554*4882a593Smuzhiyun 		/* Address2[0:1] & Address1 [5:4]*/
2555*4882a593Smuzhiyun 		u4bTmp = PMacTxInfo.MacAddress[4] | (PMacTxInfo.MacAddress[5] << 8) | (Adapter->mac_addr[0] << 16) | (Adapter->mac_addr[1] << 24);
2556*4882a593Smuzhiyun 		phy_set_bb_reg(Adapter, 0xb2c, bMaskDWord, u4bTmp);
2557*4882a593Smuzhiyun 
2558*4882a593Smuzhiyun 		/* Address2 [5:2] */
2559*4882a593Smuzhiyun 		u4bTmp = Adapter->mac_addr[2] | (Adapter->mac_addr[3] << 8) | (Adapter->mac_addr[4] << 16) | (Adapter->mac_addr[5] << 24);
2560*4882a593Smuzhiyun 		phy_set_bb_reg(Adapter, 0xb30, bMaskDWord, u4bTmp);
2561*4882a593Smuzhiyun 
2562*4882a593Smuzhiyun 		/* Sequence Control & Address3 [5:4]*/
2563*4882a593Smuzhiyun 		u4bTmp = PMacTxInfo.MacAddress[4] | (PMacTxInfo.MacAddress[5] << 8);
2564*4882a593Smuzhiyun 		phy_set_bb_reg(Adapter, 0xb38, bMaskDWord, u4bTmp);
2565*4882a593Smuzhiyun 	}
2566*4882a593Smuzhiyun 
2567*4882a593Smuzhiyun 	phy_set_bb_reg(Adapter, 0xb48, bMaskByte3, PMacTxInfo.TX_RATE_HEX);
2568*4882a593Smuzhiyun 
2569*4882a593Smuzhiyun 	/* 0xb4c 3:0 TXSC	5:4	BW	7:6 m_STBC	8 NDP_Sound*/
2570*4882a593Smuzhiyun 	u4bTmp = (PMacTxInfo.TX_SC) | ((PMacTxInfo.BandWidth) << 4) | ((PMacTxInfo.m_STBC - 1) << 6) | ((PMacTxInfo.NDP_sound) << 8);
2571*4882a593Smuzhiyun 	phy_set_bb_reg(Adapter, 0xb4c, 0x1ff, u4bTmp);
2572*4882a593Smuzhiyun 
2573*4882a593Smuzhiyun 	if (IS_HARDWARE_TYPE_JAGUAR2(Adapter)) {
2574*4882a593Smuzhiyun 		u32 offset = 0xb44;
2575*4882a593Smuzhiyun 
2576*4882a593Smuzhiyun 		if (IS_MPT_OFDM_RATE(PMacTxInfo.TX_RATE))
2577*4882a593Smuzhiyun 			phy_set_bb_reg(Adapter, offset, 0xc0000000, 0);
2578*4882a593Smuzhiyun 		else if (IS_MPT_HT_RATE(PMacTxInfo.TX_RATE))
2579*4882a593Smuzhiyun 			phy_set_bb_reg(Adapter, offset, 0xc0000000, 1);
2580*4882a593Smuzhiyun 		else if (IS_MPT_VHT_RATE(PMacTxInfo.TX_RATE))
2581*4882a593Smuzhiyun 			phy_set_bb_reg(Adapter, offset, 0xc0000000, 2);
2582*4882a593Smuzhiyun 
2583*4882a593Smuzhiyun 	} else if(IS_HARDWARE_TYPE_JAGUAR(Adapter)) {
2584*4882a593Smuzhiyun 		u32 offset = 0xb4c;
2585*4882a593Smuzhiyun 
2586*4882a593Smuzhiyun 		if(IS_MPT_OFDM_RATE(PMacTxInfo.TX_RATE))
2587*4882a593Smuzhiyun 			phy_set_bb_reg(Adapter, offset, 0xc0000000, 0);
2588*4882a593Smuzhiyun 		else if(IS_MPT_HT_RATE(PMacTxInfo.TX_RATE))
2589*4882a593Smuzhiyun 			phy_set_bb_reg(Adapter, offset, 0xc0000000, 1);
2590*4882a593Smuzhiyun 		else if(IS_MPT_VHT_RATE(PMacTxInfo.TX_RATE))
2591*4882a593Smuzhiyun 			phy_set_bb_reg(Adapter, offset, 0xc0000000, 2);
2592*4882a593Smuzhiyun 	}
2593*4882a593Smuzhiyun 
2594*4882a593Smuzhiyun 	phy_set_bb_reg(Adapter, 0xb00, BIT8, 1);		/*	Turn on PMAC*/
2595*4882a593Smuzhiyun 	/* phy_set_bb_reg(Adapter, 0xb04, 0xf, 2);				 */ /* TX Stop */
2596*4882a593Smuzhiyun 	if (IS_MPT_CCK_RATE(PMacTxInfo.TX_RATE)) {
2597*4882a593Smuzhiyun 		phy_set_bb_reg(Adapter, 0xb04, 0xf, 8);		/*TX CCK ON*/
2598*4882a593Smuzhiyun 		phy_set_bb_reg(Adapter, 0xA84, BIT31, 0);
2599*4882a593Smuzhiyun 	} else
2600*4882a593Smuzhiyun 		phy_set_bb_reg(Adapter, 0xb04, 0xf, 4);		/*	TX Ofdm ON	*/
2601*4882a593Smuzhiyun 
2602*4882a593Smuzhiyun 	if (PMacTxInfo.Mode == OFDM_Single_Tone_TX)
2603*4882a593Smuzhiyun 		mpt_SetSingleTone_8814A(Adapter, TRUE, TRUE);
2604*4882a593Smuzhiyun 
2605*4882a593Smuzhiyun 	return status;
2606*4882a593Smuzhiyun }
2607*4882a593Smuzhiyun 
2608*4882a593Smuzhiyun #endif
2609*4882a593Smuzhiyun 
hal_mpt_SetContinuousTx(PADAPTER pAdapter,u8 bStart)2610*4882a593Smuzhiyun void hal_mpt_SetContinuousTx(PADAPTER pAdapter, u8 bStart)
2611*4882a593Smuzhiyun {
2612*4882a593Smuzhiyun 	u8 Rate;
2613*4882a593Smuzhiyun 
2614*4882a593Smuzhiyun 	RTW_INFO("SetContinuousTx: rate:%d\n", pAdapter->mppriv.rateidx);
2615*4882a593Smuzhiyun 	Rate = HwRateToMPTRate(pAdapter->mppriv.rateidx);
2616*4882a593Smuzhiyun 	pAdapter->mppriv.mpt_ctx.is_start_cont_tx = bStart;
2617*4882a593Smuzhiyun 
2618*4882a593Smuzhiyun 	if (Rate <= MPT_RATE_11M) {
2619*4882a593Smuzhiyun 		if (bStart)
2620*4882a593Smuzhiyun 			mpt_StartCckContTx(pAdapter);
2621*4882a593Smuzhiyun 		else
2622*4882a593Smuzhiyun 			mpt_StopCckContTx(pAdapter);
2623*4882a593Smuzhiyun 
2624*4882a593Smuzhiyun 	} else if (Rate >= MPT_RATE_6M) {
2625*4882a593Smuzhiyun 		if (bStart)
2626*4882a593Smuzhiyun 			mpt_StartOfdmContTx(pAdapter);
2627*4882a593Smuzhiyun 		else
2628*4882a593Smuzhiyun 			mpt_StopOfdmContTx(pAdapter);
2629*4882a593Smuzhiyun 	}
2630*4882a593Smuzhiyun }
2631*4882a593Smuzhiyun 
mpt_trigger_tssi_tracking(PADAPTER pAdapter,u8 rf_path)2632*4882a593Smuzhiyun void mpt_trigger_tssi_tracking(PADAPTER pAdapter, u8 rf_path)
2633*4882a593Smuzhiyun {
2634*4882a593Smuzhiyun #ifdef CONFIG_RTL8814B
2635*4882a593Smuzhiyun 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
2636*4882a593Smuzhiyun 	struct dm_struct		*pDM_Odm = &pHalData->odmpriv;
2637*4882a593Smuzhiyun 
2638*4882a593Smuzhiyun 	halrf_do_tssi_8814b(pDM_Odm, rf_path);
2639*4882a593Smuzhiyun #endif
2640*4882a593Smuzhiyun }
2641*4882a593Smuzhiyun 
2642*4882a593Smuzhiyun #endif /* CONFIG_MP_INCLUDE*/
2643