hal_mp.c 87 KB

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