diff --git a/hal/OUTSRC/rtl8812a/HalPhyRf_8812A.c b/hal/OUTSRC/rtl8812a/HalPhyRf_8812A.c index 885fd1b..5ca523d 100644 --- a/hal/OUTSRC/rtl8812a/HalPhyRf_8812A.c +++ b/hal/OUTSRC/rtl8812a/HalPhyRf_8812A.c @@ -37,7 +37,7 @@ void DoIQK_8812A( PDM_ODM_T pDM_Odm, u1Byte DeltaThermalIndex, - u1Byte ThermalValue, + u1Byte ThermalValue, u1Byte Threshold ) { @@ -46,10 +46,10 @@ void DoIQK_8812A( HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter); #endif - ODM_ResetIQKResult(pDM_Odm); + ODM_ResetIQKResult(pDM_Odm); #if(DM_ODM_SUPPORT_TYPE & ODM_WIN) -#if (DEV_BUS_TYPE == RT_PCI_INTERFACE) +#if (DEV_BUS_TYPE == RT_PCI_INTERFACE) #if USE_WORKITEM PlatformAcquireMutex(&pHalData->mxChnlBwControl); #else @@ -58,15 +58,15 @@ void DoIQK_8812A( #elif((DEV_BUS_TYPE == RT_USB_INTERFACE) || (DEV_BUS_TYPE == RT_SDIO_INTERFACE)) PlatformAcquireMutex(&pHalData->mxChnlBwControl); #endif -#endif +#endif pDM_Odm->RFCalibrateInfo.ThermalValue_IQK= ThermalValue; PHY_IQCalibrate_8812A(Adapter, FALSE); - + #if(DM_ODM_SUPPORT_TYPE & ODM_WIN) -#if (DEV_BUS_TYPE == RT_PCI_INTERFACE) +#if (DEV_BUS_TYPE == RT_PCI_INTERFACE) #if USE_WORKITEM PlatformReleaseMutex(&pHalData->mxChnlBwControl); #else @@ -92,7 +92,7 @@ void DoIQK_8812A( * * Revised History: * When Who Remark - * 04/23/2012 MHC Create Version 0. + * 04/23/2012 MHC Create Version 0. * *---------------------------------------------------------------------------*/ VOID @@ -104,18 +104,18 @@ ODM_TxPwrTrackSetPwr8812A( ) { u4Byte finalBbSwingIdx[2]; - + PADAPTER Adapter = pDM_Odm->Adapter; PHAL_DATA_TYPE pHalData = GET_HAL_DATA(Adapter); u1Byte PwrTrackingLimit = 26; //+1.0dB u1Byte TxRate = 0xFF; - s1Byte Final_OFDM_Swing_Index = 0; - s1Byte Final_CCK_Swing_Index = 0; + s1Byte Final_OFDM_Swing_Index = 0; + s1Byte Final_CCK_Swing_Index = 0; u1Byte i = 0; #if 0 - #if (MP_DRIVER==1) + #if (MP_DRIVER==1) PMPT_CONTEXT pMptCtx = &(Adapter->MptCtx); TxRate = MptToMgntRate(pMptCtx->MptRateIndex); @@ -125,7 +125,7 @@ ODM_TxPwrTrackSetPwr8812A( if(!rate) //auto rate { if(pDM_Odm->TxRate != 0xFF) - TxRate = HwRateToMRate8812(pDM_Odm->TxRate); + TxRate = HwRateToMRate8812(pDM_Odm->TxRate); } else //force rate { @@ -158,7 +158,7 @@ ODM_TxPwrTrackSetPwr8812A( PwrTrackingLimit = 32; //+4dB else if((TxRate >= MGN_MCS13)&&(TxRate <= MGN_MCS15)) //64QAM PwrTrackingLimit = 30; //+3dB - + //2 VHT else if((TxRate >= MGN_VHT1SS_MCS0)&&(TxRate <= MGN_VHT1SS_MCS2)) //QPSK/BPSK PwrTrackingLimit = 34; //+5dB @@ -172,7 +172,7 @@ ODM_TxPwrTrackSetPwr8812A( PwrTrackingLimit = 26; //+1dB else if(TxRate == MGN_VHT1SS_MCS9) //256QAM PwrTrackingLimit = 24; //+0dB - + else if((TxRate >= MGN_VHT2SS_MCS0)&&(TxRate <= MGN_VHT2SS_MCS2)) //QPSK/BPSK PwrTrackingLimit = 34; //+5dB else if((TxRate >= MGN_VHT2SS_MCS3)&&(TxRate <= MGN_VHT2SS_MCS4)) //16QAM @@ -186,22 +186,22 @@ ODM_TxPwrTrackSetPwr8812A( else if(TxRate == MGN_VHT2SS_MCS9) //256QAM PwrTrackingLimit = 24; //+0dB - else + else PwrTrackingLimit = 24; } ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("TxRate=0x%x, PwrTrackingLimit=%d\n", TxRate, PwrTrackingLimit)); - + if (Method == BBSWING) { - ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("===>ODM_TxPwrTrackSetPwr8812A\n")); + ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("===>ODM_TxPwrTrackSetPwr8812A\n")); if (RFPath == ODM_RF_PATH_A) - { + { finalBbSwingIdx[ODM_RF_PATH_A] = (pDM_Odm->RFCalibrateInfo.OFDM_index[ODM_RF_PATH_A] > PwrTrackingLimit) ? PwrTrackingLimit : pDM_Odm->RFCalibrateInfo.OFDM_index[ODM_RF_PATH_A]; ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("pDM_Odm->RFCalibrateInfo.OFDM_index[ODM_RF_PATH_A]=%d, pDM_Odm->RealBbSwingIdx[ODM_RF_PATH_A]=%d\n", pDM_Odm->RFCalibrateInfo.OFDM_index[ODM_RF_PATH_A], finalBbSwingIdx[ODM_RF_PATH_A])); - + ODM_SetBBReg(pDM_Odm, rA_TxScale_Jaguar, 0xFFE00000, TxScalingTable_Jaguar[finalBbSwingIdx[ODM_RF_PATH_A]]); } else @@ -209,14 +209,14 @@ ODM_TxPwrTrackSetPwr8812A( finalBbSwingIdx[ODM_RF_PATH_B] = (pDM_Odm->RFCalibrateInfo.OFDM_index[ODM_RF_PATH_B] > PwrTrackingLimit) ? PwrTrackingLimit : pDM_Odm->RFCalibrateInfo.OFDM_index[ODM_RF_PATH_B]; ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("pDM_Odm->RFCalibrateInfo.OFDM_index[ODM_RF_PATH_B]=%d, pDM_Odm->RealBbSwingIdx[ODM_RF_PATH_B]=%d\n", pDM_Odm->RFCalibrateInfo.OFDM_index[ODM_RF_PATH_B], finalBbSwingIdx[ODM_RF_PATH_B])); - + ODM_SetBBReg(pDM_Odm, rB_TxScale_Jaguar, 0xFFE00000, TxScalingTable_Jaguar[finalBbSwingIdx[ODM_RF_PATH_B]]); } /* // <20121120> +2.5dB clipping, asked by Jerry Chang. pDM_Odm->BbSwingIdxOfdm[ODM_RF_PATH_A] = (pDM_Odm->BbSwingIdxOfdm[ODM_RF_PATH_A] > 29) ? 29 : pDM_Odm->BbSwingIdxOfdm[ODM_RF_PATH_A]; - pDM_Odm->BbSwingIdxOfdm[ODM_RF_PATH_B] = (pDM_Odm->BbSwingIdxOfdm[ODM_RF_PATH_B] > 29) ? 29 : pDM_Odm->BbSwingIdxOfdm[ODM_RF_PATH_B]; + pDM_Odm->BbSwingIdxOfdm[ODM_RF_PATH_B] = (pDM_Odm->BbSwingIdxOfdm[ODM_RF_PATH_B] > 29) ? 29 : pDM_Odm->BbSwingIdxOfdm[ODM_RF_PATH_B]; //2013.01.28 LukeLee: This is for debug request by Joe, otherwise BbSwingOffsetA and BbSwingOffsetB is 0 in normal & MP driver if(pDM_Odm->IsBbSwingOffsetPositiveA) @@ -235,7 +235,7 @@ ODM_TxPwrTrackSetPwr8812A( else finalBbSwingIdx[ODM_RF_PATH_B] = pDM_Odm->BbSwingIdxOfdm[ODM_RF_PATH_B] - pDM_Odm->BbSwingOffsetB; - // Adjust BB swing by Tx scaling, no matter CCK or OFDM. + // Adjust BB swing by Tx scaling, no matter CCK or OFDM. if (RFPath == ODM_RF_PATH_A) ODM_SetBBReg(pDM_Odm, rA_TxScale_Jaguar, 0xFFE00000, TxScalingTable_Jaguar[finalBbSwingIdx[ODM_RF_PATH_A]]); else if (RFPath == ODM_RF_PATH_B) @@ -249,16 +249,16 @@ ODM_TxPwrTrackSetPwr8812A( { ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("pDM_Odm->DefaultOfdmIndex=%d, pDM_Odm->Aboslute_OFDMSwingIdx[RFPath]=%d, RF_Path = %d\n", pDM_Odm->DefaultOfdmIndex, pDM_Odm->Aboslute_OFDMSwingIdx[RFPath],RFPath )); - - + + Final_OFDM_Swing_Index = pDM_Odm->DefaultOfdmIndex + pDM_Odm->Aboslute_OFDMSwingIdx[RFPath]; - - if (RFPath == ODM_RF_PATH_A) + + if (RFPath == ODM_RF_PATH_A) { if(Final_OFDM_Swing_Index > PwrTrackingLimit) //BBSwing higher then Limit { pDM_Odm->Remnant_CCKSwingIdx= Final_OFDM_Swing_Index - PwrTrackingLimit; // CCK Follow the same compensate value as Path A - pDM_Odm->Remnant_OFDMSwingIdx[RFPath] = Final_OFDM_Swing_Index - PwrTrackingLimit; + pDM_Odm->Remnant_OFDMSwingIdx[RFPath] = Final_OFDM_Swing_Index - PwrTrackingLimit; ODM_SetBBReg(pDM_Odm, rA_TxScale_Jaguar, 0xFFE00000, TxScalingTable_Jaguar[PwrTrackingLimit]); @@ -273,7 +273,7 @@ ODM_TxPwrTrackSetPwr8812A( else if (Final_OFDM_Swing_Index < 0) { pDM_Odm->Remnant_CCKSwingIdx= Final_OFDM_Swing_Index; // CCK Follow the same compensate value as Path A - pDM_Odm->Remnant_OFDMSwingIdx[RFPath] = Final_OFDM_Swing_Index; + pDM_Odm->Remnant_OFDMSwingIdx[RFPath] = Final_OFDM_Swing_Index; ODM_SetBBReg(pDM_Odm, rA_TxScale_Jaguar, 0xFFE00000, TxScalingTable_Jaguar[0]); @@ -294,7 +294,7 @@ ODM_TxPwrTrackSetPwr8812A( if(pDM_Odm->Modify_TxAGC_Flag_PathA) //If TxAGC has changed, reset TxAGC again { pDM_Odm->Remnant_CCKSwingIdx= 0; - pDM_Odm->Remnant_OFDMSwingIdx[RFPath] = 0; + pDM_Odm->Remnant_OFDMSwingIdx[RFPath] = 0; //Set TxAGC Page C{}; //Adapter->HalFunc.SetTxPowerLevelHandler(Adapter, pHalData->CurrentChannel); @@ -304,14 +304,14 @@ ODM_TxPwrTrackSetPwr8812A( ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("******Path_A pDM_Odm->Modify_TxAGC_Flag = FALSE \n")); } - } + } } - - if (RFPath == ODM_RF_PATH_B) + + if (RFPath == ODM_RF_PATH_B) { if(Final_OFDM_Swing_Index > PwrTrackingLimit) //BBSwing higher then Limit { - pDM_Odm->Remnant_OFDMSwingIdx[RFPath] = Final_OFDM_Swing_Index - PwrTrackingLimit; + pDM_Odm->Remnant_OFDMSwingIdx[RFPath] = Final_OFDM_Swing_Index - PwrTrackingLimit; ODM_SetBBReg(pDM_Odm, rB_TxScale_Jaguar, 0xFFE00000, TxScalingTable_Jaguar[PwrTrackingLimit]); @@ -323,7 +323,7 @@ ODM_TxPwrTrackSetPwr8812A( } else if (Final_OFDM_Swing_Index < 0) { - pDM_Odm->Remnant_OFDMSwingIdx[RFPath] = Final_OFDM_Swing_Index; + pDM_Odm->Remnant_OFDMSwingIdx[RFPath] = Final_OFDM_Swing_Index; ODM_SetBBReg(pDM_Odm, rB_TxScale_Jaguar, 0xFFE00000, TxScalingTable_Jaguar[0]); @@ -341,8 +341,8 @@ ODM_TxPwrTrackSetPwr8812A( if(pDM_Odm->Modify_TxAGC_Flag_PathB) //If TxAGC has changed, reset TxAGC again { - pDM_Odm->Remnant_CCKSwingIdx= 0; - pDM_Odm->Remnant_OFDMSwingIdx[RFPath] = 0; + pDM_Odm->Remnant_CCKSwingIdx= 0; + pDM_Odm->Remnant_OFDMSwingIdx[RFPath] = 0; //Set TxAGC Page E{}; @@ -366,7 +366,7 @@ GetDeltaSwingTable_8812A( OUT pu1Byte *TemperatureUP_A, OUT pu1Byte *TemperatureDOWN_A, OUT pu1Byte *TemperatureUP_B, - OUT pu1Byte *TemperatureDOWN_B + OUT pu1Byte *TemperatureDOWN_B ) { PADAPTER Adapter = pDM_Odm->Adapter; @@ -380,12 +380,12 @@ GetDeltaSwingTable_8812A( *TemperatureUP_A = pRFCalibrateInfo->DeltaSwingTableIdx_2GCCKA_P; *TemperatureDOWN_A = pRFCalibrateInfo->DeltaSwingTableIdx_2GCCKA_N; *TemperatureUP_B = pRFCalibrateInfo->DeltaSwingTableIdx_2GCCKB_P; - *TemperatureDOWN_B = pRFCalibrateInfo->DeltaSwingTableIdx_2GCCKB_N; + *TemperatureDOWN_B = pRFCalibrateInfo->DeltaSwingTableIdx_2GCCKB_N; } else { *TemperatureUP_A = pRFCalibrateInfo->DeltaSwingTableIdx_2GA_P; *TemperatureDOWN_A = pRFCalibrateInfo->DeltaSwingTableIdx_2GA_N; *TemperatureUP_B = pRFCalibrateInfo->DeltaSwingTableIdx_2GB_P; - *TemperatureDOWN_B = pRFCalibrateInfo->DeltaSwingTableIdx_2GB_N; + *TemperatureDOWN_B = pRFCalibrateInfo->DeltaSwingTableIdx_2GB_N; } } else if ( 36 <= channel && channel <= 64) { *TemperatureUP_A = pRFCalibrateInfo->DeltaSwingTableIdx_5GA_P[0]; @@ -398,17 +398,17 @@ GetDeltaSwingTable_8812A( *TemperatureUP_B = pRFCalibrateInfo->DeltaSwingTableIdx_5GB_P[1]; *TemperatureDOWN_B = pRFCalibrateInfo->DeltaSwingTableIdx_5GB_N[1]; } else if ( 149 <= channel && channel <= 173) { - *TemperatureUP_A = pRFCalibrateInfo->DeltaSwingTableIdx_5GA_P[2]; - *TemperatureDOWN_A = pRFCalibrateInfo->DeltaSwingTableIdx_5GA_N[2]; - *TemperatureUP_B = pRFCalibrateInfo->DeltaSwingTableIdx_5GB_P[2]; - *TemperatureDOWN_B = pRFCalibrateInfo->DeltaSwingTableIdx_5GB_N[2]; + *TemperatureUP_A = pRFCalibrateInfo->DeltaSwingTableIdx_5GA_P[2]; + *TemperatureDOWN_A = pRFCalibrateInfo->DeltaSwingTableIdx_5GA_N[2]; + *TemperatureUP_B = pRFCalibrateInfo->DeltaSwingTableIdx_5GB_P[2]; + *TemperatureDOWN_B = pRFCalibrateInfo->DeltaSwingTableIdx_5GB_N[2]; } else { *TemperatureUP_A = (pu1Byte)DeltaSwingTableIdx_2GA_P_8188E; - *TemperatureDOWN_A = (pu1Byte)DeltaSwingTableIdx_2GA_N_8188E; + *TemperatureDOWN_A = (pu1Byte)DeltaSwingTableIdx_2GA_N_8188E; *TemperatureUP_B = (pu1Byte)DeltaSwingTableIdx_2GA_P_8188E; - *TemperatureDOWN_B = (pu1Byte)DeltaSwingTableIdx_2GA_N_8188E; + *TemperatureDOWN_B = (pu1Byte)DeltaSwingTableIdx_2GA_N_8188E; } - + return; } @@ -422,7 +422,7 @@ void ConfigureTxpowerTrack_8812A( pConfig->AverageThermalNum = AVG_THERMAL_NUM_8812A; pConfig->RfPathCount = MAX_PATH_NUM_8812A; pConfig->ThermalRegAddr = RF_T_METER_8812A; - + pConfig->ODM_TxPwrTrackSetPwr = ODM_TxPwrTrackSetPwr8812A; pConfig->DoIQK = DoIQK_8812A; pConfig->PHY_LCCalibrate = PHY_LCCalibrate_8812A; @@ -433,8 +433,8 @@ void ConfigureTxpowerTrack_8812A( // // 2011/07/26 MH Add an API for testing IQK fail case. // -// MP Already declare in odm.c -#if !(DM_ODM_SUPPORT_TYPE & ODM_WIN) +// MP Already declare in odm.c +#if !(DM_ODM_SUPPORT_TYPE & ODM_WIN) BOOLEAN ODM_CheckPowerStatus( IN PADAPTER Adapter) @@ -451,14 +451,14 @@ ODM_CheckPowerStatus( ODM_RT_TRACE(pDM_Odm,COMP_INIT, DBG_LOUD, ("ODM_CheckPowerStatus Return TRUE, due to initadapter")); return TRUE; } - + // // 2011/07/19 MH We can not execute tx pwoer tracking/ LLC calibrate or IQK. // - Adapter->HalFunc.GetHwRegHandler(Adapter, HW_VAR_RF_STATE, (pu1Byte)(&rtState)); + Adapter->HalFunc.GetHwRegHandler(Adapter, HW_VAR_RF_STATE, (pu1Byte)(&rtState)); if(Adapter->bDriverStopped || Adapter->bDriverIsGoingToPnpSetPowerSleep || rtState == eRfOff) { - ODM_RT_TRACE(pDM_Odm,COMP_INIT, DBG_LOUD, ("ODM_CheckPowerStatus Return FALSE, due to %d/%d/%d\n", + ODM_RT_TRACE(pDM_Odm,COMP_INIT, DBG_LOUD, ("ODM_CheckPowerStatus Return FALSE, due to %d/%d/%d\n", Adapter->bDriverStopped, Adapter->bDriverIsGoingToPnpSetPowerSleep, rtState)); return FALSE; } @@ -476,7 +476,7 @@ void _IQK_RX_FillIQC_8812A( IN ODM_RF_RADIO_PATH_E Path, IN unsigned int RX_X, IN unsigned int RX_Y - ) + ) { switch (Path) { case ODM_RF_PATH_A: @@ -496,8 +496,8 @@ void _IQK_RX_FillIQC_8812A( } break; case ODM_RF_PATH_B: - { - ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0); // [31] = 0 --> Page C + { + ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0); // [31] = 0 --> Page C if (RX_X>>1 ==0x112 || RX_Y>>1 == 0x3ee){ ODM_SetBBReg(pDM_Odm, 0xe10, 0x000003ff, 0x100); ODM_SetBBReg(pDM_Odm, 0xe10, 0x03ff0000, 0); @@ -510,10 +510,10 @@ void _IQK_RX_FillIQC_8812A( ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("0xe10 = %x====>fill to IQC\n", ODM_Read4Byte(pDM_Odm, 0xe10))); } } - break; + break; default: - break; - }; + break; + }; } void _IQK_TX_FillIQC_8812A( @@ -521,7 +521,7 @@ void _IQK_TX_FillIQC_8812A( IN ODM_RF_RADIO_PATH_E Path, IN unsigned int TX_X, IN unsigned int TX_Y - ) + ) { switch (Path) { case ODM_RF_PATH_A: @@ -547,16 +547,16 @@ void _IQK_TX_FillIQC_8812A( ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("TX_X = %x;;TX_Y = %x =====> fill to IQC\n", TX_X&0x000007ff, TX_Y&0x000007ff)); ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("0xed4 = %x;;0xecc = %x ====>fill to IQC\n", ODM_GetBBReg(pDM_Odm, 0xed4, 0x000007ff), ODM_GetBBReg(pDM_Odm, 0xecc, 0x000007ff))); } - break; + break; default: - break; - }; + break; + }; } void _IQK_BackupMacBB_8812A( IN PDM_ODM_T pDM_Odm, IN pu4Byte MACBB_backup, - IN pu4Byte Backup_MACBB_REG, + IN pu4Byte Backup_MACBB_REG, IN u4Byte MACBB_NUM ) { @@ -566,17 +566,17 @@ void _IQK_BackupMacBB_8812A( for (i = 0; i < MACBB_NUM; i++){ MACBB_backup[i] = ODM_Read4Byte(pDM_Odm, Backup_MACBB_REG[i]); } - + ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("BackupMacBB Success!!!!\n")); } void _IQK_BackupRF_8812A( IN PDM_ODM_T pDM_Odm, IN pu4Byte RFA_backup, - IN pu4Byte RFB_backup, - IN pu4Byte Backup_RF_REG, + IN pu4Byte RFB_backup, + IN pu4Byte Backup_RF_REG, IN u4Byte RF_NUM - ) + ) { u4Byte i; @@ -592,15 +592,15 @@ void _IQK_BackupRF_8812A( void _IQK_BackupAFE_8812A( IN PDM_ODM_T pDM_Odm, IN pu4Byte AFE_backup, - IN pu4Byte Backup_AFE_REG, + IN pu4Byte Backup_AFE_REG, IN u4Byte AFE_NUM ) { u4Byte i; ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0); // [31] = 0 --> Page C - //Save AFE Parameters + //Save AFE Parameters for (i = 0; i < AFE_NUM; i++){ - AFE_backup[i] = ODM_Read4Byte(pDM_Odm, Backup_AFE_REG[i]); + AFE_backup[i] = ODM_Read4Byte(pDM_Odm, Backup_AFE_REG[i]); } ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("BackupAFE Success!!!!\n")); } @@ -608,13 +608,13 @@ void _IQK_BackupAFE_8812A( void _IQK_RestoreMacBB_8812A( IN PDM_ODM_T pDM_Odm, IN pu4Byte MACBB_backup, - IN pu4Byte Backup_MACBB_REG, + IN pu4Byte Backup_MACBB_REG, IN u4Byte MACBB_NUM - ) + ) { u4Byte i; ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0); // [31] = 0 --> Page C - //Reload MacBB Parameters + //Reload MacBB Parameters for (i = 0; i < MACBB_NUM; i++){ ODM_Write4Byte(pDM_Odm, Backup_MACBB_REG[i], MACBB_backup[i]); } @@ -628,7 +628,7 @@ void _IQK_RestoreRF_8812A( IN pu4Byte RF_backup, IN u4Byte RF_REG_NUM ) -{ +{ u4Byte i; ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0); // [31] = 0 --> Page C @@ -656,13 +656,13 @@ void _IQK_RestoreRF_8812A( void _IQK_RestoreAFE_8812A( IN PDM_ODM_T pDM_Odm, IN pu4Byte AFE_backup, - IN pu4Byte Backup_AFE_REG, + IN pu4Byte Backup_AFE_REG, IN u4Byte AFE_NUM ) { u4Byte i; ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0); // [31] = 0 --> Page C - //Reload AFE Parameters + //Reload AFE Parameters for (i = 0; i < AFE_NUM; i++){ ODM_Write4Byte(pDM_Odm, Backup_AFE_REG[i], AFE_backup[i]); } @@ -685,7 +685,7 @@ void _IQK_ConfigureMAC_8812A( ) { // ========MAC register setting======== - ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0); // [31] = 0 --> Page C + ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0); // [31] = 0 --> Page C ODM_Write1Byte(pDM_Odm, 0x522, 0x3f); ODM_SetBBReg(pDM_Odm, 0x550, BIT(11)|BIT(3), 0x0); ODM_SetBBReg(pDM_Odm, 0x808, BIT(28), 0x0); // CCK Off @@ -693,7 +693,7 @@ void _IQK_ConfigureMAC_8812A( ODM_SetBBReg(pDM_Odm, 0x838, 0xf, 0xc); // CCA off } -#define cal_num 3 +#define cal_num 10 void _IQK_Tx_8812A( IN PDM_ODM_T pDM_Odm, @@ -703,13 +703,13 @@ void _IQK_Tx_8812A( { u4Byte TX_fail,RX_fail, delay_count, IQK_ready, cal_retry, cal = 0, temp_reg65; int TX_X = 0, TX_Y = 0, RX_X = 0, RX_Y = 0, TX_Average = 0, RX_Average = 0; - int TX_X0[10], TX_Y0[10], RX_X0[10], RX_Y0[10]; + int TX_X0[cal_num], TX_Y0[cal_num], RX_X0[cal_num], RX_Y0[cal_num]; BOOLEAN TX0IQKOK = FALSE, RX0IQKOK = FALSE; - int TX_X1[10], TX_Y1[10], RX_X1[10], RX_Y1[10]; + int TX_X1[cal_num], TX_Y1[cal_num], RX_X1[cal_num], RX_Y1[cal_num]; BOOLEAN TX1IQKOK = FALSE, RX1IQKOK = FALSE, VDF_enable = FALSE; int i, k, VDF_Y[3], VDF_X[3], Tx_dt[3], Rx_dt[3], ii, dx = 0, dy = 0, TX_finish = 0, RX_finish = 0, dt = 0; PODM_RF_CAL_T pRFCalibrateInfo = &(pDM_Odm->RFCalibrateInfo); - + ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("BandWidth = %d, ExtPA5G = %d, ExtPA2G = %d\n", *pDM_Odm->pBandWidth, pDM_Odm->ExtPA5G, pDM_Odm->ExtPA)); if (*pDM_Odm->pBandWidth == 2){ VDF_enable = TRUE; @@ -725,13 +725,13 @@ void _IQK_Tx_8812A( // Port 0 DAC/ADC on ODM_Write4Byte(pDM_Odm, 0xc60, 0x77777777); ODM_Write4Byte(pDM_Odm, 0xc64, 0x77777777); - + // Port 1 DAC/ADC off ODM_Write4Byte(pDM_Odm, 0xe60, 0x00000000); ODM_Write4Byte(pDM_Odm, 0xe64, 0x00000000); ODM_Write4Byte(pDM_Odm, 0xc68, 0x19791979); - + ODM_SetBBReg(pDM_Odm, 0xc00, 0xf, 0x4);// hardware 3-wire off // DAC/ADC sampling rate (160 MHz) @@ -747,7 +747,7 @@ void _IQK_Tx_8812A( // Port 0 DAC/ADC off ODM_Write4Byte(pDM_Odm, 0xc60, 0x00000000); ODM_Write4Byte(pDM_Odm, 0xc64, 0x00000000); - + // Port 1 DAC/ADC on ODM_Write4Byte(pDM_Odm, 0xe60, 0x77777777); ODM_Write4Byte(pDM_Odm, 0xe64, 0x77777777); @@ -760,7 +760,7 @@ void _IQK_Tx_8812A( ODM_SetBBReg(pDM_Odm, 0xe5c, BIT(26)|BIT(25)|BIT(24), 0x7); ODM_SetBBReg(pDM_Odm, 0x8c4, BIT(30), 0x1); //ODM_SetBBReg(pDM_Odm, 0xeb0, 0x00ff0000, 0x77); - //ODM_SetBBReg(pDM_Odm, 0xeb4, 0x03000000, 0x0); + //ODM_SetBBReg(pDM_Odm, 0xeb4, 0x03000000, 0x0); } break; default: @@ -769,7 +769,7 @@ void _IQK_Tx_8812A( switch (Path) { case ODM_RF_PATH_A: - { + { //====== TX IQK ====== ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0); // [31] = 0 --> Page C ODM_SetRFReg(pDM_Odm, Path, 0xef, bRFRegOffsetMask, 0x80002); @@ -900,7 +900,6 @@ void _IQK_Tx_8812A( ODM_Write4Byte(pDM_Odm, 0xc84, 0x38008c10);// RX_Tone_idx[9:0], RxK_Mask[29] ODM_Write4Byte(pDM_Odm, 0xce8, 0x00000000); - TX_Average = 0; for(cal = 0; cal < cal_num; cal++){ cal_retry = 0; while(1){ @@ -962,7 +961,7 @@ void _IQK_Tx_8812A( TX0IQKOK = FALSE; cal_retry++; if (cal_retry == 10) - break; + break; } } ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("TXA_cal_retry = %d\n", cal_retry)); @@ -1000,7 +999,7 @@ void _IQK_Tx_8812A( ODM_Write4Byte(pDM_Odm, 0xc88, 0x02140119); ODM_Write4Byte(pDM_Odm, 0xc8c, 0x28161420); - for (k = 0;k <= 2; k++){ + for (k = 0;k <= 2; k++){ ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0); // [31] = 0 --> Page C ODM_SetBBReg(pDM_Odm, 0x978, 0x03FF8000, (VDF_X[k])>>21&0x000007ff); ODM_SetBBReg(pDM_Odm, 0x978, 0x000007FF, (VDF_Y[k])>>21&0x000007ff); @@ -1222,7 +1221,7 @@ void _IQK_Tx_8812A( ODM_Write4Byte(pDM_Odm, 0x984, 0x00462910);// [0]:AGC_en, [15]:idac_K_Mask ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x1); // [31] = 1 --> Page C1 - + if (pDM_Odm->ExtPA5G) ODM_Write4Byte(pDM_Odm, 0xe88, 0x821403f7); else @@ -1293,7 +1292,7 @@ void _IQK_Tx_8812A( if (delay_count < 20){ // If 20ms No Result, then cal_retry++ // ============TXIQK Check============== TX_fail = ODM_GetBBReg(pDM_Odm, 0xd40, BIT(12)); - + if (~TX_fail){ ODM_Write4Byte(pDM_Odm, 0xeb8, 0x02000000); VDF_X[k] = ODM_GetBBReg(pDM_Odm, 0xd40, 0x07ff0000)<<21; @@ -1328,8 +1327,6 @@ void _IQK_Tx_8812A( ODM_Write4Byte(pDM_Odm, 0xe84, 0x38008c10);// RX_Tone_idx[9:0], RxK_Mask[29] ODM_Write4Byte(pDM_Odm, 0xee8, 0x00000000); - TX_Average = 0; - for(cal = 0; cal < cal_num; cal++){ cal_retry = 0; while(1){ @@ -1397,20 +1394,20 @@ void _IQK_Tx_8812A( ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("TXB_cal_retry = %d\n", cal_retry)); if (TX1IQKOK) TX_Average++; - } + } } ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0); // [31] = 0 --> Page C ODM_SetRFReg(pDM_Odm, Path, 0x58, 0x7fe00, ODM_GetRFReg(pDM_Odm, Path, 0x8, 0xffc00)); // Load LOK ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x1); // [31] = 1 --> Page C1 - + if (TX1IQKOK == FALSE) break; // TXK fail, Don't do RXK - + if (VDF_enable == 1){ ODM_SetBBReg(pDM_Odm, 0xee8, BIT(31), 0x0); // TX VDF Disable ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("RXVDF Start\n")); - + //====== RX IQK ====== ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0); // [31] = 0 --> Page C ODM_SetRFReg(pDM_Odm, Path, 0xef, bRFRegOffsetMask, 0x80000); @@ -1420,14 +1417,14 @@ void _IQK_Tx_8812A( ODM_SetRFReg(pDM_Odm, Path, 0x8f, bRFRegOffsetMask, 0x88001); ODM_SetRFReg(pDM_Odm, Path, 0x65, bRFRegOffsetMask, 0x931d0); ODM_SetRFReg(pDM_Odm, Path, 0xef, bRFRegOffsetMask, 0x00000); - + ODM_SetBBReg(pDM_Odm, 0x978, BIT(31), 0x1); ODM_SetBBReg(pDM_Odm, 0x97c, BIT(31), 0x0); ODM_Write4Byte(pDM_Odm, 0x984, 0x0046a911); ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x1); // [31] = 1 --> Page C1 ODM_Write4Byte(pDM_Odm, 0xe88, 0x02140119); ODM_Write4Byte(pDM_Odm, 0xe8c, 0x28161420); - + for (k = 0;k <= 2; k++){ ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0); // [31] = 0 --> Page C ODM_SetBBReg(pDM_Odm, 0x978, 0x03FF8000, (VDF_X[k])>>21&0x000007ff); @@ -1464,13 +1461,13 @@ void _IQK_Tx_8812A( default: break; } - - + + if (k==2){ ODM_SetBBReg(pDM_Odm, 0xee8, BIT(30), 0x1); //RX VDF Enable } ODM_Write4Byte(pDM_Odm, 0xeb8, 0x00100000);// cb8[20] 將 SI/PI 使用權切給 iqk_dpk module - + cal_retry = 0; while(1){ // one shot @@ -1490,7 +1487,7 @@ void _IQK_Tx_8812A( delay_count++; } } - + if (delay_count < 20){ // If 20ms No Result, then cal_retry++ // ============RXIQK Check============== RX_fail = ODM_GetBBReg(pDM_Odm, 0xd40, BIT(11)); @@ -1509,7 +1506,7 @@ void _IQK_Tx_8812A( cal_retry++; if (cal_retry == 10) break; - + } } else{ @@ -1519,7 +1516,7 @@ void _IQK_Tx_8812A( break; } } - + } ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("RXB_VDF_cal_retry = %d\n", cal_retry)); RX_X1[cal] = VDF_X[k-1] ; @@ -1527,7 +1524,7 @@ void _IQK_Tx_8812A( ODM_SetBBReg(pDM_Odm, 0xee8, BIT(31), 0x1); // TX VDF Enable } else{ - + //====== RX IQK ====== ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0); // [31] = 0 --> Page C ODM_SetRFReg(pDM_Odm, Path, 0xef, bRFRegOffsetMask, 0x80000); @@ -1625,11 +1622,11 @@ void _IQK_Tx_8812A( } } } - break; + break; default: - break; + break; } - + // FillIQK Result switch (Path){ case ODM_RF_PATH_A: @@ -1642,7 +1639,7 @@ void _IQK_Tx_8812A( for (i = 0; i < TX_Average; i++){ ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("TX_X0[%d] = %x ;; TX_Y0[%d] = %x\n", i, (TX_X0[i])>>21&0x000007ff, i, (TX_Y0[i])>>21&0x000007ff)); } - + for (i = 0; i < TX_Average; i++){ for (ii = i+1; ii >21) - (TX_X0[ii]>>21); @@ -1661,7 +1658,7 @@ void _IQK_Tx_8812A( } if (TX_finish == 1) break; - } + } if (*pDM_Odm->pBandWidth == 2){ ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x1); // [31] = 0 --> Page C ODM_SetBBReg(pDM_Odm, 0xce8, 0x3fff0000, Tx_dt[0] & 0x00003fff); @@ -1673,7 +1670,7 @@ void _IQK_Tx_8812A( else{ _IQK_TX_FillIQC_8812A(pDM_Odm, Path, 0x200, 0x0); } - + if (RX_Average == 0){ _IQK_RX_FillIQC_8812A(pDM_Odm, Path, 0x200, 0x0); break; @@ -1682,7 +1679,7 @@ void _IQK_Tx_8812A( for (i = 0; i < RX_Average; i++){ ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("RX_X0[%d] = %x ;; RX_Y0[%d] = %x\n", i, (RX_X0[i])>>21&0x000007ff, i, (RX_Y0[i])>>21&0x000007ff)); } - + for (i = 0; i < RX_Average; i++){ for (ii = i+1; ii >21) - (RX_X0[ii]>>21); @@ -1717,14 +1714,14 @@ void _IQK_Tx_8812A( pRFCalibrateInfo->bNeedIQK = FALSE; pRFCalibrateInfo->IQKMatrixRegSetting[chnlIdx].Value[*pDM_Odm->pBandWidth][0] = ((TX_X & 0x000007ff) << 16) + (TX_Y & 0x000007ff); //Path A TX pRFCalibrateInfo->IQKMatrixRegSetting[chnlIdx].Value[*pDM_Odm->pBandWidth][1] = ((RX_X & 0x000007ff) << 16) + (RX_Y & 0x000007ff); //Path A RX - + if (*pDM_Odm->pBandWidth == 2){ ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x1); // [31] = 0 --> Page C pRFCalibrateInfo->IQKMatrixRegSetting[chnlIdx].Value[*pDM_Odm->pBandWidth][4] = ODM_Read4Byte( pDM_Odm, 0xce8); //Path B VDF ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0); // [31] = 0 --> Page C - } + } } - + } break; case ODM_RF_PATH_B: @@ -1757,7 +1754,7 @@ void _IQK_Tx_8812A( } if (TX_finish == 1) break; - } + } if (*pDM_Odm->pBandWidth == 2){ ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x1); // [31] = 0 --> Page C ODM_SetBBReg(pDM_Odm, 0xee8, 0x3fff0000, Tx_dt[0] & 0x00003fff); @@ -1797,7 +1794,7 @@ void _IQK_Tx_8812A( } if (RX_finish == 1) break; - } + } if (*pDM_Odm->pBandWidth == 2){ ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x1); // [31] = 0 --> Page C ODM_SetBBReg(pDM_Odm, 0xee8, 0x00003fff, Rx_dt[0] & 0x00003fff); @@ -1815,14 +1812,14 @@ void _IQK_Tx_8812A( pRFCalibrateInfo->bNeedIQK = FALSE; pRFCalibrateInfo->IQKMatrixRegSetting[chnlIdx].Value[*pDM_Odm->pBandWidth][2] = ((TX_X & 0x000007ff) << 16) + (TX_Y & 0x000007ff); //Path B TX pRFCalibrateInfo->IQKMatrixRegSetting[chnlIdx].Value[*pDM_Odm->pBandWidth][3] = ((RX_X & 0x000007ff) << 16) + (RX_Y & 0x000007ff); //Path B RX - + if (*pDM_Odm->pBandWidth == 2){ ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x1); // [31] = 0 --> Page C pRFCalibrateInfo->IQKMatrixRegSetting[chnlIdx].Value[*pDM_Odm->pBandWidth][5] = ODM_Read4Byte( pDM_Odm, 0xee8); //Path B VDF ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0); // [31] = 0 --> Page C - } + } } - + } break; default: @@ -1835,30 +1832,30 @@ void _IQK_Tx_8812A( #define RF_REG_NUM 3 // Maintained by BB James. -VOID +VOID phy_IQCalibrate_8812A( IN PDM_ODM_T pDM_Odm, IN u1Byte Channel ) { u4Byte MACBB_backup[MACBB_REG_NUM], AFE_backup[AFE_REG_NUM], RFA_backup[RF_REG_NUM], RFB_backup[RF_REG_NUM]; - u4Byte Backup_MACBB_REG[MACBB_REG_NUM] = {0xb00, 0x520, 0x550, 0x808, 0x90c, 0xc00, 0xe00, 0x8c4,0x838, 0x82c}; + u4Byte Backup_MACBB_REG[MACBB_REG_NUM] = {0xb00, 0x520, 0x550, 0x808, 0x90c, 0xc00, 0xe00, 0x8c4,0x838, 0x82c}; u4Byte Backup_AFE_REG[AFE_REG_NUM] = {0xc5c, 0xc60, 0xc64, 0xc68, 0xcb8, 0xcb0, 0xcb4, - 0xe5c, 0xe60, 0xe64, 0xe68, 0xeb8, 0xeb0, 0xeb4}; - u4Byte Backup_RF_REG[RF_REG_NUM] = {0x65, 0x8f, 0x0}; + 0xe5c, 0xe60, 0xe64, 0xe68, 0xeb8, 0xeb0, 0xeb4}; + u4Byte Backup_RF_REG[RF_REG_NUM] = {0x65, 0x8f, 0x0}; u1Byte chnlIdx = ODM_GetRightChnlPlaceforIQK(Channel); - + _IQK_BackupMacBB_8812A(pDM_Odm, MACBB_backup, Backup_MACBB_REG, MACBB_REG_NUM); _IQK_BackupAFE_8812A(pDM_Odm, AFE_backup, Backup_AFE_REG, AFE_REG_NUM); _IQK_BackupRF_8812A(pDM_Odm, RFA_backup, RFB_backup, Backup_RF_REG, RF_REG_NUM); - + _IQK_ConfigureMAC_8812A(pDM_Odm); _IQK_Tx_8812A(pDM_Odm, ODM_RF_PATH_A, chnlIdx); _IQK_RestoreRF_8812A(pDM_Odm, ODM_RF_PATH_A, Backup_RF_REG, RFA_backup, RF_REG_NUM); - + _IQK_Tx_8812A(pDM_Odm, ODM_RF_PATH_B, chnlIdx); _IQK_RestoreRF_8812A(pDM_Odm, ODM_RF_PATH_B, Backup_RF_REG, RFB_backup, RF_REG_NUM); - + _IQK_RestoreAFE_8812A(pDM_Odm, AFE_backup, Backup_AFE_REG, AFE_REG_NUM); _IQK_RestoreMacBB_8812A(pDM_Odm, MACBB_backup, Backup_MACBB_REG, MACBB_REG_NUM); @@ -1866,14 +1863,14 @@ phy_IQCalibrate_8812A( } -VOID +VOID phy_LCCalibrate_8812A( IN PDM_ODM_T pDM_Odm, IN BOOLEAN is2T ) { u4Byte /*RF_Amode=0, RF_Bmode=0,*/ LC_Cal = 0, tmp = 0; - + //Check continuous TX and Packet TX u4Byte reg0x914 = ODM_Read4Byte(pDM_Odm, rSingleTone_ContTx_Jaguar);; @@ -1883,22 +1880,22 @@ phy_LCCalibrate_8812A( if((reg0x914 & 0x70000) != 0) //If contTx, disable all continuous TX. 0x914[18:16] // <20121121, Kordan> A workaround: If we set 0x914[18:16] as zero, BB turns off ContTx // until another packet comes in. To avoid ContTx being turned off, we skip this step. - ;//ODM_Write4Byte(pDM_Odm, rSingleTone_ContTx_Jaguar, reg0x914 & (~0x70000)); + ;//ODM_Write4Byte(pDM_Odm, rSingleTone_ContTx_Jaguar, reg0x914 & (~0x70000)); else // If packet Tx-ing, pause Tx. - ODM_Write1Byte(pDM_Odm, REG_TXPAUSE, 0xFF); + ODM_Write1Byte(pDM_Odm, REG_TXPAUSE, 0xFF); /* //3 1. Read original RF mode RF_Amode = ODM_GetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_AC, bRFRegOffsetMask); if(is2T) - RF_Bmode = ODM_GetRFReg(pDM_Odm, ODM_RF_PATH_B, RF_AC, bRFRegOffsetMask); + RF_Bmode = ODM_GetRFReg(pDM_Odm, ODM_RF_PATH_B, RF_AC, bRFRegOffsetMask); //3 2. Set RF mode = standby mode ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_AC, bRFRegOffsetMask, (RF_Amode&0x8FFFF)|0x10000); if(is2T) - ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, RF_AC, bRFRegOffsetMask, (RF_Bmode&0x8FFFF)|0x10000); + ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, RF_AC, bRFRegOffsetMask, (RF_Bmode&0x8FFFF)|0x10000); */ // Enter LCK mode @@ -1907,26 +1904,26 @@ phy_LCCalibrate_8812A( //3 3. Read RF reg18 LC_Cal = ODM_GetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_CHNLBW, bRFRegOffsetMask); - + //3 4. Set LC calibration begin bit15 ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_CHNLBW, bRFRegOffsetMask, LC_Cal|0x08000); // Leave LCK mode tmp = ODM_GetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_LCK, bRFRegOffsetMask); ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_LCK, bRFRegOffsetMask, tmp & ~BIT14); - - ODM_delay_ms(100); + + ODM_delay_ms(100); //3 Restore original situation if((reg0x914 & 70000) != 0) //Deal with contisuous TX case, 0x914[18:16] - { + { // <20121121, Kordan> A workaround: If we set 0x914[18:16] as zero, BB turns off ContTx // until another packet comes in. To avoid ContTx being turned off, we skip this step. - //ODM_Write4Byte(pDM_Odm, rSingleTone_ContTx_Jaguar, reg0x914); + //ODM_Write4Byte(pDM_Odm, rSingleTone_ContTx_Jaguar, reg0x914); } else // Deal with Packet TX case { - ODM_Write1Byte(pDM_Odm, REG_TXPAUSE, 0x00); + ODM_Write1Byte(pDM_Odm, REG_TXPAUSE, 0x00); } // Recover channel number @@ -1951,7 +1948,7 @@ phy_LCCalibrate_8812A( #define DP_DPK_NUM 3 #define DP_DPK_VALUE_NUM 2 -VOID +VOID phy_ReloadIQKSetting_8812A( IN PDM_ODM_T pDM_Odm, IN u1Byte Channel @@ -1979,11 +1976,11 @@ phy_ReloadIQKSetting_8812A( ODM_SetBBReg(pDM_Odm, 0xc10, 0x03ff0000, (pRFCalibrateInfo->IQKMatrixRegSetting[chnlIdx].Value[*pDM_Odm->pBandWidth][1]&0x7ff)>>1); ODM_SetBBReg(pDM_Odm, 0xe10, 0x000003ff, (pRFCalibrateInfo->IQKMatrixRegSetting[chnlIdx].Value[*pDM_Odm->pBandWidth][3]&0x7ff0000)>>17); ODM_SetBBReg(pDM_Odm, 0xe10, 0x03ff0000, (pRFCalibrateInfo->IQKMatrixRegSetting[chnlIdx].Value[*pDM_Odm->pBandWidth][3]&0x7ff)>>1); - + } -VOID +VOID PHY_ResetIQKResult_8812A( IN PDM_ODM_T pDM_Odm ) @@ -2015,7 +2012,7 @@ phy_IQCalibrate_By_FW_8812A( Buf1 = 0x2<<4; else Buf1 = 0x1<<4; - + //Byte 2, Bit 0 ~ Bit 3 : Bandwidth if(pHalData->CurrentChannelBW == CHANNEL_WIDTH_20) Buf2 = 0x1; @@ -2025,13 +2022,13 @@ phy_IQCalibrate_By_FW_8812A( Buf2 = 0x1<<2; else Buf2 = 0x1<<3; - + IQKcmd[1] = Buf1 | Buf2; IQKcmd[2] = pHalData->ExternalPA_5G | pHalData->ExternalLNA_5G<<1; RT_TRACE(COMP_MP, DBG_LOUD, ("== Start ==\n")); - - + + //FillH2CCmd_8812(pAdapter, 0x45, 3, IQKcmd); } @@ -2044,21 +2041,21 @@ PHY_IQCalibrate_8812A( #if !(DM_ODM_SUPPORT_TYPE & ODM_AP) - HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter); + HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter); #if (DM_ODM_SUPPORT_TYPE == ODM_WIN) - PDM_ODM_T pDM_Odm = &pHalData->DM_OutSrc; + PDM_ODM_T pDM_Odm = &pHalData->DM_OutSrc; #else // (DM_ODM_SUPPORT_TYPE == ODM_CE) - PDM_ODM_T pDM_Odm = &pHalData->odmpriv; + PDM_ODM_T pDM_Odm = &pHalData->odmpriv; #endif -#endif +#endif #if (MP_DRIVER == 1) - #if (DM_ODM_SUPPORT_TYPE == ODM_WIN) - PMPT_CONTEXT pMptCtx = &(pAdapter->MptCtx); + #if (DM_ODM_SUPPORT_TYPE == ODM_WIN) + PMPT_CONTEXT pMptCtx = &(pAdapter->MptCtx); #else// (DM_ODM_SUPPORT_TYPE == ODM_CE) - PMPT_CONTEXT pMptCtx = &(pAdapter->mppriv.MptCtx); - #endif + PMPT_CONTEXT pMptCtx = &(pAdapter->mppriv.MptCtx); + #endif #endif//(MP_DRIVER == 1) #if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE) ) @@ -2066,18 +2063,18 @@ PHY_IQCalibrate_8812A( return; #endif -#if MP_DRIVER == 1 +#if MP_DRIVER == 1 if( ! (pMptCtx->bSingleTone || pMptCtx->bCarrierSuppression) ) -#endif +#endif { //if(pMgntInfo->RegIQKFWOffload) // phy_IQCalibrate_By_FW_8812A(pAdapter); //else phy_IQCalibrate_8812A(pDM_Odm, pHalData->CurrentChannel); - + } - + } @@ -2087,29 +2084,29 @@ PHY_LCCalibrate_8812A( ) { BOOLEAN bStartContTx = FALSE, bSingleTone = FALSE, bCarrierSuppression = FALSE; - + #if !(DM_ODM_SUPPORT_TYPE & ODM_AP) PADAPTER pAdapter = pDM_Odm->Adapter; - HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter); + HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter); #if (MP_DRIVER == 1) #if (DM_ODM_SUPPORT_TYPE == ODM_WIN) - PMPT_CONTEXT pMptCtx = &(pAdapter->MptCtx); + PMPT_CONTEXT pMptCtx = &(pAdapter->MptCtx); #else// (DM_ODM_SUPPORT_TYPE == ODM_CE) - PMPT_CONTEXT pMptCtx = &(pAdapter->mppriv.MptCtx); + PMPT_CONTEXT pMptCtx = &(pAdapter->mppriv.MptCtx); #endif bStartContTx = pMptCtx->bStartContTx; bSingleTone = pMptCtx->bSingleTone; bCarrierSuppression = pMptCtx->bCarrierSuppression; #endif//(MP_DRIVER == 1) -#endif +#endif ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("===> PHY_LCCalibrate_8812A\n")); -#if (MP_DRIVER == 1) +#if (MP_DRIVER == 1) phy_LCCalibrate_8812A(pDM_Odm, TRUE); -#endif +#endif ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("<=== PHY_LCCalibrate_8812A\n")); @@ -2133,27 +2130,27 @@ VOID phy_SetRFPathSwitch_8812A( PDM_ODM_T pDM_Odm = &pHalData->DM_OutSrc; #endif -#endif +#endif - if (IS_HARDWARE_TYPE_8821(pAdapter)) + if (IS_HARDWARE_TYPE_8821(pAdapter)) { if(bMain) ODM_SetBBReg(pDM_Odm, rA_RFE_Pinmux_Jaguar+4, BIT29|BIT28, 0x1); //Main else ODM_SetBBReg(pDM_Odm, rA_RFE_Pinmux_Jaguar+4, BIT29|BIT28, 0x2); //Aux } - else if (IS_HARDWARE_TYPE_8812(pAdapter)) + else if (IS_HARDWARE_TYPE_8812(pAdapter)) { if (pHalData->RFEType == 5) { if(bMain) { - //WiFi - ODM_SetBBReg(pDM_Odm, r_ANTSEL_SW_Jaguar, BIT1|BIT0, 0x2); - ODM_SetBBReg(pDM_Odm, r_ANTSEL_SW_Jaguar, BIT9|BIT8, 0x3); + //WiFi + ODM_SetBBReg(pDM_Odm, r_ANTSEL_SW_Jaguar, BIT1|BIT0, 0x2); + ODM_SetBBReg(pDM_Odm, r_ANTSEL_SW_Jaguar, BIT9|BIT8, 0x3); } else { // BT - ODM_SetBBReg(pDM_Odm, r_ANTSEL_SW_Jaguar, BIT1|BIT0, 0x1); - ODM_SetBBReg(pDM_Odm, r_ANTSEL_SW_Jaguar, BIT9|BIT8, 0x3); + ODM_SetBBReg(pDM_Odm, r_ANTSEL_SW_Jaguar, BIT1|BIT0, 0x1); + ODM_SetBBReg(pDM_Odm, r_ANTSEL_SW_Jaguar, BIT9|BIT8, 0x3); } } } @@ -2178,7 +2175,7 @@ VOID PHY_SetRFPathSwitch_8812A( phy_SetRFPathSwitch_8812A(pAdapter, bMain, TRUE); -#endif +#endif } @@ -2193,10 +2190,10 @@ VOID _DPK_parareload( IN PDM_ODM_T pDM_Odm, IN pu4Byte MACBB_backup, - IN pu4Byte Backup_MACBB_REG, + IN pu4Byte Backup_MACBB_REG, IN u4Byte MACBB_NUM - + ) { u4Byte i; @@ -2213,10 +2210,10 @@ VOID _DPK_parabackup( IN PDM_ODM_T pDM_Odm, IN pu4Byte MACBB_backup, - IN pu4Byte Backup_MACBB_REG, + IN pu4Byte Backup_MACBB_REG, IN u4Byte MACBB_NUM - + ) { u4Byte i; @@ -2230,21 +2227,21 @@ _DPK_parabackup( VOID _DPK_Globalparaset( - IN PDM_ODM_T pDM_Odm + IN PDM_ODM_T pDM_Odm ) { //***************************************// //set MAC register //***************************************// - + //TX pause ODM_Write4Byte(pDM_Odm, 0x520, 0x007f3F0F); //***************************************// //set BB register //***************************************// - + // reg82c[31] = b'0, 切換到 page C ODM_Write4Byte(pDM_Odm, 0x82c, 0x002083d5); @@ -2252,31 +2249,31 @@ _DPK_Globalparaset( ODM_Write4Byte(pDM_Odm, 0x970, 0x00000000); // path A regcb8[3:0] = h'd, TRSW to TX - ODM_Write4Byte(pDM_Odm, 0xcb8, 0x0050824d); + ODM_Write4Byte(pDM_Odm, 0xcb8, 0x0050824d); // path B regeb8[3:0] = h'd, TRSW to TX - ODM_Write4Byte(pDM_Odm, 0xeb8, 0x0050824d); - + ODM_Write4Byte(pDM_Odm, 0xeb8, 0x0050824d); + // reg838[3:0] = h'c, CCA off - ODM_Write4Byte(pDM_Odm, 0x838, 0x06c8d24c); + ODM_Write4Byte(pDM_Odm, 0x838, 0x06c8d24c); // path A 3-wire off - ODM_Write4Byte(pDM_Odm, 0xc00, 0x00000004); - + ODM_Write4Byte(pDM_Odm, 0xc00, 0x00000004); + // path B 3-wire off - ODM_Write4Byte(pDM_Odm, 0xe00, 0x00000004); - + ODM_Write4Byte(pDM_Odm, 0xe00, 0x00000004); + // reg90c[15] = b'1, DAC fifo reset by CSWU - ODM_Write4Byte(pDM_Odm, 0x90c, 0x00008000); - + ODM_Write4Byte(pDM_Odm, 0x90c, 0x00008000); + // reset DPK circuit - ODM_Write4Byte(pDM_Odm, 0xb00, 0x03000100); - + ODM_Write4Byte(pDM_Odm, 0xb00, 0x03000100); + // path A regc94[0] = b'1 (r_gothrough_iqkdpk), 將 DPK 切進 normal path - ODM_Write4Byte(pDM_Odm, 0xc94, 0x01000001); + ODM_Write4Byte(pDM_Odm, 0xc94, 0x01000001); // path B rege94[0] = b'1 (r_gothrough_iqkdpk), 將 DPK 切進 normal path - ODM_Write4Byte(pDM_Odm, 0xe94, 0x01000001); + ODM_Write4Byte(pDM_Odm, 0xe94, 0x01000001); //***************************************// //set AFE register @@ -2285,47 +2282,47 @@ _DPK_Globalparaset( //path A //regc68 到 regc84應該是要跟正常 Tx mode 時的設定一致 - ODM_Write4Byte(pDM_Odm, 0xc68, 0x19791979); - ODM_Write4Byte(pDM_Odm, 0xc6c, 0x19791979); - ODM_Write4Byte(pDM_Odm, 0xc70, 0x19791979); - ODM_Write4Byte(pDM_Odm, 0xc74, 0x19791979); - ODM_Write4Byte(pDM_Odm, 0xc78, 0x19791979); - ODM_Write4Byte(pDM_Odm, 0xc7c, 0x19791979); - ODM_Write4Byte(pDM_Odm, 0xc80, 0x19791979); - ODM_Write4Byte(pDM_Odm, 0xc84, 0x19791979); + ODM_Write4Byte(pDM_Odm, 0xc68, 0x19791979); + ODM_Write4Byte(pDM_Odm, 0xc6c, 0x19791979); + ODM_Write4Byte(pDM_Odm, 0xc70, 0x19791979); + ODM_Write4Byte(pDM_Odm, 0xc74, 0x19791979); + ODM_Write4Byte(pDM_Odm, 0xc78, 0x19791979); + ODM_Write4Byte(pDM_Odm, 0xc7c, 0x19791979); + ODM_Write4Byte(pDM_Odm, 0xc80, 0x19791979); + ODM_Write4Byte(pDM_Odm, 0xc84, 0x19791979); // force DAC/ADC power on - ODM_Write4Byte(pDM_Odm, 0xc60, 0x77777777); - ODM_Write4Byte(pDM_Odm, 0xc64, 0x77777777); + ODM_Write4Byte(pDM_Odm, 0xc60, 0x77777777); + ODM_Write4Byte(pDM_Odm, 0xc64, 0x77777777); //path B //rege68 到 rege84應該是要跟正常 Tx mode 時的設定一致 - ODM_Write4Byte(pDM_Odm, 0xe68, 0x19791979); - ODM_Write4Byte(pDM_Odm, 0xe6c, 0x19791979); - ODM_Write4Byte(pDM_Odm, 0xe70, 0x19791979); - ODM_Write4Byte(pDM_Odm, 0xe74, 0x19791979); - ODM_Write4Byte(pDM_Odm, 0xe78, 0x19791979); - ODM_Write4Byte(pDM_Odm, 0xe7c, 0x19791979); - ODM_Write4Byte(pDM_Odm, 0xe80, 0x19791979); - ODM_Write4Byte(pDM_Odm, 0xe84, 0x19791979); + ODM_Write4Byte(pDM_Odm, 0xe68, 0x19791979); + ODM_Write4Byte(pDM_Odm, 0xe6c, 0x19791979); + ODM_Write4Byte(pDM_Odm, 0xe70, 0x19791979); + ODM_Write4Byte(pDM_Odm, 0xe74, 0x19791979); + ODM_Write4Byte(pDM_Odm, 0xe78, 0x19791979); + ODM_Write4Byte(pDM_Odm, 0xe7c, 0x19791979); + ODM_Write4Byte(pDM_Odm, 0xe80, 0x19791979); + ODM_Write4Byte(pDM_Odm, 0xe84, 0x19791979); // force DAC/ADC power on - ODM_Write4Byte(pDM_Odm, 0xe60, 0x77777777); - ODM_Write4Byte(pDM_Odm, 0xe64, 0x77777777); + ODM_Write4Byte(pDM_Odm, 0xe60, 0x77777777); + ODM_Write4Byte(pDM_Odm, 0xe64, 0x77777777); } VOID _DPK_GetGainLoss( - IN PDM_ODM_T pDM_Odm, + IN PDM_ODM_T pDM_Odm, IN u1Byte path ) { u4Byte GL_I=0,GL_Q=0; u4Byte GL_I_tmp=0,GL_Q_tmp=0; - + u4Byte Power_GL; u2Byte Scaler[]={0x4000, 0x41db, 0x43c7, 0x45c3, 0x47cf, 0x49ec, 0x4c19, 0x4e46, 0x5093,0x52f2, //10 0x5560, 0x57cf, 0x5a7f, 0x5d0e, 0x5fbe @@ -2344,8 +2341,8 @@ _DPK_GetGainLoss( regsel = 0x40; } - ODM_Write4Byte(pDM_Odm, 0xc90+pagesel, 0x0601f0bf); - ODM_Write4Byte(pDM_Odm, 0xcb8+pagesel, 0x0c000000); + ODM_Write4Byte(pDM_Odm, 0xc90+pagesel, 0x0601f0bf); + ODM_Write4Byte(pDM_Odm, 0xcb8+pagesel, 0x0c000000); @@ -2361,8 +2358,8 @@ _DPK_GetGainLoss( if(GL_Q_tmp >= 0x8000) GL_Q = (GL_Q_tmp-0x8000+0x1); else - GL_Q = GL_Q_tmp; - + GL_Q = GL_Q_tmp; + Power_GL = ((GL_I*GL_I)+(GL_Q*GL_Q))/4; ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Power_GL = 0x%x", Power_GL)); @@ -2371,59 +2368,59 @@ _DPK_GetGainLoss( ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Gainloss = 0 dB\n")); } else if (63676 >= Power_GL && Power_GL > 60114){ - sindex = 1; + sindex = 1; ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Gainloss = 0.25 dB\n")); - } + } else if (60114 >= Power_GL && Power_GL> 56751){ - sindex = 2; + sindex = 2; ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Gainloss = 0.5 dB\n")); } else if (56751 >= Power_GL && Power_GL> 53577){ - sindex = 3; + sindex = 3; ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Gainloss = 0.75 dB\n")); } else if (53577 >= Power_GL && Power_GL> 49145){ - sindex = 4; + sindex = 4; ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Gainloss = 1 dB\n")); } else if (49145 >= Power_GL && Power_GL> 47750){ - sindex = 5; + sindex = 5; ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Gainloss = 1.25 dB\n")); } else if (47750 >= Power_GL && Power_GL> 45079){ - sindex = 6; + sindex = 6; ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Gainloss = 1.5 dB\n")); } else if (45079 >= Power_GL && Power_GL> 42557){ - sindex = 7; + sindex = 7; ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Gainloss = 1.75 dB\n")); } else if (42557 >= Power_GL && Power_GL> 40177){ - sindex = 8; + sindex = 8; ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Gainloss = 2 dB\n")); } else if (40177 >= Power_GL && Power_GL> 37929){ - sindex = 9; + sindex = 9; ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Gainloss = 2.25 dB\n")); } else if (37929 >= Power_GL && Power_GL> 35807){ - sindex = 10; + sindex = 10; ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Gainloss = 2.5 dB\n")); } else if (35807 >= Power_GL && Power_GL> 33804){ - sindex = 11; + sindex = 11; ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Gainloss = 2.75 dB\n")); } else if (33804 >= Power_GL && Power_GL> 31913){ - sindex = 12; + sindex = 12; ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Gainloss = 3 dB\n")); } else if (31913 >= Power_GL && Power_GL> 30128){ - sindex = 13; + sindex = 13; ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Gainloss = 3.25 dB\n")); } else if (30128 >= Power_GL){ - sindex = 14; + sindex = 14; ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Gainloss = 3.5 dB\n")); } @@ -2434,7 +2431,7 @@ _DPK_GetGainLoss( } -VOID +VOID _DPK_EnableDP( IN PDM_ODM_T pDM_Odm, IN u1Byte path, @@ -2444,7 +2441,7 @@ _DPK_EnableDP( //***************************************// //Enable DP - //***************************************// + //***************************************// //PWSF[6] = 0x40 = 0dB, set the address represented TXindex as 0dB u1Byte PWSF[] = { 0xff, 0xca, 0xa1, 0x80, 0x65, 0x51, 0x40, //6~0dB @@ -2473,18 +2470,18 @@ _DPK_EnableDP( // DPK setting // //=========// // reg82c[31] = b'1, 切換到 page C1 - ODM_Write4Byte(pDM_Odm, 0x82c, 0x802083d5); + ODM_Write4Byte(pDM_Odm, 0x82c, 0x802083d5); - ODM_Write4Byte(pDM_Odm, 0xc90+pagesel, 0x0000f098); - ODM_Write4Byte(pDM_Odm, 0xc94+pagesel, 0x776c9f84); - ODM_Write4Byte(pDM_Odm, 0xcc4+pagesel, 0x08840000); - ODM_Write4Byte(pDM_Odm, 0xcc8+pagesel, 0x20000000); - ODM_Write4Byte(pDM_Odm, 0xc8c+pagesel, 0x3c000000); + ODM_Write4Byte(pDM_Odm, 0xc90+pagesel, 0x0000f098); + ODM_Write4Byte(pDM_Odm, 0xc94+pagesel, 0x776c9f84); + ODM_Write4Byte(pDM_Odm, 0xcc4+pagesel, 0x08840000); + ODM_Write4Byte(pDM_Odm, 0xcc8+pagesel, 0x20000000); + ODM_Write4Byte(pDM_Odm, 0xc8c+pagesel, 0x3c000000); // 寫PWSF table in 1st SRAM for PA = 11 use - ODM_Write4Byte(pDM_Odm, 0xc20+pagesel, 0x00000800); + ODM_Write4Byte(pDM_Odm, 0xc20+pagesel, 0x00000800); ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Write PWSF table\n")); @@ -2506,7 +2503,7 @@ _DPK_EnableDP( else zeropoint = 6; - + for(i=0;i<16;i++) { @@ -2522,27 +2519,27 @@ _DPK_EnableDP( ODM_Write4Byte(pDM_Odm, 0xce4+pagesel, 0x00000001 | i<<1 | (PWSF[pwsf1]<<8) | (PWSF[pwsf2]<<16)); ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("0x%x\n", ODM_Read4Byte(pDM_Odm, 0xce4+pagesel))); - ODM_SetBBReg(pDM_Odm, 0xce4+pagesel, 0xff, 0x0); + ODM_SetBBReg(pDM_Odm, 0xce4+pagesel, 0xff, 0x0); } - ODM_Write4Byte(pDM_Odm, 0xce4+pagesel, 0x00000000); + ODM_Write4Byte(pDM_Odm, 0xce4+pagesel, 0x00000000); // reg82c[31] = b'0, 切換到 page C - ODM_Write4Byte(pDM_Odm, 0x82c, 0x002083d5); + ODM_Write4Byte(pDM_Odm, 0x82c, 0x002083d5); } VOID _DPK_pathABDPK( - IN PDM_ODM_T pDM_Odm + IN PDM_ODM_T pDM_Odm ) { u4Byte TXindex = 0; u1Byte path = 0; u4Byte pagesel = 0,regsel = 0; u4Byte i=0,j=0; - + for(path=0;path<2;path ++) //path A = 0; path B = 1; { ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("path %s DPK start!!!\n", (path==0)?"A":"B")); @@ -2557,12 +2554,12 @@ _DPK_pathABDPK( pagesel = 0x200; regsel = 0x40; } - + //***************************************// //find compress-2.5dB TX index //***************************************// - + // reg82c[31] = b'1, 切換到 page C1 ODM_Write4Byte(pDM_Odm, 0x82c, 0x802083d5); @@ -2576,38 +2573,38 @@ _DPK_pathABDPK( // dB_sel = b'110 ' 4.0 dB PA gain loss ODM_Write4Byte(pDM_Odm, 0xc20+pagesel, 0x00006000); - ODM_Write4Byte(pDM_Odm, 0xc90+pagesel, 0x0401e038); - ODM_Write4Byte(pDM_Odm, 0xc94+pagesel, 0xf76c9f84); - ODM_Write4Byte(pDM_Odm, 0xcc8+pagesel, 0x000c5599); - ODM_Write4Byte(pDM_Odm, 0xcc4+pagesel, 0x148b0000); - ODM_Write4Byte(pDM_Odm, 0xc8c+pagesel, 0x3c000000); + ODM_Write4Byte(pDM_Odm, 0xc90+pagesel, 0x0401e038); + ODM_Write4Byte(pDM_Odm, 0xc94+pagesel, 0xf76c9f84); + ODM_Write4Byte(pDM_Odm, 0xcc8+pagesel, 0x000c5599); + ODM_Write4Byte(pDM_Odm, 0xcc4+pagesel, 0x148b0000); + ODM_Write4Byte(pDM_Odm, 0xc8c+pagesel, 0x3c000000); // tx_amp ' 決定 Ramp 中各弦波的振幅大小 - ODM_Write4Byte(pDM_Odm, 0xc98+pagesel, 0x41382e21); - ODM_Write4Byte(pDM_Odm, 0xc9c+pagesel, 0x5b554f48); - ODM_Write4Byte(pDM_Odm, 0xca0+pagesel, 0x6f6b6661); - ODM_Write4Byte(pDM_Odm, 0xca4+pagesel, 0x817d7874); - ODM_Write4Byte(pDM_Odm, 0xca8+pagesel, 0x908c8884); - ODM_Write4Byte(pDM_Odm, 0xcac+pagesel, 0x9d9a9793); - ODM_Write4Byte(pDM_Odm, 0xcb0+pagesel, 0xaaa7a4a1); + ODM_Write4Byte(pDM_Odm, 0xc98+pagesel, 0x41382e21); + ODM_Write4Byte(pDM_Odm, 0xc9c+pagesel, 0x5b554f48); + ODM_Write4Byte(pDM_Odm, 0xca0+pagesel, 0x6f6b6661); + ODM_Write4Byte(pDM_Odm, 0xca4+pagesel, 0x817d7874); + ODM_Write4Byte(pDM_Odm, 0xca8+pagesel, 0x908c8884); + ODM_Write4Byte(pDM_Odm, 0xcac+pagesel, 0x9d9a9793); + ODM_Write4Byte(pDM_Odm, 0xcb0+pagesel, 0xaaa7a4a1); ODM_Write4Byte(pDM_Odm, 0xcb4+pagesel, 0xb6b3b0ad); - + // tx_inverse ' Ramp 中各弦波power 的倒數, 以計算出 PA 的 gain report?? - ODM_Write4Byte(pDM_Odm, 0xc40+pagesel, 0x02ce03e9); - ODM_Write4Byte(pDM_Odm, 0xc44+pagesel, 0x01fd0249); - ODM_Write4Byte(pDM_Odm, 0xc48+pagesel, 0x01a101c9); - ODM_Write4Byte(pDM_Odm, 0xc4c+pagesel, 0x016a0181); - ODM_Write4Byte(pDM_Odm, 0xc50+pagesel, 0x01430155); - ODM_Write4Byte(pDM_Odm, 0xc54+pagesel, 0x01270135); - ODM_Write4Byte(pDM_Odm, 0xc58+pagesel, 0x0112011c); + ODM_Write4Byte(pDM_Odm, 0xc40+pagesel, 0x02ce03e9); + ODM_Write4Byte(pDM_Odm, 0xc44+pagesel, 0x01fd0249); + ODM_Write4Byte(pDM_Odm, 0xc48+pagesel, 0x01a101c9); + ODM_Write4Byte(pDM_Odm, 0xc4c+pagesel, 0x016a0181); + ODM_Write4Byte(pDM_Odm, 0xc50+pagesel, 0x01430155); + ODM_Write4Byte(pDM_Odm, 0xc54+pagesel, 0x01270135); + ODM_Write4Byte(pDM_Odm, 0xc58+pagesel, 0x0112011c); ODM_Write4Byte(pDM_Odm, 0xc5c+pagesel, 0x01000108); - ODM_Write4Byte(pDM_Odm, 0xc60+pagesel, 0x00f100f8); - ODM_Write4Byte(pDM_Odm, 0xc64+pagesel, 0x00e500eb); - ODM_Write4Byte(pDM_Odm, 0xc68+pagesel, 0x00db00e0); - ODM_Write4Byte(pDM_Odm, 0xc6c+pagesel, 0x00d100d5); - ODM_Write4Byte(pDM_Odm, 0xc70+pagesel, 0x00c900cd); - ODM_Write4Byte(pDM_Odm, 0xc74+pagesel, 0x00c200c5); - ODM_Write4Byte(pDM_Odm, 0xc78+pagesel, 0x00bb00be); + ODM_Write4Byte(pDM_Odm, 0xc60+pagesel, 0x00f100f8); + ODM_Write4Byte(pDM_Odm, 0xc64+pagesel, 0x00e500eb); + ODM_Write4Byte(pDM_Odm, 0xc68+pagesel, 0x00db00e0); + ODM_Write4Byte(pDM_Odm, 0xc6c+pagesel, 0x00d100d5); + ODM_Write4Byte(pDM_Odm, 0xc70+pagesel, 0x00c900cd); + ODM_Write4Byte(pDM_Odm, 0xc74+pagesel, 0x00c200c5); + ODM_Write4Byte(pDM_Odm, 0xc78+pagesel, 0x00bb00be); ODM_Write4Byte(pDM_Odm, 0xc7c+pagesel, 0x00b500b8); //============// @@ -2617,7 +2614,7 @@ _DPK_pathABDPK( //pathA,pathB standby mode ODM_SetRFReg(pDM_Odm, (ODM_RF_RADIO_PATH_E)0x0, 0x0, bRFRegOffsetMask, 0x10000); ODM_SetRFReg(pDM_Odm, (ODM_RF_RADIO_PATH_E)0x1, 0x0, bRFRegOffsetMask, 0x10000); - + // 00[4:0] = Tx AGC, 00[9:5] = Rx AGC (BB), 00[12:10] = Rx AGC (LNA) ODM_SetRFReg(pDM_Odm, (ODM_RF_RADIO_PATH_E)(0x0+path), 0x0, bRFRegOffsetMask, 0x50bff); @@ -2628,19 +2625,19 @@ _DPK_pathABDPK( // 8f[14:13] = PGA2 gain ODM_SetRFReg(pDM_Odm, (ODM_RF_RADIO_PATH_E)(0x0+path), 0x8f, bRFRegOffsetMask, 0x8e001); - + // one shot - ODM_Write4Byte(pDM_Odm, 0xcc8+pagesel, 0x800c5599); - ODM_Write4Byte(pDM_Odm, 0xcc8+pagesel, 0x000c5599); - + ODM_Write4Byte(pDM_Odm, 0xcc8+pagesel, 0x800c5599); + ODM_Write4Byte(pDM_Odm, 0xcc8+pagesel, 0x000c5599); + // delay 100 ms ODM_delay_ms(100); - + // read back - ODM_Write4Byte(pDM_Odm, 0xc90+pagesel, 0x0109f018); - ODM_Write4Byte(pDM_Odm, 0xcb8+pagesel, 0x09000000); + ODM_Write4Byte(pDM_Odm, 0xc90+pagesel, 0x0109f018); + ODM_Write4Byte(pDM_Odm, 0xcb8+pagesel, 0x09000000); // 可以在 d00[3:0] 中讀回, dB_sel 中所設定的 gain loss 會落在哪一個 Tx AGC 設定 // 讀回d00[3:0] = h'1 ' Tx AGC = 15 // 讀回d00[3:0] = h'2 ' Tx AGC = 16 @@ -2661,71 +2658,71 @@ _DPK_pathABDPK( //get LUT //***************************************// - ODM_Write4Byte(pDM_Odm, 0xc90+pagesel, 0x0001e038); - ODM_Write4Byte(pDM_Odm, 0xc94+pagesel, 0xf76c9f84); - ODM_Write4Byte(pDM_Odm, 0xcc8+pagesel, 0x400c5599); + ODM_Write4Byte(pDM_Odm, 0xc90+pagesel, 0x0001e038); + ODM_Write4Byte(pDM_Odm, 0xc94+pagesel, 0xf76c9f84); + ODM_Write4Byte(pDM_Odm, 0xcc8+pagesel, 0x400c5599); ODM_Write4Byte(pDM_Odm, 0xcc4+pagesel, 0x11930080); //0xcc4[9:4]= DPk fail threshold - ODM_Write4Byte(pDM_Odm, 0xc8c+pagesel, 0x3c000000); - + ODM_Write4Byte(pDM_Odm, 0xc8c+pagesel, 0x3c000000); + // tx_amp ' 決定 Ramp 中各弦波的振幅大小 - ODM_Write4Byte(pDM_Odm, 0xc98+pagesel, 0x41382e21); - ODM_Write4Byte(pDM_Odm, 0xc9c+pagesel, 0x5b554f48); - ODM_Write4Byte(pDM_Odm, 0xca0+pagesel, 0x6f6b6661); - ODM_Write4Byte(pDM_Odm, 0xca4+pagesel, 0x817d7874); - ODM_Write4Byte(pDM_Odm, 0xca8+pagesel, 0x908c8884); - ODM_Write4Byte(pDM_Odm, 0xcac+pagesel, 0x9d9a9793); - ODM_Write4Byte(pDM_Odm, 0xcb0+pagesel, 0xaaa7a4a1); - ODM_Write4Byte(pDM_Odm, 0xcb4+pagesel, 0xb6b3b0ad); - - // tx_inverse ' Ramp 中各弦波power 的倒數, 以計算出 PA 的 gain - ODM_Write4Byte(pDM_Odm, 0xc40+pagesel, 0x02ce03e9); - ODM_Write4Byte(pDM_Odm, 0xc44+pagesel, 0x01fd0249); - ODM_Write4Byte(pDM_Odm, 0xc48+pagesel, 0x01a101c9); - ODM_Write4Byte(pDM_Odm, 0xc4c+pagesel, 0x016a0181); - ODM_Write4Byte(pDM_Odm, 0xc50+pagesel, 0x01430155); - ODM_Write4Byte(pDM_Odm, 0xc54+pagesel, 0x01270135); - ODM_Write4Byte(pDM_Odm, 0xc58+pagesel, 0x0112011c); - ODM_Write4Byte(pDM_Odm, 0xc5c+pagesel, 0x01000108); - ODM_Write4Byte(pDM_Odm, 0xc60+pagesel, 0x00f100f8); - ODM_Write4Byte(pDM_Odm, 0xc64+pagesel, 0x00e500eb); - ODM_Write4Byte(pDM_Odm, 0xc68+pagesel, 0x00db00e0); - ODM_Write4Byte(pDM_Odm, 0xc6c+pagesel, 0x00d100d5); - ODM_Write4Byte(pDM_Odm, 0xc70+pagesel, 0x00c900cd); - ODM_Write4Byte(pDM_Odm, 0xc74+pagesel, 0x00c200c5); - ODM_Write4Byte(pDM_Odm, 0xc78+pagesel, 0x00bb00be); - ODM_Write4Byte(pDM_Odm, 0xc7c+pagesel, 0x00b500b8); - - //fill BB TX index for the DPK reference + ODM_Write4Byte(pDM_Odm, 0xc98+pagesel, 0x41382e21); + ODM_Write4Byte(pDM_Odm, 0xc9c+pagesel, 0x5b554f48); + ODM_Write4Byte(pDM_Odm, 0xca0+pagesel, 0x6f6b6661); + ODM_Write4Byte(pDM_Odm, 0xca4+pagesel, 0x817d7874); + ODM_Write4Byte(pDM_Odm, 0xca8+pagesel, 0x908c8884); + ODM_Write4Byte(pDM_Odm, 0xcac+pagesel, 0x9d9a9793); + ODM_Write4Byte(pDM_Odm, 0xcb0+pagesel, 0xaaa7a4a1); + ODM_Write4Byte(pDM_Odm, 0xcb4+pagesel, 0xb6b3b0ad); + + // tx_inverse ' Ramp 中各弦波power 的倒數, 以計算出 PA 的 gain + ODM_Write4Byte(pDM_Odm, 0xc40+pagesel, 0x02ce03e9); + ODM_Write4Byte(pDM_Odm, 0xc44+pagesel, 0x01fd0249); + ODM_Write4Byte(pDM_Odm, 0xc48+pagesel, 0x01a101c9); + ODM_Write4Byte(pDM_Odm, 0xc4c+pagesel, 0x016a0181); + ODM_Write4Byte(pDM_Odm, 0xc50+pagesel, 0x01430155); + ODM_Write4Byte(pDM_Odm, 0xc54+pagesel, 0x01270135); + ODM_Write4Byte(pDM_Odm, 0xc58+pagesel, 0x0112011c); + ODM_Write4Byte(pDM_Odm, 0xc5c+pagesel, 0x01000108); + ODM_Write4Byte(pDM_Odm, 0xc60+pagesel, 0x00f100f8); + ODM_Write4Byte(pDM_Odm, 0xc64+pagesel, 0x00e500eb); + ODM_Write4Byte(pDM_Odm, 0xc68+pagesel, 0x00db00e0); + ODM_Write4Byte(pDM_Odm, 0xc6c+pagesel, 0x00d100d5); + ODM_Write4Byte(pDM_Odm, 0xc70+pagesel, 0x00c900cd); + ODM_Write4Byte(pDM_Odm, 0xc74+pagesel, 0x00c200c5); + ODM_Write4Byte(pDM_Odm, 0xc78+pagesel, 0x00bb00be); + ODM_Write4Byte(pDM_Odm, 0xc7c+pagesel, 0x00b500b8); + + //fill BB TX index for the DPK reference // reg82c[31] =1b'0, 切換到 page C - ODM_Write4Byte(pDM_Odm, 0x82c, 0x002083d5); + ODM_Write4Byte(pDM_Odm, 0x82c, 0x002083d5); - ODM_Write4Byte(pDM_Odm, 0xc20+pagesel, 0x3c3c3c3c); - ODM_Write4Byte(pDM_Odm, 0xc24+pagesel, 0x3c3c3c3c); - ODM_Write4Byte(pDM_Odm, 0xc28+pagesel, 0x3c3c3c3c); - ODM_Write4Byte(pDM_Odm, 0xc2c+pagesel, 0x3c3c3c3c); - ODM_Write4Byte(pDM_Odm, 0xc30+pagesel, 0x3c3c3c3c); - ODM_Write4Byte(pDM_Odm, 0xc34+pagesel, 0x3c3c3c3c); - ODM_Write4Byte(pDM_Odm, 0xc38+pagesel, 0x3c3c3c3c); - ODM_Write4Byte(pDM_Odm, 0xc3c+pagesel, 0x3c3c3c3c); - ODM_Write4Byte(pDM_Odm, 0xc40+pagesel, 0x3c3c3c3c); - ODM_Write4Byte(pDM_Odm, 0xc44+pagesel, 0x3c3c3c3c); - ODM_Write4Byte(pDM_Odm, 0xc48+pagesel, 0x3c3c3c3c); - ODM_Write4Byte(pDM_Odm, 0xc4c+pagesel, 0x3c3c3c3c); + ODM_Write4Byte(pDM_Odm, 0xc20+pagesel, 0x3c3c3c3c); + ODM_Write4Byte(pDM_Odm, 0xc24+pagesel, 0x3c3c3c3c); + ODM_Write4Byte(pDM_Odm, 0xc28+pagesel, 0x3c3c3c3c); + ODM_Write4Byte(pDM_Odm, 0xc2c+pagesel, 0x3c3c3c3c); + ODM_Write4Byte(pDM_Odm, 0xc30+pagesel, 0x3c3c3c3c); + ODM_Write4Byte(pDM_Odm, 0xc34+pagesel, 0x3c3c3c3c); + ODM_Write4Byte(pDM_Odm, 0xc38+pagesel, 0x3c3c3c3c); + ODM_Write4Byte(pDM_Odm, 0xc3c+pagesel, 0x3c3c3c3c); + ODM_Write4Byte(pDM_Odm, 0xc40+pagesel, 0x3c3c3c3c); + ODM_Write4Byte(pDM_Odm, 0xc44+pagesel, 0x3c3c3c3c); + ODM_Write4Byte(pDM_Odm, 0xc48+pagesel, 0x3c3c3c3c); + ODM_Write4Byte(pDM_Odm, 0xc4c+pagesel, 0x3c3c3c3c); // reg82c[31] =1b'1, 切換到 page C1 - ODM_Write4Byte(pDM_Odm, 0x82c, 0x802083d5); - - + ODM_Write4Byte(pDM_Odm, 0x82c, 0x802083d5); + + // r_agc_boudary // PA gain = 11 對應 tx_agc 從1f 到11 boundary = b'11111 ' PageC1 的 bc0[4:0] = 11111 // PA gain = 10 對應 tx_agc 從11 到11 ? boundary = b'10011 ' PageC1 的 bc0[9:5] = 10001 // PA gain = 01 對應 tx_agc 從10 到0e ? boundary = b'10000 ' PageC1 的 bc0[14:10] = 10000 // PA gain = 00 對應 tx_agc 從0d 到00 ? boundary = b'01101 ' PageC1 的 bc0[19:15] = 01101 - ODM_Write4Byte(pDM_Odm, 0xcbc+pagesel, 0x0006c23f); - + ODM_Write4Byte(pDM_Odm, 0xcbc+pagesel, 0x0006c23f); + // r_bnd, 另外4塊 PWSF (power scaling factor) 的 boundary, 因為目前只有在 PA gain = 11 時才做補償, 所以設成 h'fffff 即可. ODM_Write4Byte(pDM_Odm, 0xcb8+pagesel, 0x000fffff); @@ -2743,7 +2740,7 @@ _DPK_pathABDPK( // delay 100 ms ODM_delay_ms(100); - + // read back dp_fail report ODM_Write4Byte(pDM_Odm, 0xcb8+pagesel, 0x00000000); @@ -2761,9 +2758,9 @@ _DPK_pathABDPK( - //read LMS table -->debug message only + //read LMS table -->debug message only ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("read LMS\n")); - + for(i=0;i<8;i++){ ODM_Write4Byte(pDM_Odm, 0xc90+pagesel, 0x0601f0b8+i); for(j=0;j<4;j++){ @@ -2771,8 +2768,8 @@ _DPK_pathABDPK( ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("0x%x", ODM_Read4Byte(pDM_Odm, 0xd00+regsel))); } } - - + + //***************************************// //get gain loss //***************************************// @@ -2782,19 +2779,19 @@ _DPK_pathABDPK( //***************************************// //Enable DP - //***************************************// + //***************************************// _DPK_EnableDP(pDM_Odm, path, TXindex); } - + } -VOID +VOID phy_DPCalibrate_8812A( IN PDM_ODM_T pDM_Odm ) @@ -2805,7 +2802,7 @@ phy_DPCalibrate_8812A( 0xc20, 0xc24, 0xc28, 0xc2c, 0xc30, 0xc34, 0xc38, 0xc3c, 0xc40, 0xc44, // 30 0xc48, 0xc4c, 0xe50, 0xe20, 0xe24, 0xe28, 0xe2c, 0xe30, 0xe34, 0xe38, // 40 0xe3c, 0xe40, 0xe44, 0xe48, 0xe4c, 0xeb8, 0xe00, 0xe94, 0xe60, 0xe64, //50 - 0xe68, 0xe6c, 0xe70, 0xe74, 0xe78, 0xe7c, 0xe80, 0xe84 + 0xe68, 0xe6c, 0xe70, 0xe74, 0xe78, 0xe7c, 0xe80, 0xe84 }; u4Byte backupRegData[sizeof(backupRegAddrs)/sizeof(u4Byte)]; @@ -2826,20 +2823,20 @@ phy_DPCalibrate_8812A( //reload BB&MAC defaul value; _DPK_parareload(pDM_Odm,backupRegAddrs, backupRegData, sizeof(backupRegAddrs)/sizeof(u4Byte)); - -} - -VOID -PHY_DPCalibrate_8812A( - IN PDM_ODM_T pDM_Odm - ) -{ + +} + +VOID +PHY_DPCalibrate_8812A( + IN PDM_ODM_T pDM_Odm + ) +{ ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("===> PHY_DPCalibrate_8812A\n")); - phy_DPCalibrate_8812A(pDM_Odm); + phy_DPCalibrate_8812A(pDM_Odm); ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("<=== PHY_DPCalibrate_8812A\n")); -} - - - - - +} + + + + + diff --git a/hal/OUTSRC/rtl8821a/HalPhyRf_8821A.c b/hal/OUTSRC/rtl8821a/HalPhyRf_8821A.c index 534186f..de7ecc4 100644 --- a/hal/OUTSRC/rtl8821a/HalPhyRf_8821A.c +++ b/hal/OUTSRC/rtl8821a/HalPhyRf_8821A.c @@ -543,7 +543,7 @@ void _IQK_ConfigureMAC_8821A( ODM_SetBBReg(pDM_Odm, 0x838, 0xf, 0xc); // CCA off } -#define cal_num 3 +#define cal_num 10 void _IQK_Tx_8821A( IN PDM_ODM_T pDM_Odm, @@ -552,7 +552,7 @@ void _IQK_Tx_8821A( { u4Byte TX_fail, RX_fail, delay_count, IQK_ready, cal_retry, cal = 0, temp_reg65; int TX_X = 0, TX_Y = 0, RX_X = 0, RX_Y = 0, TX_Average = 0, RX_Average = 0; - int TX_X0[10], TX_Y0[10], TX_X0_RXK[10], TX_Y0_RXK[10], RX_X0[10], RX_Y0[10]; + int TX_X0[cal_num], TX_Y0[cal_num], TX_X0_RXK[cal_num], TX_Y0_RXK[cal_num], RX_X0[cal_num], RX_Y0[cal_num]; BOOLEAN TX0IQKOK = FALSE, RX0IQKOK = FALSE; BOOLEAN VDF_enable = FALSE; int i, k, VDF_Y[3], VDF_X[3], Tx_dt[3], Rx_dt[3], ii, dx = 0, dy = 0, TX_finish = 0, RX_finish = 0;