halhwimg8821c_testchip_bb.c 42 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925
  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: 2.22*/
  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. u32 cond1 = condition1, cond2 = condition2, cond3 = condition3, cond4 = condition4;
  39. u32 driver1 = p_dm_odm->cut_version << 24 |
  40. (p_dm_odm->support_interface & 0xF0) << 16 |
  41. p_dm_odm->support_platform << 16 |
  42. p_dm_odm->package_type << 12 |
  43. (p_dm_odm->support_interface & 0x0F) << 8 |
  44. _board_type;
  45. u32 driver2 = (p_dm_odm->type_glna & 0xFF) << 0 |
  46. (p_dm_odm->type_gpa & 0xFF) << 8 |
  47. (p_dm_odm->type_alna & 0xFF) << 16 |
  48. (p_dm_odm->type_apa & 0xFF) << 24;
  49. u32 driver3 = 0;
  50. u32 driver4 = (p_dm_odm->type_glna & 0xFF00) >> 8 |
  51. (p_dm_odm->type_gpa & 0xFF00) |
  52. (p_dm_odm->type_alna & 0xFF00) << 8 |
  53. (p_dm_odm->type_apa & 0xFF00) << 16;
  54. ODM_RT_TRACE(p_dm_odm, ODM_COMP_INIT, ODM_DBG_TRACE,
  55. ("===> check_positive (cond1, cond2, cond3, cond4) = (0x%X 0x%X 0x%X 0x%X)\n", cond1, cond2, cond3, cond4));
  56. ODM_RT_TRACE(p_dm_odm, ODM_COMP_INIT, ODM_DBG_TRACE,
  57. ("===> check_positive (driver1, driver2, driver3, driver4) = (0x%X 0x%X 0x%X 0x%X)\n", driver1, driver2, driver3, driver4));
  58. ODM_RT_TRACE(p_dm_odm, ODM_COMP_INIT, ODM_DBG_TRACE,
  59. (" (Platform, Interface) = (0x%X, 0x%X)\n", p_dm_odm->support_platform, p_dm_odm->support_interface));
  60. ODM_RT_TRACE(p_dm_odm, ODM_COMP_INIT, ODM_DBG_TRACE,
  61. (" (Board, Package) = (0x%X, 0x%X)\n", p_dm_odm->board_type, p_dm_odm->package_type));
  62. /*============== value Defined Check ===============*/
  63. /*QFN type [15:12] and cut version [27:24] need to do value check*/
  64. if (((cond1 & 0x0000F000) != 0) && ((cond1 & 0x0000F000) != (driver1 & 0x0000F000)))
  65. return false;
  66. if (((cond1 & 0x0F000000) != 0) && ((cond1 & 0x0F000000) != (driver1 & 0x0F000000)))
  67. return false;
  68. /*=============== Bit Defined Check ================*/
  69. /* We don't care [31:28] */
  70. cond1 &= 0x00FF0FFF;
  71. driver1 &= 0x00FF0FFF;
  72. if ((cond1 & driver1) == cond1) {
  73. u32 bit_mask = 0;
  74. if ((cond1 & 0x0F) == 0) /* board_type is DONTCARE*/
  75. return true;
  76. if ((cond1 & BIT(0)) != 0) /*GLNA*/
  77. bit_mask |= 0x000000FF;
  78. if ((cond1 & BIT(1)) != 0) /*GPA*/
  79. bit_mask |= 0x0000FF00;
  80. if ((cond1 & BIT(2)) != 0) /*ALNA*/
  81. bit_mask |= 0x00FF0000;
  82. if ((cond1 & BIT(3)) != 0) /*APA*/
  83. bit_mask |= 0xFF000000;
  84. if (((cond2 & bit_mask) == (driver2 & bit_mask)) && ((cond4 & bit_mask) == (driver4 & bit_mask))) /* board_type of each RF path is matched*/
  85. return true;
  86. else
  87. return false;
  88. } else
  89. return false;
  90. }
  91. static boolean
  92. check_negative(
  93. struct PHY_DM_STRUCT *p_dm_odm,
  94. const u32 condition1,
  95. const u32 condition2
  96. )
  97. {
  98. return true;
  99. }
  100. /******************************************************************************
  101. * AGC_TAB.TXT
  102. ******************************************************************************/
  103. u32 array_tc_8821c_agc_tab[] = {
  104. 0x81C, 0xFB000003,
  105. 0x81C, 0xFA020003,
  106. 0x81C, 0xF9040003,
  107. 0x81C, 0xF8060003,
  108. 0x81C, 0xF7080003,
  109. 0x81C, 0xF60A0003,
  110. 0x81C, 0xF50C0003,
  111. 0x81C, 0xF40E0003,
  112. 0x81C, 0xF3100003,
  113. 0x81C, 0xF2120003,
  114. 0x81C, 0xF1140003,
  115. 0x81C, 0xF0160003,
  116. 0x81C, 0xEF180003,
  117. 0x81C, 0xEE1A0003,
  118. 0x81C, 0xED1C0003,
  119. 0x81C, 0xEC1E0003,
  120. 0x81C, 0xEB200003,
  121. 0x81C, 0xEA220003,
  122. 0x81C, 0xE9240003,
  123. 0x81C, 0xE8260003,
  124. 0x81C, 0xE7280003,
  125. 0x81C, 0xE62A0003,
  126. 0x81C, 0xCA2C0003,
  127. 0x81C, 0xC92E0003,
  128. 0x81C, 0xC8300003,
  129. 0x81C, 0xC7320003,
  130. 0x81C, 0xC6340003,
  131. 0x81C, 0xC5360003,
  132. 0x81C, 0xC4380003,
  133. 0x81C, 0xC33A0003,
  134. 0x81C, 0xC23C0003,
  135. 0x81C, 0xC13E0003,
  136. 0x81C, 0x88400003,
  137. 0x81C, 0x87420003,
  138. 0x81C, 0x86440003,
  139. 0x81C, 0x85460003,
  140. 0x81C, 0x84480003,
  141. 0x81C, 0x834A0003,
  142. 0x81C, 0x674C0003,
  143. 0x81C, 0x664E0003,
  144. 0x81C, 0x65500003,
  145. 0x81C, 0x64520003,
  146. 0x81C, 0x63540003,
  147. 0x81C, 0x62560003,
  148. 0x81C, 0x61580003,
  149. 0x81C, 0x455A0003,
  150. 0x81C, 0x445C0003,
  151. 0x81C, 0x435E0003,
  152. 0x81C, 0x42600003,
  153. 0x81C, 0x41620003,
  154. 0x81C, 0x25640003,
  155. 0x81C, 0x24660003,
  156. 0x81C, 0x23680003,
  157. 0x81C, 0x226A0003,
  158. 0x81C, 0x216C0003,
  159. 0x81C, 0x016E0003,
  160. 0x81C, 0x01700003,
  161. 0x81C, 0x01720003,
  162. 0x81C, 0x01740003,
  163. 0x81C, 0x01760003,
  164. 0x81C, 0x01780003,
  165. 0x81C, 0x017A0003,
  166. 0x81C, 0x017C0003,
  167. 0x81C, 0x017E0003,
  168. 0x81C, 0xFF000103,
  169. 0x81C, 0xFF020103,
  170. 0x81C, 0xFF040103,
  171. 0x81C, 0xFE060103,
  172. 0x81C, 0xFD080103,
  173. 0x81C, 0xFC0A0103,
  174. 0x81C, 0xFB0C0103,
  175. 0x81C, 0xFA0E0103,
  176. 0x81C, 0xF9100103,
  177. 0x81C, 0xF8120103,
  178. 0x81C, 0xF7140103,
  179. 0x81C, 0xF6160103,
  180. 0x81C, 0xF5180103,
  181. 0x81C, 0xF41A0103,
  182. 0x81C, 0xF31C0103,
  183. 0x81C, 0xF21E0103,
  184. 0x81C, 0xF1200103,
  185. 0x81C, 0xF0220103,
  186. 0x81C, 0xEF240103,
  187. 0x81C, 0xEE260103,
  188. 0x81C, 0xED280103,
  189. 0x81C, 0xEC2A0103,
  190. 0x81C, 0xEB2C0103,
  191. 0x81C, 0xEA2E0103,
  192. 0x81C, 0xE9300103,
  193. 0x81C, 0xE8320103,
  194. 0x81C, 0xE7340103,
  195. 0x81C, 0xE6360103,
  196. 0x81C, 0xE5380103,
  197. 0x81C, 0xE43A0103,
  198. 0x81C, 0xC63C0103,
  199. 0x81C, 0xC53E0103,
  200. 0x81C, 0xC4400103,
  201. 0x81C, 0xC3420103,
  202. 0x81C, 0xC2440103,
  203. 0x81C, 0xC1460103,
  204. 0x81C, 0xA3480103,
  205. 0x81C, 0xA24A0103,
  206. 0x81C, 0xA14C0103,
  207. 0x81C, 0x834E0103,
  208. 0x81C, 0x82500103,
  209. 0x81C, 0x81520103,
  210. 0x81C, 0x64540103,
  211. 0x81C, 0x63560103,
  212. 0x81C, 0x62580103,
  213. 0x81C, 0x615A0103,
  214. 0x81C, 0x425C0103,
  215. 0x81C, 0x415E0103,
  216. 0x81C, 0x24600103,
  217. 0x81C, 0x23620103,
  218. 0x81C, 0x22640103,
  219. 0x81C, 0x21660103,
  220. 0x81C, 0x03680103,
  221. 0x81C, 0x026A0103,
  222. 0x81C, 0x016C0103,
  223. 0x81C, 0x016E0103,
  224. 0x81C, 0x01700103,
  225. 0x81C, 0x01720103,
  226. 0x81C, 0x01740103,
  227. 0x81C, 0x01760103,
  228. 0x81C, 0x01780103,
  229. 0x81C, 0x017A0103,
  230. 0x81C, 0x017C0103,
  231. 0x81C, 0x017E0103,
  232. 0x81C, 0xFF000203,
  233. 0x81C, 0xFF020203,
  234. 0x81C, 0xFE040203,
  235. 0x81C, 0xFD060203,
  236. 0x81C, 0xFC080203,
  237. 0x81C, 0xFB0A0203,
  238. 0x81C, 0xFA0C0203,
  239. 0x81C, 0xF90E0203,
  240. 0x81C, 0xF8100203,
  241. 0x81C, 0xF7120203,
  242. 0x81C, 0xF6140203,
  243. 0x81C, 0xF5160203,
  244. 0x81C, 0xF4180203,
  245. 0x81C, 0xF31A0203,
  246. 0x81C, 0xF21C0203,
  247. 0x81C, 0xF11E0203,
  248. 0x81C, 0xF0200203,
  249. 0x81C, 0xEF220203,
  250. 0x81C, 0xEE240203,
  251. 0x81C, 0xED260203,
  252. 0x81C, 0xEC280203,
  253. 0x81C, 0xEB2A0203,
  254. 0x81C, 0xEA2C0203,
  255. 0x81C, 0xE92E0203,
  256. 0x81C, 0xE8300203,
  257. 0x81C, 0xE7320203,
  258. 0x81C, 0xE6340203,
  259. 0x81C, 0xE5360203,
  260. 0x81C, 0xE4380203,
  261. 0x81C, 0xE33A0203,
  262. 0x81C, 0xE23C0203,
  263. 0x81C, 0xE13E0203,
  264. 0x81C, 0xC4400203,
  265. 0x81C, 0xC3420203,
  266. 0x81C, 0xC2440203,
  267. 0x81C, 0xC1460203,
  268. 0x81C, 0xA3480203,
  269. 0x81C, 0xA24A0203,
  270. 0x81C, 0xA14C0203,
  271. 0x81C, 0x834E0203,
  272. 0x81C, 0x82500203,
  273. 0x81C, 0x81520203,
  274. 0x81C, 0x64540203,
  275. 0x81C, 0x63560203,
  276. 0x81C, 0x62580203,
  277. 0x81C, 0x615A0203,
  278. 0x81C, 0x425C0203,
  279. 0x81C, 0x415E0203,
  280. 0x81C, 0x22600203,
  281. 0x81C, 0x21620203,
  282. 0x81C, 0x04640203,
  283. 0x81C, 0x03660203,
  284. 0x81C, 0x02680203,
  285. 0x81C, 0x016A0203,
  286. 0x81C, 0x016C0203,
  287. 0x81C, 0x016E0203,
  288. 0x81C, 0x01700203,
  289. 0x81C, 0x01720203,
  290. 0x81C, 0x01740203,
  291. 0x81C, 0x01760203,
  292. 0x81C, 0x01780203,
  293. 0x81C, 0x017A0203,
  294. 0x81C, 0x017C0203,
  295. 0x81C, 0x017E0203,
  296. 0x81C, 0xFF000303,
  297. 0x81C, 0xFF020303,
  298. 0x81C, 0xFE040303,
  299. 0x81C, 0xFD060303,
  300. 0x81C, 0xFC080303,
  301. 0x81C, 0xFB0A0303,
  302. 0x81C, 0xFA0C0303,
  303. 0x81C, 0xF90E0303,
  304. 0x81C, 0xF8100303,
  305. 0x81C, 0xF7120303,
  306. 0x81C, 0xF6140303,
  307. 0x81C, 0xF5160303,
  308. 0x81C, 0xF4180303,
  309. 0x81C, 0xF31A0303,
  310. 0x81C, 0xF21C0303,
  311. 0x81C, 0xF11E0303,
  312. 0x81C, 0xF0200303,
  313. 0x81C, 0xEF220303,
  314. 0x81C, 0xEE240303,
  315. 0x81C, 0xED260303,
  316. 0x81C, 0xEC280303,
  317. 0x81C, 0xEB2A0303,
  318. 0x81C, 0xEA2C0303,
  319. 0x81C, 0xE92E0303,
  320. 0x81C, 0xE8300303,
  321. 0x81C, 0xE7320303,
  322. 0x81C, 0xE6340303,
  323. 0x81C, 0xE5360303,
  324. 0x81C, 0xE4380303,
  325. 0x81C, 0xE33A0303,
  326. 0x81C, 0xE23C0303,
  327. 0x81C, 0xE13E0303,
  328. 0x81C, 0xC4400303,
  329. 0x81C, 0xC3420303,
  330. 0x81C, 0xC2440303,
  331. 0x81C, 0xC1460303,
  332. 0x81C, 0xA4480303,
  333. 0x81C, 0xA34A0303,
  334. 0x81C, 0xA24C0303,
  335. 0x81C, 0xA14E0303,
  336. 0x81C, 0x83500303,
  337. 0x81C, 0x82520303,
  338. 0x81C, 0x81540303,
  339. 0x81C, 0x64560303,
  340. 0x81C, 0x63580303,
  341. 0x81C, 0x625A0303,
  342. 0x81C, 0x615C0303,
  343. 0x81C, 0x425E0303,
  344. 0x81C, 0x41600303,
  345. 0x81C, 0x23620303,
  346. 0x81C, 0x22640303,
  347. 0x81C, 0x21660303,
  348. 0x81C, 0x03680303,
  349. 0x81C, 0x026A0303,
  350. 0x81C, 0x016C0303,
  351. 0x81C, 0x016E0303,
  352. 0x81C, 0x01700303,
  353. 0x81C, 0x01720303,
  354. 0x81C, 0x01740303,
  355. 0x81C, 0x01760303,
  356. 0x81C, 0x01780303,
  357. 0x81C, 0x017A0303,
  358. 0x81C, 0x017C0303,
  359. 0x81C, 0x017E0303,
  360. 0x81C, 0xFB000403,
  361. 0x81C, 0xFA020403,
  362. 0x81C, 0xF9040403,
  363. 0x81C, 0xF8060403,
  364. 0x81C, 0xF7080403,
  365. 0x81C, 0xF60A0403,
  366. 0x81C, 0xF50C0403,
  367. 0x81C, 0xF40E0403,
  368. 0x81C, 0xF3100403,
  369. 0x81C, 0xF2120403,
  370. 0x81C, 0xF1140403,
  371. 0x81C, 0xF0160403,
  372. 0x81C, 0xEF180403,
  373. 0x81C, 0xEE1A0403,
  374. 0x81C, 0xED1C0403,
  375. 0x81C, 0xB61E0403,
  376. 0x81C, 0xB5200403,
  377. 0x81C, 0xB4220403,
  378. 0x81C, 0xB3240403,
  379. 0x81C, 0xB2260403,
  380. 0x81C, 0xB1280403,
  381. 0x81C, 0xAF2A0403,
  382. 0x81C, 0xAE2C0403,
  383. 0x81C, 0xAD2E0403,
  384. 0x81C, 0xAC300403,
  385. 0x81C, 0xAB320403,
  386. 0x81C, 0xAA340403,
  387. 0x81C, 0xA9360403,
  388. 0x81C, 0xA8380403,
  389. 0x81C, 0xA73A0403,
  390. 0x81C, 0xA63C0403,
  391. 0x81C, 0xA53E0403,
  392. 0x81C, 0x88400403,
  393. 0x81C, 0x87420403,
  394. 0x81C, 0x86440403,
  395. 0x81C, 0x85460403,
  396. 0x81C, 0x84480403,
  397. 0x81C, 0x834A0403,
  398. 0x81C, 0x674C0403,
  399. 0x81C, 0x664E0403,
  400. 0x81C, 0x65500403,
  401. 0x81C, 0x64520403,
  402. 0x81C, 0x63540403,
  403. 0x81C, 0x62560403,
  404. 0x81C, 0x61580403,
  405. 0x81C, 0x455A0403,
  406. 0x81C, 0x445C0403,
  407. 0x81C, 0x435E0403,
  408. 0x81C, 0x42600403,
  409. 0x81C, 0x41620403,
  410. 0x81C, 0x25640403,
  411. 0x81C, 0x24660403,
  412. 0x81C, 0x23680403,
  413. 0x81C, 0x226A0403,
  414. 0x81C, 0x216C0403,
  415. 0x81C, 0x016E0403,
  416. 0x81C, 0x01700403,
  417. 0x81C, 0x01720403,
  418. 0x81C, 0x01740403,
  419. 0x81C, 0x01760403,
  420. 0x81C, 0x01780403,
  421. 0x81C, 0x017A0403,
  422. 0x81C, 0x017C0403,
  423. 0x81C, 0x017E0403,
  424. 0xC50, 0x00000022,
  425. 0xC50, 0x00000020,
  426. };
  427. void
  428. odm_read_and_config_tc_8821c_agc_tab(
  429. struct PHY_DM_STRUCT *p_dm_odm
  430. )
  431. {
  432. u32 i = 0;
  433. u8 c_cond;
  434. boolean is_matched = true, is_skipped = false;
  435. u32 array_len = sizeof(array_tc_8821c_agc_tab) / sizeof(u32);
  436. u32 *array = array_tc_8821c_agc_tab;
  437. u32 v1 = 0, v2 = 0, pre_v1 = 0, pre_v2 = 0;
  438. ODM_RT_TRACE(p_dm_odm, ODM_COMP_INIT, ODM_DBG_LOUD, ("===> odm_read_and_config_tc_8821c_agc_tab\n"));
  439. while ((i + 1) < array_len) {
  440. v1 = array[i];
  441. v2 = array[i + 1];
  442. if (v1 & (BIT(31) | BIT30)) {/*positive & negative condition*/
  443. if (v1 & BIT(31)) {/* positive condition*/
  444. c_cond = (u8)((v1 & (BIT(29) | BIT(28))) >> 28);
  445. if (c_cond == COND_ENDIF) {/*end*/
  446. is_matched = true;
  447. is_skipped = false;
  448. ODM_RT_TRACE(p_dm_odm, ODM_COMP_INIT, ODM_DBG_LOUD, ("ENDIF\n"));
  449. } else if (c_cond == COND_ELSE) { /*else*/
  450. is_matched = is_skipped ? false : true;
  451. ODM_RT_TRACE(p_dm_odm, ODM_COMP_INIT, ODM_DBG_LOUD, ("ELSE\n"));
  452. } else {/*if , else if*/
  453. pre_v1 = v1;
  454. pre_v2 = v2;
  455. ODM_RT_TRACE(p_dm_odm, ODM_COMP_INIT, ODM_DBG_LOUD, ("IF or ELSE IF\n"));
  456. }
  457. } else if (v1 & BIT(30)) { /*negative condition*/
  458. if (is_skipped == false) {
  459. if (check_positive(p_dm_odm, pre_v1, pre_v2, v1, v2)) {
  460. is_matched = true;
  461. is_skipped = true;
  462. } else {
  463. is_matched = false;
  464. is_skipped = false;
  465. }
  466. } else
  467. is_matched = false;
  468. }
  469. } else {
  470. if (is_matched)
  471. odm_config_bb_agc_8821c(p_dm_odm, v1, MASKDWORD, v2);
  472. }
  473. i = i + 2;
  474. }
  475. }
  476. u32
  477. odm_get_version_tc_8821c_agc_tab(void)
  478. {
  479. return 9;
  480. }
  481. /******************************************************************************
  482. * PHY_REG.TXT
  483. ******************************************************************************/
  484. u32 array_tc_8821c_phy_reg[] = {
  485. 0x800, 0x9020D010,
  486. 0x804, 0x80018180,
  487. 0x808, 0x04028211,
  488. 0x80C, 0x13D10011,
  489. 0x810, 0x21101263,
  490. 0x814, 0x020C3D10,
  491. 0x818, 0x84A10385,
  492. 0x81C, 0x1E1E081F,
  493. 0x820, 0x0001AAAA,
  494. 0x824, 0x00030FE0,
  495. 0x828, 0x0000CCCC,
  496. 0x82C, 0x75CB7010,
  497. 0x830, 0x79A0EA2A,
  498. 0x834, 0x072E6986,
  499. 0x838, 0x87766461,
  500. 0x83C, 0x9194B2B6,
  501. 0x840, 0x171740E0,
  502. 0x844, 0x4D3D7CDB,
  503. 0x848, 0x4AD0408B,
  504. 0x84C, 0x6AFBF7A5,
  505. 0x850, 0x28A74706,
  506. 0x854, 0x0001520C,
  507. 0x858, 0x4060C000,
  508. 0x85C, 0x74010360,
  509. 0x860, 0x68A7C321,
  510. 0x864, 0x79F27432,
  511. 0x868, 0x8CA7A314,
  512. 0x86C, 0x778C2878,
  513. 0x870, 0x77777777,
  514. 0x874, 0x27612C2E,
  515. 0x878, 0xC0003152,
  516. 0x87C, 0x5C8FC000,
  517. 0x880, 0x00000000,
  518. 0x884, 0x00000000,
  519. 0x888, 0x00000000,
  520. 0x88C, 0x00000000,
  521. 0x890, 0x00000000,
  522. 0x894, 0x00000000,
  523. 0x898, 0x00000000,
  524. 0x89C, 0x00000000,
  525. 0x8A0, 0x00000013,
  526. 0x8A4, 0x7F7F7F7F,
  527. 0x8A8, 0x2202033E,
  528. 0x8AC, 0xF00F000A,
  529. 0x8B0, 0x00000600,
  530. 0x8B4, 0x000FC080,
  531. 0x8B8, 0xEC0057FF,
  532. 0x8BC, 0xACB520A3,
  533. 0x8C0, 0xFFE04020,
  534. 0x8C4, 0x47C00000,
  535. 0x8C8, 0x000251A5,
  536. 0x8CC, 0x08108492,
  537. 0x8D0, 0x0000B800,
  538. 0x8D4, 0x860308A0,
  539. 0x8D8, 0x290B5612,
  540. 0x8DC, 0x00000000,
  541. 0x8E0, 0x32D16777,
  542. 0x8E4, 0x49092925,
  543. 0x8E8, 0xFFFFC42C,
  544. 0x8EC, 0x99999999,
  545. 0x8F0, 0x00009999,
  546. 0x8F4, 0x00D80FA1,
  547. 0x8F8, 0x400000C0,
  548. 0x8FC, 0x00000130,
  549. 0x900, 0x00C00000,
  550. 0x904, 0x0FFF0FFF,
  551. 0x908, 0x00000000,
  552. 0x90C, 0x13000000,
  553. 0x910, 0x0000FC00,
  554. 0x914, 0xC6380000,
  555. 0x918, 0x1C1028C0,
  556. 0x91C, 0x64B11A1C,
  557. 0x920, 0xE0767233,
  558. 0x924, 0x055A2500,
  559. 0x928, 0x4AB0E4E4,
  560. 0x92C, 0xFFFEB200,
  561. 0x930, 0xFFFFFFFE,
  562. 0x934, 0x001FFFFF,
  563. 0x938, 0x00008480,
  564. 0x93C, 0xE41C0642,
  565. 0x940, 0x0E470430,
  566. 0x944, 0x00000000,
  567. 0x948, 0xAC000000,
  568. 0x94C, 0x10000083,
  569. 0x950, 0xF2010080,
  570. 0x954, 0x86510080,
  571. 0x958, 0x00000001,
  572. 0x95C, 0x04248000,
  573. 0x960, 0x00000000,
  574. 0x964, 0x00000000,
  575. 0x968, 0x00000000,
  576. 0x96C, 0x00000000,
  577. 0x970, 0x00001FFF,
  578. 0x974, 0x04000FFF,
  579. 0x978, 0x00000000,
  580. 0x97C, 0x00000000,
  581. 0x980, 0x00000000,
  582. 0x984, 0x00000000,
  583. 0x988, 0x00000000,
  584. 0x98C, 0x23440000,
  585. 0x990, 0x27100000,
  586. 0x994, 0xFFFF0100,
  587. 0x998, 0xFFFFFF5C,
  588. 0x99C, 0xFFFFFFFF,
  589. 0x9A0, 0x000000FF,
  590. 0x9A4, 0x80000088,
  591. 0x9A8, 0x0C2F0000,
  592. 0x9AC, 0x01560000,
  593. 0x9B0, 0x70000000,
  594. 0x9B4, 0x00000000,
  595. 0x9B8, 0x00000000,
  596. 0x9BC, 0x00000000,
  597. 0x9C0, 0x00000000,
  598. 0x9C4, 0x00000000,
  599. 0x9C8, 0x00000000,
  600. 0x9CC, 0x00000000,
  601. 0x9D0, 0x00000000,
  602. 0x9D4, 0x00000000,
  603. 0x9D8, 0x00000000,
  604. 0x9DC, 0x00000000,
  605. 0x9E0, 0x00000000,
  606. 0x9E4, 0x02000402,
  607. 0x9E8, 0x000022D4,
  608. 0x9EC, 0x00000000,
  609. 0x9F0, 0x00000000,
  610. 0x9F4, 0x00000000,
  611. 0x9F8, 0x00000000,
  612. 0x9FC, 0xEFFFF7FF,
  613. 0xA00, 0x00D047C8,
  614. 0xA04, 0x80FF800C,
  615. 0xA08, 0x9C838300,
  616. 0xA0C, 0x2E20200F,
  617. 0xA10, 0x9500BB78,
  618. 0xA14, 0x1114D028,
  619. 0xA18, 0x00881117,
  620. 0xA1C, 0x89140F00,
  621. 0xA20, 0xE82C0000,
  622. 0xA24, 0x64B80C1C,
  623. 0xA28, 0x00008810,
  624. 0xA2C, 0x00D20000,
  625. 0xA70, 0x101FBF00,
  626. 0xA74, 0x00000107,
  627. 0xA78, 0x00008900,
  628. 0xA7C, 0x225B0606,
  629. 0xA80, 0x21807532,
  630. 0xA84, 0x80200000,
  631. 0xA88, 0x048C0000,
  632. 0xA8C, 0x12345678,
  633. 0xA90, 0xABCDEF00,
  634. 0xA94, 0x001B1B89,
  635. 0xA98, 0x00000000,
  636. 0xA9C, 0x00060000,
  637. 0xAA0, 0x00000000,
  638. 0xAA4, 0x00040000,
  639. 0xAA8, 0xEACF0004,
  640. 0xAAC, 0x01235667,
  641. 0xAB0, 0x00000000,
  642. 0xB00, 0xE1000440,
  643. 0xB04, 0x00800000,
  644. 0xB08, 0xFF02030B,
  645. 0xB0C, 0x01EAA406,
  646. 0xB10, 0x00030690,
  647. 0xB14, 0x006000FA,
  648. 0xB18, 0x00000002,
  649. 0xB1C, 0x00000002,
  650. 0xB20, 0x4B00001F,
  651. 0xB24, 0x4E8E3E40,
  652. 0xB28, 0x03020100,
  653. 0xB2C, 0x07060504,
  654. 0xB30, 0x0B0A0908,
  655. 0xB34, 0x0F0E0D0C,
  656. 0xB38, 0x13121110,
  657. 0xB3C, 0x0000003A,
  658. 0xB40, 0x00000000,
  659. 0xB44, 0x80000000,
  660. 0xB48, 0x3F0000FA,
  661. 0xB4C, 0x88C80020,
  662. 0xB50, 0x00000000,
  663. 0xB54, 0x00004241,
  664. 0xB58, 0xE0008208,
  665. 0xB5C, 0x41EFFFF9,
  666. 0xB60, 0x00000000,
  667. 0xB64, 0x00200063,
  668. 0xB68, 0x0000003A,
  669. 0xB6C, 0x00000102,
  670. 0xB70, 0x4E6D1870,
  671. 0xB74, 0x03020100,
  672. 0xB78, 0x07060504,
  673. 0xB7C, 0x0B0A0908,
  674. 0xB80, 0x0F0E0D0C,
  675. 0xB84, 0x13121110,
  676. 0xB88, 0x00000000,
  677. 0xB8C, 0x00000000,
  678. 0xC00, 0x00000007,
  679. 0xC04, 0x03000020,
  680. 0xC08, 0x60403231,
  681. 0xC0C, 0x00012345,
  682. 0xC10, 0x00000100,
  683. 0xC14, 0x01000000,
  684. 0xC18, 0x00000000,
  685. 0xC1C, 0x40040053,
  686. 0xC20, 0x000503A3,
  687. 0xC24, 0x00000000,
  688. 0xC28, 0x00000000,
  689. 0xC2C, 0x00000000,
  690. 0xC30, 0x00000000,
  691. 0xC34, 0x00000000,
  692. 0xC38, 0x00000000,
  693. 0xC3C, 0x00000000,
  694. 0xC40, 0x00000000,
  695. 0xC44, 0x00000000,
  696. 0xC48, 0x00000000,
  697. 0xC4C, 0x00000000,
  698. 0xC50, 0x00000020,
  699. 0xC54, 0x00000000,
  700. 0xC58, 0xD8020402,
  701. 0xC5C, 0xDE000120,
  702. 0xC68, 0x00000179,
  703. 0xC6C, 0x0000122A,
  704. 0xC70, 0x00000000,
  705. 0xC74, 0x00000000,
  706. 0xC78, 0x00000000,
  707. 0xC7C, 0x00000000,
  708. 0xC80, 0x00000000,
  709. 0xC84, 0x00000000,
  710. 0xC88, 0x00000000,
  711. 0xC8C, 0x07000000,
  712. 0xC94, 0x01000100,
  713. 0xC98, 0x201C8000,
  714. 0xC9C, 0x00000000,
  715. 0xCA0, 0x0000A555,
  716. 0xCA4, 0x08040201,
  717. 0xCA8, 0x80402010,
  718. 0xCAC, 0x00000000,
  719. 0xCB0, 0x98543210,
  720. 0xCB4, 0x10000077,
  721. 0xCB8, 0x00000000,
  722. 0xCBC, 0x00000000,
  723. 0xCC0, 0x00000000,
  724. 0xCC4, 0x00000000,
  725. 0xCC8, 0x00000000,
  726. 0xCCC, 0x00000000,
  727. 0xCD0, 0x00000000,
  728. 0xCD4, 0x00000000,
  729. 0xCD8, 0x00000000,
  730. 0xCDC, 0x00000000,
  731. 0xCE0, 0x00000000,
  732. 0xCE4, 0x00000000,
  733. 0xCE8, 0x00000000,
  734. 0xCEC, 0x00000000,
  735. 0xE00, 0x00000007,
  736. 0xE04, 0x00000020,
  737. 0xE08, 0x60403231,
  738. 0xE0C, 0x00012345,
  739. 0xE10, 0x00000100,
  740. 0xE14, 0x01000000,
  741. 0xE18, 0x00000000,
  742. 0xE1C, 0x40040053,
  743. 0xE20, 0x00020103,
  744. 0xE24, 0x00000000,
  745. 0xE28, 0x00000000,
  746. 0xE2C, 0x00000000,
  747. 0xE30, 0x00000000,
  748. 0xE34, 0x00000000,
  749. 0xE38, 0x00000000,
  750. 0xE3C, 0x00000000,
  751. 0xE40, 0x00000000,
  752. 0xE44, 0x00000000,
  753. 0xE48, 0x00000000,
  754. 0xE4C, 0x00000000,
  755. 0xE50, 0x00000020,
  756. 0xE54, 0x00000000,
  757. 0xE58, 0xD8020402,
  758. 0xE5C, 0xDE000120,
  759. 0xE68, 0x59799979,
  760. 0xE6C, 0x0000122A,
  761. 0xE70, 0x99795979,
  762. 0xE74, 0x99795979,
  763. 0xE78, 0x99799979,
  764. 0xE7C, 0x99791979,
  765. 0xE80, 0x19791979,
  766. 0xE84, 0x19791979,
  767. 0xE88, 0x00000000,
  768. 0xE8C, 0x07000000,
  769. 0xE94, 0x01000100,
  770. 0xE98, 0x201C8000,
  771. 0xE9C, 0x00000000,
  772. 0xEA0, 0x0000A555,
  773. 0xEA4, 0x08040201,
  774. 0xEA8, 0x80402010,
  775. 0xEAC, 0x00000000,
  776. 0xEB0, 0x98543210,
  777. 0xEB4, 0x000000BA,
  778. 0xEB8, 0x00000000,
  779. 0xEBC, 0x00000000,
  780. 0xEC0, 0x00000000,
  781. 0xEC4, 0x00000000,
  782. 0xEC8, 0x00000000,
  783. 0xECC, 0x00000000,
  784. 0xED0, 0x00000000,
  785. 0xED4, 0x00000000,
  786. 0xED8, 0x00000000,
  787. 0xEDC, 0x00000000,
  788. 0xEE0, 0x00000000,
  789. 0xEE4, 0x00000000,
  790. 0xEE8, 0x00000000,
  791. 0xEEC, 0x00000000,
  792. 0x1900, 0x00000000,
  793. 0x1904, 0x00238000,
  794. 0x1908, 0x00000000,
  795. 0x190C, 0x00000000,
  796. 0x1910, 0x00000000,
  797. 0x1914, 0x00000000,
  798. 0x1918, 0x00000000,
  799. 0x191C, 0x00000000,
  800. 0x1920, 0x00000000,
  801. 0x1924, 0x00000000,
  802. 0x1928, 0x00000000,
  803. 0x192C, 0x00000000,
  804. 0x1930, 0x00000000,
  805. 0x1934, 0x00000000,
  806. 0x1938, 0x00000000,
  807. 0x193C, 0x00000000,
  808. 0x1940, 0x00000000,
  809. 0x1944, 0x00000000,
  810. 0x1948, 0x00000000,
  811. 0x194C, 0x00000000,
  812. 0x1950, 0x00000000,
  813. 0x1954, 0x00000000,
  814. 0x1958, 0x00000000,
  815. 0x195C, 0x00000000,
  816. 0x1960, 0x00000000,
  817. 0x1964, 0x00000000,
  818. 0x1968, 0x00000000,
  819. 0x196C, 0x00000000,
  820. 0x1970, 0x00000000,
  821. 0x1974, 0x00000000,
  822. 0x1978, 0x00000000,
  823. 0x197C, 0x00000000,
  824. 0x1980, 0x00000000,
  825. 0x1984, 0x03000000,
  826. 0x1988, 0x21401E88,
  827. 0x198C, 0x00004000,
  828. 0x1990, 0x00000000,
  829. 0x1994, 0x00000000,
  830. 0x1998, 0x00000053,
  831. 0x199C, 0x00000000,
  832. 0x19A0, 0x00000000,
  833. 0x19A4, 0x00000000,
  834. 0x19A8, 0x00000000,
  835. 0x19AC, 0x0E47E47F,
  836. 0x19B0, 0x00000000,
  837. 0x19B4, 0x0E47E47F,
  838. 0x19B8, 0x00000000,
  839. 0x19BC, 0x00000000,
  840. 0x19C0, 0x00000000,
  841. 0x19C4, 0x00000000,
  842. 0x19C8, 0x00000000,
  843. 0x19CC, 0x00000000,
  844. 0x19D0, 0x00000000,
  845. 0x19D4, 0x77777777,
  846. 0x19D8, 0x00000777,
  847. 0x19DC, 0x133E0F37,
  848. 0x19E0, 0x00000000,
  849. 0x19E4, 0x00000000,
  850. 0x19E8, 0x00000000,
  851. 0x19EC, 0x00000000,
  852. 0x19F0, 0x00000000,
  853. 0x19F4, 0x00000000,
  854. 0x19F8, 0x01A00000,
  855. 0x19FC, 0x00000000,
  856. 0x1C00, 0x00000100,
  857. 0x1C04, 0x01000000,
  858. 0x1C08, 0x00000100,
  859. 0x1C0C, 0x01000000,
  860. 0x1C10, 0x00000100,
  861. 0x1C14, 0x01000000,
  862. 0x1C18, 0x00000100,
  863. 0x1C1C, 0x01000000,
  864. 0x1C20, 0x00000100,
  865. 0x1C24, 0x01000000,
  866. 0x1C28, 0x00000100,
  867. 0x1C2C, 0x01000000,
  868. 0x1C30, 0x00000100,
  869. 0x1C34, 0x01000000,
  870. 0x1C38, 0x00000000,
  871. 0x1C3C, 0x00000000,
  872. 0x1C40, 0x000C0100,
  873. 0x1C44, 0x000000F3,
  874. 0x1C48, 0x1A8249A8,
  875. 0x1C4C, 0x1461C826,
  876. 0x1C50, 0x0001469E,
  877. 0x1C54, 0x58D158D1,
  878. 0x1C58, 0x04490088,
  879. 0x1C5C, 0x04004400,
  880. 0x1C60, 0x00000000,
  881. 0x1C64, 0x04004400,
  882. 0x1C68, 0x00000100,
  883. 0x1C6C, 0x01000000,
  884. 0x1C70, 0x00A018C6,
  885. 0x1C74, 0x2080E0C0,
  886. 0x1C78, 0x00000000,
  887. 0x1C7C, 0x00000010,
  888. 0x1C80, 0x00000100,
  889. 0x1C84, 0x01000000,
  890. 0x1C88, 0x00000100,
  891. 0x1C8C, 0x01000000,
  892. 0x1C90, 0x00000100,
  893. 0x1C94, 0x01000000,
  894. 0x1C98, 0x00000100,
  895. 0x1C9C, 0x01000000,
  896. 0x1CA0, 0x00000100,
  897. 0x1CA4, 0x01000000,
  898. 0x1CA8, 0x00000100,
  899. 0x1CAC, 0x01000000,
  900. 0x1CB0, 0x00000100,
  901. 0x1CB4, 0x01000000,
  902. 0x1CB8, 0x00000000,
  903. 0x1CBC, 0x00000000,
  904. 0x1CC0, 0x50055100,
  905. 0x1CC4, 0x06318000,
  906. 0x1CC8, 0x5B75B6EB,
  907. 0x1CCC, 0x01000000,
  908. 0x1CD0, 0x00000100,
  909. 0x1CD4, 0x01000014,
  910. 0x1CD8, 0x00000100,
  911. 0x1CDC, 0x01000000,
  912. 0x1CE0, 0x02050205,
  913. 0x1CE4, 0x7B780003,
  914. 0x1CE8, 0x00000100,
  915. 0x1CEC, 0x01000000,
  916. 0x1CF0, 0x00000100,
  917. 0x1CF4, 0x01000000,
  918. 0x1CF8, 0x01B8ADEB,
  919. 0x1CFC, 0x00000000,
  920. 0xC60, 0x700B8040,
  921. 0xC60, 0x700B8040,
  922. 0xC60, 0x70146040,
  923. 0xC60, 0x70246040,
  924. 0xC60, 0x70346040,
  925. 0xC60, 0x70446040,
  926. 0xC60, 0x705B2040,
  927. 0xC60, 0x70646040,
  928. 0xC60, 0x707B8040,
  929. 0xC60, 0x708B8040,
  930. 0xC60, 0x709B8040,
  931. 0xC60, 0x70AB8040,
  932. 0xC60, 0x70BB6040,
  933. 0xC60, 0x70C06040,
  934. 0xC60, 0x70D06040,
  935. 0xC60, 0x70EF6040,
  936. 0xC60, 0x70F06040,
  937. 0xE60, 0x700B8040,
  938. 0xE60, 0x700B8040,
  939. 0xE60, 0x70146040,
  940. 0xE60, 0x70246040,
  941. 0xE60, 0x70346040,
  942. 0xE60, 0x70446040,
  943. 0xE60, 0x705B2040,
  944. 0xE60, 0x70646040,
  945. 0xE60, 0x707B8040,
  946. 0xE60, 0x708B8040,
  947. 0xE60, 0x709B8040,
  948. 0xE60, 0x70AB8040,
  949. 0xE60, 0x70BB6040,
  950. 0xE60, 0x70C06040,
  951. 0xE60, 0x70D06040,
  952. 0xE60, 0x70EF6040,
  953. 0xE60, 0x70F06040,
  954. 0xC64, 0x00800000,
  955. 0xC64, 0x08800001,
  956. 0xC64, 0x00800002,
  957. 0xC64, 0x00800003,
  958. 0xC64, 0x00800004,
  959. 0xC64, 0x00800005,
  960. 0xC64, 0x00800006,
  961. 0xC64, 0x08800007,
  962. 0xC64, 0x00004000,
  963. 0xE64, 0x00800000,
  964. 0xE64, 0x08800001,
  965. 0xE64, 0x00800002,
  966. 0xE64, 0x00800003,
  967. 0xE64, 0x00800004,
  968. 0xE64, 0x00800005,
  969. 0xE64, 0x00800006,
  970. 0xE64, 0x08800007,
  971. 0xE64, 0x00004000,
  972. 0x1B00, 0xF8000008,
  973. 0x1B00, 0xF80A7008,
  974. 0x1B00, 0xF8015008,
  975. 0x1B00, 0xF8000008,
  976. 0x1B04, 0xE24629D2,
  977. 0x1B08, 0x00000080,
  978. 0x1B0C, 0x00000000,
  979. 0x1B10, 0x00010C00,
  980. 0x1B14, 0x00000000,
  981. 0x1B18, 0x00292903,
  982. 0x1B1C, 0xA2193C32,
  983. 0x1B20, 0x01840008,
  984. 0x1B24, 0x01860008,
  985. 0x1B28, 0x80060300,
  986. 0x1B2C, 0x00000003,
  987. 0x1B30, 0x20000000,
  988. 0x1B34, 0x00000800,
  989. 0x1B3C, 0x20000000,
  990. 0x1BC0, 0x01000000,
  991. 0x1BCC, 0x00000000,
  992. 0x1B00, 0xF800000A,
  993. 0x1B1C, 0xA2193C32,
  994. 0x1B20, 0x01840008,
  995. 0x1B24, 0x01860008,
  996. 0x1B28, 0x80060300,
  997. 0x1B2C, 0x00000003,
  998. 0x1B30, 0x20000000,
  999. 0x1B34, 0x00000800,
  1000. 0x1B3C, 0x20000000,
  1001. 0x1BC0, 0x01000000,
  1002. 0x1BCC, 0x00000000,
  1003. 0x1B00, 0xF8000008,
  1004. 0x1B80, 0x00000007,
  1005. 0x1B80, 0x090A0005,
  1006. 0x1B80, 0x090A0007,
  1007. 0x1B80, 0x0FFE0015,
  1008. 0x1B80, 0x0FFE0017,
  1009. 0x1B80, 0x00220025,
  1010. 0x1B80, 0x00220027,
  1011. 0x1B80, 0x00040035,
  1012. 0x1B80, 0x00040037,
  1013. 0x1B80, 0x05C00045,
  1014. 0x1B80, 0x05C00047,
  1015. 0x1B80, 0x00070055,
  1016. 0x1B80, 0x00070057,
  1017. 0x1B80, 0x64000065,
  1018. 0x1B80, 0x64000067,
  1019. 0x1B80, 0x00020075,
  1020. 0x1B80, 0x00020077,
  1021. 0x1B80, 0x00080085,
  1022. 0x1B80, 0x00080087,
  1023. 0x1B80, 0x80000095,
  1024. 0x1B80, 0x80000097,
  1025. 0x1B80, 0x090800A5,
  1026. 0x1B80, 0x090800A7,
  1027. 0x1B80, 0x0F0200B5,
  1028. 0x1B80, 0x0F0200B7,
  1029. 0x1B80, 0x002200C5,
  1030. 0x1B80, 0x002200C7,
  1031. 0x1B80, 0x000400D5,
  1032. 0x1B80, 0x000400D7,
  1033. 0x1B80, 0x05C000E5,
  1034. 0x1B80, 0x05C000E7,
  1035. 0x1B80, 0x000700F5,
  1036. 0x1B80, 0x000700F7,
  1037. 0x1B80, 0x64020105,
  1038. 0x1B80, 0x64020107,
  1039. 0x1B80, 0x00020115,
  1040. 0x1B80, 0x00020117,
  1041. 0x1B80, 0x00040125,
  1042. 0x1B80, 0x00040127,
  1043. 0x1B80, 0x4A000135,
  1044. 0x1B80, 0x4A000137,
  1045. 0x1B80, 0x4B040145,
  1046. 0x1B80, 0x4B040147,
  1047. 0x1B80, 0x85030155,
  1048. 0x1B80, 0x85030157,
  1049. 0x1B80, 0x40090165,
  1050. 0x1B80, 0x40090167,
  1051. 0x1B80, 0xE0210175,
  1052. 0x1B80, 0xE0210177,
  1053. 0x1B80, 0x4B050185,
  1054. 0x1B80, 0x4B050187,
  1055. 0x1B80, 0x86030195,
  1056. 0x1B80, 0x86030197,
  1057. 0x1B80, 0x400B01A5,
  1058. 0x1B80, 0x400B01A7,
  1059. 0x1B80, 0xE02101B5,
  1060. 0x1B80, 0xE02101B7,
  1061. 0x1B80, 0x4B0001C5,
  1062. 0x1B80, 0x4B0001C7,
  1063. 0x1B80, 0x000701D5,
  1064. 0x1B80, 0x000701D7,
  1065. 0x1B80, 0x4C0001E5,
  1066. 0x1B80, 0x4C0001E7,
  1067. 0x1B80, 0x000401F5,
  1068. 0x1B80, 0x000401F7,
  1069. 0x1B80, 0x30000205,
  1070. 0x1B80, 0x30000207,
  1071. 0x1B80, 0xFE160215,
  1072. 0x1B80, 0xFE160217,
  1073. 0x1B80, 0xFF160225,
  1074. 0x1B80, 0xFF160227,
  1075. 0x1B80, 0xE1670235,
  1076. 0x1B80, 0xE1670237,
  1077. 0x1B80, 0xF00A0245,
  1078. 0x1B80, 0xF00A0247,
  1079. 0x1B80, 0xF10A0255,
  1080. 0x1B80, 0xF10A0257,
  1081. 0x1B80, 0xF20A0265,
  1082. 0x1B80, 0xF20A0267,
  1083. 0x1B80, 0xF30A0275,
  1084. 0x1B80, 0xF30A0277,
  1085. 0x1B80, 0xF40A0285,
  1086. 0x1B80, 0xF40A0287,
  1087. 0x1B80, 0xF50A0295,
  1088. 0x1B80, 0xF50A0297,
  1089. 0x1B80, 0xF60A02A5,
  1090. 0x1B80, 0xF60A02A7,
  1091. 0x1B80, 0xF70A02B5,
  1092. 0x1B80, 0xF70A02B7,
  1093. 0x1B80, 0xF80A02C5,
  1094. 0x1B80, 0xF80A02C7,
  1095. 0x1B80, 0x000102D5,
  1096. 0x1B80, 0x000102D7,
  1097. 0x1B80, 0x303902E5,
  1098. 0x1B80, 0x303902E7,
  1099. 0x1B80, 0x305102F5,
  1100. 0x1B80, 0x305102F7,
  1101. 0x1B80, 0x309C0305,
  1102. 0x1B80, 0x309C0307,
  1103. 0x1B80, 0x30530315,
  1104. 0x1B80, 0x30530317,
  1105. 0x1B80, 0x305E0325,
  1106. 0x1B80, 0x305E0327,
  1107. 0x1B80, 0x30690335,
  1108. 0x1B80, 0x30690337,
  1109. 0x1B80, 0x30A00345,
  1110. 0x1B80, 0x30A00347,
  1111. 0x1B80, 0x30AF0355,
  1112. 0x1B80, 0x30AF0357,
  1113. 0x1B80, 0x30BA0365,
  1114. 0x1B80, 0x30BA0367,
  1115. 0x1B80, 0x30ED0375,
  1116. 0x1B80, 0x30ED0377,
  1117. 0x1B80, 0x30F00385,
  1118. 0x1B80, 0x30F00387,
  1119. 0x1B80, 0xE1060395,
  1120. 0x1B80, 0xE1060397,
  1121. 0x1B80, 0x4D0403A5,
  1122. 0x1B80, 0x4D0403A7,
  1123. 0x1B80, 0x208003B5,
  1124. 0x1B80, 0x208003B7,
  1125. 0x1B80, 0x000003C5,
  1126. 0x1B80, 0x000003C7,
  1127. 0x1B80, 0x4D0003D5,
  1128. 0x1B80, 0x4D0003D7,
  1129. 0x1B80, 0x550703E5,
  1130. 0x1B80, 0x550703E7,
  1131. 0x1B80, 0xE0FE03F5,
  1132. 0x1B80, 0xE0FE03F7,
  1133. 0x1B80, 0xE0FE0405,
  1134. 0x1B80, 0xE0FE0407,
  1135. 0x1B80, 0x4D040415,
  1136. 0x1B80, 0x4D040417,
  1137. 0x1B80, 0x20880425,
  1138. 0x1B80, 0x20880427,
  1139. 0x1B80, 0x02000435,
  1140. 0x1B80, 0x02000437,
  1141. 0x1B80, 0x4D000445,
  1142. 0x1B80, 0x4D000447,
  1143. 0x1B80, 0x550F0455,
  1144. 0x1B80, 0x550F0457,
  1145. 0x1B80, 0xE0FE0465,
  1146. 0x1B80, 0xE0FE0467,
  1147. 0x1B80, 0x4F020475,
  1148. 0x1B80, 0x4F020477,
  1149. 0x1B80, 0x4E000485,
  1150. 0x1B80, 0x4E000487,
  1151. 0x1B80, 0x53020495,
  1152. 0x1B80, 0x53020497,
  1153. 0x1B80, 0x520104A5,
  1154. 0x1B80, 0x520104A7,
  1155. 0x1B80, 0xE10204B5,
  1156. 0x1B80, 0xE10204B7,
  1157. 0x1B80, 0x4D0804C5,
  1158. 0x1B80, 0x4D0804C7,
  1159. 0x1B80, 0x571004D5,
  1160. 0x1B80, 0x571004D7,
  1161. 0x1B80, 0x570004E5,
  1162. 0x1B80, 0x570004E7,
  1163. 0x1B80, 0x4D0004F5,
  1164. 0x1B80, 0x4D0004F7,
  1165. 0x1B80, 0x00010505,
  1166. 0x1B80, 0x00010507,
  1167. 0x1B80, 0xE1060515,
  1168. 0x1B80, 0xE1060517,
  1169. 0x1B80, 0x00010525,
  1170. 0x1B80, 0x00010527,
  1171. 0x1B80, 0x30730535,
  1172. 0x1B80, 0x30730537,
  1173. 0x1B80, 0x00230545,
  1174. 0x1B80, 0x00230547,
  1175. 0x1B80, 0xE15A0555,
  1176. 0x1B80, 0xE15A0557,
  1177. 0x1B80, 0x00020565,
  1178. 0x1B80, 0x00020567,
  1179. 0x1B80, 0x54E90575,
  1180. 0x1B80, 0x54E90577,
  1181. 0x1B80, 0x0BA60585,
  1182. 0x1B80, 0x0BA60587,
  1183. 0x1B80, 0x00230595,
  1184. 0x1B80, 0x00230597,
  1185. 0x1B80, 0xE15A05A5,
  1186. 0x1B80, 0xE15A05A7,
  1187. 0x1B80, 0x000205B5,
  1188. 0x1B80, 0x000205B7,
  1189. 0x1B80, 0x4D3005C5,
  1190. 0x1B80, 0x4D3005C7,
  1191. 0x1B80, 0x308C05D5,
  1192. 0x1B80, 0x308C05D7,
  1193. 0x1B80, 0x306F05E5,
  1194. 0x1B80, 0x306F05E7,
  1195. 0x1B80, 0x002205F5,
  1196. 0x1B80, 0x002205F7,
  1197. 0x1B80, 0xE15A0605,
  1198. 0x1B80, 0xE15A0607,
  1199. 0x1B80, 0x00020615,
  1200. 0x1B80, 0x00020617,
  1201. 0x1B80, 0x54E80625,
  1202. 0x1B80, 0x54E80627,
  1203. 0x1B80, 0x0BA60635,
  1204. 0x1B80, 0x0BA60637,
  1205. 0x1B80, 0x00220645,
  1206. 0x1B80, 0x00220647,
  1207. 0x1B80, 0xE15A0655,
  1208. 0x1B80, 0xE15A0657,
  1209. 0x1B80, 0x00020665,
  1210. 0x1B80, 0x00020667,
  1211. 0x1B80, 0x4D300675,
  1212. 0x1B80, 0x4D300677,
  1213. 0x1B80, 0x308C0685,
  1214. 0x1B80, 0x308C0687,
  1215. 0x1B80, 0x63F10695,
  1216. 0x1B80, 0x63F10697,
  1217. 0x1B80, 0xE10606A5,
  1218. 0x1B80, 0xE10606A7,
  1219. 0x1B80, 0xE15A06B5,
  1220. 0x1B80, 0xE15A06B7,
  1221. 0x1B80, 0x63F406C5,
  1222. 0x1B80, 0x63F406C7,
  1223. 0x1B80, 0xE10606D5,
  1224. 0x1B80, 0xE10606D7,
  1225. 0x1B80, 0xE15A06E5,
  1226. 0x1B80, 0xE15A06E7,
  1227. 0x1B80, 0x0BA806F5,
  1228. 0x1B80, 0x0BA806F7,
  1229. 0x1B80, 0x63F80705,
  1230. 0x1B80, 0x63F80707,
  1231. 0x1B80, 0xE1060715,
  1232. 0x1B80, 0xE1060717,
  1233. 0x1B80, 0xE15A0725,
  1234. 0x1B80, 0xE15A0727,
  1235. 0x1B80, 0x0BA90735,
  1236. 0x1B80, 0x0BA90737,
  1237. 0x1B80, 0x63FC0745,
  1238. 0x1B80, 0x63FC0747,
  1239. 0x1B80, 0xE1060755,
  1240. 0x1B80, 0xE1060757,
  1241. 0x1B80, 0xE15A0765,
  1242. 0x1B80, 0xE15A0767,
  1243. 0x1B80, 0x63FF0775,
  1244. 0x1B80, 0x63FF0777,
  1245. 0x1B80, 0xE1060785,
  1246. 0x1B80, 0xE1060787,
  1247. 0x1B80, 0xE15A0795,
  1248. 0x1B80, 0xE15A0797,
  1249. 0x1B80, 0x630007A5,
  1250. 0x1B80, 0x630007A7,
  1251. 0x1B80, 0xE10607B5,
  1252. 0x1B80, 0xE10607B7,
  1253. 0x1B80, 0xE15A07C5,
  1254. 0x1B80, 0xE15A07C7,
  1255. 0x1B80, 0x630307D5,
  1256. 0x1B80, 0x630307D7,
  1257. 0x1B80, 0xE10607E5,
  1258. 0x1B80, 0xE10607E7,
  1259. 0x1B80, 0xE15A07F5,
  1260. 0x1B80, 0xE15A07F7,
  1261. 0x1B80, 0xF3D40805,
  1262. 0x1B80, 0xF3D40807,
  1263. 0x1B80, 0x63070815,
  1264. 0x1B80, 0x63070817,
  1265. 0x1B80, 0xE1060825,
  1266. 0x1B80, 0xE1060827,
  1267. 0x1B80, 0xE15A0835,
  1268. 0x1B80, 0xE15A0837,
  1269. 0x1B80, 0xF4DB0845,
  1270. 0x1B80, 0xF4DB0847,
  1271. 0x1B80, 0x630B0855,
  1272. 0x1B80, 0x630B0857,
  1273. 0x1B80, 0xE1060865,
  1274. 0x1B80, 0xE1060867,
  1275. 0x1B80, 0xE15A0875,
  1276. 0x1B80, 0xE15A0877,
  1277. 0x1B80, 0x630E0885,
  1278. 0x1B80, 0x630E0887,
  1279. 0x1B80, 0xE1060895,
  1280. 0x1B80, 0xE1060897,
  1281. 0x1B80, 0xE15A08A5,
  1282. 0x1B80, 0xE15A08A7,
  1283. 0x1B80, 0x4D3008B5,
  1284. 0x1B80, 0x4D3008B7,
  1285. 0x1B80, 0x550108C5,
  1286. 0x1B80, 0x550108C7,
  1287. 0x1B80, 0x570408D5,
  1288. 0x1B80, 0x570408D7,
  1289. 0x1B80, 0x570008E5,
  1290. 0x1B80, 0x570008E7,
  1291. 0x1B80, 0x960008F5,
  1292. 0x1B80, 0x960008F7,
  1293. 0x1B80, 0x57080905,
  1294. 0x1B80, 0x57080907,
  1295. 0x1B80, 0x57000915,
  1296. 0x1B80, 0x57000917,
  1297. 0x1B80, 0x95000925,
  1298. 0x1B80, 0x95000927,
  1299. 0x1B80, 0x4D000935,
  1300. 0x1B80, 0x4D000937,
  1301. 0x1B80, 0x6C070945,
  1302. 0x1B80, 0x6C070947,
  1303. 0x1B80, 0x7B200955,
  1304. 0x1B80, 0x7B200957,
  1305. 0x1B80, 0x7A000965,
  1306. 0x1B80, 0x7A000967,
  1307. 0x1B80, 0x79000975,
  1308. 0x1B80, 0x79000977,
  1309. 0x1B80, 0x7F200985,
  1310. 0x1B80, 0x7F200987,
  1311. 0x1B80, 0x7E000995,
  1312. 0x1B80, 0x7E000997,
  1313. 0x1B80, 0x7D0009A5,
  1314. 0x1B80, 0x7D0009A7,
  1315. 0x1B80, 0x000109B5,
  1316. 0x1B80, 0x000109B7,
  1317. 0x1B80, 0x628509C5,
  1318. 0x1B80, 0x628509C7,
  1319. 0x1B80, 0xE10609D5,
  1320. 0x1B80, 0xE10609D7,
  1321. 0x1B80, 0xE13409E5,
  1322. 0x1B80, 0xE13409E7,
  1323. 0x1B80, 0x000109F5,
  1324. 0x1B80, 0x000109F7,
  1325. 0x1B80, 0x5C320A05,
  1326. 0x1B80, 0x5C320A07,
  1327. 0x1B80, 0x63FC0A15,
  1328. 0x1B80, 0x63FC0A17,
  1329. 0x1B80, 0x62850A25,
  1330. 0x1B80, 0x62850A27,
  1331. 0x1B80, 0xE1060A35,
  1332. 0x1B80, 0xE1060A37,
  1333. 0x1B80, 0x30CC0A45,
  1334. 0x1B80, 0x30CC0A47,
  1335. 0x1B80, 0x00230A55,
  1336. 0x1B80, 0x00230A57,
  1337. 0x1B80, 0xE15F0A65,
  1338. 0x1B80, 0xE15F0A67,
  1339. 0x1B80, 0x00020A75,
  1340. 0x1B80, 0x00020A77,
  1341. 0x1B80, 0x54E90A85,
  1342. 0x1B80, 0x54E90A87,
  1343. 0x1B80, 0x0BA60A95,
  1344. 0x1B80, 0x0BA60A97,
  1345. 0x1B80, 0x00230AA5,
  1346. 0x1B80, 0x00230AA7,
  1347. 0x1B80, 0xE15F0AB5,
  1348. 0x1B80, 0xE15F0AB7,
  1349. 0x1B80, 0x00020AC5,
  1350. 0x1B80, 0x00020AC7,
  1351. 0x1B80, 0x4D100AD5,
  1352. 0x1B80, 0x4D100AD7,
  1353. 0x1B80, 0x308C0AE5,
  1354. 0x1B80, 0x308C0AE7,
  1355. 0x1B80, 0x30C40AF5,
  1356. 0x1B80, 0x30C40AF7,
  1357. 0x1B80, 0x00220B05,
  1358. 0x1B80, 0x00220B07,
  1359. 0x1B80, 0xE15F0B15,
  1360. 0x1B80, 0xE15F0B17,
  1361. 0x1B80, 0x00020B25,
  1362. 0x1B80, 0x00020B27,
  1363. 0x1B80, 0x54E80B35,
  1364. 0x1B80, 0x54E80B37,
  1365. 0x1B80, 0x0BA60B45,
  1366. 0x1B80, 0x0BA60B47,
  1367. 0x1B80, 0x00220B55,
  1368. 0x1B80, 0x00220B57,
  1369. 0x1B80, 0xE15F0B65,
  1370. 0x1B80, 0xE15F0B67,
  1371. 0x1B80, 0x00020B75,
  1372. 0x1B80, 0x00020B77,
  1373. 0x1B80, 0x4D100B85,
  1374. 0x1B80, 0x4D100B87,
  1375. 0x1B80, 0x308C0B95,
  1376. 0x1B80, 0x308C0B97,
  1377. 0x1B80, 0x5C320BA5,
  1378. 0x1B80, 0x5C320BA7,
  1379. 0x1B80, 0x63F40BB5,
  1380. 0x1B80, 0x63F40BB7,
  1381. 0x1B80, 0x62850BC5,
  1382. 0x1B80, 0x62850BC7,
  1383. 0x1B80, 0xE1060BD5,
  1384. 0x1B80, 0xE1060BD7,
  1385. 0x1B80, 0x67F10BE5,
  1386. 0x1B80, 0x67F10BE7,
  1387. 0x1B80, 0xE1340BF5,
  1388. 0x1B80, 0xE1340BF7,
  1389. 0x1B80, 0xE15F0C05,
  1390. 0x1B80, 0xE15F0C07,
  1391. 0x1B80, 0x67F40C15,
  1392. 0x1B80, 0x67F40C17,
  1393. 0x1B80, 0xE1340C25,
  1394. 0x1B80, 0xE1340C27,
  1395. 0x1B80, 0xE15F0C35,
  1396. 0x1B80, 0xE15F0C37,
  1397. 0x1B80, 0x5C320C45,
  1398. 0x1B80, 0x5C320C47,
  1399. 0x1B80, 0x63FC0C55,
  1400. 0x1B80, 0x63FC0C57,
  1401. 0x1B80, 0x62850C65,
  1402. 0x1B80, 0x62850C67,
  1403. 0x1B80, 0xE1060C75,
  1404. 0x1B80, 0xE1060C77,
  1405. 0x1B80, 0x0BA80C85,
  1406. 0x1B80, 0x0BA80C87,
  1407. 0x1B80, 0x67F80C95,
  1408. 0x1B80, 0x67F80C97,
  1409. 0x1B80, 0xE1340CA5,
  1410. 0x1B80, 0xE1340CA7,
  1411. 0x1B80, 0xE15F0CB5,
  1412. 0x1B80, 0xE15F0CB7,
  1413. 0x1B80, 0x0BA90CC5,
  1414. 0x1B80, 0x0BA90CC7,
  1415. 0x1B80, 0x67FC0CD5,
  1416. 0x1B80, 0x67FC0CD7,
  1417. 0x1B80, 0xE1340CE5,
  1418. 0x1B80, 0xE1340CE7,
  1419. 0x1B80, 0xE15F0CF5,
  1420. 0x1B80, 0xE15F0CF7,
  1421. 0x1B80, 0x67FF0D05,
  1422. 0x1B80, 0x67FF0D07,
  1423. 0x1B80, 0xE1340D15,
  1424. 0x1B80, 0xE1340D17,
  1425. 0x1B80, 0xE15F0D25,
  1426. 0x1B80, 0xE15F0D27,
  1427. 0x1B80, 0x5C320D35,
  1428. 0x1B80, 0x5C320D37,
  1429. 0x1B80, 0x63030D45,
  1430. 0x1B80, 0x63030D47,
  1431. 0x1B80, 0xE1060D55,
  1432. 0x1B80, 0xE1060D57,
  1433. 0x1B80, 0x67000D65,
  1434. 0x1B80, 0x67000D67,
  1435. 0x1B80, 0xE1340D75,
  1436. 0x1B80, 0xE1340D77,
  1437. 0x1B80, 0xE15F0D85,
  1438. 0x1B80, 0xE15F0D87,
  1439. 0x1B80, 0x67030D95,
  1440. 0x1B80, 0x67030D97,
  1441. 0x1B80, 0xE1340DA5,
  1442. 0x1B80, 0xE1340DA7,
  1443. 0x1B80, 0xE15F0DB5,
  1444. 0x1B80, 0xE15F0DB7,
  1445. 0x1B80, 0xF6C90DC5,
  1446. 0x1B80, 0xF6C90DC7,
  1447. 0x1B80, 0x67070DD5,
  1448. 0x1B80, 0x67070DD7,
  1449. 0x1B80, 0xE1340DE5,
  1450. 0x1B80, 0xE1340DE7,
  1451. 0x1B80, 0xE15F0DF5,
  1452. 0x1B80, 0xE15F0DF7,
  1453. 0x1B80, 0xF7D00E05,
  1454. 0x1B80, 0xF7D00E07,
  1455. 0x1B80, 0x5C320E15,
  1456. 0x1B80, 0x5C320E17,
  1457. 0x1B80, 0x630B0E25,
  1458. 0x1B80, 0x630B0E27,
  1459. 0x1B80, 0xE1060E35,
  1460. 0x1B80, 0xE1060E37,
  1461. 0x1B80, 0x670B0E45,
  1462. 0x1B80, 0x670B0E47,
  1463. 0x1B80, 0xE1340E55,
  1464. 0x1B80, 0xE1340E57,
  1465. 0x1B80, 0xE15F0E65,
  1466. 0x1B80, 0xE15F0E67,
  1467. 0x1B80, 0x670E0E75,
  1468. 0x1B80, 0x670E0E77,
  1469. 0x1B80, 0xE1340E85,
  1470. 0x1B80, 0xE1340E87,
  1471. 0x1B80, 0xE15F0E95,
  1472. 0x1B80, 0xE15F0E97,
  1473. 0x1B80, 0x4D100EA5,
  1474. 0x1B80, 0x4D100EA7,
  1475. 0x1B80, 0x308C0EB5,
  1476. 0x1B80, 0x308C0EB7,
  1477. 0x1B80, 0x00010EC5,
  1478. 0x1B80, 0x00010EC7,
  1479. 0x1B80, 0x62850ED5,
  1480. 0x1B80, 0x62850ED7,
  1481. 0x1B80, 0xE1060EE5,
  1482. 0x1B80, 0xE1060EE7,
  1483. 0x1B80, 0x00010EF5,
  1484. 0x1B80, 0x00010EF7,
  1485. 0x1B80, 0xE1340F05,
  1486. 0x1B80, 0xE1340F07,
  1487. 0x1B80, 0x00010F15,
  1488. 0x1B80, 0x00010F17,
  1489. 0x1B80, 0x7B240F25,
  1490. 0x1B80, 0x7B240F27,
  1491. 0x1B80, 0x7A400F35,
  1492. 0x1B80, 0x7A400F37,
  1493. 0x1B80, 0x79000F45,
  1494. 0x1B80, 0x79000F47,
  1495. 0x1B80, 0x55030F55,
  1496. 0x1B80, 0x55030F57,
  1497. 0x1B80, 0x30FE0F65,
  1498. 0x1B80, 0x30FE0F67,
  1499. 0x1B80, 0x7B1C0F75,
  1500. 0x1B80, 0x7B1C0F77,
  1501. 0x1B80, 0x7A400F85,
  1502. 0x1B80, 0x7A400F87,
  1503. 0x1B80, 0x550B0F95,
  1504. 0x1B80, 0x550B0F97,
  1505. 0x1B80, 0x30FE0FA5,
  1506. 0x1B80, 0x30FE0FA7,
  1507. 0x1B80, 0x7B200FB5,
  1508. 0x1B80, 0x7B200FB7,
  1509. 0x1B80, 0x7A000FC5,
  1510. 0x1B80, 0x7A000FC7,
  1511. 0x1B80, 0x55130FD5,
  1512. 0x1B80, 0x55130FD7,
  1513. 0x1B80, 0x74010FE5,
  1514. 0x1B80, 0x74010FE7,
  1515. 0x1B80, 0x74000FF5,
  1516. 0x1B80, 0x74000FF7,
  1517. 0x1B80, 0x8E001005,
  1518. 0x1B80, 0x8E001007,
  1519. 0x1B80, 0x00011015,
  1520. 0x1B80, 0x00011017,
  1521. 0x1B80, 0x57021025,
  1522. 0x1B80, 0x57021027,
  1523. 0x1B80, 0x57001035,
  1524. 0x1B80, 0x57001037,
  1525. 0x1B80, 0x97001045,
  1526. 0x1B80, 0x97001047,
  1527. 0x1B80, 0x00011055,
  1528. 0x1B80, 0x00011057,
  1529. 0x1B80, 0x4F781065,
  1530. 0x1B80, 0x4F781067,
  1531. 0x1B80, 0x53881075,
  1532. 0x1B80, 0x53881077,
  1533. 0x1B80, 0xE1141085,
  1534. 0x1B80, 0xE1141087,
  1535. 0x1B80, 0x54801095,
  1536. 0x1B80, 0x54801097,
  1537. 0x1B80, 0x540010A5,
  1538. 0x1B80, 0x540010A7,
  1539. 0x1B80, 0xE11410B5,
  1540. 0x1B80, 0xE11410B7,
  1541. 0x1B80, 0x548110C5,
  1542. 0x1B80, 0x548110C7,
  1543. 0x1B80, 0x540010D5,
  1544. 0x1B80, 0x540010D7,
  1545. 0x1B80, 0xE11410E5,
  1546. 0x1B80, 0xE11410E7,
  1547. 0x1B80, 0x548210F5,
  1548. 0x1B80, 0x548210F7,
  1549. 0x1B80, 0x54001105,
  1550. 0x1B80, 0x54001107,
  1551. 0x1B80, 0xE11F1115,
  1552. 0x1B80, 0xE11F1117,
  1553. 0x1B80, 0xBF1D1125,
  1554. 0x1B80, 0xBF1D1127,
  1555. 0x1B80, 0x301D1135,
  1556. 0x1B80, 0x301D1137,
  1557. 0x1B80, 0xE0F21145,
  1558. 0x1B80, 0xE0F21147,
  1559. 0x1B80, 0xE0F71155,
  1560. 0x1B80, 0xE0F71157,
  1561. 0x1B80, 0xE0FB1165,
  1562. 0x1B80, 0xE0FB1167,
  1563. 0x1B80, 0xE1021175,
  1564. 0x1B80, 0xE1021177,
  1565. 0x1B80, 0xE1561185,
  1566. 0x1B80, 0xE1561187,
  1567. 0x1B80, 0x55131195,
  1568. 0x1B80, 0x55131197,
  1569. 0x1B80, 0xE0FE11A5,
  1570. 0x1B80, 0xE0FE11A7,
  1571. 0x1B80, 0x551511B5,
  1572. 0x1B80, 0x551511B7,
  1573. 0x1B80, 0xE10211C5,
  1574. 0x1B80, 0xE10211C7,
  1575. 0x1B80, 0xE15611D5,
  1576. 0x1B80, 0xE15611D7,
  1577. 0x1B80, 0x000111E5,
  1578. 0x1B80, 0x000111E7,
  1579. 0x1B80, 0x54BF11F5,
  1580. 0x1B80, 0x54BF11F7,
  1581. 0x1B80, 0x54C01205,
  1582. 0x1B80, 0x54C01207,
  1583. 0x1B80, 0x54A31215,
  1584. 0x1B80, 0x54A31217,
  1585. 0x1B80, 0x54C11225,
  1586. 0x1B80, 0x54C11227,
  1587. 0x1B80, 0x54A41235,
  1588. 0x1B80, 0x54A41237,
  1589. 0x1B80, 0x4C181245,
  1590. 0x1B80, 0x4C181247,
  1591. 0x1B80, 0xBF071255,
  1592. 0x1B80, 0xBF071257,
  1593. 0x1B80, 0x54C21265,
  1594. 0x1B80, 0x54C21267,
  1595. 0x1B80, 0x54A41275,
  1596. 0x1B80, 0x54A41277,
  1597. 0x1B80, 0xBF041285,
  1598. 0x1B80, 0xBF041287,
  1599. 0x1B80, 0x54C11295,
  1600. 0x1B80, 0x54C11297,
  1601. 0x1B80, 0x54A312A5,
  1602. 0x1B80, 0x54A312A7,
  1603. 0x1B80, 0xBF0112B5,
  1604. 0x1B80, 0xBF0112B7,
  1605. 0x1B80, 0xE16412C5,
  1606. 0x1B80, 0xE16412C7,
  1607. 0x1B80, 0x54DF12D5,
  1608. 0x1B80, 0x54DF12D7,
  1609. 0x1B80, 0x000112E5,
  1610. 0x1B80, 0x000112E7,
  1611. 0x1B80, 0x54BF12F5,
  1612. 0x1B80, 0x54BF12F7,
  1613. 0x1B80, 0x54E51305,
  1614. 0x1B80, 0x54E51307,
  1615. 0x1B80, 0x050A1315,
  1616. 0x1B80, 0x050A1317,
  1617. 0x1B80, 0x54DF1325,
  1618. 0x1B80, 0x54DF1327,
  1619. 0x1B80, 0x00011335,
  1620. 0x1B80, 0x00011337,
  1621. 0x1B80, 0x7F201345,
  1622. 0x1B80, 0x7F201347,
  1623. 0x1B80, 0x7E001355,
  1624. 0x1B80, 0x7E001357,
  1625. 0x1B80, 0x7D001365,
  1626. 0x1B80, 0x7D001367,
  1627. 0x1B80, 0x55011375,
  1628. 0x1B80, 0x55011377,
  1629. 0x1B80, 0x5C311385,
  1630. 0x1B80, 0x5C311387,
  1631. 0x1B80, 0xE0FE1395,
  1632. 0x1B80, 0xE0FE1397,
  1633. 0x1B80, 0xE10213A5,
  1634. 0x1B80, 0xE10213A7,
  1635. 0x1B80, 0x548013B5,
  1636. 0x1B80, 0x548013B7,
  1637. 0x1B80, 0x540013C5,
  1638. 0x1B80, 0x540013C7,
  1639. 0x1B80, 0xE0FE13D5,
  1640. 0x1B80, 0xE0FE13D7,
  1641. 0x1B80, 0xE10213E5,
  1642. 0x1B80, 0xE10213E7,
  1643. 0x1B80, 0x548113F5,
  1644. 0x1B80, 0x548113F7,
  1645. 0x1B80, 0x54001405,
  1646. 0x1B80, 0x54001407,
  1647. 0x1B80, 0xE0FE1415,
  1648. 0x1B80, 0xE0FE1417,
  1649. 0x1B80, 0xE1021425,
  1650. 0x1B80, 0xE1021427,
  1651. 0x1B80, 0x54821435,
  1652. 0x1B80, 0x54821437,
  1653. 0x1B80, 0x54001445,
  1654. 0x1B80, 0x54001447,
  1655. 0x1B80, 0xE11F1455,
  1656. 0x1B80, 0xE11F1457,
  1657. 0x1B80, 0xBFE91465,
  1658. 0x1B80, 0xBFE91467,
  1659. 0x1B80, 0x301D1475,
  1660. 0x1B80, 0x301D1477,
  1661. 0x1B80, 0x00231485,
  1662. 0x1B80, 0x00231487,
  1663. 0x1B80, 0x7B201495,
  1664. 0x1B80, 0x7B201497,
  1665. 0x1B80, 0x7A0014A5,
  1666. 0x1B80, 0x7A0014A7,
  1667. 0x1B80, 0x790014B5,
  1668. 0x1B80, 0x790014B7,
  1669. 0x1B80, 0xE15A14C5,
  1670. 0x1B80, 0xE15A14C7,
  1671. 0x1B80, 0x000214D5,
  1672. 0x1B80, 0x000214D7,
  1673. 0x1B80, 0x000114E5,
  1674. 0x1B80, 0x000114E7,
  1675. 0x1B80, 0x002214F5,
  1676. 0x1B80, 0x002214F7,
  1677. 0x1B80, 0x7B201505,
  1678. 0x1B80, 0x7B201507,
  1679. 0x1B80, 0x7A001515,
  1680. 0x1B80, 0x7A001517,
  1681. 0x1B80, 0x79001525,
  1682. 0x1B80, 0x79001527,
  1683. 0x1B80, 0xE15A1535,
  1684. 0x1B80, 0xE15A1537,
  1685. 0x1B80, 0x00021545,
  1686. 0x1B80, 0x00021547,
  1687. 0x1B80, 0x00011555,
  1688. 0x1B80, 0x00011557,
  1689. 0x1B80, 0x549F1565,
  1690. 0x1B80, 0x549F1567,
  1691. 0x1B80, 0x54FF1575,
  1692. 0x1B80, 0x54FF1577,
  1693. 0x1B80, 0x54001585,
  1694. 0x1B80, 0x54001587,
  1695. 0x1B80, 0x00011595,
  1696. 0x1B80, 0x00011597,
  1697. 0x1B80, 0x5C3115A5,
  1698. 0x1B80, 0x5C3115A7,
  1699. 0x1B80, 0x071415B5,
  1700. 0x1B80, 0x071415B7,
  1701. 0x1B80, 0x540015C5,
  1702. 0x1B80, 0x540015C7,
  1703. 0x1B80, 0x5C3215D5,
  1704. 0x1B80, 0x5C3215D7,
  1705. 0x1B80, 0x000115E5,
  1706. 0x1B80, 0x000115E7,
  1707. 0x1B80, 0x5C3215F5,
  1708. 0x1B80, 0x5C3215F7,
  1709. 0x1B80, 0x07141605,
  1710. 0x1B80, 0x07141607,
  1711. 0x1B80, 0x54001615,
  1712. 0x1B80, 0x54001617,
  1713. 0x1B80, 0x5C311625,
  1714. 0x1B80, 0x5C311627,
  1715. 0x1B80, 0x00011635,
  1716. 0x1B80, 0x00011637,
  1717. 0x1B80, 0x4C981645,
  1718. 0x1B80, 0x4C981647,
  1719. 0x1B80, 0x4C181655,
  1720. 0x1B80, 0x4C181657,
  1721. 0x1B80, 0x00011665,
  1722. 0x1B80, 0x00011667,
  1723. 0x1B80, 0x5C321675,
  1724. 0x1B80, 0x5C321677,
  1725. 0x1B80, 0x62841685,
  1726. 0x1B80, 0x62841687,
  1727. 0x1B80, 0x66861695,
  1728. 0x1B80, 0x66861697,
  1729. 0x1B80, 0x6C0316A5,
  1730. 0x1B80, 0x6C0316A7,
  1731. 0x1B80, 0x7B2016B5,
  1732. 0x1B80, 0x7B2016B7,
  1733. 0x1B80, 0x7A0016C5,
  1734. 0x1B80, 0x7A0016C7,
  1735. 0x1B80, 0x790016D5,
  1736. 0x1B80, 0x790016D7,
  1737. 0x1B80, 0x7F2016E5,
  1738. 0x1B80, 0x7F2016E7,
  1739. 0x1B80, 0x7E0016F5,
  1740. 0x1B80, 0x7E0016F7,
  1741. 0x1B80, 0x7D001705,
  1742. 0x1B80, 0x7D001707,
  1743. 0x1B80, 0x09011715,
  1744. 0x1B80, 0x09011717,
  1745. 0x1B80, 0x0C011725,
  1746. 0x1B80, 0x0C011727,
  1747. 0x1B80, 0x0BA61735,
  1748. 0x1B80, 0x0BA61737,
  1749. 0x1B80, 0x00011745,
  1750. 0x1B80, 0x00011747,
  1751. 0x1B80, 0x00000006,
  1752. 0x1B80, 0x00000002,
  1753. };
  1754. void
  1755. odm_read_and_config_tc_8821c_phy_reg(
  1756. struct PHY_DM_STRUCT *p_dm_odm
  1757. )
  1758. {
  1759. u32 i = 0;
  1760. u8 c_cond;
  1761. boolean is_matched = true, is_skipped = false;
  1762. u32 array_len = sizeof(array_tc_8821c_phy_reg) / sizeof(u32);
  1763. u32 *array = array_tc_8821c_phy_reg;
  1764. u32 v1 = 0, v2 = 0, pre_v1 = 0, pre_v2 = 0;
  1765. ODM_RT_TRACE(p_dm_odm, ODM_COMP_INIT, ODM_DBG_LOUD, ("===> odm_read_and_config_tc_8821c_phy_reg\n"));
  1766. while ((i + 1) < array_len) {
  1767. v1 = array[i];
  1768. v2 = array[i + 1];
  1769. if (v1 & (BIT(31) | BIT30)) {/*positive & negative condition*/
  1770. if (v1 & BIT(31)) {/* positive condition*/
  1771. c_cond = (u8)((v1 & (BIT(29) | BIT(28))) >> 28);
  1772. if (c_cond == COND_ENDIF) {/*end*/
  1773. is_matched = true;
  1774. is_skipped = false;
  1775. ODM_RT_TRACE(p_dm_odm, ODM_COMP_INIT, ODM_DBG_LOUD, ("ENDIF\n"));
  1776. } else if (c_cond == COND_ELSE) { /*else*/
  1777. is_matched = is_skipped ? false : true;
  1778. ODM_RT_TRACE(p_dm_odm, ODM_COMP_INIT, ODM_DBG_LOUD, ("ELSE\n"));
  1779. } else {/*if , else if*/
  1780. pre_v1 = v1;
  1781. pre_v2 = v2;
  1782. ODM_RT_TRACE(p_dm_odm, ODM_COMP_INIT, ODM_DBG_LOUD, ("IF or ELSE IF\n"));
  1783. }
  1784. } else if (v1 & BIT(30)) { /*negative condition*/
  1785. if (is_skipped == false) {
  1786. if (check_positive(p_dm_odm, pre_v1, pre_v2, v1, v2)) {
  1787. is_matched = true;
  1788. is_skipped = true;
  1789. } else {
  1790. is_matched = false;
  1791. is_skipped = false;
  1792. }
  1793. } else
  1794. is_matched = false;
  1795. }
  1796. } else {
  1797. if (is_matched)
  1798. odm_config_bb_phy_8821c(p_dm_odm, v1, MASKDWORD, v2);
  1799. }
  1800. i = i + 2;
  1801. }
  1802. }
  1803. u32
  1804. odm_get_version_tc_8821c_phy_reg(void)
  1805. {
  1806. return 9;
  1807. }
  1808. /******************************************************************************
  1809. * PHY_REG_PG.TXT
  1810. ******************************************************************************/
  1811. u32 array_tc_8821c_phy_reg_pg[] = {
  1812. 0, 0, 0, 0x00000c20, 0xffffffff, 0x34363840,
  1813. 0, 0, 0, 0x00000c24, 0xffffffff, 0x42424444,
  1814. 0, 0, 0, 0x00000c28, 0xffffffff, 0x30323638,
  1815. 0, 0, 0, 0x00000c2c, 0xffffffff, 0x40424444,
  1816. 0, 0, 0, 0x00000c30, 0xffffffff, 0x28303236,
  1817. 0, 0, 1, 0x00000c34, 0xffffffff, 0x38404242,
  1818. 0, 0, 1, 0x00000c38, 0xffffffff, 0x26283034,
  1819. 0, 0, 2, 0x00000cd8, 0xffffffff, 0x36384040,
  1820. 0, 0, 2, 0x00000cdc, 0xffffffff, 0x24262832,
  1821. 0, 0, 0, 0x00000c3c, 0xffffffff, 0x40424444,
  1822. 0, 0, 0, 0x00000c40, 0xffffffff, 0x28303236,
  1823. 0, 0, 0, 0x00000c44, 0xffffffff, 0x42422426,
  1824. 0, 0, 1, 0x00000c48, 0xffffffff, 0x30343840,
  1825. 0, 0, 1, 0x00000c4c, 0xffffffff, 0x22242628,
  1826. 0, 0, 2, 0x00000ce0, 0xffffffff, 0x36384040,
  1827. 0, 0, 2, 0x00000ce4, 0xffffffff, 0x24262832,
  1828. 0, 0, 2, 0x00000ce8, 0x0000ffff, 0x20202022,
  1829. 1, 0, 0, 0x00000c24, 0xffffffff, 0x42424444,
  1830. 1, 0, 0, 0x00000c28, 0xffffffff, 0x30323640,
  1831. 1, 0, 0, 0x00000c2c, 0xffffffff, 0x40424444,
  1832. 1, 0, 0, 0x00000c30, 0xffffffff, 0x28303236,
  1833. 1, 0, 1, 0x00000c34, 0xffffffff, 0x38404242,
  1834. 1, 0, 1, 0x00000c38, 0xffffffff, 0x26283034,
  1835. 1, 0, 2, 0x00000cd8, 0xffffffff, 0x36384040,
  1836. 1, 0, 2, 0x00000cdc, 0xffffffff, 0x24262832,
  1837. 1, 0, 0, 0x00000c3c, 0xffffffff, 0x40424444,
  1838. 1, 0, 0, 0x00000c40, 0xffffffff, 0x28303236,
  1839. 1, 0, 0, 0x00000c44, 0xffffffff, 0x42422426,
  1840. 1, 0, 1, 0x00000c48, 0xffffffff, 0x30343840,
  1841. 1, 0, 1, 0x00000c4c, 0xffffffff, 0x22242628,
  1842. 1, 0, 2, 0x00000ce0, 0xffffffff, 0x36384040,
  1843. 1, 0, 2, 0x00000ce4, 0xffffffff, 0x24262832,
  1844. 1, 0, 2, 0x00000ce8, 0x0000ffff, 0x20202022
  1845. };
  1846. void
  1847. odm_read_and_config_tc_8821c_phy_reg_pg(
  1848. struct PHY_DM_STRUCT *p_dm_odm
  1849. )
  1850. {
  1851. u32 i = 0;
  1852. u32 array_len = sizeof(array_tc_8821c_phy_reg_pg) / sizeof(u32);
  1853. u32 *array = array_tc_8821c_phy_reg_pg;
  1854. #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
  1855. struct _ADAPTER *adapter = p_dm_odm->adapter;
  1856. HAL_DATA_TYPE *p_hal_data = GET_HAL_DATA(adapter);
  1857. PlatformZeroMemory(p_hal_data->BufOfLinesPwrByRate, MAX_LINES_HWCONFIG_TXT * MAX_BYTES_LINE_HWCONFIG_TXT);
  1858. p_hal_data->nLinesReadPwrByRate = array_len / 6;
  1859. #endif
  1860. ODM_RT_TRACE(p_dm_odm, ODM_COMP_INIT, ODM_DBG_LOUD, ("===> odm_read_and_config_tc_8821c_phy_reg_pg\n"));
  1861. p_dm_odm->phy_reg_pg_version = 1;
  1862. p_dm_odm->phy_reg_pg_value_type = PHY_REG_PG_EXACT_VALUE;
  1863. for (i = 0; i < array_len; i += 6) {
  1864. u32 v1 = array[i];
  1865. u32 v2 = array[i + 1];
  1866. u32 v3 = array[i + 2];
  1867. u32 v4 = array[i + 3];
  1868. u32 v5 = array[i + 4];
  1869. u32 v6 = array[i + 5];
  1870. odm_config_bb_phy_reg_pg_8821c(p_dm_odm, v1, v2, v3, v4, v5, v6);
  1871. #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
  1872. rsprintf((char *)p_hal_data->BufOfLinesPwrByRate[i / 6], 100, "%s, %s, %s, 0x%X, 0x%08X, 0x%08X,",
  1873. (v1 == 0 ? "2.4G" : " 5G"), (v2 == 0 ? "A" : "B"), (v3 == 0 ? "1Tx" : "2Tx"), v4, v5, v6);
  1874. #endif
  1875. }
  1876. }
  1877. #endif /* end of HWIMG_SUPPORT*/