hal_mp.c 82 KB

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