1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842 |
- #include "../odm_precomp.h"
- #define ODM_TXPWRTRACK_MAX_IDX8812A 6
- void DoIQK_8812A(
- PDM_ODM_T pDM_Odm,
- u1Byte DeltaThermalIndex,
- u1Byte ThermalValue,
- u1Byte Threshold
- )
- {
- #if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
- PADAPTER Adapter = pDM_Odm->Adapter;
- HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
- #endif
- ODM_ResetIQKResult(pDM_Odm);
- #if(DM_ODM_SUPPORT_TYPE & ODM_WIN)
- #if (DEV_BUS_TYPE == RT_PCI_INTERFACE)
- #if USE_WORKITEM
- PlatformAcquireMutex(&pHalData->mxChnlBwControl);
- #else
- PlatformAcquireSpinLock(Adapter, RT_CHANNEL_AND_BANDWIDTH_SPINLOCK);
- #endif
- #elif((DEV_BUS_TYPE == RT_USB_INTERFACE) || (DEV_BUS_TYPE == RT_SDIO_INTERFACE))
- PlatformAcquireMutex(&pHalData->mxChnlBwControl);
- #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 USE_WORKITEM
- PlatformReleaseMutex(&pHalData->mxChnlBwControl);
- #else
- PlatformReleaseSpinLock(Adapter, RT_CHANNEL_AND_BANDWIDTH_SPINLOCK);
- #endif
- #elif((DEV_BUS_TYPE == RT_USB_INTERFACE) || (DEV_BUS_TYPE == RT_SDIO_INTERFACE))
- PlatformReleaseMutex(&pHalData->mxChnlBwControl);
- #endif
- #endif
- }
- VOID
- ODM_TxPwrTrackSetPwr8812A(
- PDM_ODM_T pDM_Odm,
- PWRTRACK_METHOD Method,
- u1Byte RFPath,
- u1Byte ChannelMappedIndex
- )
- {
- u4Byte finalBbSwingIdx[2];
-
- PADAPTER Adapter = pDM_Odm->Adapter;
- PHAL_DATA_TYPE pHalData = GET_HAL_DATA(Adapter);
- u1Byte PwrTrackingLimit = 26;
- u1Byte TxRate = 0xFF;
- s1Byte Final_OFDM_Swing_Index = 0;
- s1Byte Final_CCK_Swing_Index = 0;
- u1Byte i = 0;
- #if 0
- #if (MP_DRIVER==1)
- PMPT_CONTEXT pMptCtx = &(Adapter->MptCtx);
- TxRate = MptToMgntRate(pMptCtx->MptRateIndex);
- #else
- u2Byte rate = *(pDM_Odm->pForcedDataRate);
- if(!rate)
- {
- if(pDM_Odm->TxRate != 0xFF)
- TxRate = HwRateToMRate8812(pDM_Odm->TxRate);
- }
- else
- {
- TxRate = (u1Byte) rate;
- }
- #endif
- ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("===>ODM_TxPwrTrackSetPwr8812A\n"));
- #endif
- if(TxRate != 0xFF)
- {
-
- if((TxRate >= MGN_1M)&&(TxRate <= MGN_11M))
- PwrTrackingLimit = 32;
-
- else if((TxRate >= MGN_6M)&&(TxRate <= MGN_48M))
- PwrTrackingLimit = 32;
- else if(TxRate == MGN_54M)
- PwrTrackingLimit = 30;
-
- else if((TxRate >= MGN_MCS0)&&(TxRate <= MGN_MCS2))
- PwrTrackingLimit = 34;
- else if((TxRate >= MGN_MCS3)&&(TxRate <= MGN_MCS4))
- PwrTrackingLimit = 32;
- else if((TxRate >= MGN_MCS5)&&(TxRate <= MGN_MCS7))
- PwrTrackingLimit = 30;
- else if((TxRate >= MGN_MCS8)&&(TxRate <= MGN_MCS10))
- PwrTrackingLimit = 34;
- else if((TxRate >= MGN_MCS11)&&(TxRate <= MGN_MCS12))
- PwrTrackingLimit = 32;
- else if((TxRate >= MGN_MCS13)&&(TxRate <= MGN_MCS15))
- PwrTrackingLimit = 30;
-
-
- else if((TxRate >= MGN_VHT1SS_MCS0)&&(TxRate <= MGN_VHT1SS_MCS2))
- PwrTrackingLimit = 34;
- else if((TxRate >= MGN_VHT1SS_MCS3)&&(TxRate <= MGN_VHT1SS_MCS4))
- PwrTrackingLimit = 32;
- else if((TxRate >= MGN_VHT1SS_MCS5)&&(TxRate <= MGN_VHT1SS_MCS6))
- PwrTrackingLimit = 30;
- else if(TxRate == MGN_VHT1SS_MCS7)
- PwrTrackingLimit = 28;
- else if(TxRate == MGN_VHT1SS_MCS8)
- PwrTrackingLimit = 26;
- else if(TxRate == MGN_VHT1SS_MCS9)
- PwrTrackingLimit = 24;
-
- else if((TxRate >= MGN_VHT2SS_MCS0)&&(TxRate <= MGN_VHT2SS_MCS2))
- PwrTrackingLimit = 34;
- else if((TxRate >= MGN_VHT2SS_MCS3)&&(TxRate <= MGN_VHT2SS_MCS4))
- PwrTrackingLimit = 32;
- else if((TxRate >= MGN_VHT2SS_MCS5)&&(TxRate <= MGN_VHT2SS_MCS6))
- PwrTrackingLimit = 30;
- else if(TxRate == MGN_VHT2SS_MCS7)
- PwrTrackingLimit = 28;
- else if(TxRate == MGN_VHT2SS_MCS8)
- PwrTrackingLimit = 26;
- else if(TxRate == MGN_VHT2SS_MCS9)
- PwrTrackingLimit = 24;
- 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"));
- 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
- {
- 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]]);
- }
-
- }
- else if (Method == MIX_MODE)
- {
- 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(Final_OFDM_Swing_Index > PwrTrackingLimit)
- {
- pDM_Odm->Remnant_CCKSwingIdx= 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]);
- pDM_Odm->Modify_TxAGC_Flag_PathA= TRUE;
-
-
- PHY_SetTxPowerLevel8812(Adapter, pHalData->CurrentChannel);
- ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("******Path_A Over BBSwing Limit , PwrTrackingLimit = %d , Remnant TxAGC Value = %d \n", PwrTrackingLimit, pDM_Odm->Remnant_OFDMSwingIdx[RFPath]));
- }
- else if (Final_OFDM_Swing_Index < 0)
- {
- pDM_Odm->Remnant_CCKSwingIdx= Final_OFDM_Swing_Index;
- pDM_Odm->Remnant_OFDMSwingIdx[RFPath] = Final_OFDM_Swing_Index;
- ODM_SetBBReg(pDM_Odm, rA_TxScale_Jaguar, 0xFFE00000, TxScalingTable_Jaguar[0]);
- pDM_Odm->Modify_TxAGC_Flag_PathA= TRUE;
-
-
- PHY_SetTxPowerLevel8812(Adapter, pHalData->CurrentChannel);
- ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("******Path_A Lower then BBSwing lower bound 0 , Remnant TxAGC Value = %d \n", pDM_Odm->Remnant_OFDMSwingIdx[RFPath]));
- }
- else
- {
- ODM_SetBBReg(pDM_Odm, rA_TxScale_Jaguar, 0xFFE00000, TxScalingTable_Jaguar[Final_OFDM_Swing_Index]);
- ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("******Path_A Compensate with BBSwing , Final_OFDM_Swing_Index = %d \n", Final_OFDM_Swing_Index));
- if(pDM_Odm->Modify_TxAGC_Flag_PathA)
- {
- pDM_Odm->Remnant_CCKSwingIdx= 0;
- pDM_Odm->Remnant_OFDMSwingIdx[RFPath] = 0;
-
-
- PHY_SetTxPowerLevel8812(Adapter, pHalData->CurrentChannel);
- pDM_Odm->Modify_TxAGC_Flag_PathA= FALSE;
- 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(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]);
- pDM_Odm->Modify_TxAGC_Flag_PathB= TRUE;
-
- ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("******Path_B Over BBSwing Limit , PwrTrackingLimit = %d , Remnant TxAGC Value = %d \n", PwrTrackingLimit, pDM_Odm->Remnant_OFDMSwingIdx[RFPath]));
- }
- else if (Final_OFDM_Swing_Index < 0)
- {
- pDM_Odm->Remnant_OFDMSwingIdx[RFPath] = Final_OFDM_Swing_Index;
- ODM_SetBBReg(pDM_Odm, rB_TxScale_Jaguar, 0xFFE00000, TxScalingTable_Jaguar[0]);
- pDM_Odm->Modify_TxAGC_Flag_PathB = TRUE;
-
- ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("******Path_B Lower then BBSwing lower bound 0 , Remnant TxAGC Value = %d \n", pDM_Odm->Remnant_OFDMSwingIdx[RFPath]));
- }
- else
- {
- ODM_SetBBReg(pDM_Odm, rB_TxScale_Jaguar, 0xFFE00000, TxScalingTable_Jaguar[Final_OFDM_Swing_Index]);
- ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("******Path_B Compensate with BBSwing , Final_OFDM_Swing_Index = %d \n", Final_OFDM_Swing_Index));
- if(pDM_Odm->Modify_TxAGC_Flag_PathB)
- {
- pDM_Odm->Remnant_CCKSwingIdx= 0;
- pDM_Odm->Remnant_OFDMSwingIdx[RFPath] = 0;
-
- pDM_Odm->Modify_TxAGC_Flag_PathB = FALSE;
- ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("******Path_B pDM_Odm->Modify_TxAGC_Flag = FALSE \n"));
- }
- }
- }
- }
- else
- {
- return;
- }
- }
- VOID
- GetDeltaSwingTable_8812A(
- IN PDM_ODM_T pDM_Odm,
- OUT pu1Byte *TemperatureUP_A,
- OUT pu1Byte *TemperatureDOWN_A,
- OUT pu1Byte *TemperatureUP_B,
- OUT pu1Byte *TemperatureDOWN_B
- )
- {
- PADAPTER Adapter = pDM_Odm->Adapter;
- PODM_RF_CAL_T pRFCalibrateInfo = &(pDM_Odm->RFCalibrateInfo);
- HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
- u2Byte rate = *(pDM_Odm->pForcedDataRate);
- u1Byte channel = pHalData->CurrentChannel;
- if ( 1 <= channel && channel <= 14) {
- if (IS_CCK_RATE(rate)) {
- *TemperatureUP_A = pRFCalibrateInfo->DeltaSwingTableIdx_2GCCKA_P;
- *TemperatureDOWN_A = pRFCalibrateInfo->DeltaSwingTableIdx_2GCCKA_N;
- *TemperatureUP_B = pRFCalibrateInfo->DeltaSwingTableIdx_2GCCKB_P;
- *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;
- }
- } else if ( 36 <= channel && channel <= 64) {
- *TemperatureUP_A = pRFCalibrateInfo->DeltaSwingTableIdx_5GA_P[0];
- *TemperatureDOWN_A = pRFCalibrateInfo->DeltaSwingTableIdx_5GA_N[0];
- *TemperatureUP_B = pRFCalibrateInfo->DeltaSwingTableIdx_5GB_P[0];
- *TemperatureDOWN_B = pRFCalibrateInfo->DeltaSwingTableIdx_5GB_N[0];
- } else if ( 100 <= channel && channel <= 140) {
- *TemperatureUP_A = pRFCalibrateInfo->DeltaSwingTableIdx_5GA_P[1];
- *TemperatureDOWN_A = pRFCalibrateInfo->DeltaSwingTableIdx_5GA_N[1];
- *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];
- } else {
- *TemperatureUP_A = (pu1Byte)DeltaSwingTableIdx_2GA_P_8188E;
- *TemperatureDOWN_A = (pu1Byte)DeltaSwingTableIdx_2GA_N_8188E;
- *TemperatureUP_B = (pu1Byte)DeltaSwingTableIdx_2GA_P_8188E;
- *TemperatureDOWN_B = (pu1Byte)DeltaSwingTableIdx_2GA_N_8188E;
- }
-
- return;
- }
- void ConfigureTxpowerTrack_8812A(
- PTXPWRTRACK_CFG pConfig
- )
- {
- pConfig->SwingTableSize_CCK = TXSCALE_TABLE_SIZE;
- pConfig->SwingTableSize_OFDM = TXSCALE_TABLE_SIZE;
- pConfig->Threshold_IQK = IQK_THRESHOLD;
- 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;
- pConfig->GetDeltaSwingTable = GetDeltaSwingTable_8812A;
- }
- #if !(DM_ODM_SUPPORT_TYPE & ODM_WIN)
- BOOLEAN
- ODM_CheckPowerStatus(
- IN PADAPTER Adapter)
- {
- return TRUE;
- }
- #endif
- #define BW_20M 0
- #define BW_40M 1
- #define BW_80M 2
- void _IQK_RX_FillIQC_8812A(
- IN PDM_ODM_T pDM_Odm,
- IN ODM_RF_RADIO_PATH_E Path,
- IN unsigned int RX_X,
- IN unsigned int RX_Y
- )
- {
- switch (Path) {
- case ODM_RF_PATH_A:
- {
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0);
- if (RX_X>>1 ==0x112 || RX_Y>>1 == 0x3ee){
- ODM_SetBBReg(pDM_Odm, 0xc10, 0x000003ff, 0x100);
- ODM_SetBBReg(pDM_Odm, 0xc10, 0x03ff0000, 0);
- ODM_RT_TRACE(pDM_Odm,ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("RX_X = %x;;RX_Y = %x ====>fill to IQC\n", RX_X>>1&0x000003ff, RX_Y>>1&0x000003ff));
- }
- else{
- ODM_SetBBReg(pDM_Odm, 0xc10, 0x000003ff, RX_X>>1);
- ODM_SetBBReg(pDM_Odm, 0xc10, 0x03ff0000, RX_Y>>1);
- ODM_RT_TRACE(pDM_Odm,ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("RX_X = %x;;RX_Y = %x ====>fill to IQC\n", RX_X>>1&0x000003ff, RX_Y>>1&0x000003ff));
- ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("0xc10 = %x ====>fill to IQC\n", ODM_Read4Byte(pDM_Odm, 0xc10)));
- }
- }
- break;
- case ODM_RF_PATH_B:
- {
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0);
- if (RX_X>>1 ==0x112 || RX_Y>>1 == 0x3ee){
- ODM_SetBBReg(pDM_Odm, 0xe10, 0x000003ff, 0x100);
- ODM_SetBBReg(pDM_Odm, 0xe10, 0x03ff0000, 0);
- ODM_RT_TRACE(pDM_Odm,ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("RX_X = %x;;RX_Y = %x ====>fill to IQC\n", RX_X>>1&0x000003ff, RX_Y>>1&0x000003ff));
- }
- else{
- ODM_SetBBReg(pDM_Odm, 0xe10, 0x000003ff, RX_X>>1);
- ODM_SetBBReg(pDM_Odm, 0xe10, 0x03ff0000, RX_Y>>1);
- ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("RX_X = %x;;RX_Y = %x====>fill to IQC\n ", RX_X>>1&0x000003ff, RX_Y>>1&0x000003ff));
- ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("0xe10 = %x====>fill to IQC\n", ODM_Read4Byte(pDM_Odm, 0xe10)));
- }
- }
- break;
- default:
- break;
- };
- }
- void _IQK_TX_FillIQC_8812A(
- IN PDM_ODM_T pDM_Odm,
- IN ODM_RF_RADIO_PATH_E Path,
- IN unsigned int TX_X,
- IN unsigned int TX_Y
- )
- {
- switch (Path) {
- case ODM_RF_PATH_A:
- {
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x1);
- ODM_Write4Byte(pDM_Odm, 0xc90, 0x00000080);
- ODM_Write4Byte(pDM_Odm, 0xcc4, 0x20040000);
- ODM_Write4Byte(pDM_Odm, 0xcc8, 0x20000000);
- ODM_SetBBReg(pDM_Odm, 0xccc, 0x000007ff, TX_Y);
- ODM_SetBBReg(pDM_Odm, 0xcd4, 0x000007ff, TX_X);
- 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, ("0xcd4 = %x;;0xccc = %x ====>fill to IQC\n", ODM_GetBBReg(pDM_Odm, 0xcd4, 0x000007ff), ODM_GetBBReg(pDM_Odm, 0xccc, 0x000007ff)));
- }
- break;
- case ODM_RF_PATH_B:
- {
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x1);
- ODM_Write4Byte(pDM_Odm, 0xe90, 0x00000080);
- ODM_Write4Byte(pDM_Odm, 0xec4, 0x20040000);
- ODM_Write4Byte(pDM_Odm, 0xec8, 0x20000000);
- ODM_SetBBReg(pDM_Odm, 0xecc, 0x000007ff, TX_Y);
- ODM_SetBBReg(pDM_Odm, 0xed4, 0x000007ff, TX_X);
- 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;
- default:
- break;
- };
- }
- void _IQK_BackupMacBB_8812A(
- IN PDM_ODM_T pDM_Odm,
- IN pu4Byte MACBB_backup,
- IN pu4Byte Backup_MACBB_REG,
- IN u4Byte MACBB_NUM
- )
- {
- u4Byte i;
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0);
-
- 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 u4Byte RF_NUM
- )
- {
- u4Byte i;
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0);
-
- for (i = 0; i < RF_NUM; i++){
- RFA_backup[i] = ODM_GetRFReg(pDM_Odm, ODM_RF_PATH_A, Backup_RF_REG[i], bMaskDWord);
- RFB_backup[i] = ODM_GetRFReg(pDM_Odm, ODM_RF_PATH_B, Backup_RF_REG[i], bMaskDWord);
- }
- ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("BackupRF Success!!!!\n"));
- }
- void _IQK_BackupAFE_8812A(
- IN PDM_ODM_T pDM_Odm,
- IN pu4Byte AFE_backup,
- IN pu4Byte Backup_AFE_REG,
- IN u4Byte AFE_NUM
- )
- {
- u4Byte i;
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0);
-
- for (i = 0; i < AFE_NUM; 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"));
- }
- void _IQK_RestoreMacBB_8812A(
- IN PDM_ODM_T pDM_Odm,
- IN pu4Byte MACBB_backup,
- IN pu4Byte Backup_MACBB_REG,
- IN u4Byte MACBB_NUM
- )
- {
- u4Byte i;
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0);
-
- for (i = 0; i < MACBB_NUM; i++){
- ODM_Write4Byte(pDM_Odm, Backup_MACBB_REG[i], MACBB_backup[i]);
- }
- ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("RestoreMacBB Success!!!!\n"));
- }
- void _IQK_RestoreRF_8812A(
- IN PDM_ODM_T pDM_Odm,
- IN ODM_RF_RADIO_PATH_E Path,
- IN pu4Byte Backup_RF_REG,
- IN pu4Byte RF_backup,
- IN u4Byte RF_REG_NUM
- )
- {
- u4Byte i;
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0);
- for (i = 0; i < RF_REG_NUM; i++)
- ODM_SetRFReg(pDM_Odm, Path, Backup_RF_REG[i], bRFRegOffsetMask, RF_backup[i]);
- ODM_SetRFReg(pDM_Odm, Path, 0xef, bRFRegOffsetMask, 0x0);
- switch(Path){
- case ODM_RF_PATH_A:
- {
- ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("RestoreRF Path A Success!!!!\n"));
- }
- break;
- case ODM_RF_PATH_B:
- {
- ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("RestoreRF Path B Success!!!!\n"));
- }
- break;
- default:
- break;
- }
- }
- void _IQK_RestoreAFE_8812A(
- IN PDM_ODM_T pDM_Odm,
- IN pu4Byte AFE_backup,
- IN pu4Byte Backup_AFE_REG,
- IN u4Byte AFE_NUM
- )
- {
- u4Byte i;
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0);
-
- for (i = 0; i < AFE_NUM; i++){
- ODM_Write4Byte(pDM_Odm, Backup_AFE_REG[i], AFE_backup[i]);
- }
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x1);
- ODM_Write4Byte(pDM_Odm, 0xc80, 0x0);
- ODM_Write4Byte(pDM_Odm, 0xc84, 0x0);
- ODM_Write4Byte(pDM_Odm, 0xc88, 0x0);
- ODM_Write4Byte(pDM_Odm, 0xc8c, 0x3c000000);
- ODM_Write4Byte(pDM_Odm, 0xcb8, 0x0);
- ODM_Write4Byte(pDM_Odm, 0xe80, 0x0);
- ODM_Write4Byte(pDM_Odm, 0xe84, 0x0);
- ODM_Write4Byte(pDM_Odm, 0xe88, 0x0);
- ODM_Write4Byte(pDM_Odm, 0xe8c, 0x3c000000);
- ODM_Write4Byte(pDM_Odm, 0xeb8, 0x0);
- ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("RestoreAFE Success!!!!\n"));
- }
- void _IQK_ConfigureMAC_8812A(
- IN PDM_ODM_T pDM_Odm
- )
- {
-
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0);
- ODM_Write1Byte(pDM_Odm, 0x522, 0x3f);
- ODM_SetBBReg(pDM_Odm, 0x550, BIT(11)|BIT(3), 0x0);
- ODM_SetBBReg(pDM_Odm, 0x808, BIT(28), 0x0);
- ODM_Write1Byte(pDM_Odm, 0x808, 0x00);
- ODM_SetBBReg(pDM_Odm, 0x838, 0xf, 0xc);
- }
- #define cal_num 3
- void _IQK_Tx_8812A(
- IN PDM_ODM_T pDM_Odm,
- IN ODM_RF_RADIO_PATH_E Path,
- IN u1Byte chnlIdx
- )
- {
- 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[cal_num], TX_Y0[cal_num], RX_X0[cal_num], RX_Y0[cal_num];
- BOOLEAN TX0IQKOK = FALSE, RX0IQKOK = FALSE;
- 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;
- }
- VDF_enable = FALSE;
- temp_reg65 = ODM_GetRFReg(pDM_Odm, Path, 0x65, bMaskDWord);
- switch(Path){
- case ODM_RF_PATH_A:
- {
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0);
-
-
- ODM_Write4Byte(pDM_Odm, 0xc60, 0x77777777);
- ODM_Write4Byte(pDM_Odm, 0xc64, 0x77777777);
-
-
- 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);
-
- ODM_SetBBReg(pDM_Odm, 0xc5c, BIT(26)|BIT(25)|BIT(24), 0x7);
- ODM_SetBBReg(pDM_Odm, 0x8c4, BIT(30), 0x1);
-
-
- }
- break;
- case ODM_RF_PATH_B:
- {ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0);
-
-
- ODM_Write4Byte(pDM_Odm, 0xc60, 0x00000000);
- ODM_Write4Byte(pDM_Odm, 0xc64, 0x00000000);
-
-
- ODM_Write4Byte(pDM_Odm, 0xe60, 0x77777777);
- ODM_Write4Byte(pDM_Odm, 0xe64, 0x77777777);
- ODM_Write4Byte(pDM_Odm, 0xe68, 0x19791979);
- ODM_SetBBReg(pDM_Odm, 0xe00, 0xf, 0x4);
-
- ODM_SetBBReg(pDM_Odm, 0xe5c, BIT(26)|BIT(25)|BIT(24), 0x7);
- ODM_SetBBReg(pDM_Odm, 0x8c4, BIT(30), 0x1);
-
-
- }
- break;
- default:
- break;
- }
- switch (Path) {
- case ODM_RF_PATH_A:
- {
-
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0);
- ODM_SetRFReg(pDM_Odm, Path, 0xef, bRFRegOffsetMask, 0x80002);
- ODM_SetRFReg(pDM_Odm, Path, 0x30, bRFRegOffsetMask, 0x20000);
- ODM_SetRFReg(pDM_Odm, Path, 0x31, bRFRegOffsetMask, 0x3fffd);
- ODM_SetRFReg(pDM_Odm, Path, 0x32, bRFRegOffsetMask, 0xfe83f);
- ODM_SetRFReg(pDM_Odm, Path, 0x65, bRFRegOffsetMask, 0x931d5);
- ODM_SetRFReg(pDM_Odm, Path, 0x8f, bRFRegOffsetMask, 0x8a001);
- ODM_Write4Byte(pDM_Odm, 0x90c, 0x00008000);
- ODM_Write4Byte(pDM_Odm, 0xb00, 0x03000100);
- ODM_SetBBReg(pDM_Odm, 0xc94, BIT(0), 0x1);
- ODM_Write4Byte(pDM_Odm, 0x978, 0x29002000);
- ODM_Write4Byte(pDM_Odm, 0x97c, 0xa9002000);
- ODM_Write4Byte(pDM_Odm, 0x984, 0x00462910);
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x1);
- if (pDM_Odm->ExtPA5G)
- ODM_Write4Byte(pDM_Odm, 0xc88, 0x821403f7);
- else
- ODM_Write4Byte(pDM_Odm, 0xc88, 0x821403f1);
- if (*pDM_Odm->pBandType)
- ODM_Write4Byte(pDM_Odm, 0xc8c, 0x68163e96);
- else{
- ODM_Write4Byte(pDM_Odm, 0xc8c, 0x28163e96);
- if (pDM_Odm->RFEType == 3)
- { if (pDM_Odm->ExtPA)
- ODM_Write4Byte(pDM_Odm, 0xc88, 0x821403e3);
- else
- ODM_Write4Byte(pDM_Odm, 0xc88, 0x821403f7);
- }
- }
- if (VDF_enable == 1){
- ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("TXVDF Start\n"));
- for (k = 0;k <= 2; k++){
- switch (k){
- case 0:
- {
- ODM_Write4Byte(pDM_Odm, 0xc80, 0x18008c38);
- ODM_Write4Byte(pDM_Odm, 0xc84, 0x38008c38);
- ODM_Write4Byte(pDM_Odm, 0x984, 0x00462910);
- ODM_SetBBReg(pDM_Odm, 0xce8, BIT(31), 0x0);
- }
- break;
- case 1:
- {
- ODM_SetBBReg(pDM_Odm, 0xc80, BIT(28), 0x0);
- ODM_SetBBReg(pDM_Odm, 0xc84, BIT(28), 0x0);
- ODM_Write4Byte(pDM_Odm, 0x984, 0x0046a910);
- }
- break;
- case 2:
- {
- ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("VDF_Y[1] = %x;;;VDF_Y[0] = %x\n", VDF_Y[1]>>21 & 0x00007ff, VDF_Y[0]>>21 & 0x00007ff));
- ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("VDF_X[1] = %x;;;VDF_X[0] = %x\n", VDF_X[1]>>21 & 0x00007ff, VDF_X[0]>>21 & 0x00007ff));
- Tx_dt[cal] = (VDF_Y[1]>>20)-(VDF_Y[0]>>20);
- ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Tx_dt = %d\n", Tx_dt[cal]));
- Tx_dt[cal] = ((16*Tx_dt[cal])*10000/15708);
- Tx_dt[cal] = (Tx_dt[cal] >> 1 )+(Tx_dt[cal] & BIT(0));
- ODM_Write4Byte(pDM_Odm, 0xc80, 0x18008c20);
- ODM_Write4Byte(pDM_Odm, 0xc84, 0x38008c20);
- ODM_SetBBReg(pDM_Odm, 0xce8, BIT(31), 0x1);
- ODM_SetBBReg(pDM_Odm, 0xce8, 0x3fff0000, Tx_dt[cal] & 0x00003fff);
- }
- break;
- default:
- break;
- }
- ODM_Write4Byte(pDM_Odm, 0xcb8, 0x00100000);
- cal_retry = 0;
- while(1){
-
- ODM_Write4Byte(pDM_Odm, 0x980, 0xfa000000);
- ODM_Write4Byte(pDM_Odm, 0x980, 0xf8000000);
- ODM_delay_ms(10);
- ODM_Write4Byte(pDM_Odm, 0xcb8, 0x00000000);
- delay_count = 0;
- while (1){
- IQK_ready = ODM_GetBBReg(pDM_Odm, 0xd00, BIT(10));
- if ((IQK_ready) || (delay_count>20)){
- break;
- }
- else{
- ODM_delay_ms(1);
- delay_count++;
- }
- }
- if (delay_count < 20){
-
- TX_fail = ODM_GetBBReg(pDM_Odm, 0xd00, BIT(12));
- if (~TX_fail){
- ODM_Write4Byte(pDM_Odm, 0xcb8, 0x02000000);
- VDF_X[k] = ODM_GetBBReg(pDM_Odm, 0xd00, 0x07ff0000)<<21;
- ODM_Write4Byte(pDM_Odm, 0xcb8, 0x04000000);
- VDF_Y[k] = ODM_GetBBReg(pDM_Odm, 0xd00, 0x07ff0000)<<21;
- TX0IQKOK = TRUE;
- break;
- }
- else{
- TX0IQKOK = FALSE;
- cal_retry++;
- if (cal_retry == 10) {
- break;
- }
- }
- }
- else{
- TX0IQKOK = FALSE;
- cal_retry++;
- if (cal_retry == 10){
- break;
- }
- }
- }
- }
- ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("TXA_VDF_cal_retry = %d\n", cal_retry));
- TX_X0[cal] = VDF_X[k-1] ;
- TX_Y0[cal] = VDF_Y[k-1];
- }
- else{
- ODM_Write4Byte(pDM_Odm, 0xc80, 0x18008c10);
- ODM_Write4Byte(pDM_Odm, 0xc84, 0x38008c10);
- ODM_Write4Byte(pDM_Odm, 0xce8, 0x00000000);
- for(cal = 0; cal < cal_num; cal++){
- cal_retry = 0;
- while(1){
-
- ODM_Write4Byte(pDM_Odm, 0xcb8, 0x00100000);
- ODM_Write4Byte(pDM_Odm, 0x980, 0xfa000000);
- ODM_Write4Byte(pDM_Odm, 0x980, 0xf8000000);
- ODM_delay_ms(10);
- ODM_Write4Byte(pDM_Odm, 0xcb8, 0x00000000);
- delay_count = 0;
- while (1){
- IQK_ready = ODM_GetBBReg(pDM_Odm, 0xd00, BIT(10));
- if ((IQK_ready) || (delay_count>20)) {
- break;
- }
- else{
- ODM_delay_ms(1);
- delay_count++;
- }
- }
- if (delay_count < 20){
-
- TX_fail = ODM_GetBBReg(pDM_Odm, 0xd00, BIT(12));
- if (~TX_fail){
- ODM_Write4Byte(pDM_Odm, 0xcb8, 0x02000000);
- TX_X0[cal] = ODM_GetBBReg(pDM_Odm, 0xd00, 0x07ff0000)<<21;
- ODM_Write4Byte(pDM_Odm, 0xcb8, 0x04000000);
- TX_Y0[cal] = ODM_GetBBReg(pDM_Odm, 0xd00, 0x07ff0000)<<21;
- TX0IQKOK = TRUE;
-
- break;
- }
- else{
- TX0IQKOK = FALSE;
- cal_retry++;
- if (cal_retry == 10) {
- break;
- }
- }
- }
- else{
- TX0IQKOK = FALSE;
- cal_retry++;
- if (cal_retry == 10)
- break;
- }
- }
- ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("TXA_cal_retry = %d\n", cal_retry));
- if (TX0IQKOK)
- TX_Average++;
- }
- }
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0);
- ODM_SetRFReg(pDM_Odm, Path, 0x58, 0x7fe00, ODM_GetRFReg(pDM_Odm, Path, 0x8, 0xffc00));
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x1);
- if (TX0IQKOK == FALSE)
- break;
- if (VDF_enable == 1){
- ODM_SetBBReg(pDM_Odm, 0xce8, BIT(31), 0x0);
- ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("RXVDF Start\n"));
-
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0);
- ODM_SetRFReg(pDM_Odm, Path, 0xef, bRFRegOffsetMask, 0x80000);
- ODM_SetRFReg(pDM_Odm, Path, 0x30, bRFRegOffsetMask, 0x30000);
- ODM_SetRFReg(pDM_Odm, Path, 0x31, bRFRegOffsetMask, 0x3f7ff);
- ODM_SetRFReg(pDM_Odm, Path, 0x32, bRFRegOffsetMask, 0xfe7bf);
- 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);
- ODM_Write4Byte(pDM_Odm, 0xc88, 0x02140119);
- ODM_Write4Byte(pDM_Odm, 0xc8c, 0x28161420);
- for (k = 0;k <= 2; k++){
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0);
- ODM_SetBBReg(pDM_Odm, 0x978, 0x03FF8000, (VDF_X[k])>>21&0x000007ff);
- ODM_SetBBReg(pDM_Odm, 0x978, 0x000007FF, (VDF_Y[k])>>21&0x000007ff);
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x1);
- switch (k){
- case 0:
- {
- ODM_Write4Byte(pDM_Odm, 0xc80, 0x38008c38);
- ODM_Write4Byte(pDM_Odm, 0xc84, 0x18008c38);
- ODM_SetBBReg(pDM_Odm, 0xce8, BIT(30), 0x0);
- }
- break;
- case 1:
- {
- ODM_Write4Byte(pDM_Odm, 0xc80, 0x28008c38);
- ODM_Write4Byte(pDM_Odm, 0xc84, 0x08008c38);
- }
- break;
- case 2:
- {
- ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("VDF_Y[1] = %x;;;VDF_Y[0] = %x\n", VDF_Y[1]>>21 & 0x00007ff, VDF_Y[0]>>21 & 0x00007ff));
- ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("VDF_X[1] = %x;;;VDF_X[0] = %x\n", VDF_X[1]>>21 & 0x00007ff, VDF_X[0]>>21 & 0x00007ff));
- Rx_dt[cal] = (VDF_Y[1]>>20)-(VDF_Y[0]>>20);
- ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Rx_dt = %d\n", Rx_dt[cal]));
- Rx_dt[cal] = ((16*Rx_dt[cal])*10000/13823);
- Rx_dt[cal] = (Rx_dt[cal] >> 1 )+(Rx_dt[cal] & BIT(0));
- ODM_Write4Byte(pDM_Odm, 0xc80, 0x38008c20);
- ODM_Write4Byte(pDM_Odm, 0xc84, 0x18008c20);
- ODM_SetBBReg(pDM_Odm, 0xce8, 0x00003fff, Rx_dt[cal] & 0x00003fff);
- }
- break;
- default:
- break;
- }
- if (k==2){
- ODM_SetBBReg(pDM_Odm, 0xce8, BIT(30), 0x1);
- }
- ODM_Write4Byte(pDM_Odm, 0xcb8, 0x00100000);
- cal_retry = 0;
- while(1){
-
- ODM_Write4Byte(pDM_Odm, 0x980, 0xfa000000);
- ODM_Write4Byte(pDM_Odm, 0x980, 0xf8000000);
- ODM_delay_ms(10);
- ODM_Write4Byte(pDM_Odm, 0xcb8, 0x00000000);
- delay_count = 0;
- while (1){
- IQK_ready = ODM_GetBBReg(pDM_Odm, 0xd00, BIT(10));
- if ((IQK_ready)||(delay_count>20)){
- break;
- }
- else{
- ODM_delay_ms(1);
- delay_count++;
- }
- }
- if (delay_count < 20){
-
- RX_fail = ODM_GetBBReg(pDM_Odm, 0xd00, BIT(11));
- if (RX_fail == 0){
- ODM_Write4Byte(pDM_Odm, 0xcb8, 0x06000000);
- VDF_X[k] = ODM_GetBBReg(pDM_Odm, 0xd00, 0x07ff0000)<<21;
- ODM_Write4Byte(pDM_Odm, 0xcb8, 0x08000000);
- VDF_Y[k] = ODM_GetBBReg(pDM_Odm, 0xd00, 0x07ff0000)<<21;
- RX0IQKOK = TRUE;
- break;
- }
- else{
- ODM_SetBBReg(pDM_Odm, 0xc10, 0x000003ff, 0x200>>1);
- ODM_SetBBReg(pDM_Odm, 0xc10, 0x03ff0000, 0x0>>1);
- RX0IQKOK = FALSE;
- cal_retry++;
- if (cal_retry == 10)
- break;
- }
- }
- else{
- RX0IQKOK = FALSE;
- cal_retry++;
- if (cal_retry == 10)
- break;
- }
- }
- }
- ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("RXA_VDF_cal_retry = %d\n", cal_retry));
- RX_X0[cal] = VDF_X[k-1] ;
- RX_Y0[cal] = VDF_Y[k-1];
- ODM_SetBBReg(pDM_Odm, 0xce8, BIT(31), 0x1);
- }
- else{
-
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0);
-
- ODM_SetRFReg(pDM_Odm, Path, 0xef, bRFRegOffsetMask, 0x80000);
- ODM_SetRFReg(pDM_Odm, Path, 0x30, bRFRegOffsetMask, 0x30000);
- ODM_SetRFReg(pDM_Odm, Path, 0x31, bRFRegOffsetMask, 0x3f7ff);
- ODM_SetRFReg(pDM_Odm, Path, 0x32, bRFRegOffsetMask, 0xfe7bf);
- 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, 0x90c, 0x00008000);
-
- ODM_Write4Byte(pDM_Odm, 0x984, 0x0046a891);
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x1);
- ODM_Write4Byte(pDM_Odm, 0xc80, 0x38008c10);
- ODM_Write4Byte(pDM_Odm, 0xc84, 0x18008c10);
- ODM_Write4Byte(pDM_Odm, 0xc88, 0x02140119);
- ODM_Write4Byte(pDM_Odm, 0xc8c, 0x28160d40);
- for(cal = 0; cal < cal_num; cal++){
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0);
- ODM_SetBBReg(pDM_Odm, 0x978, 0x03FF8000, (TX_X0[cal])>>21&0x000007ff);
- ODM_SetBBReg(pDM_Odm, 0x978, 0x000007FF, (TX_Y0[cal])>>21&0x000007ff);
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x1);
- cal_retry = 0;
- while(1){
-
- ODM_Write4Byte(pDM_Odm, 0xcb8, 0x00100000);
- ODM_Write4Byte(pDM_Odm, 0x980, 0xfa000000);
- ODM_Write4Byte(pDM_Odm, 0x980, 0xf8000000);
- ODM_delay_ms(10);
- ODM_Write4Byte(pDM_Odm, 0xcb8, 0x00000000);
- delay_count = 0;
- while (1){
- IQK_ready = ODM_GetBBReg(pDM_Odm, 0xd00, BIT(10));
- if ((IQK_ready)||(delay_count>20)){
- break;
- }
- else{
- ODM_delay_ms(1);
- delay_count++;
- }
- }
- if (delay_count < 20){
-
- RX_fail = ODM_GetBBReg(pDM_Odm, 0xd00, BIT(11));
- if (RX_fail == 0){
- ODM_Write4Byte(pDM_Odm, 0xcb8, 0x06000000);
- RX_X0[cal] = ODM_GetBBReg(pDM_Odm, 0xd00, 0x07ff0000)<<21;
- ODM_Write4Byte(pDM_Odm, 0xcb8, 0x08000000);
- RX_Y0[cal] = ODM_GetBBReg(pDM_Odm, 0xd00, 0x07ff0000)<<21;
- RX0IQKOK = TRUE;
-
- break;
- }
- else{
- ODM_SetBBReg(pDM_Odm, 0xc10, 0x000003ff, 0x200>>1);
- ODM_SetBBReg(pDM_Odm, 0xc10, 0x03ff0000, 0x0>>1);
- RX0IQKOK = FALSE;
- cal_retry++;
- if (cal_retry == 10)
- break;
- }
- }
- else{
- RX0IQKOK = FALSE;
- cal_retry++;
- if (cal_retry == 10)
- break;
- }
- }
- ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("RXA_cal_retry = %d\n", cal_retry));
- if (RX0IQKOK)
- RX_Average++;
- }
- }
- }
- break;
- case ODM_RF_PATH_B:
- {
-
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0);
- ODM_SetRFReg(pDM_Odm, Path, 0xef, bRFRegOffsetMask, 0x80002);
- ODM_SetRFReg(pDM_Odm, Path, 0x30, bRFRegOffsetMask, 0x20000);
- ODM_SetRFReg(pDM_Odm, Path, 0x31, bRFRegOffsetMask, 0x3fffd);
- ODM_SetRFReg(pDM_Odm, Path, 0x32, bRFRegOffsetMask, 0xfe83f);
- ODM_SetRFReg(pDM_Odm, Path, 0x65, bRFRegOffsetMask, 0x931d5);
- ODM_SetRFReg(pDM_Odm, Path, 0x8f, bRFRegOffsetMask, 0x8a001);
- ODM_Write4Byte(pDM_Odm, 0x90c, 0x00008000);
- ODM_Write4Byte(pDM_Odm, 0xb00, 0x03000100);
- ODM_SetBBReg(pDM_Odm, 0xe94, BIT(0), 0x1);
- ODM_Write4Byte(pDM_Odm, 0x978, 0x29002000);
- ODM_Write4Byte(pDM_Odm, 0x97c, 0xa9002000);
- ODM_Write4Byte(pDM_Odm, 0x984, 0x00462910);
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x1);
-
- if (pDM_Odm->ExtPA5G)
- ODM_Write4Byte(pDM_Odm, 0xe88, 0x821403f7);
- else
- ODM_Write4Byte(pDM_Odm, 0xe88, 0x821403f1);
- if (*pDM_Odm->pBandType)
- ODM_Write4Byte(pDM_Odm, 0xe8c, 0x68163e96);
- else
- ODM_Write4Byte(pDM_Odm, 0xe8c, 0x28163e96);
- if (VDF_enable == 1){
- for (k = 0;k <= 2; k++){
- switch (k){
- case 0:
- {
- ODM_Write4Byte(pDM_Odm, 0xe80, 0x18008c38);
- ODM_Write4Byte(pDM_Odm, 0xe84, 0x38008c38);
- ODM_Write4Byte(pDM_Odm, 0x984, 0x00462910);
- ODM_SetBBReg(pDM_Odm, 0xee8, BIT(31), 0x0);
- }
- break;
- case 1:
- {
- ODM_SetBBReg(pDM_Odm, 0xe80, BIT(28), 0x0);
- ODM_SetBBReg(pDM_Odm, 0xe84, BIT(28), 0x0);
- ODM_Write4Byte(pDM_Odm, 0x984, 0x0046a910);
- ODM_SetBBReg(pDM_Odm, 0xee8, BIT(31), 0x0);
- }
- break;
- case 2:
- {
- ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("VDF_Y[1] = %x;;;VDF_Y[0] = %x\n", VDF_Y[1]>>21 & 0x00007ff, VDF_Y[0]>>21 & 0x00007ff));
- ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("VDF_X[1] = %x;;;VDF_X[0] = %x\n", VDF_X[1]>>21 & 0x00007ff, VDF_X[0]>>21 & 0x00007ff));
- Tx_dt[cal] = (VDF_Y[1]>>20)-(VDF_Y[0]>>20);
- ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Tx_dt = %d\n", Tx_dt[cal]));
- Tx_dt[cal] = ((16*Tx_dt[cal])*10000/15708);
- Tx_dt[cal] = (Tx_dt[cal] >> 1 )+(Tx_dt[cal] & BIT(0));
- ODM_Write4Byte(pDM_Odm, 0xe80, 0x18008c20);
- ODM_Write4Byte(pDM_Odm, 0xe84, 0x38008c20);
- ODM_SetBBReg(pDM_Odm, 0xee8, BIT(31), 0x1);
- ODM_SetBBReg(pDM_Odm, 0xee8, 0x3fff0000, Tx_dt[cal] & 0x00003fff);
- }
- break;
- default:
- break;
- }
- ODM_Write4Byte(pDM_Odm, 0xeb8, 0x00100000);
- cal_retry = 0;
- while(1){
-
- ODM_Write4Byte(pDM_Odm, 0x980, 0xfa000000);
- ODM_Write4Byte(pDM_Odm, 0x980, 0xf8000000);
- ODM_delay_ms(10);
- ODM_Write4Byte(pDM_Odm, 0xeb8, 0x00000000);
- delay_count = 0;
- while (1){
- IQK_ready = ODM_GetBBReg(pDM_Odm, 0xd40, BIT(10));
- if ((IQK_ready) || (delay_count>20)) {
- break;
- }
- else {
- ODM_delay_ms(1);
- delay_count++;
- }
- }
- if (delay_count < 20){
-
- 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;
- ODM_Write4Byte(pDM_Odm, 0xeb8, 0x04000000);
- VDF_Y[k] = ODM_GetBBReg(pDM_Odm, 0xd40, 0x07ff0000)<<21;
- TX1IQKOK = TRUE;
- break;
- }
- else{
- TX1IQKOK = FALSE;
- cal_retry++;
- if (cal_retry == 10) {
- break;
- }
- }
- }
- else{
- TX1IQKOK = FALSE;
- cal_retry++;
- if (cal_retry == 10){
- break;
- }
- }
- }
- }
- ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("TXB_VDF_cal_retry = %d\n", cal_retry));
- TX_X1[cal] = VDF_X[k-1] ;
- TX_Y1[cal] = VDF_Y[k-1];
- }
- else{
- ODM_Write4Byte(pDM_Odm, 0xe80, 0x18008c10);
- ODM_Write4Byte(pDM_Odm, 0xe84, 0x38008c10);
- ODM_Write4Byte(pDM_Odm, 0xee8, 0x00000000);
- for(cal = 0; cal < cal_num; cal++){
- cal_retry = 0;
- while(1){
-
- ODM_Write4Byte(pDM_Odm, 0xeb8, 0x00100000);
- ODM_Write4Byte(pDM_Odm, 0x980, 0xfa000000);
- ODM_Write4Byte(pDM_Odm, 0x980, 0xf8000000);
- ODM_delay_ms(10);
- ODM_Write4Byte(pDM_Odm, 0xeb8, 0x00000000);
- delay_count = 0;
- while (1){
- IQK_ready = ODM_GetBBReg(pDM_Odm, 0xd40, BIT(10));
- if ((IQK_ready)||(delay_count>20)){
- break;
- }
- else{
- ODM_delay_ms(1);
- delay_count++;
- }
- }
- if (delay_count < 20){
-
- TX_fail = ODM_GetBBReg(pDM_Odm, 0xd40, BIT(12));
- if (~TX_fail){
- ODM_Write4Byte(pDM_Odm, 0xeb8, 0x02000000);
- TX_X1[cal] = ODM_GetBBReg(pDM_Odm, 0xd40, 0x07ff0000)<<21;
- ODM_Write4Byte(pDM_Odm, 0xeb8, 0x04000000);
- TX_Y1[cal] = ODM_GetBBReg(pDM_Odm, 0xd40, 0x07ff0000)<<21;
- TX1IQKOK = TRUE;
-
- break;
- }
- else{
- TX1IQKOK = FALSE;
- cal_retry++;
- if (cal_retry == 10){
- break;
- }
- }
- }
- else {
- TX1IQKOK = FALSE;
- cal_retry++;
- if (cal_retry == 10){
- break;
- }
- }
- }
- 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);
- ODM_SetRFReg(pDM_Odm, Path, 0x58, 0x7fe00, ODM_GetRFReg(pDM_Odm, Path, 0x8, 0xffc00));
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x1);
-
- if (TX1IQKOK == FALSE)
- break;
-
- if (VDF_enable == 1){
- ODM_SetBBReg(pDM_Odm, 0xee8, BIT(31), 0x0);
- ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("RXVDF Start\n"));
-
-
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0);
- ODM_SetRFReg(pDM_Odm, Path, 0xef, bRFRegOffsetMask, 0x80000);
- ODM_SetRFReg(pDM_Odm, Path, 0x30, bRFRegOffsetMask, 0x30000);
- ODM_SetRFReg(pDM_Odm, Path, 0x31, bRFRegOffsetMask, 0x3f7ff);
- ODM_SetRFReg(pDM_Odm, Path, 0x32, bRFRegOffsetMask, 0xfe7bf);
- 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);
- 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);
- ODM_SetBBReg(pDM_Odm, 0x978, 0x03FF8000, (VDF_X[k])>>21&0x000007ff);
- ODM_SetBBReg(pDM_Odm, 0x978, 0x000007FF, (VDF_Y[k])>>21&0x000007ff);
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x1);
- switch (k){
- case 0:
- {
- ODM_Write4Byte(pDM_Odm, 0xe80, 0x38008c38);
- ODM_Write4Byte(pDM_Odm, 0xe84, 0x18008c38);
- ODM_SetBBReg(pDM_Odm, 0xee8, BIT(30), 0x0);
- }
- break;
- case 1:
- {
- ODM_Write4Byte(pDM_Odm, 0xe80, 0x28008c38);
- ODM_Write4Byte(pDM_Odm, 0xe84, 0x08008c38);
- ODM_SetBBReg(pDM_Odm, 0xee8, BIT(30), 0x0);
- }
- break;
- case 2:
- {
- ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("VDF_Y[1] = %x;;;VDF_Y[0] = %x\n", VDF_Y[1]>>21 & 0x00007ff, VDF_Y[0]>>21 & 0x00007ff));
- ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("VDF_X[1] = %x;;;VDF_X[0] = %x\n", VDF_X[1]>>21 & 0x00007ff, VDF_X[0]>>21 & 0x00007ff));
- Rx_dt[cal] = (VDF_Y[1]>>20)-(VDF_Y[0]>>20);
- ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Rx_dt = %d\n", Rx_dt[cal]));
- Rx_dt[cal] = ((16*Rx_dt[cal])*10000/13823);
- Rx_dt[cal] = (Rx_dt[cal] >> 1 )+(Rx_dt[cal] & BIT(0));
- ODM_Write4Byte(pDM_Odm, 0xe80, 0x38008c20);
- ODM_Write4Byte(pDM_Odm, 0xe84, 0x18008c20);
- ODM_SetBBReg(pDM_Odm, 0xee8, 0x00003fff, Rx_dt[cal] & 0x00003fff);
- }
- break;
- default:
- break;
- }
-
-
- if (k==2){
- ODM_SetBBReg(pDM_Odm, 0xee8, BIT(30), 0x1);
- }
- ODM_Write4Byte(pDM_Odm, 0xeb8, 0x00100000);
-
- cal_retry = 0;
- while(1){
-
- ODM_Write4Byte(pDM_Odm, 0x980, 0xfa000000);
- ODM_Write4Byte(pDM_Odm, 0x980, 0xf8000000);
- ODM_delay_ms(10);
- ODM_Write4Byte(pDM_Odm, 0xeb8, 0x00000000);
- delay_count = 0;
- while (1){
- IQK_ready = ODM_GetBBReg(pDM_Odm, 0xd40, BIT(10));
- if ((IQK_ready)||(delay_count>20)){
- break;
- }
- else{
- ODM_delay_ms(1);
- delay_count++;
- }
- }
-
- if (delay_count < 20){
-
- RX_fail = ODM_GetBBReg(pDM_Odm, 0xd40, BIT(11));
- if (RX_fail == 0){
- ODM_Write4Byte(pDM_Odm, 0xeb8, 0x06000000);
- VDF_X[k] = ODM_GetBBReg(pDM_Odm, 0xd40, 0x07ff0000)<<21;
- ODM_Write4Byte(pDM_Odm, 0xeb8, 0x08000000);
- VDF_Y[k] = ODM_GetBBReg(pDM_Odm, 0xd40, 0x07ff0000)<<21;
- RX1IQKOK = TRUE;
- break;
- }
- else{
- ODM_SetBBReg(pDM_Odm, 0xe10, 0x000003ff, 0x200>>1);
- ODM_SetBBReg(pDM_Odm, 0xe10, 0x03ff0000, 0x0>>1);
- RX1IQKOK = FALSE;
- cal_retry++;
- if (cal_retry == 10)
- break;
-
- }
- }
- else{
- RX1IQKOK = FALSE;
- cal_retry++;
- if (cal_retry == 10)
- 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] ;
- RX_Y1[cal] = VDF_Y[k-1];
- ODM_SetBBReg(pDM_Odm, 0xee8, BIT(31), 0x1);
- }
- else{
-
-
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0);
- ODM_SetRFReg(pDM_Odm, Path, 0xef, bRFRegOffsetMask, 0x80000);
- ODM_SetRFReg(pDM_Odm, Path, 0x30, bRFRegOffsetMask, 0x30000);
- ODM_SetRFReg(pDM_Odm, Path, 0x31, bRFRegOffsetMask, 0x3f7ff);
- ODM_SetRFReg(pDM_Odm, Path, 0x32, bRFRegOffsetMask, 0xfe7bf);
- 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, 0x90c, 0x00008000);
-
- ODM_Write4Byte(pDM_Odm, 0x984, 0x0046a891);
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x1);
- ODM_Write4Byte(pDM_Odm, 0xe80, 0x38008c10);
- ODM_Write4Byte(pDM_Odm, 0xe84, 0x18008c10);
- ODM_Write4Byte(pDM_Odm, 0xe88, 0x02140119);
- ODM_Write4Byte(pDM_Odm, 0xe8c, 0x28161180);
- for(cal = 0; cal < cal_num; cal++){
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0);
- ODM_SetBBReg(pDM_Odm, 0x978, 0x03FF8000, (TX_X1[cal])>>21&0x000007ff);
- ODM_SetBBReg(pDM_Odm, 0x978, 0x000007FF, (TX_Y1[cal])>>21&0x000007ff);
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x1);
- cal_retry = 0;
- while(1){
-
- ODM_Write4Byte(pDM_Odm, 0xeb8, 0x00100000);
- ODM_Write4Byte(pDM_Odm, 0x980, 0xfa000000);
- ODM_Write4Byte(pDM_Odm, 0x980, 0xf8000000);
- ODM_delay_ms(10);
- ODM_Write4Byte(pDM_Odm, 0xeb8, 0x00000000);
- delay_count = 0;
- while (1){
- IQK_ready = ODM_GetBBReg(pDM_Odm, 0xd40, BIT(10));
- if ((IQK_ready)||(delay_count>20)){
- break;
- }
- else {
- ODM_delay_ms(1);
- delay_count++;
- }
- }
- if (delay_count < 20){
-
- RX_fail = ODM_GetBBReg(pDM_Odm, 0xd40, BIT(11));
- if (RX_fail == 0){
- ODM_Write4Byte(pDM_Odm, 0xeb8, 0x06000000);
- RX_X1[cal] = ODM_GetBBReg(pDM_Odm, 0xd40, 0x07ff0000)<<21;
- ODM_Write4Byte(pDM_Odm, 0xeb8, 0x08000000);
- RX_Y1[cal] = ODM_GetBBReg(pDM_Odm, 0xd40, 0x07ff0000)<<21;
- RX1IQKOK = TRUE;
- break;
- }
- else{
- ODM_SetBBReg(pDM_Odm, 0xe10, 0x000003ff, 0x200>>1);
- ODM_SetBBReg(pDM_Odm, 0xe10, 0x03ff0000, 0x0>>1);
- RX1IQKOK = FALSE;
- cal_retry++;
- if (cal_retry == 10)
- break;
- }
- }
- else{
- RX1IQKOK = FALSE;
- cal_retry++;
- if (cal_retry == 10)
- break;
- }
- }
- ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("RXB_cal_retry = %d\n", cal_retry));
- if (RX1IQKOK)
- RX_Average++;
- }
- }
- }
- break;
- default:
- break;
- }
-
-
- switch (Path){
- case ODM_RF_PATH_A:
- {
- ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("========Path_A =======\n"));
- if (TX_Average == 0){
- _IQK_TX_FillIQC_8812A(pDM_Odm, Path, 0x200, 0x0);
- break;
- }
- 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 <TX_Average; ii++){
- dx = (TX_X0[i]>>21) - (TX_X0[ii]>>21);
- if (dx < 4 && dx > -4){
- dy = (TX_Y0[i]>>21) - (TX_Y0[ii]>>21);
- if (dy < 4 && dy > -4){
- TX_X = ((TX_X0[i]>>21) + (TX_X0[ii]>>21))/2;
- TX_Y = ((TX_Y0[i]>>21) + (TX_Y0[ii]>>21))/2;
- if (*pDM_Odm->pBandWidth == 2){
- Tx_dt[0] = (Tx_dt[i] + Tx_dt[ii])/2;
- }
- TX_finish = 1;
- break;
- }
- }
- }
- if (TX_finish == 1)
- break;
- }
- if (*pDM_Odm->pBandWidth == 2){
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x1);
- ODM_SetBBReg(pDM_Odm, 0xce8, 0x3fff0000, Tx_dt[0] & 0x00003fff);
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0);
- }
- if (TX_finish == 1){
- _IQK_TX_FillIQC_8812A(pDM_Odm, Path, TX_X, TX_Y);
- }
- else{
- _IQK_TX_FillIQC_8812A(pDM_Odm, Path, 0x200, 0x0);
- }
-
- if (RX_Average == 0){
- _IQK_RX_FillIQC_8812A(pDM_Odm, Path, 0x200, 0x0);
- break;
- }
- 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 <RX_Average; ii++){
- dx = (RX_X0[i]>>21) - (RX_X0[ii]>>21);
- if (dx < 4 && dx > -4){
- dy = (RX_Y0[i]>>21) - (RX_Y0[ii]>>21);
- if (dy < 4 && dy > -4){
- RX_X = ((RX_X0[i]>>21) + (RX_X0[ii]>>21))/2;
- RX_Y = ((RX_Y0[i]>>21) + (RX_Y0[ii]>>21))/2;
- if (*pDM_Odm->pBandWidth == 2){
- Rx_dt[0] = (Rx_dt[i] + Rx_dt[ii])/2;
- }
- RX_finish = 1;
- break;
- }
- }
- }
- if (RX_finish == 1)
- break;
- }
- if (*pDM_Odm->pBandWidth == 2){
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x1);
- ODM_SetBBReg(pDM_Odm, 0xce8, 0x00003fff, Rx_dt[0] & 0x00003fff);
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0);
- }
- if (RX_finish == 1){
- _IQK_RX_FillIQC_8812A(pDM_Odm, Path, RX_X, RX_Y);
- }
- else{
- _IQK_RX_FillIQC_8812A(pDM_Odm, Path, 0x200, 0x0);
- }
- if (TX_finish && RX_finish){
- pRFCalibrateInfo->bNeedIQK = FALSE;
- pRFCalibrateInfo->IQKMatrixRegSetting[chnlIdx].Value[*pDM_Odm->pBandWidth][0] = ((TX_X & 0x000007ff) << 16) + (TX_Y & 0x000007ff);
- pRFCalibrateInfo->IQKMatrixRegSetting[chnlIdx].Value[*pDM_Odm->pBandWidth][1] = ((RX_X & 0x000007ff) << 16) + (RX_Y & 0x000007ff);
-
- if (*pDM_Odm->pBandWidth == 2){
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x1);
- pRFCalibrateInfo->IQKMatrixRegSetting[chnlIdx].Value[*pDM_Odm->pBandWidth][4] = ODM_Read4Byte( pDM_Odm, 0xce8);
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0);
- }
- }
-
- }
- break;
- case ODM_RF_PATH_B:
- {
- ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("========Path_B =======\n"));
- if (TX_Average == 0){
- _IQK_TX_FillIQC_8812A(pDM_Odm, Path, 0x200, 0x0);
- break;
- }
- for (i = 0; i < TX_Average; i++){
- ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("TX_X1[%d] = %x ;; TX_Y1[%d] = %x\n", i, (TX_X1[i])>>21&0x000007ff, i, (TX_Y1[i])>>21&0x000007ff));
- }
- for (i = 0; i < TX_Average; i++){
- for (ii = i+1; ii <TX_Average; ii++){
- dx = (TX_X1[i]>>21) - (TX_X1[ii]>>21);
- if (dx < 4 && dx > -4){
- dy = (TX_Y1[i]>>21) - (TX_Y1[ii]>>21);
- if (dy < 4 && dy > -4){
- TX_X = ((TX_X1[i]>>21) + (TX_X1[ii]>>21))/2;
- TX_Y = ((TX_Y1[i]>>21) + (TX_Y1[ii]>>21))/2;
- if (*pDM_Odm->pBandWidth == 2){
- Tx_dt[0] = (Tx_dt[i] + Tx_dt[ii])/2;
- }
- TX_finish = 1;
- break;
- }
- }
- }
- if (TX_finish == 1)
- break;
- }
- if (*pDM_Odm->pBandWidth == 2){
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x1);
- ODM_SetBBReg(pDM_Odm, 0xee8, 0x3fff0000, Tx_dt[0] & 0x00003fff);
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0);
- }
- if (TX_finish == 1){
- _IQK_TX_FillIQC_8812A(pDM_Odm, Path, TX_X, TX_Y);
- }
- else{
- _IQK_TX_FillIQC_8812A(pDM_Odm, Path, 0x200, 0x0);
- }
- if (RX_Average == 0){
- _IQK_RX_FillIQC_8812A(pDM_Odm, Path, 0x200, 0x0);
- break;
- }
- for (i = 0; i < RX_Average; i++){
- ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("RX_X1[%d] = %x ;; RX_Y1[%d] = %x\n", i, (RX_X1[i])>>21&0x000007ff, i, (RX_Y1[i])>>21&0x000007ff));
- }
- for (i = 0; i < RX_Average; i++){
- for (ii = i+1; ii <RX_Average; ii++){
- dx = (RX_X1[i]>>21) - (RX_X1[ii]>>21);
- if (dx < 4 && dx > -4){
- dy = (RX_Y1[i]>>21) - (RX_Y1[ii]>>21);
- if (dy < 4 && dy > -4){
- RX_X = ((RX_X1[i]>>21) + (RX_X1[ii]>>21))/2;
- RX_Y = ((RX_Y1[i]>>21) + (RX_Y1[ii]>>21))/2;
- if (*pDM_Odm->pBandWidth == 2){
- Rx_dt[0] = (Rx_dt[i] + Rx_dt[ii])/2;
- }
- RX_finish = 1;
- break;
- }
- }
- }
- if (RX_finish == 1)
- break;
- }
- if (*pDM_Odm->pBandWidth == 2){
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x1);
- ODM_SetBBReg(pDM_Odm, 0xee8, 0x00003fff, Rx_dt[0] & 0x00003fff);
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0);
- }
- if (RX_finish == 1){
- _IQK_RX_FillIQC_8812A(pDM_Odm, Path, RX_X, RX_Y);
- }
- else{
- _IQK_RX_FillIQC_8812A(pDM_Odm, Path, 0x200, 0x0);
- }
- if (TX_finish && RX_finish){
- pRFCalibrateInfo->bNeedIQK = FALSE;
- pRFCalibrateInfo->IQKMatrixRegSetting[chnlIdx].Value[*pDM_Odm->pBandWidth][2] = ((TX_X & 0x000007ff) << 16) + (TX_Y & 0x000007ff);
- pRFCalibrateInfo->IQKMatrixRegSetting[chnlIdx].Value[*pDM_Odm->pBandWidth][3] = ((RX_X & 0x000007ff) << 16) + (RX_Y & 0x000007ff);
-
- if (*pDM_Odm->pBandWidth == 2){
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x1);
- pRFCalibrateInfo->IQKMatrixRegSetting[chnlIdx].Value[*pDM_Odm->pBandWidth][5] = ODM_Read4Byte( pDM_Odm, 0xee8);
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0);
- }
- }
-
- }
- break;
- default:
- break;
- }
- }
- #define MACBB_REG_NUM 10
- #define AFE_REG_NUM 14
- #define RF_REG_NUM 3
- 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_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};
- 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);
- }
- VOID
- phy_LCCalibrate_8812A(
- IN PDM_ODM_T pDM_Odm,
- IN BOOLEAN is2T
- )
- {
- u4Byte LC_Cal = 0, tmp = 0;
-
-
- u4Byte reg0x914 = ODM_Read4Byte(pDM_Odm, rSingleTone_ContTx_Jaguar);;
-
- LC_Cal = ODM_GetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_CHNLBW, bRFRegOffsetMask);
- if((reg0x914 & 0x70000) != 0)
-
-
- ;
- else
- ODM_Write1Byte(pDM_Odm, REG_TXPAUSE, 0xFF);
-
- 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);
-
- LC_Cal = ODM_GetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_CHNLBW, bRFRegOffsetMask);
-
-
- ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_CHNLBW, bRFRegOffsetMask, LC_Cal|0x08000);
-
- 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);
-
- if((reg0x914 & 70000) != 0)
- {
-
-
-
- }
- else
- {
- ODM_Write1Byte(pDM_Odm, REG_TXPAUSE, 0x00);
- }
-
- ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_CHNLBW, bRFRegOffsetMask, LC_Cal);
-
- }
- #define DP_BB_REG_NUM 7
- #define DP_RF_REG_NUM 1
- #define DP_RETRY_LIMIT 10
- #define DP_PATH_NUM 2
- #define DP_DPK_NUM 3
- #define DP_DPK_VALUE_NUM 2
- VOID
- phy_ReloadIQKSetting_8812A(
- IN PDM_ODM_T pDM_Odm,
- IN u1Byte Channel
- )
- {
- PODM_RF_CAL_T pRFCalibrateInfo = &(pDM_Odm->RFCalibrateInfo);
- u1Byte chnlIdx = ODM_GetRightChnlPlaceforIQK(Channel);
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x1);
- ODM_SetBBReg(pDM_Odm, 0xccc, 0x000007ff, pRFCalibrateInfo->IQKMatrixRegSetting[chnlIdx].Value[*pDM_Odm->pBandWidth][0]&0x7ff);
- ODM_SetBBReg(pDM_Odm, 0xcd4, 0x000007ff, (pRFCalibrateInfo->IQKMatrixRegSetting[chnlIdx].Value[*pDM_Odm->pBandWidth][0]&0x7ff0000)>>16);
- ODM_SetBBReg(pDM_Odm, 0xecc, 0x000007ff, pRFCalibrateInfo->IQKMatrixRegSetting[chnlIdx].Value[*pDM_Odm->pBandWidth][2]&0x7ff);
- ODM_SetBBReg(pDM_Odm, 0xed4, 0x000007ff, (pRFCalibrateInfo->IQKMatrixRegSetting[chnlIdx].Value[*pDM_Odm->pBandWidth][2]&0x7ff0000)>>16);
- if (*pDM_Odm->pBandWidth != 2){
- ODM_Write4Byte(pDM_Odm, 0xce8, 0x0);
- ODM_Write4Byte(pDM_Odm, 0xee8, 0x0);
- }
- else{
- ODM_Write4Byte(pDM_Odm, 0xce8, pRFCalibrateInfo->IQKMatrixRegSetting[chnlIdx].Value[*pDM_Odm->pBandWidth][4]);
- ODM_Write4Byte(pDM_Odm, 0xee8, pRFCalibrateInfo->IQKMatrixRegSetting[chnlIdx].Value[*pDM_Odm->pBandWidth][5]);
- }
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0);
- ODM_SetBBReg(pDM_Odm, 0xc10, 0x000003ff, (pRFCalibrateInfo->IQKMatrixRegSetting[chnlIdx].Value[*pDM_Odm->pBandWidth][1]&0x7ff0000)>>17);
- 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
- PHY_ResetIQKResult_8812A(
- IN PDM_ODM_T pDM_Odm
- )
- {
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x1);
- ODM_SetBBReg(pDM_Odm, 0xccc, 0x000007ff, 0x0);
- ODM_SetBBReg(pDM_Odm, 0xcd4, 0x000007ff, 0x200);
- ODM_SetBBReg(pDM_Odm, 0xecc, 0x000007ff, 0x0);
- ODM_SetBBReg(pDM_Odm, 0xed4, 0x000007ff, 0x200);
- ODM_Write4Byte(pDM_Odm, 0xce8, 0x0);
- ODM_Write4Byte(pDM_Odm, 0xee8, 0x0);
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0);
- ODM_SetBBReg(pDM_Odm, 0xc10, 0x000003ff, 0x100);
- ODM_SetBBReg(pDM_Odm, 0xe10, 0x000003ff, 0x100);
- }
- VOID
- phy_IQCalibrate_By_FW_8812A(
- IN PADAPTER pAdapter
- )
- {
- HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
- u1Byte IQKcmd[3] = {pHalData->CurrentChannel, 0x0, 0x0};
- u1Byte Buf1 = 0x0;
- u1Byte Buf2 = 0x0;
- if(pHalData->CurrentBandType)
- Buf1 = 0x2<<4;
- else
- Buf1 = 0x1<<4;
-
- if(pHalData->CurrentChannelBW == CHANNEL_WIDTH_20)
- Buf2 = 0x1;
- else if(pHalData->CurrentChannelBW == CHANNEL_WIDTH_40)
- Buf2 = 0x1<<1;
- else if(pHalData->CurrentChannelBW == CHANNEL_WIDTH_80)
- 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"));
-
-
-
- }
- VOID
- PHY_IQCalibrate_8812A(
- IN PADAPTER pAdapter,
- IN BOOLEAN bReCovery
- )
- {
- #if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
- HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
- #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
- PDM_ODM_T pDM_Odm = &pHalData->DM_OutSrc;
- #else
- PDM_ODM_T pDM_Odm = &pHalData->odmpriv;
- #endif
- #endif
- #if (MP_DRIVER == 1)
- #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
- PMPT_CONTEXT pMptCtx = &(pAdapter->MptCtx);
- #else
- PMPT_CONTEXT pMptCtx = &(pAdapter->mppriv.MptCtx);
- #endif
- #endif
- #if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE) )
- if (ODM_CheckPowerStatus(pAdapter) == FALSE)
- return;
- #endif
- #if MP_DRIVER == 1
- if( ! (pMptCtx->bSingleTone || pMptCtx->bCarrierSuppression) )
- #endif
- {
-
-
-
- phy_IQCalibrate_8812A(pDM_Odm, pHalData->CurrentChannel);
-
- }
-
- }
- VOID
- PHY_LCCalibrate_8812A(
- IN PDM_ODM_T pDM_Odm
- )
- {
- 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);
- #if (MP_DRIVER == 1)
- #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
- PMPT_CONTEXT pMptCtx = &(pAdapter->MptCtx);
- #else
- PMPT_CONTEXT pMptCtx = &(pAdapter->mppriv.MptCtx);
- #endif
- bStartContTx = pMptCtx->bStartContTx;
- bSingleTone = pMptCtx->bSingleTone;
- bCarrierSuppression = pMptCtx->bCarrierSuppression;
- #endif
- #endif
- ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("===> PHY_LCCalibrate_8812A\n"));
- #if (MP_DRIVER == 1)
- phy_LCCalibrate_8812A(pDM_Odm, TRUE);
- #endif
- ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("<=== PHY_LCCalibrate_8812A\n"));
- }
- VOID phy_SetRFPathSwitch_8812A(
- #if (DM_ODM_SUPPORT_TYPE & ODM_AP)
- IN PDM_ODM_T pDM_Odm,
- #else
- IN PADAPTER pAdapter,
- #endif
- IN BOOLEAN bMain,
- IN BOOLEAN is2T
- )
- {
- #if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
- HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
- #if (DM_ODM_SUPPORT_TYPE == ODM_CE)
- PDM_ODM_T pDM_Odm = &pHalData->odmpriv;
- #elif (DM_ODM_SUPPORT_TYPE == ODM_WIN)
- PDM_ODM_T pDM_Odm = &pHalData->DM_OutSrc;
- #endif
- #endif
- if (IS_HARDWARE_TYPE_8821(pAdapter))
- {
- if(bMain)
- ODM_SetBBReg(pDM_Odm, rA_RFE_Pinmux_Jaguar+4, BIT29|BIT28, 0x1);
- else
- ODM_SetBBReg(pDM_Odm, rA_RFE_Pinmux_Jaguar+4, BIT29|BIT28, 0x2);
- }
- else if (IS_HARDWARE_TYPE_8812(pAdapter))
- {
- if (pHalData->RFEType == 5)
- {
- if(bMain) {
-
- ODM_SetBBReg(pDM_Odm, r_ANTSEL_SW_Jaguar, BIT1|BIT0, 0x2);
- ODM_SetBBReg(pDM_Odm, r_ANTSEL_SW_Jaguar, BIT9|BIT8, 0x3);
- } else {
-
- ODM_SetBBReg(pDM_Odm, r_ANTSEL_SW_Jaguar, BIT1|BIT0, 0x1);
- ODM_SetBBReg(pDM_Odm, r_ANTSEL_SW_Jaguar, BIT9|BIT8, 0x3);
- }
- }
- }
- }
- VOID PHY_SetRFPathSwitch_8812A(
- #if (DM_ODM_SUPPORT_TYPE & ODM_AP)
- IN PDM_ODM_T pDM_Odm,
- #else
- IN PADAPTER pAdapter,
- #endif
- IN BOOLEAN bMain
- )
- {
- #if DISABLE_BB_RF
- return;
- #endif
- #if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
- phy_SetRFPathSwitch_8812A(pAdapter, bMain, TRUE);
- #endif
- }
- VOID
- _DPK_ThermalCompensation(
- IN PDM_ODM_T pDM_Odm
- )
- {
- }
- VOID
- _DPK_parareload(
- IN PDM_ODM_T pDM_Odm,
- IN pu4Byte MACBB_backup,
- IN pu4Byte Backup_MACBB_REG,
- IN u4Byte MACBB_NUM
-
- )
- {
- u4Byte i;
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0);
-
- for (i = 0; i < MACBB_NUM; i++){
- ODM_Write4Byte(pDM_Odm, Backup_MACBB_REG[i], MACBB_backup[i]);
- }
- }
- VOID
- _DPK_parabackup(
- IN PDM_ODM_T pDM_Odm,
- IN pu4Byte MACBB_backup,
- IN pu4Byte Backup_MACBB_REG,
- IN u4Byte MACBB_NUM
-
- )
- {
- u4Byte i;
- ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0);
-
- for (i = 0; i < MACBB_NUM; i++){
- MACBB_backup[i] = ODM_Read4Byte(pDM_Odm, Backup_MACBB_REG[i]);
- }
- }
- VOID
- _DPK_Globalparaset(
- IN PDM_ODM_T pDM_Odm
- )
- {
-
-
-
-
-
- ODM_Write4Byte(pDM_Odm, 0x520, 0x007f3F0F);
-
-
-
-
-
- ODM_Write4Byte(pDM_Odm, 0x82c, 0x002083d5);
-
- ODM_Write4Byte(pDM_Odm, 0x970, 0x00000000);
-
- ODM_Write4Byte(pDM_Odm, 0xcb8, 0x0050824d);
-
- ODM_Write4Byte(pDM_Odm, 0xeb8, 0x0050824d);
-
-
- ODM_Write4Byte(pDM_Odm, 0x838, 0x06c8d24c);
-
- ODM_Write4Byte(pDM_Odm, 0xc00, 0x00000004);
-
-
- ODM_Write4Byte(pDM_Odm, 0xe00, 0x00000004);
-
-
- ODM_Write4Byte(pDM_Odm, 0x90c, 0x00008000);
-
-
- ODM_Write4Byte(pDM_Odm, 0xb00, 0x03000100);
-
-
- ODM_Write4Byte(pDM_Odm, 0xc94, 0x01000001);
-
- ODM_Write4Byte(pDM_Odm, 0xe94, 0x01000001);
-
-
-
-
-
- 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, 0xc60, 0x77777777);
- ODM_Write4Byte(pDM_Odm, 0xc64, 0x77777777);
-
-
- 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, 0xe60, 0x77777777);
- ODM_Write4Byte(pDM_Odm, 0xe64, 0x77777777);
- }
- VOID
- _DPK_GetGainLoss(
- 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,
- 0x5560, 0x57cf, 0x5a7f, 0x5d0e, 0x5fbe
- };
- u1Byte sindex=0;
- u4Byte pagesel = 0,regsel = 0;
- if(path == 0)
- {
- pagesel = 0;
- regsel = 0;
- }
- else
- {
- pagesel = 0x200;
- regsel = 0x40;
- }
- ODM_Write4Byte(pDM_Odm, 0xc90+pagesel, 0x0601f0bf);
- ODM_Write4Byte(pDM_Odm, 0xcb8+pagesel, 0x0c000000);
- GL_I_tmp = ODM_GetBBReg(pDM_Odm, 0xd00+regsel, 0xffff0000);
- GL_Q_tmp = ODM_GetBBReg(pDM_Odm, 0xd00+regsel, 0x0000ffff);
- if(GL_I_tmp >= 0x8000)
- GL_I = (GL_I_tmp-0x8000+0x1);
- else
- GL_I = GL_I_tmp;
- if(GL_Q_tmp >= 0x8000)
- GL_Q = (GL_Q_tmp-0x8000+0x1);
- else
- 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));
- if (Power_GL > 63676){
- sindex = 0;
- 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;
- 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;
- 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;
- 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;
- 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;
- 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;
- 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;
- 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;
- 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;
- 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;
- 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;
- 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;
- 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;
- ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Gainloss = 3.25 dB\n"));
- }
- else if (30128 >= Power_GL){
- sindex = 14;
- ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Gainloss = 3.5 dB\n"));
- }
- ODM_Write4Byte(pDM_Odm, 0xc98+pagesel, (Scaler[sindex] << 16) | Scaler[sindex]);
- ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Set Gainloss reg 0xc98(0xe98)= 0x%x\n",ODM_Read4Byte(pDM_Odm, 0xc98+pagesel)));
- }
- VOID
- _DPK_EnableDP(
- IN PDM_ODM_T pDM_Odm,
- IN u1Byte path,
- IN u4Byte TXindex
- )
- {
-
-
-
-
- u1Byte PWSF[] = { 0xff, 0xca, 0xa1, 0x80, 0x65, 0x51, 0x40,
- 0x33, 0x28, 0x20, 0x19, 0x14, 0x10, 0x0d,
- 0x0a, 0x08, 0x06, 0x05, 0x04, 0x03, 0x03,
- 0x02, 0x02, 0x01, 0x01,
- };
- u1Byte zeropoint;
- u1Byte pwsf1,pwsf2;
- u1Byte i;
- u4Byte pagesel = 0,regsel = 0;
- if(path == 0)
- {
- pagesel = 0;
- regsel = 0;
- }
- else
- {
- pagesel = 0x200;
- regsel = 0x40;
- }
-
-
-
-
- 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, 0xc20+pagesel, 0x00000800);
- ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Write PWSF table\n"));
- if(TXindex == 0x1f)
- zeropoint = 0;
- else if(TXindex == 0x1e)
- zeropoint = 1;
- else if(TXindex == 0x1d)
- zeropoint = 2;
- else if(TXindex == 0x1c)
- zeropoint = 3;
- else if(TXindex == 0x1b)
- zeropoint = 4;
- else if(TXindex == 0x1a)
- zeropoint = 5;
- else if(TXindex == 0x19)
- zeropoint = 6;
- else
- zeropoint = 6;
-
- for(i=0;i<16;i++)
- {
- if((6-zeropoint)+i*2 > 24)
- pwsf1 = 24;
- else
- pwsf1 = (6-zeropoint)+i*2;
- if((6-zeropoint-1)+i*2 > 24)
- pwsf2 = 24;
- else
- pwsf2 = (6-zeropoint-1)+i*2;
- 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_Write4Byte(pDM_Odm, 0xce4+pagesel, 0x00000000);
-
- ODM_Write4Byte(pDM_Odm, 0x82c, 0x002083d5);
- }
- VOID
- _DPK_pathABDPK(
- 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 ++)
- {
- ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("path %s DPK start!!!\n", (path==0)?"A":"B"));
- if(path == 0)
- {
- pagesel = 0;
- regsel = 0;
- }
- else
- {
- pagesel = 0x200;
- regsel = 0x40;
- }
-
-
-
-
-
-
- ODM_Write4Byte(pDM_Odm, 0x82c, 0x802083d5);
-
-
-
-
-
-
-
-
- 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, 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);
-
-
- 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);
-
-
-
-
- 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);
-
-
- ODM_SetRFReg(pDM_Odm, (ODM_RF_RADIO_PATH_E)(0x0+path), 0x0, bRFRegOffsetMask, 0x50bff);
-
- ODM_SetRFReg(pDM_Odm, (ODM_RF_RADIO_PATH_E)(0x0+path), 0x64, bRFRegOffsetMask, 0x19aac);
-
- ODM_SetRFReg(pDM_Odm, (ODM_RF_RADIO_PATH_E)(0x0+path), 0x8f, bRFRegOffsetMask, 0x8e001);
-
-
- ODM_Write4Byte(pDM_Odm, 0xcc8+pagesel, 0x800c5599);
- ODM_Write4Byte(pDM_Odm, 0xcc8+pagesel, 0x000c5599);
-
-
- ODM_delay_ms(100);
-
-
- ODM_Write4Byte(pDM_Odm, 0xc90+pagesel, 0x0109f018);
- ODM_Write4Byte(pDM_Odm, 0xcb8+pagesel, 0x09000000);
-
-
-
-
-
-
-
-
-
-
-
-
- TXindex = ODM_GetBBReg(pDM_Odm, 0xd00+regsel, 0x0000000f);
-
-
-
- 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);
- ODM_Write4Byte(pDM_Odm, 0xc8c+pagesel, 0x3c000000);
-
-
- 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);
-
-
- 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);
-
-
-
- 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, 0x82c, 0x802083d5);
-
-
-
-
-
-
-
- ODM_Write4Byte(pDM_Odm, 0xcbc+pagesel, 0x0006c23f);
-
-
- ODM_Write4Byte(pDM_Odm, 0xcb8+pagesel, 0x000fffff);
-
-
-
-
-
- ODM_SetRFReg(pDM_Odm, (ODM_RF_RADIO_PATH_E)(0x0+path), 0x0, bRFRegOffsetMask, 0x517e0 | TXindex);
- ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("RF 0x0 = 0x%x\n", 0x517e0 | TXindex));
-
- ODM_Write4Byte(pDM_Odm, 0xcc8+pagesel, 0xc00c5599);
- ODM_Write4Byte(pDM_Odm, 0xcc8+pagesel, 0x400c5599);
-
- ODM_delay_ms(100);
-
-
- ODM_Write4Byte(pDM_Odm, 0xcb8+pagesel, 0x00000000);
-
- if(ODM_GetBBReg(pDM_Odm, 0xd00+regsel, BIT6))
- {
-
- ODM_Write4Byte(pDM_Odm, 0xcc4+pagesel, 0x28848000);
- ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("path %s DPK fail!!!!!!!!!!!!!!!!!!!!!\n", (path==0)?"A":"B"));
- return;
- }
- ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("path %s DPK ok!!!!!!!!!!!!!!!!!!!!!\n", (path==0)?"A":"B"));
-
- 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++){
- ODM_Write4Byte(pDM_Odm, 0xcb8+pagesel, 0x09000000+(j<<24));
- ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("0x%x", ODM_Read4Byte(pDM_Odm, 0xd00+regsel)));
- }
- }
-
-
-
-
-
- _DPK_GetGainLoss(pDM_Odm,path);
-
-
-
- _DPK_EnableDP(pDM_Odm, path, TXindex);
- }
-
- }
- VOID
- phy_DPCalibrate_8812A(
- IN PDM_ODM_T pDM_Odm
- )
- {
- u4Byte backupRegAddrs[] = {
- 0x970, 0xcb8, 0x838, 0xc00, 0x90c, 0xb00, 0xc94, 0x82c, 0x520, 0xc60,
- 0xc64, 0xc68, 0xc6c, 0xc70, 0xc74, 0xc78, 0xc7c, 0xc80, 0xc84, 0xc50,
- 0xc20, 0xc24, 0xc28, 0xc2c, 0xc30, 0xc34, 0xc38, 0xc3c, 0xc40, 0xc44,
- 0xc48, 0xc4c, 0xe50, 0xe20, 0xe24, 0xe28, 0xe2c, 0xe30, 0xe34, 0xe38,
- 0xe3c, 0xe40, 0xe44, 0xe48, 0xe4c, 0xeb8, 0xe00, 0xe94, 0xe60, 0xe64,
- 0xe68, 0xe6c, 0xe70, 0xe74, 0xe78, 0xe7c, 0xe80, 0xe84
- };
- u4Byte backupRegData[sizeof(backupRegAddrs)/sizeof(u4Byte)];
-
- _DPK_parabackup(pDM_Odm,backupRegAddrs, backupRegData, sizeof(backupRegAddrs)/sizeof(u4Byte));
-
- _DPK_Globalparaset(pDM_Odm);
-
- _DPK_pathABDPK(pDM_Odm);
-
-
- _DPK_parareload(pDM_Odm,backupRegAddrs, backupRegData, sizeof(backupRegAddrs)/sizeof(u4Byte));
-
- }
-
- 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);
- ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("<=== PHY_DPCalibrate_8812A\n"));
- }
-
-
-
-
-
|