halhwimg8821c_rf.c 60 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838
  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. /*Image2HeaderVersion: 3.4*/
  21. #include "mp_precomp.h"
  22. #include "../phydm_precomp.h"
  23. #if (RTL8821C_SUPPORT == 1)
  24. static boolean
  25. check_positive(
  26. struct PHY_DM_STRUCT *p_dm_odm,
  27. const u32 condition1,
  28. const u32 condition2,
  29. const u32 condition3,
  30. const u32 condition4
  31. )
  32. {
  33. u8 _board_type = ((p_dm_odm->board_type & BIT(4)) >> 4) << 0 | /* _GLNA*/
  34. ((p_dm_odm->board_type & BIT(3)) >> 3) << 1 | /* _GPA*/
  35. ((p_dm_odm->board_type & BIT(7)) >> 7) << 2 | /* _ALNA*/
  36. ((p_dm_odm->board_type & BIT(6)) >> 6) << 3 | /* _APA */
  37. ((p_dm_odm->board_type & BIT(2)) >> 2) << 4 | /* _BT*/
  38. ((p_dm_odm->board_type & BIT(1)) >> 1) << 5; /* _NGFF*/
  39. u32 cond1 = condition1, cond2 = condition2, cond3 = condition3, cond4 = condition4;
  40. u8 cut_version_for_para = (p_dm_odm->cut_version == ODM_CUT_A) ? 15 : p_dm_odm->cut_version;
  41. u8 pkg_type_for_para = (p_dm_odm->package_type == 0) ? 15 : p_dm_odm->package_type;
  42. u32 driver1 = cut_version_for_para << 24 |
  43. (p_dm_odm->support_interface & 0xF0) << 16 |
  44. p_dm_odm->support_platform << 16 |
  45. pkg_type_for_para << 12 |
  46. (p_dm_odm->support_interface & 0x0F) << 8 |
  47. _board_type;
  48. u32 driver2 = (p_dm_odm->type_glna & 0xFF) << 0 |
  49. (p_dm_odm->type_gpa & 0xFF) << 8 |
  50. (p_dm_odm->type_alna & 0xFF) << 16 |
  51. (p_dm_odm->type_apa & 0xFF) << 24;
  52. u32 driver3 = 0;
  53. u32 driver4 = (p_dm_odm->type_glna & 0xFF00) >> 8 |
  54. (p_dm_odm->type_gpa & 0xFF00) |
  55. (p_dm_odm->type_alna & 0xFF00) << 8 |
  56. (p_dm_odm->type_apa & 0xFF00) << 16;
  57. ODM_RT_TRACE(p_dm_odm, ODM_COMP_INIT, ODM_DBG_TRACE,
  58. ("===> check_positive (cond1, cond2, cond3, cond4) = (0x%X 0x%X 0x%X 0x%X)\n", cond1, cond2, cond3, cond4));
  59. ODM_RT_TRACE(p_dm_odm, ODM_COMP_INIT, ODM_DBG_TRACE,
  60. ("===> check_positive (driver1, driver2, driver3, driver4) = (0x%X 0x%X 0x%X 0x%X)\n", driver1, driver2, driver3, driver4));
  61. ODM_RT_TRACE(p_dm_odm, ODM_COMP_INIT, ODM_DBG_TRACE,
  62. (" (Platform, Interface) = (0x%X, 0x%X)\n", p_dm_odm->support_platform, p_dm_odm->support_interface));
  63. ODM_RT_TRACE(p_dm_odm, ODM_COMP_INIT, ODM_DBG_TRACE,
  64. (" (Board, Package) = (0x%X, 0x%X)\n", p_dm_odm->board_type, p_dm_odm->package_type));
  65. /*============== value Defined Check ===============*/
  66. /*QFN type [15:12] and cut version [27:24] need to do value check*/
  67. if (((cond1 & 0x0000F000) != 0) && ((cond1 & 0x0000F000) != (driver1 & 0x0000F000)))
  68. return false;
  69. if (((cond1 & 0x0F000000) != 0) && ((cond1 & 0x0F000000) != (driver1 & 0x0F000000)))
  70. return false;
  71. /*=============== Bit Defined Check ================*/
  72. /* We don't care [31:28] */
  73. cond1 &= 0x00FF0FFF;
  74. driver1 &= 0x00FF0FFF;
  75. if ((cond1 & driver1) == cond1) {
  76. u32 bit_mask = 0;
  77. if ((cond1 & 0x0F) == 0) /* board_type is DONTCARE*/
  78. return true;
  79. if ((cond1 & BIT(0)) != 0) /*GLNA*/
  80. bit_mask |= 0x000000FF;
  81. if ((cond1 & BIT(1)) != 0) /*GPA*/
  82. bit_mask |= 0x0000FF00;
  83. if ((cond1 & BIT(2)) != 0) /*ALNA*/
  84. bit_mask |= 0x00FF0000;
  85. if ((cond1 & BIT(3)) != 0) /*APA*/
  86. bit_mask |= 0xFF000000;
  87. if (((cond2 & bit_mask) == (driver2 & bit_mask)) && ((cond4 & bit_mask) == (driver4 & bit_mask))) /* board_type of each RF path is matched*/
  88. return true;
  89. else
  90. return false;
  91. } else
  92. return false;
  93. }
  94. static boolean
  95. check_negative(
  96. struct PHY_DM_STRUCT *p_dm_odm,
  97. const u32 condition1,
  98. const u32 condition2
  99. )
  100. {
  101. return true;
  102. }
  103. /******************************************************************************
  104. * radioa.TXT
  105. ******************************************************************************/
  106. u32 array_mp_8821c_radioa[] = {
  107. 0x000, 0x00010000,
  108. 0x018, 0x00010D24,
  109. 0x0EF, 0x00080000,
  110. 0x033, 0x00000002,
  111. 0x03E, 0x0000003F,
  112. 0x03F, 0x000C0F4E,
  113. 0x033, 0x00000001,
  114. 0x03E, 0x00000034,
  115. 0x03F, 0x0004080E,
  116. 0x0EF, 0x00002000,
  117. 0x033, 0x00000000,
  118. 0x03F, 0x000005DF,
  119. 0x0EF, 0x00000000,
  120. 0x0EE, 0x00000400,
  121. 0x033, 0x00000000,
  122. 0x03F, 0x000005DF,
  123. 0x0EE, 0x00000000,
  124. 0x0B0, 0x000FF0F8,
  125. 0x0B1, 0x0007DBE4,
  126. 0x0B2, 0x000225D1,
  127. 0x0B3, 0x000FC760,
  128. 0x0B4, 0x00099DD0,
  129. 0x0B5, 0x000400FC,
  130. 0x0B6, 0x000187F0,
  131. 0x0B7, 0x00030018,
  132. 0x0B8, 0x00080800,
  133. 0x0B9, 0x00000000,
  134. 0x0BA, 0x00008000,
  135. 0x0BB, 0x00000004,
  136. 0x0BC, 0x00040000,
  137. 0x0BD, 0x00000000,
  138. 0x0BE, 0x00000000,
  139. 0x0BF, 0x00000000,
  140. 0x0C0, 0x00000000,
  141. 0x0C1, 0x00000000,
  142. 0x0C2, 0x00000000,
  143. 0x0C3, 0x00000000,
  144. 0x0C4, 0x00002402,
  145. 0x0C5, 0x00000009,
  146. 0x0C6, 0x00040299,
  147. 0x0C7, 0x00055555,
  148. 0x0C8, 0x0000C16C,
  149. 0x0C9, 0x0001C140,
  150. 0x0CA, 0x00000000,
  151. 0x0CB, 0x00000000,
  152. 0x0CC, 0x00000000,
  153. 0x0CD, 0x00000000,
  154. 0x0CE, 0x00090C00,
  155. 0x0CF, 0x0006D200,
  156. 0x0DF, 0x00000009,
  157. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  158. 0x0EE, 0x00010000,
  159. 0x033, 0x00000058,
  160. 0x03F, 0x0000001C,
  161. 0x0EE, 0x00000000,
  162. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  163. 0x0EE, 0x00010000,
  164. 0x033, 0x00000058,
  165. 0x03F, 0x0000001C,
  166. 0x0EE, 0x00000000,
  167. 0xA0000000, 0x00000000,
  168. 0x0EE, 0x00010000,
  169. 0x033, 0x00000058,
  170. 0x03F, 0x0000002C,
  171. 0x0EE, 0x00000000,
  172. 0xB0000000, 0x00000000,
  173. 0x018, 0x00010524,
  174. 0x081, 0x0000FCC1,
  175. 0x089, 0x00000004,
  176. 0x08A, 0x0008A186,
  177. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  178. 0x08B, 0x0006FFFC,
  179. 0x90001000, 0x00000000, 0x40000000, 0x00000000,
  180. 0x08B, 0x0006FFFC,
  181. 0xA0000000, 0x00000000,
  182. 0x08B, 0x0007060C,
  183. 0xB0000000, 0x00000000,
  184. 0x08C, 0x000312C7,
  185. 0x08D, 0x00020888,
  186. 0x81000000, 0x00000000, 0x40000000, 0x00000000,
  187. 0x08E, 0x00064140,
  188. 0xA0000000, 0x00000000,
  189. 0x08E, 0x00064540,
  190. 0xB0000000, 0x00000000,
  191. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  192. 0x08F, 0x000A8010,
  193. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  194. 0x08F, 0x000A8010,
  195. 0xA0000000, 0x00000000,
  196. 0x08F, 0x000A8018,
  197. 0xB0000000, 0x00000000,
  198. 0x0DD, 0x00000020,
  199. 0x0EF, 0x00020000,
  200. 0x033, 0x00000007,
  201. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  202. 0x03E, 0x00038000,
  203. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  204. 0x03E, 0x00038000,
  205. 0xA0000000, 0x00000000,
  206. 0x03E, 0x0003C000,
  207. 0xB0000000, 0x00000000,
  208. 0x03F, 0x000C3186,
  209. 0x033, 0x00000006,
  210. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  211. 0x03E, 0x00038080,
  212. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  213. 0x03E, 0x00038080,
  214. 0xA0000000, 0x00000000,
  215. 0x03E, 0x0003C080,
  216. 0xB0000000, 0x00000000,
  217. 0x03F, 0x000C3186,
  218. 0x033, 0x00000005,
  219. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  220. 0x03E, 0x000380C8,
  221. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  222. 0x03E, 0x000380C8,
  223. 0xA0000000, 0x00000000,
  224. 0x03E, 0x0003C0C8,
  225. 0xB0000000, 0x00000000,
  226. 0x03F, 0x000C3186,
  227. 0x033, 0x00000004,
  228. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  229. 0x03E, 0x00038190,
  230. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  231. 0x03E, 0x00038190,
  232. 0xA0000000, 0x00000000,
  233. 0x03E, 0x0003C190,
  234. 0xB0000000, 0x00000000,
  235. 0x03F, 0x000C3186,
  236. 0x033, 0x00000003,
  237. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  238. 0x03E, 0x00038998,
  239. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  240. 0x03E, 0x00038998,
  241. 0xA0000000, 0x00000000,
  242. 0x03E, 0x0003C998,
  243. 0xB0000000, 0x00000000,
  244. 0x03F, 0x000C3186,
  245. 0x033, 0x00000002,
  246. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  247. 0x03E, 0x00039840,
  248. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  249. 0x03E, 0x00039840,
  250. 0xA0000000, 0x00000000,
  251. 0x03E, 0x0003D840,
  252. 0xB0000000, 0x00000000,
  253. 0x03F, 0x000C3186,
  254. 0x033, 0x00000001,
  255. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  256. 0x03E, 0x000398C4,
  257. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  258. 0x03E, 0x000398C4,
  259. 0xA0000000, 0x00000000,
  260. 0x03E, 0x0003D8C4,
  261. 0xB0000000, 0x00000000,
  262. 0x03F, 0x000C3186,
  263. 0x033, 0x00000000,
  264. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  265. 0x03E, 0x00039930,
  266. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  267. 0x03E, 0x00039930,
  268. 0xA0000000, 0x00000000,
  269. 0x03E, 0x0003D930,
  270. 0xB0000000, 0x00000000,
  271. 0x03F, 0x000C3186,
  272. 0x033, 0x0000000F,
  273. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  274. 0x03E, 0x00038000,
  275. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  276. 0x03E, 0x00038000,
  277. 0xA0000000, 0x00000000,
  278. 0x03E, 0x0003C000,
  279. 0xB0000000, 0x00000000,
  280. 0x03F, 0x000C3186,
  281. 0x033, 0x0000000E,
  282. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  283. 0x03E, 0x00038080,
  284. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  285. 0x03E, 0x00038080,
  286. 0xA0000000, 0x00000000,
  287. 0x03E, 0x0003C080,
  288. 0xB0000000, 0x00000000,
  289. 0x03F, 0x000C3186,
  290. 0x033, 0x0000000D,
  291. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  292. 0x03E, 0x000380C8,
  293. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  294. 0x03E, 0x000380C8,
  295. 0xA0000000, 0x00000000,
  296. 0x03E, 0x0003C0C8,
  297. 0xB0000000, 0x00000000,
  298. 0x03F, 0x000C3186,
  299. 0x033, 0x0000000C,
  300. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  301. 0x03E, 0x00038190,
  302. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  303. 0x03E, 0x00038190,
  304. 0xA0000000, 0x00000000,
  305. 0x03E, 0x0003C190,
  306. 0xB0000000, 0x00000000,
  307. 0x03F, 0x000C3186,
  308. 0x033, 0x0000000B,
  309. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  310. 0x03E, 0x00038998,
  311. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  312. 0x03E, 0x00038998,
  313. 0xA0000000, 0x00000000,
  314. 0x03E, 0x0003C998,
  315. 0xB0000000, 0x00000000,
  316. 0x03F, 0x000C3186,
  317. 0x033, 0x0000000A,
  318. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  319. 0x03E, 0x00039840,
  320. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  321. 0x03E, 0x00039840,
  322. 0xA0000000, 0x00000000,
  323. 0x03E, 0x0003D840,
  324. 0xB0000000, 0x00000000,
  325. 0x03F, 0x000C3186,
  326. 0x033, 0x00000009,
  327. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  328. 0x03E, 0x000398C4,
  329. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  330. 0x03E, 0x000398C4,
  331. 0xA0000000, 0x00000000,
  332. 0x03E, 0x0003D8C4,
  333. 0xB0000000, 0x00000000,
  334. 0x03F, 0x000C3186,
  335. 0x033, 0x00000008,
  336. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  337. 0x03E, 0x00039930,
  338. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  339. 0x03E, 0x00039930,
  340. 0xA0000000, 0x00000000,
  341. 0x03E, 0x0003D930,
  342. 0xB0000000, 0x00000000,
  343. 0x03F, 0x000C3186,
  344. 0x033, 0x00000017,
  345. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  346. 0x03E, 0x00038000,
  347. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  348. 0x03E, 0x00038000,
  349. 0xA0000000, 0x00000000,
  350. 0x03E, 0x0003C000,
  351. 0xB0000000, 0x00000000,
  352. 0x03F, 0x000C3186,
  353. 0x033, 0x00000016,
  354. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  355. 0x03E, 0x00038080,
  356. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  357. 0x03E, 0x00038080,
  358. 0xA0000000, 0x00000000,
  359. 0x03E, 0x0003C080,
  360. 0xB0000000, 0x00000000,
  361. 0x03F, 0x000C3186,
  362. 0x033, 0x00000015,
  363. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  364. 0x03E, 0x000380C8,
  365. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  366. 0x03E, 0x000380C8,
  367. 0xA0000000, 0x00000000,
  368. 0x03E, 0x0003C0C8,
  369. 0xB0000000, 0x00000000,
  370. 0x03F, 0x000C3186,
  371. 0x033, 0x00000014,
  372. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  373. 0x03E, 0x00038190,
  374. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  375. 0x03E, 0x00038190,
  376. 0xA0000000, 0x00000000,
  377. 0x03E, 0x0003C190,
  378. 0xB0000000, 0x00000000,
  379. 0x03F, 0x000C3186,
  380. 0x033, 0x00000013,
  381. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  382. 0x03E, 0x00038998,
  383. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  384. 0x03E, 0x00038998,
  385. 0xA0000000, 0x00000000,
  386. 0x03E, 0x0003C998,
  387. 0xB0000000, 0x00000000,
  388. 0x03F, 0x000C3186,
  389. 0x033, 0x00000012,
  390. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  391. 0x03E, 0x00039840,
  392. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  393. 0x03E, 0x00039840,
  394. 0xA0000000, 0x00000000,
  395. 0x03E, 0x0003D840,
  396. 0xB0000000, 0x00000000,
  397. 0x03F, 0x000C3186,
  398. 0x033, 0x00000011,
  399. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  400. 0x03E, 0x000398C4,
  401. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  402. 0x03E, 0x000398C4,
  403. 0xA0000000, 0x00000000,
  404. 0x03E, 0x0003D8C4,
  405. 0xB0000000, 0x00000000,
  406. 0x03F, 0x000C3186,
  407. 0x033, 0x00000010,
  408. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  409. 0x03E, 0x00039930,
  410. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  411. 0x03E, 0x00039930,
  412. 0xA0000000, 0x00000000,
  413. 0x03E, 0x0003D930,
  414. 0xB0000000, 0x00000000,
  415. 0x03F, 0x000C3186,
  416. 0x0EF, 0x00000000,
  417. 0x0EF, 0x00004000,
  418. 0x033, 0x00000000,
  419. 0x03F, 0x0000000F,
  420. 0x033, 0x00000001,
  421. 0x03F, 0x0000000A,
  422. 0x033, 0x00000002,
  423. 0x03F, 0x00000005,
  424. 0x0EF, 0x00000000,
  425. 0x018, 0x00000401,
  426. 0x084, 0x00001209,
  427. 0x086, 0x000001A0,
  428. 0x087, 0x000E8180,
  429. 0x088, 0x00047020,
  430. 0x0DF, 0x00008009,
  431. 0x0EF, 0x00008000,
  432. 0x033, 0x0000000F,
  433. 0x03F, 0x0000003C,
  434. 0x033, 0x0000000E,
  435. 0x03F, 0x00000038,
  436. 0x033, 0x0000000D,
  437. 0x03F, 0x00000030,
  438. 0x033, 0x0000000C,
  439. 0x03F, 0x00000028,
  440. 0x033, 0x0000000B,
  441. 0x03F, 0x00000020,
  442. 0x033, 0x0000000A,
  443. 0x03F, 0x00000018,
  444. 0x033, 0x00000009,
  445. 0x03F, 0x00000010,
  446. 0x033, 0x00000008,
  447. 0x03F, 0x00000008,
  448. 0x033, 0x00000007,
  449. 0x03F, 0x0000003C,
  450. 0x033, 0x00000006,
  451. 0x03F, 0x00000038,
  452. 0x033, 0x00000005,
  453. 0x03F, 0x00000030,
  454. 0x033, 0x00000004,
  455. 0x03F, 0x00000028,
  456. 0x033, 0x00000003,
  457. 0x03F, 0x00000020,
  458. 0x033, 0x00000002,
  459. 0x03F, 0x00000018,
  460. 0x033, 0x00000001,
  461. 0x03F, 0x00000010,
  462. 0x033, 0x00000000,
  463. 0x03F, 0x00000008,
  464. 0x0EF, 0x00000000,
  465. 0x0EE, 0x00000002,
  466. 0x033, 0x0000001E,
  467. 0x03F, 0x00000000,
  468. 0x033, 0x0000001C,
  469. 0x81000000, 0x00000000, 0x40000000, 0x00000000,
  470. 0x03F, 0x00000000,
  471. 0xA0000000, 0x00000000,
  472. 0x03F, 0x00000006,
  473. 0xB0000000, 0x00000000,
  474. 0x033, 0x0000000E,
  475. 0x81000000, 0x00000000, 0x40000000, 0x00000000,
  476. 0x03F, 0x00000000,
  477. 0xA0000000, 0x00000000,
  478. 0x03F, 0x00000006,
  479. 0xB0000000, 0x00000000,
  480. 0x033, 0x0000000C,
  481. 0x81000000, 0x00000000, 0x40000000, 0x00000000,
  482. 0x03F, 0x00000000,
  483. 0xA0000000, 0x00000000,
  484. 0x03F, 0x00000006,
  485. 0xB0000000, 0x00000000,
  486. 0x033, 0x0000000A,
  487. 0x81000000, 0x00000000, 0x40000000, 0x00000000,
  488. 0x03F, 0x00000000,
  489. 0xA0000000, 0x00000000,
  490. 0x03F, 0x00000006,
  491. 0xB0000000, 0x00000000,
  492. 0x033, 0x00000008,
  493. 0x81000000, 0x00000000, 0x40000000, 0x00000000,
  494. 0x03F, 0x00000000,
  495. 0xA0000000, 0x00000000,
  496. 0x03F, 0x00000006,
  497. 0xB0000000, 0x00000000,
  498. 0x033, 0x00000036,
  499. 0x03F, 0x00000000,
  500. 0x033, 0x00000037,
  501. 0x03F, 0x00000000,
  502. 0x033, 0x00000034,
  503. 0x03F, 0x00000000,
  504. 0x033, 0x00000026,
  505. 0x03F, 0x00000006,
  506. 0x033, 0x00000027,
  507. 0x03F, 0x00000006,
  508. 0x033, 0x00000024,
  509. 0x03F, 0x00000006,
  510. 0x033, 0x00000022,
  511. 0x03F, 0x00000006,
  512. 0x033, 0x00000020,
  513. 0x03F, 0x00000006,
  514. 0x033, 0x00000006,
  515. 0x03F, 0x00000000,
  516. 0x033, 0x00000007,
  517. 0x03F, 0x00000006,
  518. 0x033, 0x00000004,
  519. 0x03F, 0x00000006,
  520. 0x033, 0x00000002,
  521. 0x03F, 0x00000006,
  522. 0x033, 0x00000000,
  523. 0x03F, 0x00000006,
  524. 0x0EE, 0x00000000,
  525. 0x0A0, 0x000F0005,
  526. 0x0A1, 0x0006C000,
  527. 0x0A2, 0x0000161B,
  528. 0x0A3, 0x000B9D3D,
  529. 0x0AF, 0x00070000,
  530. 0x0DE, 0x00000200,
  531. 0x0EE, 0x00000100,
  532. 0x033, 0x00000007,
  533. 0x03F, 0x00000043,
  534. 0x033, 0x00000006,
  535. 0x03F, 0x0000007A,
  536. 0x033, 0x00000005,
  537. 0x03F, 0x00000041,
  538. 0x033, 0x00000004,
  539. 0x03F, 0x00000079,
  540. 0x033, 0x00000003,
  541. 0x03F, 0x00000043,
  542. 0x033, 0x00000002,
  543. 0x03F, 0x0000007A,
  544. 0x033, 0x00000001,
  545. 0x03F, 0x00000041,
  546. 0x033, 0x00000000,
  547. 0x03F, 0x00000079,
  548. 0x0EE, 0x00000000,
  549. 0x0B8, 0x00080A00,
  550. 0x0B0, 0x000FF0FA,
  551. 0xFFE, 0x00000000,
  552. 0x0CA, 0x00080000,
  553. 0x0C9, 0x0001C141,
  554. 0xFFE, 0x00000000,
  555. 0x0B0, 0x000FF0F8,
  556. 0x018, 0x00018D24,
  557. 0xFFE, 0x00000000,
  558. 0xFFE, 0x00000000,
  559. 0xFFE, 0x00000000,
  560. 0xFFE, 0x00000000,
  561. 0xFFE, 0x00000000,
  562. 0xFFE, 0x00000000,
  563. 0x018, 0x00010D24,
  564. 0x01B, 0x00003A40,
  565. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  566. 0x061, 0x0004D3A3,
  567. 0x90001000, 0x00000000, 0x40000000, 0x00000000,
  568. 0x061, 0x0004D3A3,
  569. 0xA0000000, 0x00000000,
  570. 0x061, 0x0004D3A1,
  571. 0xB0000000, 0x00000000,
  572. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  573. 0x062, 0x0000D303,
  574. 0xA0000000, 0x00000000,
  575. 0x062, 0x0000D3A3,
  576. 0xB0000000, 0x00000000,
  577. 0x063, 0x00000002,
  578. 0x0EF, 0x00000200,
  579. 0x030, 0x00000000,
  580. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  581. 0x03F, 0x00033303,
  582. 0x90001000, 0x00000000, 0x40000000, 0x00000000,
  583. 0x03F, 0x000313A0,
  584. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  585. 0x03F, 0x000335A3,
  586. 0xA0000000, 0x00000000,
  587. 0x03F, 0x000335A1,
  588. 0xB0000000, 0x00000000,
  589. 0x030, 0x00001000,
  590. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  591. 0x03F, 0x00033303,
  592. 0x90001000, 0x00000000, 0x40000000, 0x00000000,
  593. 0x03F, 0x000313A0,
  594. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  595. 0x03F, 0x000335A3,
  596. 0xA0000000, 0x00000000,
  597. 0x03F, 0x000335A1,
  598. 0xB0000000, 0x00000000,
  599. 0x030, 0x00002000,
  600. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  601. 0x03F, 0x00033303,
  602. 0x90001000, 0x00000000, 0x40000000, 0x00000000,
  603. 0x03F, 0x000331A0,
  604. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  605. 0x03F, 0x000335A3,
  606. 0xA0000000, 0x00000000,
  607. 0x03F, 0x000335A1,
  608. 0xB0000000, 0x00000000,
  609. 0x030, 0x00003000,
  610. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  611. 0x03F, 0x00033303,
  612. 0x90001000, 0x00000000, 0x40000000, 0x00000000,
  613. 0x03F, 0x000313A0,
  614. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  615. 0x03F, 0x000335A3,
  616. 0xA0000000, 0x00000000,
  617. 0x03F, 0x000335A1,
  618. 0xB0000000, 0x00000000,
  619. 0x030, 0x00004000,
  620. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  621. 0x03F, 0x000313A3,
  622. 0x90001000, 0x00000000, 0x40000000, 0x00000000,
  623. 0x03F, 0x000313A1,
  624. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  625. 0x03F, 0x000335A3,
  626. 0xA0000000, 0x00000000,
  627. 0x03F, 0x000335A1,
  628. 0xB0000000, 0x00000000,
  629. 0x030, 0x00005000,
  630. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  631. 0x03F, 0x000313A3,
  632. 0x90001000, 0x00000000, 0x40000000, 0x00000000,
  633. 0x03F, 0x000313A1,
  634. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  635. 0x03F, 0x000335A3,
  636. 0xA0000000, 0x00000000,
  637. 0x03F, 0x000335A1,
  638. 0xB0000000, 0x00000000,
  639. 0x030, 0x00006000,
  640. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  641. 0x03F, 0x000313A3,
  642. 0x90001000, 0x00000000, 0x40000000, 0x00000000,
  643. 0x03F, 0x000313A1,
  644. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  645. 0x03F, 0x000335A3,
  646. 0xA0000000, 0x00000000,
  647. 0x03F, 0x000335A1,
  648. 0xB0000000, 0x00000000,
  649. 0x030, 0x00007000,
  650. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  651. 0x03F, 0x000313A3,
  652. 0x90001000, 0x00000000, 0x40000000, 0x00000000,
  653. 0x03F, 0x000313A1,
  654. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  655. 0x03F, 0x000335A3,
  656. 0xA0000000, 0x00000000,
  657. 0x03F, 0x000335A1,
  658. 0xB0000000, 0x00000000,
  659. 0x030, 0x00008000,
  660. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  661. 0x03F, 0x000333A3,
  662. 0x90001000, 0x00000000, 0x40000000, 0x00000000,
  663. 0x03F, 0x000333A1,
  664. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  665. 0x03F, 0x000335A3,
  666. 0xA0000000, 0x00000000,
  667. 0x03F, 0x000335A1,
  668. 0xB0000000, 0x00000000,
  669. 0x030, 0x00009000,
  670. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  671. 0x03F, 0x000333A3,
  672. 0x90001000, 0x00000000, 0x40000000, 0x00000000,
  673. 0x03F, 0x000333A1,
  674. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  675. 0x03F, 0x000335A3,
  676. 0xA0000000, 0x00000000,
  677. 0x03F, 0x000335A1,
  678. 0xB0000000, 0x00000000,
  679. 0x030, 0x0000A000,
  680. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  681. 0x03F, 0x000333A3,
  682. 0x90001000, 0x00000000, 0x40000000, 0x00000000,
  683. 0x03F, 0x000333A1,
  684. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  685. 0x03F, 0x000335A3,
  686. 0xA0000000, 0x00000000,
  687. 0x03F, 0x000335A1,
  688. 0xB0000000, 0x00000000,
  689. 0x030, 0x0000B000,
  690. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  691. 0x03F, 0x000333A3,
  692. 0x90001000, 0x00000000, 0x40000000, 0x00000000,
  693. 0x03F, 0x000333A1,
  694. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  695. 0x03F, 0x000335A3,
  696. 0xA0000000, 0x00000000,
  697. 0x03F, 0x000335A1,
  698. 0xB0000000, 0x00000000,
  699. 0x0EF, 0x00000000,
  700. 0x0EF, 0x00000080,
  701. 0x033, 0x00000000,
  702. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  703. 0x03F, 0x00033303,
  704. 0x90001000, 0x00000000, 0x40000000, 0x00000000,
  705. 0x03F, 0x000313A0,
  706. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  707. 0x03F, 0x000335A3,
  708. 0xA0000000, 0x00000000,
  709. 0x03F, 0x000335A1,
  710. 0xB0000000, 0x00000000,
  711. 0x033, 0x00000001,
  712. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  713. 0x03F, 0x00033303,
  714. 0x90001000, 0x00000000, 0x40000000, 0x00000000,
  715. 0x03F, 0x000313A0,
  716. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  717. 0x03F, 0x000335A3,
  718. 0xA0000000, 0x00000000,
  719. 0x03F, 0x000335A1,
  720. 0xB0000000, 0x00000000,
  721. 0x033, 0x00000002,
  722. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  723. 0x03F, 0x00033303,
  724. 0x90001000, 0x00000000, 0x40000000, 0x00000000,
  725. 0x03F, 0x000313A0,
  726. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  727. 0x03F, 0x000335A3,
  728. 0xA0000000, 0x00000000,
  729. 0x03F, 0x000335A1,
  730. 0xB0000000, 0x00000000,
  731. 0x033, 0x00000003,
  732. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  733. 0x03F, 0x00033303,
  734. 0x90001000, 0x00000000, 0x40000000, 0x00000000,
  735. 0x03F, 0x000313A0,
  736. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  737. 0x03F, 0x000335A3,
  738. 0xA0000000, 0x00000000,
  739. 0x03F, 0x000335A1,
  740. 0xB0000000, 0x00000000,
  741. 0x033, 0x00000004,
  742. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  743. 0x03F, 0x00033303,
  744. 0x90001000, 0x00000000, 0x40000000, 0x00000000,
  745. 0x03F, 0x000313A0,
  746. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  747. 0x03F, 0x000335A3,
  748. 0xA0000000, 0x00000000,
  749. 0x03F, 0x000335A1,
  750. 0xB0000000, 0x00000000,
  751. 0x033, 0x00000005,
  752. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  753. 0x03F, 0x00033303,
  754. 0x90001000, 0x00000000, 0x40000000, 0x00000000,
  755. 0x03F, 0x000313A0,
  756. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  757. 0x03F, 0x000335A3,
  758. 0xA0000000, 0x00000000,
  759. 0x03F, 0x000335A1,
  760. 0xB0000000, 0x00000000,
  761. 0x033, 0x00000006,
  762. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  763. 0x03F, 0x00033303,
  764. 0x90001000, 0x00000000, 0x40000000, 0x00000000,
  765. 0x03F, 0x000313A0,
  766. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  767. 0x03F, 0x000335A3,
  768. 0xA0000000, 0x00000000,
  769. 0x03F, 0x000335A1,
  770. 0xB0000000, 0x00000000,
  771. 0x033, 0x00000007,
  772. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  773. 0x03F, 0x00033303,
  774. 0x90001000, 0x00000000, 0x40000000, 0x00000000,
  775. 0x03F, 0x000313A0,
  776. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  777. 0x03F, 0x000335A3,
  778. 0xA0000000, 0x00000000,
  779. 0x03F, 0x000335A1,
  780. 0xB0000000, 0x00000000,
  781. 0x033, 0x00000008,
  782. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  783. 0x03F, 0x000313A3,
  784. 0x90001000, 0x00000000, 0x40000000, 0x00000000,
  785. 0x03F, 0x000313A1,
  786. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  787. 0x03F, 0x000335A3,
  788. 0xA0000000, 0x00000000,
  789. 0x03F, 0x000335A1,
  790. 0xB0000000, 0x00000000,
  791. 0x033, 0x00000009,
  792. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  793. 0x03F, 0x000313A3,
  794. 0x90001000, 0x00000000, 0x40000000, 0x00000000,
  795. 0x03F, 0x000313A1,
  796. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  797. 0x03F, 0x000335A3,
  798. 0xA0000000, 0x00000000,
  799. 0x03F, 0x000335A1,
  800. 0xB0000000, 0x00000000,
  801. 0x033, 0x0000000A,
  802. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  803. 0x03F, 0x000313A3,
  804. 0x90001000, 0x00000000, 0x40000000, 0x00000000,
  805. 0x03F, 0x000313A1,
  806. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  807. 0x03F, 0x000335A3,
  808. 0xA0000000, 0x00000000,
  809. 0x03F, 0x000335A1,
  810. 0xB0000000, 0x00000000,
  811. 0x033, 0x0000000B,
  812. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  813. 0x03F, 0x000313A3,
  814. 0x90001000, 0x00000000, 0x40000000, 0x00000000,
  815. 0x03F, 0x000313A1,
  816. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  817. 0x03F, 0x000335A3,
  818. 0xA0000000, 0x00000000,
  819. 0x03F, 0x000335A1,
  820. 0xB0000000, 0x00000000,
  821. 0x033, 0x0000000C,
  822. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  823. 0x03F, 0x000313A3,
  824. 0x90001000, 0x00000000, 0x40000000, 0x00000000,
  825. 0x03F, 0x000313A1,
  826. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  827. 0x03F, 0x000335A3,
  828. 0xA0000000, 0x00000000,
  829. 0x03F, 0x000335A1,
  830. 0xB0000000, 0x00000000,
  831. 0x033, 0x0000000D,
  832. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  833. 0x03F, 0x000333A3,
  834. 0x90001000, 0x00000000, 0x40000000, 0x00000000,
  835. 0x03F, 0x000333A1,
  836. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  837. 0x03F, 0x000335A3,
  838. 0xA0000000, 0x00000000,
  839. 0x03F, 0x000335A1,
  840. 0xB0000000, 0x00000000,
  841. 0x033, 0x0000000E,
  842. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  843. 0x03F, 0x000333A3,
  844. 0x90001000, 0x00000000, 0x40000000, 0x00000000,
  845. 0x03F, 0x000333A1,
  846. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  847. 0x03F, 0x000335A3,
  848. 0xA0000000, 0x00000000,
  849. 0x03F, 0x000335A1,
  850. 0xB0000000, 0x00000000,
  851. 0x033, 0x0000000F,
  852. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  853. 0x03F, 0x000333A3,
  854. 0x90001000, 0x00000000, 0x40000000, 0x00000000,
  855. 0x03F, 0x000333A1,
  856. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  857. 0x03F, 0x000335A3,
  858. 0xA0000000, 0x00000000,
  859. 0x03F, 0x000335A1,
  860. 0xB0000000, 0x00000000,
  861. 0x033, 0x00000010,
  862. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  863. 0x03F, 0x000333A3,
  864. 0x90001000, 0x00000000, 0x40000000, 0x00000000,
  865. 0x03F, 0x000333A1,
  866. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  867. 0x03F, 0x000335A3,
  868. 0xA0000000, 0x00000000,
  869. 0x03F, 0x000335A1,
  870. 0xB0000000, 0x00000000,
  871. 0x033, 0x00000011,
  872. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  873. 0x03F, 0x000333A3,
  874. 0x90001000, 0x00000000, 0x40000000, 0x00000000,
  875. 0x03F, 0x000333A1,
  876. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  877. 0x03F, 0x000335A3,
  878. 0xA0000000, 0x00000000,
  879. 0x03F, 0x000335A1,
  880. 0xB0000000, 0x00000000,
  881. 0x033, 0x00000012,
  882. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  883. 0x03F, 0x000333A3,
  884. 0x90001000, 0x00000000, 0x40000000, 0x00000000,
  885. 0x03F, 0x000333A1,
  886. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  887. 0x03F, 0x000335A3,
  888. 0xA0000000, 0x00000000,
  889. 0x03F, 0x000335A1,
  890. 0xB0000000, 0x00000000,
  891. 0x0EF, 0x00000000,
  892. 0x0EF, 0x00000040,
  893. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  894. 0x030, 0x00000644,
  895. 0x030, 0x00001412,
  896. 0x90001000, 0x00000000, 0x40000000, 0x00000000,
  897. 0x030, 0x00000743,
  898. 0x030, 0x00001412,
  899. 0xA0000000, 0x00000000,
  900. 0x030, 0x00000640,
  901. 0x030, 0x00001512,
  902. 0xB0000000, 0x00000000,
  903. 0x030, 0x00002202,
  904. 0x030, 0x00004000,
  905. 0x030, 0x00005000,
  906. 0x030, 0x00006000,
  907. 0x0EF, 0x00000000,
  908. 0x0EF, 0x00000800,
  909. 0x033, 0x00000020,
  910. 0x03F, 0x00000E42,
  911. 0x033, 0x00000021,
  912. 0x03F, 0x00000E45,
  913. 0x033, 0x00000022,
  914. 0x03F, 0x00000E48,
  915. 0x033, 0x00000023,
  916. 0x03F, 0x00000E68,
  917. 0x033, 0x00000024,
  918. 0x03F, 0x00000E6B,
  919. 0x033, 0x00000025,
  920. 0x03F, 0x00000EAA,
  921. 0x033, 0x00000026,
  922. 0x03F, 0x00000EEA,
  923. 0x033, 0x00000027,
  924. 0x03F, 0x00000EED,
  925. 0x033, 0x00000028,
  926. 0x03F, 0x00000EF0,
  927. 0x033, 0x00000029,
  928. 0x03F, 0x00000EF3,
  929. 0x033, 0x0000002A,
  930. 0x03F, 0x00000EF6,
  931. 0x033, 0x00000060,
  932. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  933. 0x03F, 0x00000E0A,
  934. 0xA0000000, 0x00000000,
  935. 0x03F, 0x00000E09,
  936. 0xB0000000, 0x00000000,
  937. 0x033, 0x00000061,
  938. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  939. 0x03F, 0x00000E44,
  940. 0xA0000000, 0x00000000,
  941. 0x03F, 0x00000E43,
  942. 0xB0000000, 0x00000000,
  943. 0x033, 0x00000062,
  944. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  945. 0x03F, 0x00000E47,
  946. 0xA0000000, 0x00000000,
  947. 0x03F, 0x00000E46,
  948. 0xB0000000, 0x00000000,
  949. 0x033, 0x00000063,
  950. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  951. 0x03F, 0x00000E4A,
  952. 0xA0000000, 0x00000000,
  953. 0x03F, 0x00000E49,
  954. 0xB0000000, 0x00000000,
  955. 0x033, 0x00000064,
  956. 0x03F, 0x00000E6A,
  957. 0x033, 0x00000065,
  958. 0x03F, 0x00000EAA,
  959. 0x033, 0x00000066,
  960. 0x03F, 0x00000EEB,
  961. 0x033, 0x00000067,
  962. 0x03F, 0x00000EEE,
  963. 0x033, 0x00000068,
  964. 0x03F, 0x00000EF1,
  965. 0x033, 0x00000069,
  966. 0x03F, 0x00000EF4,
  967. 0x033, 0x0000006A,
  968. 0x03F, 0x00000EF7,
  969. 0x033, 0x000000A0,
  970. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  971. 0x03F, 0x00000E08,
  972. 0xA0000000, 0x00000000,
  973. 0x03F, 0x00000E09,
  974. 0xB0000000, 0x00000000,
  975. 0x033, 0x000000A1,
  976. 0x03F, 0x00000E42,
  977. 0x033, 0x000000A2,
  978. 0x03F, 0x00000E45,
  979. 0x033, 0x000000A3,
  980. 0x03F, 0x00000E48,
  981. 0x033, 0x000000A4,
  982. 0x03F, 0x00000E69,
  983. 0x033, 0x000000A5,
  984. 0x03F, 0x00000EA9,
  985. 0x033, 0x000000A6,
  986. 0x03F, 0x00000EEA,
  987. 0x033, 0x000000A7,
  988. 0x03F, 0x00000EED,
  989. 0x033, 0x000000A8,
  990. 0x03F, 0x00000EF0,
  991. 0x033, 0x000000A9,
  992. 0x03F, 0x00000EF3,
  993. 0x033, 0x000000AA,
  994. 0x03F, 0x00000EF6,
  995. 0x0EF, 0x00000000,
  996. 0x0EF, 0x00000400,
  997. 0x033, 0x00000000,
  998. 0x81000000, 0x00000000, 0x40000000, 0x00000000,
  999. 0x03F, 0x0006AC00,
  1000. 0xA0000000, 0x00000000,
  1001. 0x03F, 0x00086A00,
  1002. 0xB0000000, 0x00000000,
  1003. 0x033, 0x00000001,
  1004. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  1005. 0x03F, 0x00060C00,
  1006. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  1007. 0x03F, 0x00060C00,
  1008. 0xA0000000, 0x00000000,
  1009. 0x03F, 0x00086A00,
  1010. 0xB0000000, 0x00000000,
  1011. 0x033, 0x00000002,
  1012. 0x81000000, 0x00000000, 0x40000000, 0x00000000,
  1013. 0x03F, 0x0006AC00,
  1014. 0xA0000000, 0x00000000,
  1015. 0x03F, 0x00086A00,
  1016. 0xB0000000, 0x00000000,
  1017. 0x033, 0x00000003,
  1018. 0x03F, 0x00086A00,
  1019. 0x0EF, 0x00000000,
  1020. 0x0EF, 0x00000100,
  1021. 0x033, 0x00000000,
  1022. 0x03F, 0x00000040,
  1023. 0x033, 0x00000001,
  1024. 0x03F, 0x00000040,
  1025. 0x033, 0x00000002,
  1026. 0x03F, 0x00000040,
  1027. 0x033, 0x00000003,
  1028. 0x03F, 0x00000040,
  1029. 0x0EF, 0x00000000,
  1030. 0x0EF, 0x00040000,
  1031. 0x033, 0x00000000,
  1032. 0x03F, 0x00086A40,
  1033. 0x033, 0x00000001,
  1034. 0x03F, 0x00086A40,
  1035. 0x033, 0x00000002,
  1036. 0x03F, 0x00086A40,
  1037. 0x033, 0x00000003,
  1038. 0x03F, 0x00086A40,
  1039. 0x033, 0x00000004,
  1040. 0x03F, 0x00086A40,
  1041. 0x033, 0x00000005,
  1042. 0x03F, 0x00086A40,
  1043. 0x033, 0x00000006,
  1044. 0x03F, 0x00084A40,
  1045. 0x033, 0x00000007,
  1046. 0x03F, 0x00084A40,
  1047. 0x0EF, 0x00000000,
  1048. 0x051, 0x000801A8,
  1049. 0x052, 0x000972E3,
  1050. 0x053, 0x00008069,
  1051. 0x054, 0x00030032,
  1052. 0x055, 0x00082003,
  1053. 0x056, 0x00051CCB,
  1054. 0x057, 0x0000CFC2,
  1055. 0x058, 0x00000010,
  1056. 0x059, 0x00030000,
  1057. 0x0EF, 0x00000800,
  1058. 0x033, 0x00000000,
  1059. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  1060. 0x03F, 0x00051429,
  1061. 0x90001000, 0x00000000, 0x40000000, 0x00000000,
  1062. 0x03F, 0x00051429,
  1063. 0xA0000000, 0x00000000,
  1064. 0x03F, 0x00051427,
  1065. 0xB0000000, 0x00000000,
  1066. 0x033, 0x00000001,
  1067. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  1068. 0x03F, 0x00051449,
  1069. 0x90001000, 0x00000000, 0x40000000, 0x00000000,
  1070. 0x03F, 0x00051449,
  1071. 0xA0000000, 0x00000000,
  1072. 0x03F, 0x00051446,
  1073. 0xB0000000, 0x00000000,
  1074. 0x033, 0x00000002,
  1075. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  1076. 0x03F, 0x0005144C,
  1077. 0x90001000, 0x00000000, 0x40000000, 0x00000000,
  1078. 0x03F, 0x0005144C,
  1079. 0xA0000000, 0x00000000,
  1080. 0x03F, 0x00051449,
  1081. 0xB0000000, 0x00000000,
  1082. 0x033, 0x00000003,
  1083. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  1084. 0x03F, 0x00051C66,
  1085. 0x90001000, 0x00000000, 0x40000000, 0x00000000,
  1086. 0x03F, 0x00051C66,
  1087. 0xA0000000, 0x00000000,
  1088. 0x03F, 0x0005144C,
  1089. 0xB0000000, 0x00000000,
  1090. 0x033, 0x00000004,
  1091. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  1092. 0x03F, 0x00051C69,
  1093. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  1094. 0x03F, 0x00051C67,
  1095. 0xA0000000, 0x00000000,
  1096. 0x03F, 0x00051C69,
  1097. 0xB0000000, 0x00000000,
  1098. 0x033, 0x00000005,
  1099. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  1100. 0x03F, 0x00051C6C,
  1101. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  1102. 0x03F, 0x00051C6A,
  1103. 0xA0000000, 0x00000000,
  1104. 0x03F, 0x00051C6C,
  1105. 0xB0000000, 0x00000000,
  1106. 0x033, 0x00000006,
  1107. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  1108. 0x03F, 0x00051CE8,
  1109. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  1110. 0x03F, 0x00051C8B,
  1111. 0xA0000000, 0x00000000,
  1112. 0x03F, 0x00051C8D,
  1113. 0xB0000000, 0x00000000,
  1114. 0x033, 0x00000007,
  1115. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  1116. 0x03F, 0x00051CEB,
  1117. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  1118. 0x03F, 0x00051CE9,
  1119. 0xA0000000, 0x00000000,
  1120. 0x03F, 0x00051CEB,
  1121. 0xB0000000, 0x00000000,
  1122. 0x033, 0x00000008,
  1123. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  1124. 0x03F, 0x00051CEE,
  1125. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  1126. 0x03F, 0x00051CEC,
  1127. 0xA0000000, 0x00000000,
  1128. 0x03F, 0x00051CEE,
  1129. 0xB0000000, 0x00000000,
  1130. 0x033, 0x00000009,
  1131. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  1132. 0x03F, 0x00051CF1,
  1133. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  1134. 0x03F, 0x00051CEF,
  1135. 0xA0000000, 0x00000000,
  1136. 0x03F, 0x00051CF1,
  1137. 0xB0000000, 0x00000000,
  1138. 0x033, 0x0000000A,
  1139. 0x81001000, 0x00000000, 0x40000000, 0x00000000,
  1140. 0x03F, 0x00051CF4,
  1141. 0x90001000, 0x00000000, 0x40000000, 0x00000000,
  1142. 0x03F, 0x00051CF1,
  1143. 0x91000000, 0x00000000, 0x40000000, 0x00000000,
  1144. 0x03F, 0x00051CF2,
  1145. 0xA0000000, 0x00000000,
  1146. 0x03F, 0x00051CF4,
  1147. 0xB0000000, 0x00000000,
  1148. 0x0EF, 0x00000000,
  1149. 0x0EE, 0x00004000,
  1150. 0x033, 0x00000000,
  1151. 0x03F, 0x00048400,
  1152. 0x033, 0x00000001,
  1153. 0x03F, 0x00086E00,
  1154. 0x033, 0x00000002,
  1155. 0x03F, 0x00048400,
  1156. 0x033, 0x00000003,
  1157. 0x03F, 0x00048400,
  1158. 0x0EE, 0x00000000,
  1159. 0x0EE, 0x00002000,
  1160. 0x033, 0x00000000,
  1161. 0x03F, 0x00000000,
  1162. 0x033, 0x00000001,
  1163. 0x03F, 0x00000000,
  1164. 0x033, 0x00000002,
  1165. 0x03F, 0x00000000,
  1166. 0x033, 0x00000003,
  1167. 0x03F, 0x00000000,
  1168. 0x0EE, 0x00000000,
  1169. 0x0EE, 0x00080000,
  1170. 0x033, 0x00000000,
  1171. 0x03F, 0x00048400,
  1172. 0x033, 0x00000001,
  1173. 0x03F, 0x00048400,
  1174. 0x033, 0x00000002,
  1175. 0x03F, 0x00048400,
  1176. 0x033, 0x00000003,
  1177. 0x03F, 0x00048400,
  1178. 0x033, 0x00000004,
  1179. 0x03F, 0x00048400,
  1180. 0x033, 0x00000005,
  1181. 0x03F, 0x00048400,
  1182. 0x033, 0x00000006,
  1183. 0x03F, 0x00048400,
  1184. 0x033, 0x00000007,
  1185. 0x03F, 0x00048400,
  1186. 0x0EE, 0x00000000,
  1187. 0x070, 0x00008000,
  1188. 0x075, 0x000027DA,
  1189. 0x076, 0x00006997,
  1190. 0x077, 0x00070418,
  1191. 0x078, 0x000BB000,
  1192. 0x07D, 0x00007600,
  1193. 0x07F, 0x00000000,
  1194. 0x06A, 0x000F4C00,
  1195. 0x065, 0x00082030,
  1196. 0x0EE, 0x00008000,
  1197. 0x033, 0x00000000,
  1198. 0x03F, 0x00051427,
  1199. 0x033, 0x00000001,
  1200. 0x03F, 0x00051446,
  1201. 0x033, 0x00000002,
  1202. 0x03F, 0x00051449,
  1203. 0x033, 0x00000003,
  1204. 0x03F, 0x0005144C,
  1205. 0x033, 0x00000004,
  1206. 0x03F, 0x00051C69,
  1207. 0x033, 0x00000005,
  1208. 0x03F, 0x00051C6C,
  1209. 0x033, 0x00000006,
  1210. 0x03F, 0x00051C8D,
  1211. 0x033, 0x00000007,
  1212. 0x03F, 0x00051CEB,
  1213. 0x033, 0x00000008,
  1214. 0x03F, 0x00051CEE,
  1215. 0x033, 0x00000009,
  1216. 0x03F, 0x00051CF1,
  1217. 0x033, 0x0000000A,
  1218. 0x03F, 0x00051CF4,
  1219. 0x0EE, 0x00000000,
  1220. 0x0EF, 0x00000010,
  1221. 0x033, 0x00000000,
  1222. 0x008, 0x0009C060,
  1223. 0x033, 0x00000001,
  1224. 0x008, 0x0009C060,
  1225. 0x0EF, 0x00000000,
  1226. 0x033, 0x000000A2,
  1227. 0x0EF, 0x00080000,
  1228. 0x03E, 0x0000593F,
  1229. 0x03F, 0x000C0F4F,
  1230. 0x0EF, 0x00000000,
  1231. 0x033, 0x000000A3,
  1232. 0x0EF, 0x00080000,
  1233. 0x03E, 0x00005934,
  1234. 0x03F, 0x0005AFCF,
  1235. 0x0EF, 0x00000000,
  1236. 0x0EF, 0x00080000,
  1237. 0x033, 0x00000024,
  1238. 0x03E, 0x0000003F,
  1239. 0x03F, 0x00060FDE,
  1240. 0x0EF, 0x00000000,
  1241. 0x0EF, 0x00080000,
  1242. 0x033, 0x00000025,
  1243. 0x03E, 0x00000037,
  1244. 0x03F, 0x0007EFCE,
  1245. 0x0EF, 0x00000000,
  1246. 0x0EF, 0x00080000,
  1247. 0x033, 0x00000026,
  1248. 0x03E, 0x00000037,
  1249. 0x03F, 0x0005EFCE,
  1250. 0x0EF, 0x00000000,
  1251. 0x0EE, 0x00001000,
  1252. 0x033, 0x00000004,
  1253. 0x03F, 0x00001EC1,
  1254. 0x0EE, 0x00000000,
  1255. 0x0EE, 0x00001000,
  1256. 0x033, 0x00000005,
  1257. 0x03F, 0x00001ECF,
  1258. 0x0EE, 0x00000000,
  1259. 0x0EE, 0x00001000,
  1260. 0x033, 0x00000006,
  1261. 0x03F, 0x00001F9D,
  1262. 0x0EE, 0x00000000,
  1263. };
  1264. void
  1265. odm_read_and_config_mp_8821c_radioa(
  1266. struct PHY_DM_STRUCT *p_dm_odm
  1267. )
  1268. {
  1269. u32 i = 0;
  1270. u8 c_cond;
  1271. boolean is_matched = true, is_skipped = false;
  1272. u32 array_len = sizeof(array_mp_8821c_radioa)/sizeof(u32);
  1273. u32 *array = array_mp_8821c_radioa;
  1274. u32 v1 = 0, v2 = 0, pre_v1 = 0, pre_v2 = 0;
  1275. ODM_RT_TRACE(p_dm_odm, ODM_COMP_INIT, ODM_DBG_LOUD, ("===> odm_read_and_config_mp_8821c_radioa\n"));
  1276. while ((i + 1) < array_len) {
  1277. v1 = array[i];
  1278. v2 = array[i + 1];
  1279. if (v1 & (BIT(31) | BIT(30))) {/*positive & negative condition*/
  1280. if (v1 & BIT(31)) {/* positive condition*/
  1281. c_cond = (u8)((v1 & (BIT(29)|BIT(28))) >> 28);
  1282. if (c_cond == COND_ENDIF) {/*end*/
  1283. is_matched = true;
  1284. is_skipped = false;
  1285. ODM_RT_TRACE(p_dm_odm, ODM_COMP_INIT, ODM_DBG_LOUD, ("ENDIF\n"));
  1286. } else if (c_cond == COND_ELSE) { /*else*/
  1287. is_matched = is_skipped?false:true;
  1288. ODM_RT_TRACE(p_dm_odm, ODM_COMP_INIT, ODM_DBG_LOUD, ("ELSE\n"));
  1289. } else {/*if , else if*/
  1290. pre_v1 = v1;
  1291. pre_v2 = v2;
  1292. ODM_RT_TRACE(p_dm_odm, ODM_COMP_INIT, ODM_DBG_LOUD, ("IF or ELSE IF\n"));
  1293. }
  1294. } else if (v1 & BIT(30)) { /*negative condition*/
  1295. if (is_skipped == false) {
  1296. if (check_positive(p_dm_odm, pre_v1, pre_v2, v1, v2)) {
  1297. is_matched = true;
  1298. is_skipped = true;
  1299. } else {
  1300. is_matched = false;
  1301. is_skipped = false;
  1302. }
  1303. } else
  1304. is_matched = false;
  1305. }
  1306. } else {
  1307. if (is_matched)
  1308. odm_config_rf_radio_a_8821c(p_dm_odm, v1, v2);
  1309. }
  1310. i = i + 2;
  1311. }
  1312. }
  1313. u32
  1314. odm_get_version_mp_8821c_radioa(void)
  1315. {
  1316. return 36;
  1317. }
  1318. /******************************************************************************
  1319. * txpowertrack.TXT
  1320. ******************************************************************************/
  1321. u8 g_delta_swing_table_idx_mp_5gb_n_txpowertrack_8821c[][DELTA_SWINGIDX_SIZE] = {
  1322. {0, 1, 1, 2, 3, 3, 3, 4, 4, 5, 5, 6, 6, 6, 7, 8, 8, 8, 9, 9, 9, 10, 10, 11, 11, 12, 12, 12, 12, 12},
  1323. {0, 1, 1, 1, 2, 3, 3, 4, 4, 5, 5, 5, 6, 6, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 12, 12, 12, 12, 12},
  1324. {0, 1, 2, 2, 3, 4, 4, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 9, 10, 10, 11, 11, 12, 12, 12, 12, 12, 12},
  1325. };
  1326. u8 g_delta_swing_table_idx_mp_5gb_p_txpowertrack_8821c[][DELTA_SWINGIDX_SIZE] = {
  1327. {0, 1, 1, 2, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 11, 11, 12, 12, 12, 12, 12, 12, 12},
  1328. {0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 5, 6, 7, 7, 8, 8, 9, 10, 10, 11, 11, 12, 12, 12, 12, 12, 12, 12, 12},
  1329. {0, 1, 1, 1, 2, 3, 3, 3, 4, 4, 4, 5, 6, 6, 7, 7, 8, 8, 9, 10, 10, 11, 11, 12, 12, 12, 12, 12, 12, 12},
  1330. };
  1331. u8 g_delta_swing_table_idx_mp_5ga_n_txpowertrack_8821c[][DELTA_SWINGIDX_SIZE] = {
  1332. {0, 1, 1, 2, 3, 3, 3, 4, 4, 5, 5, 6, 6, 6, 7, 8, 8, 8, 9, 9, 9, 10, 10, 11, 11, 12, 12, 12, 12, 12},
  1333. {0, 1, 1, 1, 2, 3, 3, 4, 4, 5, 5, 5, 6, 6, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 12, 12, 12, 12, 12},
  1334. {0, 1, 2, 2, 3, 4, 4, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 9, 10, 10, 11, 11, 12, 12, 12, 12, 12, 12},
  1335. };
  1336. u8 g_delta_swing_table_idx_mp_5ga_p_txpowertrack_8821c[][DELTA_SWINGIDX_SIZE] = {
  1337. {0, 1, 1, 2, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 11, 11, 12, 12, 12, 12, 12, 12, 12},
  1338. {0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 5, 6, 7, 7, 8, 8, 9, 10, 10, 11, 11, 12, 12, 12, 12, 12, 12, 12, 12},
  1339. {0, 1, 1, 1, 2, 3, 3, 3, 4, 4, 4, 5, 6, 6, 7, 7, 8, 8, 9, 10, 10, 11, 11, 12, 12, 12, 12, 12, 12, 12},
  1340. };
  1341. u8 g_delta_swing_table_idx_mp_2gb_n_txpowertrack_8821c[] = {0, 0, 0, 1, 1, 1, 2, 2, 2, 3, 3, 3, 3, 3, 4, 4, 4, 4, 5, 5, 5, 5, 6, 6, 6, 7, 7, 8, 8, 9};
  1342. u8 g_delta_swing_table_idx_mp_2gb_p_txpowertrack_8821c[] = {0, 1, 1, 1, 1, 2, 2, 2, 3, 3, 3, 3, 4, 4, 5, 5, 5, 5, 6, 6, 6, 7, 7, 7, 8, 8, 9, 9, 9, 9};
  1343. u8 g_delta_swing_table_idx_mp_2ga_n_txpowertrack_8821c[] = {0, 0, 0, 1, 1, 1, 2, 2, 2, 3, 3, 3, 3, 3, 4, 4, 4, 4, 5, 5, 5, 5, 6, 6, 6, 7, 7, 8, 8, 9};
  1344. u8 g_delta_swing_table_idx_mp_2ga_p_txpowertrack_8821c[] = {0, 1, 1, 1, 1, 2, 2, 2, 3, 3, 3, 3, 4, 4, 5, 5, 5, 5, 6, 6, 6, 7, 7, 7, 8, 8, 9, 9, 9, 9};
  1345. u8 g_delta_swing_table_idx_mp_2g_cck_b_n_txpowertrack_8821c[] = {0, 0, 1, 1, 1, 1, 2, 2, 2, 2, 3, 3, 3, 3, 4, 4, 4, 5, 5, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 9};
  1346. u8 g_delta_swing_table_idx_mp_2g_cck_b_p_txpowertrack_8821c[] = {0, 1, 1, 1, 1, 2, 2, 2, 3, 3, 3, 4, 4, 4, 5, 5, 5, 6, 6, 7, 7, 7, 8, 8, 9, 9, 9, 9, 9, 9};
  1347. u8 g_delta_swing_table_idx_mp_2g_cck_a_n_txpowertrack_8821c[] = {0, 0, 1, 1, 1, 1, 2, 2, 2, 2, 3, 3, 3, 3, 4, 4, 4, 5, 5, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 9};
  1348. u8 g_delta_swing_table_idx_mp_2g_cck_a_p_txpowertrack_8821c[] = {0, 1, 1, 1, 1, 2, 2, 2, 3, 3, 3, 4, 4, 4, 5, 5, 5, 6, 6, 7, 7, 7, 8, 8, 9, 9, 9, 9, 9, 9};
  1349. void
  1350. odm_read_and_config_mp_8821c_txpowertrack(
  1351. struct PHY_DM_STRUCT *p_dm_odm
  1352. )
  1353. {
  1354. struct odm_rf_calibration_structure *p_rf_calibrate_info = &(p_dm_odm->rf_calibrate_info);
  1355. ODM_RT_TRACE(p_dm_odm, ODM_COMP_INIT, ODM_DBG_LOUD, ("===> ODM_ReadAndConfig_MP_mp_8821c\n"));
  1356. odm_move_memory(p_dm_odm, p_rf_calibrate_info->delta_swing_table_idx_2ga_p, g_delta_swing_table_idx_mp_2ga_p_txpowertrack_8821c, DELTA_SWINGIDX_SIZE);
  1357. odm_move_memory(p_dm_odm, p_rf_calibrate_info->delta_swing_table_idx_2ga_n, g_delta_swing_table_idx_mp_2ga_n_txpowertrack_8821c, DELTA_SWINGIDX_SIZE);
  1358. odm_move_memory(p_dm_odm, p_rf_calibrate_info->delta_swing_table_idx_2gb_p, g_delta_swing_table_idx_mp_2gb_p_txpowertrack_8821c, DELTA_SWINGIDX_SIZE);
  1359. odm_move_memory(p_dm_odm, p_rf_calibrate_info->delta_swing_table_idx_2gb_n, g_delta_swing_table_idx_mp_2gb_n_txpowertrack_8821c, DELTA_SWINGIDX_SIZE);
  1360. odm_move_memory(p_dm_odm, p_rf_calibrate_info->delta_swing_table_idx_2g_cck_a_p, g_delta_swing_table_idx_mp_2g_cck_a_p_txpowertrack_8821c, DELTA_SWINGIDX_SIZE);
  1361. odm_move_memory(p_dm_odm, p_rf_calibrate_info->delta_swing_table_idx_2g_cck_a_n, g_delta_swing_table_idx_mp_2g_cck_a_n_txpowertrack_8821c, DELTA_SWINGIDX_SIZE);
  1362. odm_move_memory(p_dm_odm, p_rf_calibrate_info->delta_swing_table_idx_2g_cck_b_p, g_delta_swing_table_idx_mp_2g_cck_b_p_txpowertrack_8821c, DELTA_SWINGIDX_SIZE);
  1363. odm_move_memory(p_dm_odm, p_rf_calibrate_info->delta_swing_table_idx_2g_cck_b_n, g_delta_swing_table_idx_mp_2g_cck_b_n_txpowertrack_8821c, DELTA_SWINGIDX_SIZE);
  1364. odm_move_memory(p_dm_odm, p_rf_calibrate_info->delta_swing_table_idx_5ga_p, g_delta_swing_table_idx_mp_5ga_p_txpowertrack_8821c, DELTA_SWINGIDX_SIZE*3);
  1365. odm_move_memory(p_dm_odm, p_rf_calibrate_info->delta_swing_table_idx_5ga_n, g_delta_swing_table_idx_mp_5ga_n_txpowertrack_8821c, DELTA_SWINGIDX_SIZE*3);
  1366. odm_move_memory(p_dm_odm, p_rf_calibrate_info->delta_swing_table_idx_5gb_p, g_delta_swing_table_idx_mp_5gb_p_txpowertrack_8821c, DELTA_SWINGIDX_SIZE*3);
  1367. odm_move_memory(p_dm_odm, p_rf_calibrate_info->delta_swing_table_idx_5gb_n, g_delta_swing_table_idx_mp_5gb_n_txpowertrack_8821c, DELTA_SWINGIDX_SIZE*3);
  1368. }
  1369. /******************************************************************************
  1370. * txpwr_lmt.TXT
  1371. ******************************************************************************/
  1372. const char *array_mp_8821c_txpwr_lmt[] = {
  1373. "FCC", "2.4G", "20M", "CCK", "1T", "01", "30",
  1374. "ETSI", "2.4G", "20M", "CCK", "1T", "01", "30",
  1375. "MKK", "2.4G", "20M", "CCK", "1T", "01", "34",
  1376. "FCC", "2.4G", "20M", "CCK", "1T", "02", "32",
  1377. "ETSI", "2.4G", "20M", "CCK", "1T", "02", "30",
  1378. "MKK", "2.4G", "20M", "CCK", "1T", "02", "34",
  1379. "FCC", "2.4G", "20M", "CCK", "1T", "03", "32",
  1380. "ETSI", "2.4G", "20M", "CCK", "1T", "03", "30",
  1381. "MKK", "2.4G", "20M", "CCK", "1T", "03", "34",
  1382. "FCC", "2.4G", "20M", "CCK", "1T", "04", "32",
  1383. "ETSI", "2.4G", "20M", "CCK", "1T", "04", "30",
  1384. "MKK", "2.4G", "20M", "CCK", "1T", "04", "34",
  1385. "FCC", "2.4G", "20M", "CCK", "1T", "05", "32",
  1386. "ETSI", "2.4G", "20M", "CCK", "1T", "05", "30",
  1387. "MKK", "2.4G", "20M", "CCK", "1T", "05", "34",
  1388. "FCC", "2.4G", "20M", "CCK", "1T", "06", "32",
  1389. "ETSI", "2.4G", "20M", "CCK", "1T", "06", "30",
  1390. "MKK", "2.4G", "20M", "CCK", "1T", "06", "34",
  1391. "FCC", "2.4G", "20M", "CCK", "1T", "07", "32",
  1392. "ETSI", "2.4G", "20M", "CCK", "1T", "07", "30",
  1393. "MKK", "2.4G", "20M", "CCK", "1T", "07", "34",
  1394. "FCC", "2.4G", "20M", "CCK", "1T", "08", "32",
  1395. "ETSI", "2.4G", "20M", "CCK", "1T", "08", "30",
  1396. "MKK", "2.4G", "20M", "CCK", "1T", "08", "34",
  1397. "FCC", "2.4G", "20M", "CCK", "1T", "09", "32",
  1398. "ETSI", "2.4G", "20M", "CCK", "1T", "09", "30",
  1399. "MKK", "2.4G", "20M", "CCK", "1T", "09", "34",
  1400. "FCC", "2.4G", "20M", "CCK", "1T", "10", "32",
  1401. "ETSI", "2.4G", "20M", "CCK", "1T", "10", "30",
  1402. "MKK", "2.4G", "20M", "CCK", "1T", "10", "34",
  1403. "FCC", "2.4G", "20M", "CCK", "1T", "11", "32",
  1404. "ETSI", "2.4G", "20M", "CCK", "1T", "11", "30",
  1405. "MKK", "2.4G", "20M", "CCK", "1T", "11", "34",
  1406. "FCC", "2.4G", "20M", "CCK", "1T", "12", "24",
  1407. "ETSI", "2.4G", "20M", "CCK", "1T", "12", "30",
  1408. "MKK", "2.4G", "20M", "CCK", "1T", "12", "34",
  1409. "FCC", "2.4G", "20M", "CCK", "1T", "13", "16",
  1410. "ETSI", "2.4G", "20M", "CCK", "1T", "13", "30",
  1411. "MKK", "2.4G", "20M", "CCK", "1T", "13", "34",
  1412. "FCC", "2.4G", "20M", "CCK", "1T", "14", "63",
  1413. "ETSI", "2.4G", "20M", "CCK", "1T", "14", "63",
  1414. "MKK", "2.4G", "20M", "CCK", "1T", "14", "34",
  1415. "FCC", "2.4G", "20M", "OFDM", "1T", "01", "30",
  1416. "ETSI", "2.4G", "20M", "OFDM", "1T", "01", "30",
  1417. "MKK", "2.4G", "20M", "OFDM", "1T", "01", "34",
  1418. "FCC", "2.4G", "20M", "OFDM", "1T", "02", "32",
  1419. "ETSI", "2.4G", "20M", "OFDM", "1T", "02", "30",
  1420. "MKK", "2.4G", "20M", "OFDM", "1T", "02", "34",
  1421. "FCC", "2.4G", "20M", "OFDM", "1T", "03", "34",
  1422. "ETSI", "2.4G", "20M", "OFDM", "1T", "03", "30",
  1423. "MKK", "2.4G", "20M", "OFDM", "1T", "03", "34",
  1424. "FCC", "2.4G", "20M", "OFDM", "1T", "04", "34",
  1425. "ETSI", "2.4G", "20M", "OFDM", "1T", "04", "30",
  1426. "MKK", "2.4G", "20M", "OFDM", "1T", "04", "34",
  1427. "FCC", "2.4G", "20M", "OFDM", "1T", "05", "34",
  1428. "ETSI", "2.4G", "20M", "OFDM", "1T", "05", "30",
  1429. "MKK", "2.4G", "20M", "OFDM", "1T", "05", "34",
  1430. "FCC", "2.4G", "20M", "OFDM", "1T", "06", "34",
  1431. "ETSI", "2.4G", "20M", "OFDM", "1T", "06", "30",
  1432. "MKK", "2.4G", "20M", "OFDM", "1T", "06", "34",
  1433. "FCC", "2.4G", "20M", "OFDM", "1T", "07", "34",
  1434. "ETSI", "2.4G", "20M", "OFDM", "1T", "07", "30",
  1435. "MKK", "2.4G", "20M", "OFDM", "1T", "07", "34",
  1436. "FCC", "2.4G", "20M", "OFDM", "1T", "08", "34",
  1437. "ETSI", "2.4G", "20M", "OFDM", "1T", "08", "30",
  1438. "MKK", "2.4G", "20M", "OFDM", "1T", "08", "34",
  1439. "FCC", "2.4G", "20M", "OFDM", "1T", "09", "34",
  1440. "ETSI", "2.4G", "20M", "OFDM", "1T", "09", "30",
  1441. "MKK", "2.4G", "20M", "OFDM", "1T", "09", "34",
  1442. "FCC", "2.4G", "20M", "OFDM", "1T", "10", "32",
  1443. "ETSI", "2.4G", "20M", "OFDM", "1T", "10", "30",
  1444. "MKK", "2.4G", "20M", "OFDM", "1T", "10", "34",
  1445. "FCC", "2.4G", "20M", "OFDM", "1T", "11", "30",
  1446. "ETSI", "2.4G", "20M", "OFDM", "1T", "11", "30",
  1447. "MKK", "2.4G", "20M", "OFDM", "1T", "11", "34",
  1448. "FCC", "2.4G", "20M", "OFDM", "1T", "12", "28",
  1449. "ETSI", "2.4G", "20M", "OFDM", "1T", "12", "30",
  1450. "MKK", "2.4G", "20M", "OFDM", "1T", "12", "34",
  1451. "FCC", "2.4G", "20M", "OFDM", "1T", "13", "16",
  1452. "ETSI", "2.4G", "20M", "OFDM", "1T", "13", "30",
  1453. "MKK", "2.4G", "20M", "OFDM", "1T", "13", "34",
  1454. "FCC", "2.4G", "20M", "OFDM", "1T", "14", "63",
  1455. "ETSI", "2.4G", "20M", "OFDM", "1T", "14", "63",
  1456. "MKK", "2.4G", "20M", "OFDM", "1T", "14", "63",
  1457. "FCC", "2.4G", "20M", "HT", "1T", "01", "26",
  1458. "ETSI", "2.4G", "20M", "HT", "1T", "01", "30",
  1459. "MKK", "2.4G", "20M", "HT", "1T", "01", "34",
  1460. "FCC", "2.4G", "20M", "HT", "1T", "02", "30",
  1461. "ETSI", "2.4G", "20M", "HT", "1T", "02", "30",
  1462. "MKK", "2.4G", "20M", "HT", "1T", "02", "34",
  1463. "FCC", "2.4G", "20M", "HT", "1T", "03", "32",
  1464. "ETSI", "2.4G", "20M", "HT", "1T", "03", "30",
  1465. "MKK", "2.4G", "20M", "HT", "1T", "03", "34",
  1466. "FCC", "2.4G", "20M", "HT", "1T", "04", "34",
  1467. "ETSI", "2.4G", "20M", "HT", "1T", "04", "30",
  1468. "MKK", "2.4G", "20M", "HT", "1T", "04", "34",
  1469. "FCC", "2.4G", "20M", "HT", "1T", "05", "34",
  1470. "ETSI", "2.4G", "20M", "HT", "1T", "05", "30",
  1471. "MKK", "2.4G", "20M", "HT", "1T", "05", "34",
  1472. "FCC", "2.4G", "20M", "HT", "1T", "06", "34",
  1473. "ETSI", "2.4G", "20M", "HT", "1T", "06", "30",
  1474. "MKK", "2.4G", "20M", "HT", "1T", "06", "34",
  1475. "FCC", "2.4G", "20M", "HT", "1T", "07", "34",
  1476. "ETSI", "2.4G", "20M", "HT", "1T", "07", "30",
  1477. "MKK", "2.4G", "20M", "HT", "1T", "07", "34",
  1478. "FCC", "2.4G", "20M", "HT", "1T", "08", "34",
  1479. "ETSI", "2.4G", "20M", "HT", "1T", "08", "30",
  1480. "MKK", "2.4G", "20M", "HT", "1T", "08", "34",
  1481. "FCC", "2.4G", "20M", "HT", "1T", "09", "32",
  1482. "ETSI", "2.4G", "20M", "HT", "1T", "09", "30",
  1483. "MKK", "2.4G", "20M", "HT", "1T", "09", "34",
  1484. "FCC", "2.4G", "20M", "HT", "1T", "10", "30",
  1485. "ETSI", "2.4G", "20M", "HT", "1T", "10", "30",
  1486. "MKK", "2.4G", "20M", "HT", "1T", "10", "34",
  1487. "FCC", "2.4G", "20M", "HT", "1T", "11", "28",
  1488. "ETSI", "2.4G", "20M", "HT", "1T", "11", "30",
  1489. "MKK", "2.4G", "20M", "HT", "1T", "11", "34",
  1490. "FCC", "2.4G", "20M", "HT", "1T", "12", "26",
  1491. "ETSI", "2.4G", "20M", "HT", "1T", "12", "30",
  1492. "MKK", "2.4G", "20M", "HT", "1T", "12", "34",
  1493. "FCC", "2.4G", "20M", "HT", "1T", "13", "12",
  1494. "ETSI", "2.4G", "20M", "HT", "1T", "13", "30",
  1495. "MKK", "2.4G", "20M", "HT", "1T", "13", "34",
  1496. "FCC", "2.4G", "20M", "HT", "1T", "14", "63",
  1497. "ETSI", "2.4G", "20M", "HT", "1T", "14", "63",
  1498. "MKK", "2.4G", "20M", "HT", "1T", "14", "63",
  1499. "FCC", "2.4G", "40M", "HT", "1T", "01", "63",
  1500. "ETSI", "2.4G", "40M", "HT", "1T", "01", "63",
  1501. "MKK", "2.4G", "40M", "HT", "1T", "01", "63",
  1502. "FCC", "2.4G", "40M", "HT", "1T", "02", "63",
  1503. "ETSI", "2.4G", "40M", "HT", "1T", "02", "63",
  1504. "MKK", "2.4G", "40M", "HT", "1T", "02", "63",
  1505. "FCC", "2.4G", "40M", "HT", "1T", "03", "26",
  1506. "ETSI", "2.4G", "40M", "HT", "1T", "03", "30",
  1507. "MKK", "2.4G", "40M", "HT", "1T", "03", "30",
  1508. "FCC", "2.4G", "40M", "HT", "1T", "04", "26",
  1509. "ETSI", "2.4G", "40M", "HT", "1T", "04", "30",
  1510. "MKK", "2.4G", "40M", "HT", "1T", "04", "30",
  1511. "FCC", "2.4G", "40M", "HT", "1T", "05", "30",
  1512. "ETSI", "2.4G", "40M", "HT", "1T", "05", "30",
  1513. "MKK", "2.4G", "40M", "HT", "1T", "05", "30",
  1514. "FCC", "2.4G", "40M", "HT", "1T", "06", "30",
  1515. "ETSI", "2.4G", "40M", "HT", "1T", "06", "30",
  1516. "MKK", "2.4G", "40M", "HT", "1T", "06", "30",
  1517. "FCC", "2.4G", "40M", "HT", "1T", "07", "30",
  1518. "ETSI", "2.4G", "40M", "HT", "1T", "07", "30",
  1519. "MKK", "2.4G", "40M", "HT", "1T", "07", "30",
  1520. "FCC", "2.4G", "40M", "HT", "1T", "08", "26",
  1521. "ETSI", "2.4G", "40M", "HT", "1T", "08", "30",
  1522. "MKK", "2.4G", "40M", "HT", "1T", "08", "30",
  1523. "FCC", "2.4G", "40M", "HT", "1T", "09", "26",
  1524. "ETSI", "2.4G", "40M", "HT", "1T", "09", "30",
  1525. "MKK", "2.4G", "40M", "HT", "1T", "09", "30",
  1526. "FCC", "2.4G", "40M", "HT", "1T", "10", "28",
  1527. "ETSI", "2.4G", "40M", "HT", "1T", "10", "30",
  1528. "MKK", "2.4G", "40M", "HT", "1T", "10", "30",
  1529. "FCC", "2.4G", "40M", "HT", "1T", "11", "20",
  1530. "ETSI", "2.4G", "40M", "HT", "1T", "11", "30",
  1531. "MKK", "2.4G", "40M", "HT", "1T", "11", "30",
  1532. "FCC", "2.4G", "40M", "HT", "1T", "12", "63",
  1533. "ETSI", "2.4G", "40M", "HT", "1T", "12", "63",
  1534. "MKK", "2.4G", "40M", "HT", "1T", "12", "63",
  1535. "FCC", "2.4G", "40M", "HT", "1T", "13", "63",
  1536. "ETSI", "2.4G", "40M", "HT", "1T", "13", "63",
  1537. "MKK", "2.4G", "40M", "HT", "1T", "13", "63",
  1538. "FCC", "2.4G", "40M", "HT", "1T", "14", "63",
  1539. "ETSI", "2.4G", "40M", "HT", "1T", "14", "63",
  1540. "MKK", "2.4G", "40M", "HT", "1T", "14", "63",
  1541. "FCC", "5G", "20M", "OFDM", "1T", "36", "31",
  1542. "ETSI", "5G", "20M", "OFDM", "1T", "36", "32",
  1543. "MKK", "5G", "20M", "OFDM", "1T", "36", "33",
  1544. "FCC", "5G", "20M", "OFDM", "1T", "40", "33",
  1545. "ETSI", "5G", "20M", "OFDM", "1T", "40", "32",
  1546. "MKK", "5G", "20M", "OFDM", "1T", "40", "33",
  1547. "FCC", "5G", "20M", "OFDM", "1T", "44", "33",
  1548. "ETSI", "5G", "20M", "OFDM", "1T", "44", "32",
  1549. "MKK", "5G", "20M", "OFDM", "1T", "44", "33",
  1550. "FCC", "5G", "20M", "OFDM", "1T", "48", "31",
  1551. "ETSI", "5G", "20M", "OFDM", "1T", "48", "32",
  1552. "MKK", "5G", "20M", "OFDM", "1T", "48", "33",
  1553. "FCC", "5G", "20M", "OFDM", "1T", "52", "33",
  1554. "ETSI", "5G", "20M", "OFDM", "1T", "52", "32",
  1555. "MKK", "5G", "20M", "OFDM", "1T", "52", "33",
  1556. "FCC", "5G", "20M", "OFDM", "1T", "56", "33",
  1557. "ETSI", "5G", "20M", "OFDM", "1T", "56", "32",
  1558. "MKK", "5G", "20M", "OFDM", "1T", "56", "33",
  1559. "FCC", "5G", "20M", "OFDM", "1T", "60", "33",
  1560. "ETSI", "5G", "20M", "OFDM", "1T", "60", "32",
  1561. "MKK", "5G", "20M", "OFDM", "1T", "60", "33",
  1562. "FCC", "5G", "20M", "OFDM", "1T", "64", "30",
  1563. "ETSI", "5G", "20M", "OFDM", "1T", "64", "32",
  1564. "MKK", "5G", "20M", "OFDM", "1T", "64", "33",
  1565. "FCC", "5G", "20M", "OFDM", "1T", "100", "30",
  1566. "ETSI", "5G", "20M", "OFDM", "1T", "100", "32",
  1567. "MKK", "5G", "20M", "OFDM", "1T", "100", "33",
  1568. "FCC", "5G", "20M", "OFDM", "1T", "104", "33",
  1569. "ETSI", "5G", "20M", "OFDM", "1T", "104", "32",
  1570. "MKK", "5G", "20M", "OFDM", "1T", "104", "33",
  1571. "FCC", "5G", "20M", "OFDM", "1T", "108", "33",
  1572. "ETSI", "5G", "20M", "OFDM", "1T", "108", "32",
  1573. "MKK", "5G", "20M", "OFDM", "1T", "108", "33",
  1574. "FCC", "5G", "20M", "OFDM", "1T", "112", "33",
  1575. "ETSI", "5G", "20M", "OFDM", "1T", "112", "32",
  1576. "MKK", "5G", "20M", "OFDM", "1T", "112", "33",
  1577. "FCC", "5G", "20M", "OFDM", "1T", "116", "33",
  1578. "ETSI", "5G", "20M", "OFDM", "1T", "116", "32",
  1579. "MKK", "5G", "20M", "OFDM", "1T", "116", "33",
  1580. "FCC", "5G", "20M", "OFDM", "1T", "120", "33",
  1581. "ETSI", "5G", "20M", "OFDM", "1T", "120", "32",
  1582. "MKK", "5G", "20M", "OFDM", "1T", "120", "33",
  1583. "FCC", "5G", "20M", "OFDM", "1T", "124", "33",
  1584. "ETSI", "5G", "20M", "OFDM", "1T", "124", "32",
  1585. "MKK", "5G", "20M", "OFDM", "1T", "124", "33",
  1586. "FCC", "5G", "20M", "OFDM", "1T", "128", "33",
  1587. "ETSI", "5G", "20M", "OFDM", "1T", "128", "32",
  1588. "MKK", "5G", "20M", "OFDM", "1T", "128", "33",
  1589. "FCC", "5G", "20M", "OFDM", "1T", "132", "33",
  1590. "ETSI", "5G", "20M", "OFDM", "1T", "132", "32",
  1591. "MKK", "5G", "20M", "OFDM", "1T", "132", "33",
  1592. "FCC", "5G", "20M", "OFDM", "1T", "136", "33",
  1593. "ETSI", "5G", "20M", "OFDM", "1T", "136", "32",
  1594. "MKK", "5G", "20M", "OFDM", "1T", "136", "33",
  1595. "FCC", "5G", "20M", "OFDM", "1T", "140", "31",
  1596. "ETSI", "5G", "20M", "OFDM", "1T", "140", "32",
  1597. "MKK", "5G", "20M", "OFDM", "1T", "140", "33",
  1598. "FCC", "5G", "20M", "OFDM", "1T", "144", "30",
  1599. "ETSI", "5G", "20M", "OFDM", "1T", "144", "32",
  1600. "MKK", "5G", "20M", "OFDM", "1T", "144", "63",
  1601. "FCC", "5G", "20M", "OFDM", "1T", "149", "33",
  1602. "ETSI", "5G", "20M", "OFDM", "1T", "149", "63",
  1603. "MKK", "5G", "20M", "OFDM", "1T", "149", "63",
  1604. "FCC", "5G", "20M", "OFDM", "1T", "153", "33",
  1605. "ETSI", "5G", "20M", "OFDM", "1T", "153", "63",
  1606. "MKK", "5G", "20M", "OFDM", "1T", "153", "63",
  1607. "FCC", "5G", "20M", "OFDM", "1T", "157", "33",
  1608. "ETSI", "5G", "20M", "OFDM", "1T", "157", "63",
  1609. "MKK", "5G", "20M", "OFDM", "1T", "157", "63",
  1610. "FCC", "5G", "20M", "OFDM", "1T", "161", "33",
  1611. "ETSI", "5G", "20M", "OFDM", "1T", "161", "63",
  1612. "MKK", "5G", "20M", "OFDM", "1T", "161", "63",
  1613. "FCC", "5G", "20M", "OFDM", "1T", "165", "33",
  1614. "ETSI", "5G", "20M", "OFDM", "1T", "165", "63",
  1615. "MKK", "5G", "20M", "OFDM", "1T", "165", "63",
  1616. "FCC", "5G", "20M", "HT", "1T", "36", "30",
  1617. "ETSI", "5G", "20M", "HT", "1T", "36", "32",
  1618. "MKK", "5G", "20M", "HT", "1T", "36", "33",
  1619. "FCC", "5G", "20M", "HT", "1T", "40", "33",
  1620. "ETSI", "5G", "20M", "HT", "1T", "40", "32",
  1621. "MKK", "5G", "20M", "HT", "1T", "40", "33",
  1622. "FCC", "5G", "20M", "HT", "1T", "44", "33",
  1623. "ETSI", "5G", "20M", "HT", "1T", "44", "32",
  1624. "MKK", "5G", "20M", "HT", "1T", "44", "33",
  1625. "FCC", "5G", "20M", "HT", "1T", "48", "33",
  1626. "ETSI", "5G", "20M", "HT", "1T", "48", "32",
  1627. "MKK", "5G", "20M", "HT", "1T", "48", "33",
  1628. "FCC", "5G", "20M", "HT", "1T", "52", "33",
  1629. "ETSI", "5G", "20M", "HT", "1T", "52", "32",
  1630. "MKK", "5G", "20M", "HT", "1T", "52", "33",
  1631. "FCC", "5G", "20M", "HT", "1T", "56", "33",
  1632. "ETSI", "5G", "20M", "HT", "1T", "56", "32",
  1633. "MKK", "5G", "20M", "HT", "1T", "56", "33",
  1634. "FCC", "5G", "20M", "HT", "1T", "60", "33",
  1635. "ETSI", "5G", "20M", "HT", "1T", "60", "32",
  1636. "MKK", "5G", "20M", "HT", "1T", "60", "33",
  1637. "FCC", "5G", "20M", "HT", "1T", "64", "30",
  1638. "ETSI", "5G", "20M", "HT", "1T", "64", "32",
  1639. "MKK", "5G", "20M", "HT", "1T", "64", "33",
  1640. "FCC", "5G", "20M", "HT", "1T", "100", "30",
  1641. "ETSI", "5G", "20M", "HT", "1T", "100", "32",
  1642. "MKK", "5G", "20M", "HT", "1T", "100", "33",
  1643. "FCC", "5G", "20M", "HT", "1T", "104", "33",
  1644. "ETSI", "5G", "20M", "HT", "1T", "104", "32",
  1645. "MKK", "5G", "20M", "HT", "1T", "104", "33",
  1646. "FCC", "5G", "20M", "HT", "1T", "108", "33",
  1647. "ETSI", "5G", "20M", "HT", "1T", "108", "32",
  1648. "MKK", "5G", "20M", "HT", "1T", "108", "33",
  1649. "FCC", "5G", "20M", "HT", "1T", "112", "33",
  1650. "ETSI", "5G", "20M", "HT", "1T", "112", "32",
  1651. "MKK", "5G", "20M", "HT", "1T", "112", "33",
  1652. "FCC", "5G", "20M", "HT", "1T", "116", "33",
  1653. "ETSI", "5G", "20M", "HT", "1T", "116", "32",
  1654. "MKK", "5G", "20M", "HT", "1T", "116", "33",
  1655. "FCC", "5G", "20M", "HT", "1T", "120", "33",
  1656. "ETSI", "5G", "20M", "HT", "1T", "120", "32",
  1657. "MKK", "5G", "20M", "HT", "1T", "120", "33",
  1658. "FCC", "5G", "20M", "HT", "1T", "124", "33",
  1659. "ETSI", "5G", "20M", "HT", "1T", "124", "32",
  1660. "MKK", "5G", "20M", "HT", "1T", "124", "33",
  1661. "FCC", "5G", "20M", "HT", "1T", "128", "33",
  1662. "ETSI", "5G", "20M", "HT", "1T", "128", "32",
  1663. "MKK", "5G", "20M", "HT", "1T", "128", "33",
  1664. "FCC", "5G", "20M", "HT", "1T", "132", "33",
  1665. "ETSI", "5G", "20M", "HT", "1T", "132", "32",
  1666. "MKK", "5G", "20M", "HT", "1T", "132", "33",
  1667. "FCC", "5G", "20M", "HT", "1T", "136", "33",
  1668. "ETSI", "5G", "20M", "HT", "1T", "136", "32",
  1669. "MKK", "5G", "20M", "HT", "1T", "136", "33",
  1670. "FCC", "5G", "20M", "HT", "1T", "140", "29",
  1671. "ETSI", "5G", "20M", "HT", "1T", "140", "32",
  1672. "MKK", "5G", "20M", "HT", "1T", "140", "33",
  1673. "FCC", "5G", "20M", "HT", "1T", "144", "27",
  1674. "ETSI", "5G", "20M", "HT", "1T", "144", "63",
  1675. "MKK", "5G", "20M", "HT", "1T", "144", "63",
  1676. "FCC", "5G", "20M", "HT", "1T", "149", "33",
  1677. "ETSI", "5G", "20M", "HT", "1T", "149", "63",
  1678. "MKK", "5G", "20M", "HT", "1T", "149", "63",
  1679. "FCC", "5G", "20M", "HT", "1T", "153", "33",
  1680. "ETSI", "5G", "20M", "HT", "1T", "153", "63",
  1681. "MKK", "5G", "20M", "HT", "1T", "153", "63",
  1682. "FCC", "5G", "20M", "HT", "1T", "157", "33",
  1683. "ETSI", "5G", "20M", "HT", "1T", "157", "63",
  1684. "MKK", "5G", "20M", "HT", "1T", "157", "63",
  1685. "FCC", "5G", "20M", "HT", "1T", "161", "33",
  1686. "ETSI", "5G", "20M", "HT", "1T", "161", "63",
  1687. "MKK", "5G", "20M", "HT", "1T", "161", "63",
  1688. "FCC", "5G", "20M", "HT", "1T", "165", "33",
  1689. "ETSI", "5G", "20M", "HT", "1T", "165", "63",
  1690. "MKK", "5G", "20M", "HT", "1T", "165", "63",
  1691. "FCC", "5G", "40M", "HT", "1T", "38", "22",
  1692. "ETSI", "5G", "40M", "HT", "1T", "38", "32",
  1693. "MKK", "5G", "40M", "HT", "1T", "38", "32",
  1694. "FCC", "5G", "40M", "HT", "1T", "46", "32",
  1695. "ETSI", "5G", "40M", "HT", "1T", "46", "32",
  1696. "MKK", "5G", "40M", "HT", "1T", "46", "32",
  1697. "FCC", "5G", "40M", "HT", "1T", "54", "32",
  1698. "ETSI", "5G", "40M", "HT", "1T", "54", "32",
  1699. "MKK", "5G", "40M", "HT", "1T", "54", "32",
  1700. "FCC", "5G", "40M", "HT", "1T", "62", "23",
  1701. "ETSI", "5G", "40M", "HT", "1T", "62", "32",
  1702. "MKK", "5G", "40M", "HT", "1T", "62", "32",
  1703. "FCC", "5G", "40M", "HT", "1T", "102", "21",
  1704. "ETSI", "5G", "40M", "HT", "1T", "102", "32",
  1705. "MKK", "5G", "40M", "HT", "1T", "102", "32",
  1706. "FCC", "5G", "40M", "HT", "1T", "110", "32",
  1707. "ETSI", "5G", "40M", "HT", "1T", "110", "32",
  1708. "MKK", "5G", "40M", "HT", "1T", "110", "32",
  1709. "FCC", "5G", "40M", "HT", "1T", "118", "32",
  1710. "ETSI", "5G", "40M", "HT", "1T", "118", "32",
  1711. "MKK", "5G", "40M", "HT", "1T", "118", "32",
  1712. "FCC", "5G", "40M", "HT", "1T", "126", "32",
  1713. "ETSI", "5G", "40M", "HT", "1T", "126", "32",
  1714. "MKK", "5G", "40M", "HT", "1T", "126", "32",
  1715. "FCC", "5G", "40M", "HT", "1T", "134", "32",
  1716. "ETSI", "5G", "40M", "HT", "1T", "134", "32",
  1717. "MKK", "5G", "40M", "HT", "1T", "134", "32",
  1718. "FCC", "5G", "40M", "HT", "1T", "142", "29",
  1719. "ETSI", "5G", "40M", "HT", "1T", "142", "63",
  1720. "MKK", "5G", "40M", "HT", "1T", "142", "63",
  1721. "FCC", "5G", "40M", "HT", "1T", "151", "32",
  1722. "ETSI", "5G", "40M", "HT", "1T", "151", "63",
  1723. "MKK", "5G", "40M", "HT", "1T", "151", "63",
  1724. "FCC", "5G", "40M", "HT", "1T", "159", "32",
  1725. "ETSI", "5G", "40M", "HT", "1T", "159", "63",
  1726. "MKK", "5G", "40M", "HT", "1T", "159", "63",
  1727. "FCC", "5G", "80M", "VHT", "1T", "42", "19",
  1728. "ETSI", "5G", "80M", "VHT", "1T", "42", "32",
  1729. "MKK", "5G", "80M", "VHT", "1T", "42", "28",
  1730. "FCC", "5G", "80M", "VHT", "1T", "58", "22",
  1731. "ETSI", "5G", "80M", "VHT", "1T", "58", "32",
  1732. "MKK", "5G", "80M", "VHT", "1T", "58", "28",
  1733. "FCC", "5G", "80M", "VHT", "1T", "106", "18",
  1734. "ETSI", "5G", "80M", "VHT", "1T", "106", "32",
  1735. "MKK", "5G", "80M", "VHT", "1T", "106", "32",
  1736. "FCC", "5G", "80M", "VHT", "1T", "122", "32",
  1737. "ETSI", "5G", "80M", "VHT", "1T", "122", "32",
  1738. "MKK", "5G", "80M", "VHT", "1T", "122", "32",
  1739. "FCC", "5G", "80M", "VHT", "1T", "138", "28",
  1740. "ETSI", "5G", "80M", "VHT", "1T", "138", "63",
  1741. "MKK", "5G", "80M", "VHT", "1T", "138", "63",
  1742. "FCC", "5G", "80M", "VHT", "1T", "155", "32",
  1743. "ETSI", "5G", "80M", "VHT", "1T", "155", "63",
  1744. "MKK", "5G", "80M", "VHT", "1T", "155", "63"
  1745. };
  1746. void
  1747. odm_read_and_config_mp_8821c_txpwr_lmt(
  1748. struct PHY_DM_STRUCT *p_dm_odm
  1749. )
  1750. {
  1751. u32 i = 0;
  1752. #if (DM_ODM_SUPPORT_TYPE == ODM_IOT)
  1753. u32 array_len = sizeof(array_mp_8821c_txpwr_lmt)/sizeof(u8);
  1754. u8 *array = (u8 *)array_mp_8821c_txpwr_lmt;
  1755. #else
  1756. u32 array_len = sizeof(array_mp_8821c_txpwr_lmt)/sizeof(u8 *);
  1757. u8 **array = (u8 **)array_mp_8821c_txpwr_lmt;
  1758. #endif
  1759. #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
  1760. struct _ADAPTER *adapter = p_dm_odm->adapter;
  1761. HAL_DATA_TYPE *p_hal_data = GET_HAL_DATA(adapter);
  1762. PlatformZeroMemory(p_hal_data->BufOfLinesPwrLmt, MAX_LINES_HWCONFIG_TXT*MAX_BYTES_LINE_HWCONFIG_TXT);
  1763. p_hal_data->nLinesReadPwrLmt = array_len/7;
  1764. #endif
  1765. ODM_RT_TRACE(p_dm_odm, ODM_COMP_INIT, ODM_DBG_LOUD, ("===> odm_read_and_config_mp_8821c_txpwr_lmt\n"));
  1766. for (i = 0; i < array_len; i += 7) {
  1767. #if (DM_ODM_SUPPORT_TYPE == ODM_IOT)
  1768. u8 regulation = array[i];
  1769. u8 band = array[i+1];
  1770. u8 bandwidth = array[i+2];
  1771. u8 rate = array[i+3];
  1772. u8 rf_path = array[i+4];
  1773. u8 chnl = array[i+5];
  1774. u8 val = array[i+6];
  1775. #else
  1776. u8 *regulation = array[i];
  1777. u8 *band = array[i+1];
  1778. u8 *bandwidth = array[i+2];
  1779. u8 *rate = array[i+3];
  1780. u8 *rf_path = array[i+4];
  1781. u8 *chnl = array[i+5];
  1782. u8 *val = array[i+6];
  1783. #endif
  1784. odm_config_bb_txpwr_lmt_8821c(p_dm_odm, regulation, band, bandwidth, rate, rf_path, chnl, val);
  1785. #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
  1786. rsprintf((char *)p_hal_data->BufOfLinesPwrLmt[i/7], 100, "\"%s\", \"%s\", \"%s\", \"%s\", \"%s\", \"%s\", \"%s\",",
  1787. regulation, band, bandwidth, rate, rf_path, chnl, val);
  1788. #endif
  1789. }
  1790. }
  1791. #endif /* end of HWIMG_SUPPORT*/