baseband.c 42 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*
  3. * Copyright (c) 1996, 2003 VIA Networking Technologies, Inc.
  4. * All rights reserved.
  5. *
  6. * File: baseband.c
  7. *
  8. * Purpose: Implement functions to access baseband
  9. *
  10. * Author: Kyle Hsu
  11. *
  12. * Date: Aug.22, 2002
  13. *
  14. * Functions:
  15. * BBuGetFrameTime - Calculate data frame transmitting time
  16. * BBvCaculateParameter - Caculate PhyLength, PhyService and Phy Signal
  17. * parameter for baseband Tx
  18. * BBbReadEmbedded - Embedded read baseband register via MAC
  19. * BBbWriteEmbedded - Embedded write baseband register via MAC
  20. * BBbVT3253Init - VIA VT3253 baseband chip init code
  21. *
  22. * Revision History:
  23. * 06-10-2003 Bryan YC Fan: Re-write codes to support VT3253 spec.
  24. * 08-07-2003 Bryan YC Fan: Add MAXIM2827/2825 and RFMD2959 support.
  25. * 08-26-2003 Kyle Hsu : Modify BBuGetFrameTime() and
  26. * BBvCalculateParameter().
  27. * cancel the setting of MAC_REG_SOFTPWRCTL on
  28. * BBbVT3253Init().
  29. * Add the comments.
  30. * 09-01-2003 Bryan YC Fan: RF & BB tables updated.
  31. * Modified BBvLoopbackOn & BBvLoopbackOff().
  32. *
  33. *
  34. */
  35. #include "tmacro.h"
  36. #include "mac.h"
  37. #include "baseband.h"
  38. #include "srom.h"
  39. #include "rf.h"
  40. /*--------------------- Static Classes ----------------------------*/
  41. /*--------------------- Static Variables --------------------------*/
  42. /*--------------------- Static Functions --------------------------*/
  43. /*--------------------- Export Variables --------------------------*/
  44. /*--------------------- Static Definitions -------------------------*/
  45. /*--------------------- Static Classes ----------------------------*/
  46. /*--------------------- Static Variables --------------------------*/
  47. #define CB_VT3253_INIT_FOR_RFMD 446
  48. static const unsigned char byVT3253InitTab_RFMD[CB_VT3253_INIT_FOR_RFMD][2] = {
  49. {0x00, 0x30},
  50. {0x01, 0x00},
  51. {0x02, 0x00},
  52. {0x03, 0x00},
  53. {0x04, 0x00},
  54. {0x05, 0x00},
  55. {0x06, 0x00},
  56. {0x07, 0x00},
  57. {0x08, 0x70},
  58. {0x09, 0x45},
  59. {0x0a, 0x2a},
  60. {0x0b, 0x76},
  61. {0x0c, 0x00},
  62. {0x0d, 0x01},
  63. {0x0e, 0x80},
  64. {0x0f, 0x00},
  65. {0x10, 0x00},
  66. {0x11, 0x00},
  67. {0x12, 0x00},
  68. {0x13, 0x00},
  69. {0x14, 0x00},
  70. {0x15, 0x00},
  71. {0x16, 0x00},
  72. {0x17, 0x00},
  73. {0x18, 0x00},
  74. {0x19, 0x00},
  75. {0x1a, 0x00},
  76. {0x1b, 0x9d},
  77. {0x1c, 0x05},
  78. {0x1d, 0x00},
  79. {0x1e, 0x00},
  80. {0x1f, 0x00},
  81. {0x20, 0x00},
  82. {0x21, 0x00},
  83. {0x22, 0x00},
  84. {0x23, 0x00},
  85. {0x24, 0x00},
  86. {0x25, 0x4a},
  87. {0x26, 0x00},
  88. {0x27, 0x00},
  89. {0x28, 0x00},
  90. {0x29, 0x00},
  91. {0x2a, 0x00},
  92. {0x2b, 0x00},
  93. {0x2c, 0x00},
  94. {0x2d, 0xa8},
  95. {0x2e, 0x1a},
  96. {0x2f, 0x0c},
  97. {0x30, 0x26},
  98. {0x31, 0x5b},
  99. {0x32, 0x00},
  100. {0x33, 0x00},
  101. {0x34, 0x00},
  102. {0x35, 0x00},
  103. {0x36, 0xaa},
  104. {0x37, 0xaa},
  105. {0x38, 0xff},
  106. {0x39, 0xff},
  107. {0x3a, 0x00},
  108. {0x3b, 0x00},
  109. {0x3c, 0x00},
  110. {0x3d, 0x0d},
  111. {0x3e, 0x51},
  112. {0x3f, 0x04},
  113. {0x40, 0x00},
  114. {0x41, 0x08},
  115. {0x42, 0x00},
  116. {0x43, 0x08},
  117. {0x44, 0x06},
  118. {0x45, 0x14},
  119. {0x46, 0x05},
  120. {0x47, 0x08},
  121. {0x48, 0x00},
  122. {0x49, 0x00},
  123. {0x4a, 0x00},
  124. {0x4b, 0x00},
  125. {0x4c, 0x09},
  126. {0x4d, 0x80},
  127. {0x4e, 0x00},
  128. {0x4f, 0xc5},
  129. {0x50, 0x14},
  130. {0x51, 0x19},
  131. {0x52, 0x00},
  132. {0x53, 0x00},
  133. {0x54, 0x00},
  134. {0x55, 0x00},
  135. {0x56, 0x00},
  136. {0x57, 0x00},
  137. {0x58, 0x00},
  138. {0x59, 0xb0},
  139. {0x5a, 0x00},
  140. {0x5b, 0x00},
  141. {0x5c, 0x00},
  142. {0x5d, 0x00},
  143. {0x5e, 0x00},
  144. {0x5f, 0x00},
  145. {0x60, 0x44},
  146. {0x61, 0x04},
  147. {0x62, 0x00},
  148. {0x63, 0x00},
  149. {0x64, 0x00},
  150. {0x65, 0x00},
  151. {0x66, 0x04},
  152. {0x67, 0xb7},
  153. {0x68, 0x00},
  154. {0x69, 0x00},
  155. {0x6a, 0x00},
  156. {0x6b, 0x00},
  157. {0x6c, 0x00},
  158. {0x6d, 0x03},
  159. {0x6e, 0x01},
  160. {0x6f, 0x00},
  161. {0x70, 0x00},
  162. {0x71, 0x00},
  163. {0x72, 0x00},
  164. {0x73, 0x00},
  165. {0x74, 0x00},
  166. {0x75, 0x00},
  167. {0x76, 0x00},
  168. {0x77, 0x00},
  169. {0x78, 0x00},
  170. {0x79, 0x00},
  171. {0x7a, 0x00},
  172. {0x7b, 0x00},
  173. {0x7c, 0x00},
  174. {0x7d, 0x00},
  175. {0x7e, 0x00},
  176. {0x7f, 0x00},
  177. {0x80, 0x0b},
  178. {0x81, 0x00},
  179. {0x82, 0x3c},
  180. {0x83, 0x00},
  181. {0x84, 0x00},
  182. {0x85, 0x00},
  183. {0x86, 0x00},
  184. {0x87, 0x00},
  185. {0x88, 0x08},
  186. {0x89, 0x00},
  187. {0x8a, 0x08},
  188. {0x8b, 0xa6},
  189. {0x8c, 0x84},
  190. {0x8d, 0x47},
  191. {0x8e, 0xbb},
  192. {0x8f, 0x02},
  193. {0x90, 0x21},
  194. {0x91, 0x0c},
  195. {0x92, 0x04},
  196. {0x93, 0x22},
  197. {0x94, 0x00},
  198. {0x95, 0x00},
  199. {0x96, 0x00},
  200. {0x97, 0xeb},
  201. {0x98, 0x00},
  202. {0x99, 0x00},
  203. {0x9a, 0x00},
  204. {0x9b, 0x00},
  205. {0x9c, 0x00},
  206. {0x9d, 0x00},
  207. {0x9e, 0x00},
  208. {0x9f, 0x00},
  209. {0xa0, 0x00},
  210. {0xa1, 0x00},
  211. {0xa2, 0x00},
  212. {0xa3, 0x00},
  213. {0xa4, 0x00},
  214. {0xa5, 0x00},
  215. {0xa6, 0x10},
  216. {0xa7, 0x04},
  217. {0xa8, 0x10},
  218. {0xa9, 0x00},
  219. {0xaa, 0x8f},
  220. {0xab, 0x00},
  221. {0xac, 0x00},
  222. {0xad, 0x00},
  223. {0xae, 0x00},
  224. {0xaf, 0x80},
  225. {0xb0, 0x38},
  226. {0xb1, 0x00},
  227. {0xb2, 0x00},
  228. {0xb3, 0x00},
  229. {0xb4, 0xee},
  230. {0xb5, 0xff},
  231. {0xb6, 0x10},
  232. {0xb7, 0x00},
  233. {0xb8, 0x00},
  234. {0xb9, 0x00},
  235. {0xba, 0x00},
  236. {0xbb, 0x03},
  237. {0xbc, 0x00},
  238. {0xbd, 0x00},
  239. {0xbe, 0x00},
  240. {0xbf, 0x00},
  241. {0xc0, 0x10},
  242. {0xc1, 0x10},
  243. {0xc2, 0x18},
  244. {0xc3, 0x20},
  245. {0xc4, 0x10},
  246. {0xc5, 0x00},
  247. {0xc6, 0x22},
  248. {0xc7, 0x14},
  249. {0xc8, 0x0f},
  250. {0xc9, 0x08},
  251. {0xca, 0xa4},
  252. {0xcb, 0xa7},
  253. {0xcc, 0x3c},
  254. {0xcd, 0x10},
  255. {0xce, 0x20},
  256. {0xcf, 0x00},
  257. {0xd0, 0x00},
  258. {0xd1, 0x10},
  259. {0xd2, 0x00},
  260. {0xd3, 0x00},
  261. {0xd4, 0x10},
  262. {0xd5, 0x33},
  263. {0xd6, 0x70},
  264. {0xd7, 0x01},
  265. {0xd8, 0x00},
  266. {0xd9, 0x00},
  267. {0xda, 0x00},
  268. {0xdb, 0x00},
  269. {0xdc, 0x00},
  270. {0xdd, 0x00},
  271. {0xde, 0x00},
  272. {0xdf, 0x00},
  273. {0xe0, 0x00},
  274. {0xe1, 0x00},
  275. {0xe2, 0xcc},
  276. {0xe3, 0x04},
  277. {0xe4, 0x08},
  278. {0xe5, 0x10},
  279. {0xe6, 0x00},
  280. {0xe7, 0x0e},
  281. {0xe8, 0x88},
  282. {0xe9, 0xd4},
  283. {0xea, 0x05},
  284. {0xeb, 0xf0},
  285. {0xec, 0x79},
  286. {0xed, 0x0f},
  287. {0xee, 0x04},
  288. {0xef, 0x04},
  289. {0xf0, 0x00},
  290. {0xf1, 0x00},
  291. {0xf2, 0x00},
  292. {0xf3, 0x00},
  293. {0xf4, 0x00},
  294. {0xf5, 0x00},
  295. {0xf6, 0x00},
  296. {0xf7, 0x00},
  297. {0xf8, 0x00},
  298. {0xf9, 0x00},
  299. {0xF0, 0x00},
  300. {0xF1, 0xF8},
  301. {0xF0, 0x80},
  302. {0xF0, 0x00},
  303. {0xF1, 0xF4},
  304. {0xF0, 0x81},
  305. {0xF0, 0x01},
  306. {0xF1, 0xF0},
  307. {0xF0, 0x82},
  308. {0xF0, 0x02},
  309. {0xF1, 0xEC},
  310. {0xF0, 0x83},
  311. {0xF0, 0x03},
  312. {0xF1, 0xE8},
  313. {0xF0, 0x84},
  314. {0xF0, 0x04},
  315. {0xF1, 0xE4},
  316. {0xF0, 0x85},
  317. {0xF0, 0x05},
  318. {0xF1, 0xE0},
  319. {0xF0, 0x86},
  320. {0xF0, 0x06},
  321. {0xF1, 0xDC},
  322. {0xF0, 0x87},
  323. {0xF0, 0x07},
  324. {0xF1, 0xD8},
  325. {0xF0, 0x88},
  326. {0xF0, 0x08},
  327. {0xF1, 0xD4},
  328. {0xF0, 0x89},
  329. {0xF0, 0x09},
  330. {0xF1, 0xD0},
  331. {0xF0, 0x8A},
  332. {0xF0, 0x0A},
  333. {0xF1, 0xCC},
  334. {0xF0, 0x8B},
  335. {0xF0, 0x0B},
  336. {0xF1, 0xC8},
  337. {0xF0, 0x8C},
  338. {0xF0, 0x0C},
  339. {0xF1, 0xC4},
  340. {0xF0, 0x8D},
  341. {0xF0, 0x0D},
  342. {0xF1, 0xC0},
  343. {0xF0, 0x8E},
  344. {0xF0, 0x0E},
  345. {0xF1, 0xBC},
  346. {0xF0, 0x8F},
  347. {0xF0, 0x0F},
  348. {0xF1, 0xB8},
  349. {0xF0, 0x90},
  350. {0xF0, 0x10},
  351. {0xF1, 0xB4},
  352. {0xF0, 0x91},
  353. {0xF0, 0x11},
  354. {0xF1, 0xB0},
  355. {0xF0, 0x92},
  356. {0xF0, 0x12},
  357. {0xF1, 0xAC},
  358. {0xF0, 0x93},
  359. {0xF0, 0x13},
  360. {0xF1, 0xA8},
  361. {0xF0, 0x94},
  362. {0xF0, 0x14},
  363. {0xF1, 0xA4},
  364. {0xF0, 0x95},
  365. {0xF0, 0x15},
  366. {0xF1, 0xA0},
  367. {0xF0, 0x96},
  368. {0xF0, 0x16},
  369. {0xF1, 0x9C},
  370. {0xF0, 0x97},
  371. {0xF0, 0x17},
  372. {0xF1, 0x98},
  373. {0xF0, 0x98},
  374. {0xF0, 0x18},
  375. {0xF1, 0x94},
  376. {0xF0, 0x99},
  377. {0xF0, 0x19},
  378. {0xF1, 0x90},
  379. {0xF0, 0x9A},
  380. {0xF0, 0x1A},
  381. {0xF1, 0x8C},
  382. {0xF0, 0x9B},
  383. {0xF0, 0x1B},
  384. {0xF1, 0x88},
  385. {0xF0, 0x9C},
  386. {0xF0, 0x1C},
  387. {0xF1, 0x84},
  388. {0xF0, 0x9D},
  389. {0xF0, 0x1D},
  390. {0xF1, 0x80},
  391. {0xF0, 0x9E},
  392. {0xF0, 0x1E},
  393. {0xF1, 0x7C},
  394. {0xF0, 0x9F},
  395. {0xF0, 0x1F},
  396. {0xF1, 0x78},
  397. {0xF0, 0xA0},
  398. {0xF0, 0x20},
  399. {0xF1, 0x74},
  400. {0xF0, 0xA1},
  401. {0xF0, 0x21},
  402. {0xF1, 0x70},
  403. {0xF0, 0xA2},
  404. {0xF0, 0x22},
  405. {0xF1, 0x6C},
  406. {0xF0, 0xA3},
  407. {0xF0, 0x23},
  408. {0xF1, 0x68},
  409. {0xF0, 0xA4},
  410. {0xF0, 0x24},
  411. {0xF1, 0x64},
  412. {0xF0, 0xA5},
  413. {0xF0, 0x25},
  414. {0xF1, 0x60},
  415. {0xF0, 0xA6},
  416. {0xF0, 0x26},
  417. {0xF1, 0x5C},
  418. {0xF0, 0xA7},
  419. {0xF0, 0x27},
  420. {0xF1, 0x58},
  421. {0xF0, 0xA8},
  422. {0xF0, 0x28},
  423. {0xF1, 0x54},
  424. {0xF0, 0xA9},
  425. {0xF0, 0x29},
  426. {0xF1, 0x50},
  427. {0xF0, 0xAA},
  428. {0xF0, 0x2A},
  429. {0xF1, 0x4C},
  430. {0xF0, 0xAB},
  431. {0xF0, 0x2B},
  432. {0xF1, 0x48},
  433. {0xF0, 0xAC},
  434. {0xF0, 0x2C},
  435. {0xF1, 0x44},
  436. {0xF0, 0xAD},
  437. {0xF0, 0x2D},
  438. {0xF1, 0x40},
  439. {0xF0, 0xAE},
  440. {0xF0, 0x2E},
  441. {0xF1, 0x3C},
  442. {0xF0, 0xAF},
  443. {0xF0, 0x2F},
  444. {0xF1, 0x38},
  445. {0xF0, 0xB0},
  446. {0xF0, 0x30},
  447. {0xF1, 0x34},
  448. {0xF0, 0xB1},
  449. {0xF0, 0x31},
  450. {0xF1, 0x30},
  451. {0xF0, 0xB2},
  452. {0xF0, 0x32},
  453. {0xF1, 0x2C},
  454. {0xF0, 0xB3},
  455. {0xF0, 0x33},
  456. {0xF1, 0x28},
  457. {0xF0, 0xB4},
  458. {0xF0, 0x34},
  459. {0xF1, 0x24},
  460. {0xF0, 0xB5},
  461. {0xF0, 0x35},
  462. {0xF1, 0x20},
  463. {0xF0, 0xB6},
  464. {0xF0, 0x36},
  465. {0xF1, 0x1C},
  466. {0xF0, 0xB7},
  467. {0xF0, 0x37},
  468. {0xF1, 0x18},
  469. {0xF0, 0xB8},
  470. {0xF0, 0x38},
  471. {0xF1, 0x14},
  472. {0xF0, 0xB9},
  473. {0xF0, 0x39},
  474. {0xF1, 0x10},
  475. {0xF0, 0xBA},
  476. {0xF0, 0x3A},
  477. {0xF1, 0x0C},
  478. {0xF0, 0xBB},
  479. {0xF0, 0x3B},
  480. {0xF1, 0x08},
  481. {0xF0, 0x00},
  482. {0xF0, 0x3C},
  483. {0xF1, 0x04},
  484. {0xF0, 0xBD},
  485. {0xF0, 0x3D},
  486. {0xF1, 0x00},
  487. {0xF0, 0xBE},
  488. {0xF0, 0x3E},
  489. {0xF1, 0x00},
  490. {0xF0, 0xBF},
  491. {0xF0, 0x3F},
  492. {0xF1, 0x00},
  493. {0xF0, 0xC0},
  494. {0xF0, 0x00},
  495. };
  496. #define CB_VT3253B0_INIT_FOR_RFMD 256
  497. static const unsigned char byVT3253B0_RFMD[CB_VT3253B0_INIT_FOR_RFMD][2] = {
  498. {0x00, 0x31},
  499. {0x01, 0x00},
  500. {0x02, 0x00},
  501. {0x03, 0x00},
  502. {0x04, 0x00},
  503. {0x05, 0x81},
  504. {0x06, 0x00},
  505. {0x07, 0x00},
  506. {0x08, 0x38},
  507. {0x09, 0x45},
  508. {0x0a, 0x2a},
  509. {0x0b, 0x76},
  510. {0x0c, 0x00},
  511. {0x0d, 0x00},
  512. {0x0e, 0x80},
  513. {0x0f, 0x00},
  514. {0x10, 0x00},
  515. {0x11, 0x00},
  516. {0x12, 0x00},
  517. {0x13, 0x00},
  518. {0x14, 0x00},
  519. {0x15, 0x00},
  520. {0x16, 0x00},
  521. {0x17, 0x00},
  522. {0x18, 0x00},
  523. {0x19, 0x00},
  524. {0x1a, 0x00},
  525. {0x1b, 0x8e},
  526. {0x1c, 0x06},
  527. {0x1d, 0x00},
  528. {0x1e, 0x00},
  529. {0x1f, 0x00},
  530. {0x20, 0x00},
  531. {0x21, 0x00},
  532. {0x22, 0x00},
  533. {0x23, 0x00},
  534. {0x24, 0x00},
  535. {0x25, 0x4a},
  536. {0x26, 0x00},
  537. {0x27, 0x00},
  538. {0x28, 0x00},
  539. {0x29, 0x00},
  540. {0x2a, 0x00},
  541. {0x2b, 0x00},
  542. {0x2c, 0x00},
  543. {0x2d, 0x34},
  544. {0x2e, 0x18},
  545. {0x2f, 0x0c},
  546. {0x30, 0x26},
  547. {0x31, 0x5b},
  548. {0x32, 0x00},
  549. {0x33, 0x00},
  550. {0x34, 0x00},
  551. {0x35, 0x00},
  552. {0x36, 0xaa},
  553. {0x37, 0xaa},
  554. {0x38, 0xff},
  555. {0x39, 0xff},
  556. {0x3a, 0xf8},
  557. {0x3b, 0x00},
  558. {0x3c, 0x00},
  559. {0x3d, 0x09},
  560. {0x3e, 0x0d},
  561. {0x3f, 0x04},
  562. {0x40, 0x00},
  563. {0x41, 0x08},
  564. {0x42, 0x00},
  565. {0x43, 0x08},
  566. {0x44, 0x08},
  567. {0x45, 0x14},
  568. {0x46, 0x05},
  569. {0x47, 0x08},
  570. {0x48, 0x00},
  571. {0x49, 0x00},
  572. {0x4a, 0x00},
  573. {0x4b, 0x00},
  574. {0x4c, 0x09},
  575. {0x4d, 0x80},
  576. {0x4e, 0x00},
  577. {0x4f, 0xc5},
  578. {0x50, 0x14},
  579. {0x51, 0x19},
  580. {0x52, 0x00},
  581. {0x53, 0x00},
  582. {0x54, 0x00},
  583. {0x55, 0x00},
  584. {0x56, 0x00},
  585. {0x57, 0x00},
  586. {0x58, 0x00},
  587. {0x59, 0xb0},
  588. {0x5a, 0x00},
  589. {0x5b, 0x00},
  590. {0x5c, 0x00},
  591. {0x5d, 0x00},
  592. {0x5e, 0x00},
  593. {0x5f, 0x00},
  594. {0x60, 0x39},
  595. {0x61, 0x83},
  596. {0x62, 0x00},
  597. {0x63, 0x00},
  598. {0x64, 0x00},
  599. {0x65, 0x00},
  600. {0x66, 0xc0},
  601. {0x67, 0x49},
  602. {0x68, 0x00},
  603. {0x69, 0x00},
  604. {0x6a, 0x00},
  605. {0x6b, 0x00},
  606. {0x6c, 0x00},
  607. {0x6d, 0x03},
  608. {0x6e, 0x01},
  609. {0x6f, 0x00},
  610. {0x70, 0x00},
  611. {0x71, 0x00},
  612. {0x72, 0x00},
  613. {0x73, 0x00},
  614. {0x74, 0x00},
  615. {0x75, 0x00},
  616. {0x76, 0x00},
  617. {0x77, 0x00},
  618. {0x78, 0x00},
  619. {0x79, 0x00},
  620. {0x7a, 0x00},
  621. {0x7b, 0x00},
  622. {0x7c, 0x00},
  623. {0x7d, 0x00},
  624. {0x7e, 0x00},
  625. {0x7f, 0x00},
  626. {0x80, 0x89},
  627. {0x81, 0x00},
  628. {0x82, 0x0e},
  629. {0x83, 0x00},
  630. {0x84, 0x00},
  631. {0x85, 0x00},
  632. {0x86, 0x00},
  633. {0x87, 0x00},
  634. {0x88, 0x08},
  635. {0x89, 0x00},
  636. {0x8a, 0x0e},
  637. {0x8b, 0xa7},
  638. {0x8c, 0x88},
  639. {0x8d, 0x47},
  640. {0x8e, 0xaa},
  641. {0x8f, 0x02},
  642. {0x90, 0x23},
  643. {0x91, 0x0c},
  644. {0x92, 0x06},
  645. {0x93, 0x08},
  646. {0x94, 0x00},
  647. {0x95, 0x00},
  648. {0x96, 0x00},
  649. {0x97, 0xeb},
  650. {0x98, 0x00},
  651. {0x99, 0x00},
  652. {0x9a, 0x00},
  653. {0x9b, 0x00},
  654. {0x9c, 0x00},
  655. {0x9d, 0x00},
  656. {0x9e, 0x00},
  657. {0x9f, 0x00},
  658. {0xa0, 0x00},
  659. {0xa1, 0x00},
  660. {0xa2, 0x00},
  661. {0xa3, 0xcd},
  662. {0xa4, 0x07},
  663. {0xa5, 0x33},
  664. {0xa6, 0x18},
  665. {0xa7, 0x00},
  666. {0xa8, 0x18},
  667. {0xa9, 0x00},
  668. {0xaa, 0x28},
  669. {0xab, 0x00},
  670. {0xac, 0x00},
  671. {0xad, 0x00},
  672. {0xae, 0x00},
  673. {0xaf, 0x18},
  674. {0xb0, 0x38},
  675. {0xb1, 0x30},
  676. {0xb2, 0x00},
  677. {0xb3, 0x00},
  678. {0xb4, 0x00},
  679. {0xb5, 0x00},
  680. {0xb6, 0x84},
  681. {0xb7, 0xfd},
  682. {0xb8, 0x00},
  683. {0xb9, 0x00},
  684. {0xba, 0x00},
  685. {0xbb, 0x03},
  686. {0xbc, 0x00},
  687. {0xbd, 0x00},
  688. {0xbe, 0x00},
  689. {0xbf, 0x00},
  690. {0xc0, 0x10},
  691. {0xc1, 0x20},
  692. {0xc2, 0x18},
  693. {0xc3, 0x20},
  694. {0xc4, 0x10},
  695. {0xc5, 0x2c},
  696. {0xc6, 0x1e},
  697. {0xc7, 0x10},
  698. {0xc8, 0x12},
  699. {0xc9, 0x01},
  700. {0xca, 0x6f},
  701. {0xcb, 0xa7},
  702. {0xcc, 0x3c},
  703. {0xcd, 0x10},
  704. {0xce, 0x00},
  705. {0xcf, 0x22},
  706. {0xd0, 0x00},
  707. {0xd1, 0x10},
  708. {0xd2, 0x00},
  709. {0xd3, 0x00},
  710. {0xd4, 0x10},
  711. {0xd5, 0x33},
  712. {0xd6, 0x80},
  713. {0xd7, 0x21},
  714. {0xd8, 0x00},
  715. {0xd9, 0x00},
  716. {0xda, 0x00},
  717. {0xdb, 0x00},
  718. {0xdc, 0x00},
  719. {0xdd, 0x00},
  720. {0xde, 0x00},
  721. {0xdf, 0x00},
  722. {0xe0, 0x00},
  723. {0xe1, 0xB3},
  724. {0xe2, 0x00},
  725. {0xe3, 0x00},
  726. {0xe4, 0x00},
  727. {0xe5, 0x10},
  728. {0xe6, 0x00},
  729. {0xe7, 0x18},
  730. {0xe8, 0x08},
  731. {0xe9, 0xd4},
  732. {0xea, 0x00},
  733. {0xeb, 0xff},
  734. {0xec, 0x79},
  735. {0xed, 0x10},
  736. {0xee, 0x30},
  737. {0xef, 0x02},
  738. {0xf0, 0x00},
  739. {0xf1, 0x09},
  740. {0xf2, 0x00},
  741. {0xf3, 0x00},
  742. {0xf4, 0x00},
  743. {0xf5, 0x00},
  744. {0xf6, 0x00},
  745. {0xf7, 0x00},
  746. {0xf8, 0x00},
  747. {0xf9, 0x00},
  748. {0xfa, 0x00},
  749. {0xfb, 0x00},
  750. {0xfc, 0x00},
  751. {0xfd, 0x00},
  752. {0xfe, 0x00},
  753. {0xff, 0x00},
  754. };
  755. #define CB_VT3253B0_AGC_FOR_RFMD2959 195
  756. /* For RFMD2959 */
  757. static
  758. unsigned char byVT3253B0_AGC4_RFMD2959[CB_VT3253B0_AGC_FOR_RFMD2959][2] = {
  759. {0xF0, 0x00},
  760. {0xF1, 0x3E},
  761. {0xF0, 0x80},
  762. {0xF0, 0x00},
  763. {0xF1, 0x3E},
  764. {0xF0, 0x81},
  765. {0xF0, 0x01},
  766. {0xF1, 0x3E},
  767. {0xF0, 0x82},
  768. {0xF0, 0x02},
  769. {0xF1, 0x3E},
  770. {0xF0, 0x83},
  771. {0xF0, 0x03},
  772. {0xF1, 0x3B},
  773. {0xF0, 0x84},
  774. {0xF0, 0x04},
  775. {0xF1, 0x39},
  776. {0xF0, 0x85},
  777. {0xF0, 0x05},
  778. {0xF1, 0x38},
  779. {0xF0, 0x86},
  780. {0xF0, 0x06},
  781. {0xF1, 0x37},
  782. {0xF0, 0x87},
  783. {0xF0, 0x07},
  784. {0xF1, 0x36},
  785. {0xF0, 0x88},
  786. {0xF0, 0x08},
  787. {0xF1, 0x35},
  788. {0xF0, 0x89},
  789. {0xF0, 0x09},
  790. {0xF1, 0x35},
  791. {0xF0, 0x8A},
  792. {0xF0, 0x0A},
  793. {0xF1, 0x34},
  794. {0xF0, 0x8B},
  795. {0xF0, 0x0B},
  796. {0xF1, 0x34},
  797. {0xF0, 0x8C},
  798. {0xF0, 0x0C},
  799. {0xF1, 0x33},
  800. {0xF0, 0x8D},
  801. {0xF0, 0x0D},
  802. {0xF1, 0x32},
  803. {0xF0, 0x8E},
  804. {0xF0, 0x0E},
  805. {0xF1, 0x31},
  806. {0xF0, 0x8F},
  807. {0xF0, 0x0F},
  808. {0xF1, 0x30},
  809. {0xF0, 0x90},
  810. {0xF0, 0x10},
  811. {0xF1, 0x2F},
  812. {0xF0, 0x91},
  813. {0xF0, 0x11},
  814. {0xF1, 0x2F},
  815. {0xF0, 0x92},
  816. {0xF0, 0x12},
  817. {0xF1, 0x2E},
  818. {0xF0, 0x93},
  819. {0xF0, 0x13},
  820. {0xF1, 0x2D},
  821. {0xF0, 0x94},
  822. {0xF0, 0x14},
  823. {0xF1, 0x2C},
  824. {0xF0, 0x95},
  825. {0xF0, 0x15},
  826. {0xF1, 0x2B},
  827. {0xF0, 0x96},
  828. {0xF0, 0x16},
  829. {0xF1, 0x2B},
  830. {0xF0, 0x97},
  831. {0xF0, 0x17},
  832. {0xF1, 0x2A},
  833. {0xF0, 0x98},
  834. {0xF0, 0x18},
  835. {0xF1, 0x29},
  836. {0xF0, 0x99},
  837. {0xF0, 0x19},
  838. {0xF1, 0x28},
  839. {0xF0, 0x9A},
  840. {0xF0, 0x1A},
  841. {0xF1, 0x27},
  842. {0xF0, 0x9B},
  843. {0xF0, 0x1B},
  844. {0xF1, 0x26},
  845. {0xF0, 0x9C},
  846. {0xF0, 0x1C},
  847. {0xF1, 0x25},
  848. {0xF0, 0x9D},
  849. {0xF0, 0x1D},
  850. {0xF1, 0x24},
  851. {0xF0, 0x9E},
  852. {0xF0, 0x1E},
  853. {0xF1, 0x24},
  854. {0xF0, 0x9F},
  855. {0xF0, 0x1F},
  856. {0xF1, 0x23},
  857. {0xF0, 0xA0},
  858. {0xF0, 0x20},
  859. {0xF1, 0x22},
  860. {0xF0, 0xA1},
  861. {0xF0, 0x21},
  862. {0xF1, 0x21},
  863. {0xF0, 0xA2},
  864. {0xF0, 0x22},
  865. {0xF1, 0x20},
  866. {0xF0, 0xA3},
  867. {0xF0, 0x23},
  868. {0xF1, 0x20},
  869. {0xF0, 0xA4},
  870. {0xF0, 0x24},
  871. {0xF1, 0x1F},
  872. {0xF0, 0xA5},
  873. {0xF0, 0x25},
  874. {0xF1, 0x1E},
  875. {0xF0, 0xA6},
  876. {0xF0, 0x26},
  877. {0xF1, 0x1D},
  878. {0xF0, 0xA7},
  879. {0xF0, 0x27},
  880. {0xF1, 0x1C},
  881. {0xF0, 0xA8},
  882. {0xF0, 0x28},
  883. {0xF1, 0x1B},
  884. {0xF0, 0xA9},
  885. {0xF0, 0x29},
  886. {0xF1, 0x1B},
  887. {0xF0, 0xAA},
  888. {0xF0, 0x2A},
  889. {0xF1, 0x1A},
  890. {0xF0, 0xAB},
  891. {0xF0, 0x2B},
  892. {0xF1, 0x1A},
  893. {0xF0, 0xAC},
  894. {0xF0, 0x2C},
  895. {0xF1, 0x19},
  896. {0xF0, 0xAD},
  897. {0xF0, 0x2D},
  898. {0xF1, 0x18},
  899. {0xF0, 0xAE},
  900. {0xF0, 0x2E},
  901. {0xF1, 0x17},
  902. {0xF0, 0xAF},
  903. {0xF0, 0x2F},
  904. {0xF1, 0x16},
  905. {0xF0, 0xB0},
  906. {0xF0, 0x30},
  907. {0xF1, 0x15},
  908. {0xF0, 0xB1},
  909. {0xF0, 0x31},
  910. {0xF1, 0x15},
  911. {0xF0, 0xB2},
  912. {0xF0, 0x32},
  913. {0xF1, 0x15},
  914. {0xF0, 0xB3},
  915. {0xF0, 0x33},
  916. {0xF1, 0x14},
  917. {0xF0, 0xB4},
  918. {0xF0, 0x34},
  919. {0xF1, 0x13},
  920. {0xF0, 0xB5},
  921. {0xF0, 0x35},
  922. {0xF1, 0x12},
  923. {0xF0, 0xB6},
  924. {0xF0, 0x36},
  925. {0xF1, 0x11},
  926. {0xF0, 0xB7},
  927. {0xF0, 0x37},
  928. {0xF1, 0x10},
  929. {0xF0, 0xB8},
  930. {0xF0, 0x38},
  931. {0xF1, 0x0F},
  932. {0xF0, 0xB9},
  933. {0xF0, 0x39},
  934. {0xF1, 0x0E},
  935. {0xF0, 0xBA},
  936. {0xF0, 0x3A},
  937. {0xF1, 0x0D},
  938. {0xF0, 0xBB},
  939. {0xF0, 0x3B},
  940. {0xF1, 0x0C},
  941. {0xF0, 0xBC},
  942. {0xF0, 0x3C},
  943. {0xF1, 0x0B},
  944. {0xF0, 0xBD},
  945. {0xF0, 0x3D},
  946. {0xF1, 0x0B},
  947. {0xF0, 0xBE},
  948. {0xF0, 0x3E},
  949. {0xF1, 0x0A},
  950. {0xF0, 0xBF},
  951. {0xF0, 0x3F},
  952. {0xF1, 0x09},
  953. {0xF0, 0x00},
  954. };
  955. #define CB_VT3253B0_INIT_FOR_AIROHA2230 256
  956. /* For AIROHA */
  957. static
  958. unsigned char byVT3253B0_AIROHA2230[CB_VT3253B0_INIT_FOR_AIROHA2230][2] = {
  959. {0x00, 0x31},
  960. {0x01, 0x00},
  961. {0x02, 0x00},
  962. {0x03, 0x00},
  963. {0x04, 0x00},
  964. {0x05, 0x80},
  965. {0x06, 0x00},
  966. {0x07, 0x00},
  967. {0x08, 0x70},
  968. {0x09, 0x41},
  969. {0x0a, 0x2A},
  970. {0x0b, 0x76},
  971. {0x0c, 0x00},
  972. {0x0d, 0x00},
  973. {0x0e, 0x80},
  974. {0x0f, 0x00},
  975. {0x10, 0x00},
  976. {0x11, 0x00},
  977. {0x12, 0x00},
  978. {0x13, 0x00},
  979. {0x14, 0x00},
  980. {0x15, 0x00},
  981. {0x16, 0x00},
  982. {0x17, 0x00},
  983. {0x18, 0x00},
  984. {0x19, 0x00},
  985. {0x1a, 0x00},
  986. {0x1b, 0x8f},
  987. {0x1c, 0x09},
  988. {0x1d, 0x00},
  989. {0x1e, 0x00},
  990. {0x1f, 0x00},
  991. {0x20, 0x00},
  992. {0x21, 0x00},
  993. {0x22, 0x00},
  994. {0x23, 0x00},
  995. {0x24, 0x00},
  996. {0x25, 0x4a},
  997. {0x26, 0x00},
  998. {0x27, 0x00},
  999. {0x28, 0x00},
  1000. {0x29, 0x00},
  1001. {0x2a, 0x00},
  1002. {0x2b, 0x00},
  1003. {0x2c, 0x00},
  1004. {0x2d, 0x4a},
  1005. {0x2e, 0x00},
  1006. {0x2f, 0x0a},
  1007. {0x30, 0x26},
  1008. {0x31, 0x5b},
  1009. {0x32, 0x00},
  1010. {0x33, 0x00},
  1011. {0x34, 0x00},
  1012. {0x35, 0x00},
  1013. {0x36, 0xaa},
  1014. {0x37, 0xaa},
  1015. {0x38, 0xff},
  1016. {0x39, 0xff},
  1017. {0x3a, 0x79},
  1018. {0x3b, 0x00},
  1019. {0x3c, 0x00},
  1020. {0x3d, 0x0b},
  1021. {0x3e, 0x48},
  1022. {0x3f, 0x04},
  1023. {0x40, 0x00},
  1024. {0x41, 0x08},
  1025. {0x42, 0x00},
  1026. {0x43, 0x08},
  1027. {0x44, 0x08},
  1028. {0x45, 0x14},
  1029. {0x46, 0x05},
  1030. {0x47, 0x09},
  1031. {0x48, 0x00},
  1032. {0x49, 0x00},
  1033. {0x4a, 0x00},
  1034. {0x4b, 0x00},
  1035. {0x4c, 0x09},
  1036. {0x4d, 0x73},
  1037. {0x4e, 0x00},
  1038. {0x4f, 0xc5},
  1039. {0x50, 0x15},
  1040. {0x51, 0x19},
  1041. {0x52, 0x00},
  1042. {0x53, 0x00},
  1043. {0x54, 0x00},
  1044. {0x55, 0x00},
  1045. {0x56, 0x00},
  1046. {0x57, 0x00},
  1047. {0x58, 0x00},
  1048. {0x59, 0xb0},
  1049. {0x5a, 0x00},
  1050. {0x5b, 0x00},
  1051. {0x5c, 0x00},
  1052. {0x5d, 0x00},
  1053. {0x5e, 0x00},
  1054. {0x5f, 0x00},
  1055. {0x60, 0xe4},
  1056. {0x61, 0x80},
  1057. {0x62, 0x00},
  1058. {0x63, 0x00},
  1059. {0x64, 0x00},
  1060. {0x65, 0x00},
  1061. {0x66, 0x98},
  1062. {0x67, 0x0a},
  1063. {0x68, 0x00},
  1064. {0x69, 0x00},
  1065. {0x6a, 0x00},
  1066. {0x6b, 0x00},
  1067. {0x6c, 0x00}, /* RobertYu:20050125, request by JJSue */
  1068. {0x6d, 0x03},
  1069. {0x6e, 0x01},
  1070. {0x6f, 0x00},
  1071. {0x70, 0x00},
  1072. {0x71, 0x00},
  1073. {0x72, 0x00},
  1074. {0x73, 0x00},
  1075. {0x74, 0x00},
  1076. {0x75, 0x00},
  1077. {0x76, 0x00},
  1078. {0x77, 0x00},
  1079. {0x78, 0x00},
  1080. {0x79, 0x00},
  1081. {0x7a, 0x00},
  1082. {0x7b, 0x00},
  1083. {0x7c, 0x00},
  1084. {0x7d, 0x00},
  1085. {0x7e, 0x00},
  1086. {0x7f, 0x00},
  1087. {0x80, 0x8c},
  1088. {0x81, 0x01},
  1089. {0x82, 0x09},
  1090. {0x83, 0x00},
  1091. {0x84, 0x00},
  1092. {0x85, 0x00},
  1093. {0x86, 0x00},
  1094. {0x87, 0x00},
  1095. {0x88, 0x08},
  1096. {0x89, 0x00},
  1097. {0x8a, 0x0f},
  1098. {0x8b, 0xb7},
  1099. {0x8c, 0x88},
  1100. {0x8d, 0x47},
  1101. {0x8e, 0xaa},
  1102. {0x8f, 0x02},
  1103. {0x90, 0x22},
  1104. {0x91, 0x00},
  1105. {0x92, 0x00},
  1106. {0x93, 0x00},
  1107. {0x94, 0x00},
  1108. {0x95, 0x00},
  1109. {0x96, 0x00},
  1110. {0x97, 0xeb},
  1111. {0x98, 0x00},
  1112. {0x99, 0x00},
  1113. {0x9a, 0x00},
  1114. {0x9b, 0x00},
  1115. {0x9c, 0x00},
  1116. {0x9d, 0x00},
  1117. {0x9e, 0x00},
  1118. {0x9f, 0x01},
  1119. {0xa0, 0x00},
  1120. {0xa1, 0x00},
  1121. {0xa2, 0x00},
  1122. {0xa3, 0x00},
  1123. {0xa4, 0x00},
  1124. {0xa5, 0x00},
  1125. {0xa6, 0x10},
  1126. {0xa7, 0x00},
  1127. {0xa8, 0x18},
  1128. {0xa9, 0x00},
  1129. {0xaa, 0x00},
  1130. {0xab, 0x00},
  1131. {0xac, 0x00},
  1132. {0xad, 0x00},
  1133. {0xae, 0x00},
  1134. {0xaf, 0x18},
  1135. {0xb0, 0x38},
  1136. {0xb1, 0x30},
  1137. {0xb2, 0x00},
  1138. {0xb3, 0x00},
  1139. {0xb4, 0xff},
  1140. {0xb5, 0x0f},
  1141. {0xb6, 0xe4},
  1142. {0xb7, 0xe2},
  1143. {0xb8, 0x00},
  1144. {0xb9, 0x00},
  1145. {0xba, 0x00},
  1146. {0xbb, 0x03},
  1147. {0xbc, 0x01},
  1148. {0xbd, 0x00},
  1149. {0xbe, 0x00},
  1150. {0xbf, 0x00},
  1151. {0xc0, 0x18},
  1152. {0xc1, 0x20},
  1153. {0xc2, 0x07},
  1154. {0xc3, 0x18},
  1155. {0xc4, 0xff},
  1156. {0xc5, 0x2c},
  1157. {0xc6, 0x0c},
  1158. {0xc7, 0x0a},
  1159. {0xc8, 0x0e},
  1160. {0xc9, 0x01},
  1161. {0xca, 0x68},
  1162. {0xcb, 0xa7},
  1163. {0xcc, 0x3c},
  1164. {0xcd, 0x10},
  1165. {0xce, 0x00},
  1166. {0xcf, 0x25},
  1167. {0xd0, 0x40},
  1168. {0xd1, 0x12},
  1169. {0xd2, 0x00},
  1170. {0xd3, 0x00},
  1171. {0xd4, 0x10},
  1172. {0xd5, 0x28},
  1173. {0xd6, 0x80},
  1174. {0xd7, 0x2A},
  1175. {0xd8, 0x00},
  1176. {0xd9, 0x00},
  1177. {0xda, 0x00},
  1178. {0xdb, 0x00},
  1179. {0xdc, 0x00},
  1180. {0xdd, 0x00},
  1181. {0xde, 0x00},
  1182. {0xdf, 0x00},
  1183. {0xe0, 0x00},
  1184. {0xe1, 0xB3},
  1185. {0xe2, 0x00},
  1186. {0xe3, 0x00},
  1187. {0xe4, 0x00},
  1188. {0xe5, 0x10},
  1189. {0xe6, 0x00},
  1190. {0xe7, 0x1C},
  1191. {0xe8, 0x00},
  1192. {0xe9, 0xf4},
  1193. {0xea, 0x00},
  1194. {0xeb, 0xff},
  1195. {0xec, 0x79},
  1196. {0xed, 0x20},
  1197. {0xee, 0x30},
  1198. {0xef, 0x01},
  1199. {0xf0, 0x00},
  1200. {0xf1, 0x3e},
  1201. {0xf2, 0x00},
  1202. {0xf3, 0x00},
  1203. {0xf4, 0x00},
  1204. {0xf5, 0x00},
  1205. {0xf6, 0x00},
  1206. {0xf7, 0x00},
  1207. {0xf8, 0x00},
  1208. {0xf9, 0x00},
  1209. {0xfa, 0x00},
  1210. {0xfb, 0x00},
  1211. {0xfc, 0x00},
  1212. {0xfd, 0x00},
  1213. {0xfe, 0x00},
  1214. {0xff, 0x00},
  1215. };
  1216. #define CB_VT3253B0_INIT_FOR_UW2451 256
  1217. /* For UW2451 */
  1218. static unsigned char byVT3253B0_UW2451[CB_VT3253B0_INIT_FOR_UW2451][2] = {
  1219. {0x00, 0x31},
  1220. {0x01, 0x00},
  1221. {0x02, 0x00},
  1222. {0x03, 0x00},
  1223. {0x04, 0x00},
  1224. {0x05, 0x81},
  1225. {0x06, 0x00},
  1226. {0x07, 0x00},
  1227. {0x08, 0x38},
  1228. {0x09, 0x45},
  1229. {0x0a, 0x28},
  1230. {0x0b, 0x76},
  1231. {0x0c, 0x00},
  1232. {0x0d, 0x00},
  1233. {0x0e, 0x80},
  1234. {0x0f, 0x00},
  1235. {0x10, 0x00},
  1236. {0x11, 0x00},
  1237. {0x12, 0x00},
  1238. {0x13, 0x00},
  1239. {0x14, 0x00},
  1240. {0x15, 0x00},
  1241. {0x16, 0x00},
  1242. {0x17, 0x00},
  1243. {0x18, 0x00},
  1244. {0x19, 0x00},
  1245. {0x1a, 0x00},
  1246. {0x1b, 0x8f},
  1247. {0x1c, 0x0f},
  1248. {0x1d, 0x00},
  1249. {0x1e, 0x00},
  1250. {0x1f, 0x00},
  1251. {0x20, 0x00},
  1252. {0x21, 0x00},
  1253. {0x22, 0x00},
  1254. {0x23, 0x00},
  1255. {0x24, 0x00},
  1256. {0x25, 0x4a},
  1257. {0x26, 0x00},
  1258. {0x27, 0x00},
  1259. {0x28, 0x00},
  1260. {0x29, 0x00},
  1261. {0x2a, 0x00},
  1262. {0x2b, 0x00},
  1263. {0x2c, 0x00},
  1264. {0x2d, 0x18},
  1265. {0x2e, 0x00},
  1266. {0x2f, 0x0a},
  1267. {0x30, 0x26},
  1268. {0x31, 0x5b},
  1269. {0x32, 0x00},
  1270. {0x33, 0x00},
  1271. {0x34, 0x00},
  1272. {0x35, 0x00},
  1273. {0x36, 0xaa},
  1274. {0x37, 0xaa},
  1275. {0x38, 0xff},
  1276. {0x39, 0xff},
  1277. {0x3a, 0x00},
  1278. {0x3b, 0x00},
  1279. {0x3c, 0x00},
  1280. {0x3d, 0x03},
  1281. {0x3e, 0x1d},
  1282. {0x3f, 0x04},
  1283. {0x40, 0x00},
  1284. {0x41, 0x08},
  1285. {0x42, 0x00},
  1286. {0x43, 0x08},
  1287. {0x44, 0x08},
  1288. {0x45, 0x14},
  1289. {0x46, 0x05},
  1290. {0x47, 0x09},
  1291. {0x48, 0x00},
  1292. {0x49, 0x00},
  1293. {0x4a, 0x00},
  1294. {0x4b, 0x00},
  1295. {0x4c, 0x09},
  1296. {0x4d, 0x90},
  1297. {0x4e, 0x00},
  1298. {0x4f, 0xc5},
  1299. {0x50, 0x15},
  1300. {0x51, 0x19},
  1301. {0x52, 0x00},
  1302. {0x53, 0x00},
  1303. {0x54, 0x00},
  1304. {0x55, 0x00},
  1305. {0x56, 0x00},
  1306. {0x57, 0x00},
  1307. {0x58, 0x00},
  1308. {0x59, 0xb0},
  1309. {0x5a, 0x00},
  1310. {0x5b, 0x00},
  1311. {0x5c, 0x00},
  1312. {0x5d, 0x00},
  1313. {0x5e, 0x00},
  1314. {0x5f, 0x00},
  1315. {0x60, 0xb3},
  1316. {0x61, 0x81},
  1317. {0x62, 0x00},
  1318. {0x63, 0x00},
  1319. {0x64, 0x00},
  1320. {0x65, 0x00},
  1321. {0x66, 0x57},
  1322. {0x67, 0x6c},
  1323. {0x68, 0x00},
  1324. {0x69, 0x00},
  1325. {0x6a, 0x00},
  1326. {0x6b, 0x00},
  1327. {0x6c, 0x00}, /* RobertYu:20050125, request by JJSue */
  1328. {0x6d, 0x03},
  1329. {0x6e, 0x01},
  1330. {0x6f, 0x00},
  1331. {0x70, 0x00},
  1332. {0x71, 0x00},
  1333. {0x72, 0x00},
  1334. {0x73, 0x00},
  1335. {0x74, 0x00},
  1336. {0x75, 0x00},
  1337. {0x76, 0x00},
  1338. {0x77, 0x00},
  1339. {0x78, 0x00},
  1340. {0x79, 0x00},
  1341. {0x7a, 0x00},
  1342. {0x7b, 0x00},
  1343. {0x7c, 0x00},
  1344. {0x7d, 0x00},
  1345. {0x7e, 0x00},
  1346. {0x7f, 0x00},
  1347. {0x80, 0x8c},
  1348. {0x81, 0x00},
  1349. {0x82, 0x0e},
  1350. {0x83, 0x00},
  1351. {0x84, 0x00},
  1352. {0x85, 0x00},
  1353. {0x86, 0x00},
  1354. {0x87, 0x00},
  1355. {0x88, 0x08},
  1356. {0x89, 0x00},
  1357. {0x8a, 0x0e},
  1358. {0x8b, 0xa7},
  1359. {0x8c, 0x88},
  1360. {0x8d, 0x47},
  1361. {0x8e, 0xaa},
  1362. {0x8f, 0x02},
  1363. {0x90, 0x00},
  1364. {0x91, 0x00},
  1365. {0x92, 0x00},
  1366. {0x93, 0x00},
  1367. {0x94, 0x00},
  1368. {0x95, 0x00},
  1369. {0x96, 0x00},
  1370. {0x97, 0xe3},
  1371. {0x98, 0x00},
  1372. {0x99, 0x00},
  1373. {0x9a, 0x00},
  1374. {0x9b, 0x00},
  1375. {0x9c, 0x00},
  1376. {0x9d, 0x00},
  1377. {0x9e, 0x00},
  1378. {0x9f, 0x00},
  1379. {0xa0, 0x00},
  1380. {0xa1, 0x00},
  1381. {0xa2, 0x00},
  1382. {0xa3, 0x00},
  1383. {0xa4, 0x00},
  1384. {0xa5, 0x00},
  1385. {0xa6, 0x10},
  1386. {0xa7, 0x00},
  1387. {0xa8, 0x18},
  1388. {0xa9, 0x00},
  1389. {0xaa, 0x00},
  1390. {0xab, 0x00},
  1391. {0xac, 0x00},
  1392. {0xad, 0x00},
  1393. {0xae, 0x00},
  1394. {0xaf, 0x18},
  1395. {0xb0, 0x18},
  1396. {0xb1, 0x30},
  1397. {0xb2, 0x00},
  1398. {0xb3, 0x00},
  1399. {0xb4, 0x00},
  1400. {0xb5, 0x00},
  1401. {0xb6, 0x00},
  1402. {0xb7, 0x00},
  1403. {0xb8, 0x00},
  1404. {0xb9, 0x00},
  1405. {0xba, 0x00},
  1406. {0xbb, 0x03},
  1407. {0xbc, 0x01},
  1408. {0xbd, 0x00},
  1409. {0xbe, 0x00},
  1410. {0xbf, 0x00},
  1411. {0xc0, 0x10},
  1412. {0xc1, 0x20},
  1413. {0xc2, 0x00},
  1414. {0xc3, 0x20},
  1415. {0xc4, 0x00},
  1416. {0xc5, 0x2c},
  1417. {0xc6, 0x1c},
  1418. {0xc7, 0x10},
  1419. {0xc8, 0x10},
  1420. {0xc9, 0x01},
  1421. {0xca, 0x68},
  1422. {0xcb, 0xa7},
  1423. {0xcc, 0x3c},
  1424. {0xcd, 0x09},
  1425. {0xce, 0x00},
  1426. {0xcf, 0x20},
  1427. {0xd0, 0x40},
  1428. {0xd1, 0x10},
  1429. {0xd2, 0x00},
  1430. {0xd3, 0x00},
  1431. {0xd4, 0x20},
  1432. {0xd5, 0x28},
  1433. {0xd6, 0xa0},
  1434. {0xd7, 0x2a},
  1435. {0xd8, 0x00},
  1436. {0xd9, 0x00},
  1437. {0xda, 0x00},
  1438. {0xdb, 0x00},
  1439. {0xdc, 0x00},
  1440. {0xdd, 0x00},
  1441. {0xde, 0x00},
  1442. {0xdf, 0x00},
  1443. {0xe0, 0x00},
  1444. {0xe1, 0xd3},
  1445. {0xe2, 0xc0},
  1446. {0xe3, 0x00},
  1447. {0xe4, 0x00},
  1448. {0xe5, 0x10},
  1449. {0xe6, 0x00},
  1450. {0xe7, 0x12},
  1451. {0xe8, 0x12},
  1452. {0xe9, 0x34},
  1453. {0xea, 0x00},
  1454. {0xeb, 0xff},
  1455. {0xec, 0x79},
  1456. {0xed, 0x20},
  1457. {0xee, 0x30},
  1458. {0xef, 0x01},
  1459. {0xf0, 0x00},
  1460. {0xf1, 0x3e},
  1461. {0xf2, 0x00},
  1462. {0xf3, 0x00},
  1463. {0xf4, 0x00},
  1464. {0xf5, 0x00},
  1465. {0xf6, 0x00},
  1466. {0xf7, 0x00},
  1467. {0xf8, 0x00},
  1468. {0xf9, 0x00},
  1469. {0xfa, 0x00},
  1470. {0xfb, 0x00},
  1471. {0xfc, 0x00},
  1472. {0xfd, 0x00},
  1473. {0xfe, 0x00},
  1474. {0xff, 0x00},
  1475. };
  1476. #define CB_VT3253B0_AGC 193
  1477. /* For AIROHA */
  1478. static unsigned char byVT3253B0_AGC[CB_VT3253B0_AGC][2] = {
  1479. {0xF0, 0x00},
  1480. {0xF1, 0x00},
  1481. {0xF0, 0x80},
  1482. {0xF0, 0x01},
  1483. {0xF1, 0x00},
  1484. {0xF0, 0x81},
  1485. {0xF0, 0x02},
  1486. {0xF1, 0x02},
  1487. {0xF0, 0x82},
  1488. {0xF0, 0x03},
  1489. {0xF1, 0x04},
  1490. {0xF0, 0x83},
  1491. {0xF0, 0x03},
  1492. {0xF1, 0x04},
  1493. {0xF0, 0x84},
  1494. {0xF0, 0x04},
  1495. {0xF1, 0x06},
  1496. {0xF0, 0x85},
  1497. {0xF0, 0x05},
  1498. {0xF1, 0x06},
  1499. {0xF0, 0x86},
  1500. {0xF0, 0x06},
  1501. {0xF1, 0x06},
  1502. {0xF0, 0x87},
  1503. {0xF0, 0x07},
  1504. {0xF1, 0x08},
  1505. {0xF0, 0x88},
  1506. {0xF0, 0x08},
  1507. {0xF1, 0x08},
  1508. {0xF0, 0x89},
  1509. {0xF0, 0x09},
  1510. {0xF1, 0x0A},
  1511. {0xF0, 0x8A},
  1512. {0xF0, 0x0A},
  1513. {0xF1, 0x0A},
  1514. {0xF0, 0x8B},
  1515. {0xF0, 0x0B},
  1516. {0xF1, 0x0C},
  1517. {0xF0, 0x8C},
  1518. {0xF0, 0x0C},
  1519. {0xF1, 0x0C},
  1520. {0xF0, 0x8D},
  1521. {0xF0, 0x0D},
  1522. {0xF1, 0x0E},
  1523. {0xF0, 0x8E},
  1524. {0xF0, 0x0E},
  1525. {0xF1, 0x0E},
  1526. {0xF0, 0x8F},
  1527. {0xF0, 0x0F},
  1528. {0xF1, 0x10},
  1529. {0xF0, 0x90},
  1530. {0xF0, 0x10},
  1531. {0xF1, 0x10},
  1532. {0xF0, 0x91},
  1533. {0xF0, 0x11},
  1534. {0xF1, 0x12},
  1535. {0xF0, 0x92},
  1536. {0xF0, 0x12},
  1537. {0xF1, 0x12},
  1538. {0xF0, 0x93},
  1539. {0xF0, 0x13},
  1540. {0xF1, 0x14},
  1541. {0xF0, 0x94},
  1542. {0xF0, 0x14},
  1543. {0xF1, 0x14},
  1544. {0xF0, 0x95},
  1545. {0xF0, 0x15},
  1546. {0xF1, 0x16},
  1547. {0xF0, 0x96},
  1548. {0xF0, 0x16},
  1549. {0xF1, 0x16},
  1550. {0xF0, 0x97},
  1551. {0xF0, 0x17},
  1552. {0xF1, 0x18},
  1553. {0xF0, 0x98},
  1554. {0xF0, 0x18},
  1555. {0xF1, 0x18},
  1556. {0xF0, 0x99},
  1557. {0xF0, 0x19},
  1558. {0xF1, 0x1A},
  1559. {0xF0, 0x9A},
  1560. {0xF0, 0x1A},
  1561. {0xF1, 0x1A},
  1562. {0xF0, 0x9B},
  1563. {0xF0, 0x1B},
  1564. {0xF1, 0x1C},
  1565. {0xF0, 0x9C},
  1566. {0xF0, 0x1C},
  1567. {0xF1, 0x1C},
  1568. {0xF0, 0x9D},
  1569. {0xF0, 0x1D},
  1570. {0xF1, 0x1E},
  1571. {0xF0, 0x9E},
  1572. {0xF0, 0x1E},
  1573. {0xF1, 0x1E},
  1574. {0xF0, 0x9F},
  1575. {0xF0, 0x1F},
  1576. {0xF1, 0x20},
  1577. {0xF0, 0xA0},
  1578. {0xF0, 0x20},
  1579. {0xF1, 0x20},
  1580. {0xF0, 0xA1},
  1581. {0xF0, 0x21},
  1582. {0xF1, 0x22},
  1583. {0xF0, 0xA2},
  1584. {0xF0, 0x22},
  1585. {0xF1, 0x22},
  1586. {0xF0, 0xA3},
  1587. {0xF0, 0x23},
  1588. {0xF1, 0x24},
  1589. {0xF0, 0xA4},
  1590. {0xF0, 0x24},
  1591. {0xF1, 0x24},
  1592. {0xF0, 0xA5},
  1593. {0xF0, 0x25},
  1594. {0xF1, 0x26},
  1595. {0xF0, 0xA6},
  1596. {0xF0, 0x26},
  1597. {0xF1, 0x26},
  1598. {0xF0, 0xA7},
  1599. {0xF0, 0x27},
  1600. {0xF1, 0x28},
  1601. {0xF0, 0xA8},
  1602. {0xF0, 0x28},
  1603. {0xF1, 0x28},
  1604. {0xF0, 0xA9},
  1605. {0xF0, 0x29},
  1606. {0xF1, 0x2A},
  1607. {0xF0, 0xAA},
  1608. {0xF0, 0x2A},
  1609. {0xF1, 0x2A},
  1610. {0xF0, 0xAB},
  1611. {0xF0, 0x2B},
  1612. {0xF1, 0x2C},
  1613. {0xF0, 0xAC},
  1614. {0xF0, 0x2C},
  1615. {0xF1, 0x2C},
  1616. {0xF0, 0xAD},
  1617. {0xF0, 0x2D},
  1618. {0xF1, 0x2E},
  1619. {0xF0, 0xAE},
  1620. {0xF0, 0x2E},
  1621. {0xF1, 0x2E},
  1622. {0xF0, 0xAF},
  1623. {0xF0, 0x2F},
  1624. {0xF1, 0x30},
  1625. {0xF0, 0xB0},
  1626. {0xF0, 0x30},
  1627. {0xF1, 0x30},
  1628. {0xF0, 0xB1},
  1629. {0xF0, 0x31},
  1630. {0xF1, 0x32},
  1631. {0xF0, 0xB2},
  1632. {0xF0, 0x32},
  1633. {0xF1, 0x32},
  1634. {0xF0, 0xB3},
  1635. {0xF0, 0x33},
  1636. {0xF1, 0x34},
  1637. {0xF0, 0xB4},
  1638. {0xF0, 0x34},
  1639. {0xF1, 0x34},
  1640. {0xF0, 0xB5},
  1641. {0xF0, 0x35},
  1642. {0xF1, 0x36},
  1643. {0xF0, 0xB6},
  1644. {0xF0, 0x36},
  1645. {0xF1, 0x36},
  1646. {0xF0, 0xB7},
  1647. {0xF0, 0x37},
  1648. {0xF1, 0x38},
  1649. {0xF0, 0xB8},
  1650. {0xF0, 0x38},
  1651. {0xF1, 0x38},
  1652. {0xF0, 0xB9},
  1653. {0xF0, 0x39},
  1654. {0xF1, 0x3A},
  1655. {0xF0, 0xBA},
  1656. {0xF0, 0x3A},
  1657. {0xF1, 0x3A},
  1658. {0xF0, 0xBB},
  1659. {0xF0, 0x3B},
  1660. {0xF1, 0x3C},
  1661. {0xF0, 0xBC},
  1662. {0xF0, 0x3C},
  1663. {0xF1, 0x3C},
  1664. {0xF0, 0xBD},
  1665. {0xF0, 0x3D},
  1666. {0xF1, 0x3E},
  1667. {0xF0, 0xBE},
  1668. {0xF0, 0x3E},
  1669. {0xF1, 0x3E},
  1670. {0xF0, 0xBF},
  1671. {0xF0, 0x00},
  1672. };
  1673. static const unsigned short awcFrameTime[MAX_RATE] = {
  1674. 10, 20, 55, 110, 24, 36, 48, 72, 96, 144, 192, 216
  1675. };
  1676. /*--------------------- Export Variables --------------------------*/
  1677. /*
  1678. * Description: Calculate data frame transmitting time
  1679. *
  1680. * Parameters:
  1681. * In:
  1682. * byPreambleType - Preamble Type
  1683. * byPktType - PK_TYPE_11A, PK_TYPE_11B, PK_TYPE_11GB, PK_TYPE_11GA
  1684. * cbFrameLength - Baseband Type
  1685. * wRate - Tx Rate
  1686. * Out:
  1687. *
  1688. * Return Value: FrameTime
  1689. *
  1690. */
  1691. unsigned int
  1692. BBuGetFrameTime(
  1693. unsigned char byPreambleType,
  1694. unsigned char byPktType,
  1695. unsigned int cbFrameLength,
  1696. unsigned short wRate
  1697. )
  1698. {
  1699. unsigned int uFrameTime;
  1700. unsigned int uPreamble;
  1701. unsigned int uTmp;
  1702. unsigned int uRateIdx = (unsigned int)wRate;
  1703. unsigned int uRate = 0;
  1704. if (uRateIdx > RATE_54M)
  1705. return 0;
  1706. uRate = (unsigned int)awcFrameTime[uRateIdx];
  1707. if (uRateIdx <= 3) { /* CCK mode */
  1708. if (byPreambleType == 1) /* Short */
  1709. uPreamble = 96;
  1710. else
  1711. uPreamble = 192;
  1712. uFrameTime = (cbFrameLength * 80) / uRate; /* ????? */
  1713. uTmp = (uFrameTime * uRate) / 80;
  1714. if (cbFrameLength != uTmp)
  1715. uFrameTime++;
  1716. return uPreamble + uFrameTime;
  1717. }
  1718. uFrameTime = (cbFrameLength * 8 + 22) / uRate; /* ???????? */
  1719. uTmp = ((uFrameTime * uRate) - 22) / 8;
  1720. if (cbFrameLength != uTmp)
  1721. uFrameTime++;
  1722. uFrameTime = uFrameTime * 4; /* ??????? */
  1723. if (byPktType != PK_TYPE_11A)
  1724. uFrameTime += 6; /* ?????? */
  1725. return 20 + uFrameTime; /* ?????? */
  1726. }
  1727. /*
  1728. * Description: Calculate Length, Service, and Signal fields of Phy for Tx
  1729. *
  1730. * Parameters:
  1731. * In:
  1732. * priv - Device Structure
  1733. * frame_length - Tx Frame Length
  1734. * tx_rate - Tx Rate
  1735. * Out:
  1736. * struct vnt_phy_field *phy
  1737. * - pointer to Phy Length field
  1738. * - pointer to Phy Service field
  1739. * - pointer to Phy Signal field
  1740. *
  1741. * Return Value: none
  1742. *
  1743. */
  1744. void vnt_get_phy_field(struct vnt_private *priv, u32 frame_length,
  1745. u16 tx_rate, u8 pkt_type, struct vnt_phy_field *phy)
  1746. {
  1747. u32 bit_count;
  1748. u32 count = 0;
  1749. u32 tmp;
  1750. int ext_bit;
  1751. u8 preamble_type = priv->byPreambleType;
  1752. bit_count = frame_length * 8;
  1753. ext_bit = false;
  1754. switch (tx_rate) {
  1755. case RATE_1M:
  1756. count = bit_count;
  1757. phy->signal = 0x00;
  1758. break;
  1759. case RATE_2M:
  1760. count = bit_count / 2;
  1761. if (preamble_type == 1)
  1762. phy->signal = 0x09;
  1763. else
  1764. phy->signal = 0x01;
  1765. break;
  1766. case RATE_5M:
  1767. count = (bit_count * 10) / 55;
  1768. tmp = (count * 55) / 10;
  1769. if (tmp != bit_count)
  1770. count++;
  1771. if (preamble_type == 1)
  1772. phy->signal = 0x0a;
  1773. else
  1774. phy->signal = 0x02;
  1775. break;
  1776. case RATE_11M:
  1777. count = bit_count / 11;
  1778. tmp = count * 11;
  1779. if (tmp != bit_count) {
  1780. count++;
  1781. if ((bit_count - tmp) <= 3)
  1782. ext_bit = true;
  1783. }
  1784. if (preamble_type == 1)
  1785. phy->signal = 0x0b;
  1786. else
  1787. phy->signal = 0x03;
  1788. break;
  1789. case RATE_6M:
  1790. if (pkt_type == PK_TYPE_11A)
  1791. phy->signal = 0x9b;
  1792. else
  1793. phy->signal = 0x8b;
  1794. break;
  1795. case RATE_9M:
  1796. if (pkt_type == PK_TYPE_11A)
  1797. phy->signal = 0x9f;
  1798. else
  1799. phy->signal = 0x8f;
  1800. break;
  1801. case RATE_12M:
  1802. if (pkt_type == PK_TYPE_11A)
  1803. phy->signal = 0x9a;
  1804. else
  1805. phy->signal = 0x8a;
  1806. break;
  1807. case RATE_18M:
  1808. if (pkt_type == PK_TYPE_11A)
  1809. phy->signal = 0x9e;
  1810. else
  1811. phy->signal = 0x8e;
  1812. break;
  1813. case RATE_24M:
  1814. if (pkt_type == PK_TYPE_11A)
  1815. phy->signal = 0x99;
  1816. else
  1817. phy->signal = 0x89;
  1818. break;
  1819. case RATE_36M:
  1820. if (pkt_type == PK_TYPE_11A)
  1821. phy->signal = 0x9d;
  1822. else
  1823. phy->signal = 0x8d;
  1824. break;
  1825. case RATE_48M:
  1826. if (pkt_type == PK_TYPE_11A)
  1827. phy->signal = 0x98;
  1828. else
  1829. phy->signal = 0x88;
  1830. break;
  1831. case RATE_54M:
  1832. if (pkt_type == PK_TYPE_11A)
  1833. phy->signal = 0x9c;
  1834. else
  1835. phy->signal = 0x8c;
  1836. break;
  1837. default:
  1838. if (pkt_type == PK_TYPE_11A)
  1839. phy->signal = 0x9c;
  1840. else
  1841. phy->signal = 0x8c;
  1842. break;
  1843. }
  1844. if (pkt_type == PK_TYPE_11B) {
  1845. phy->service = 0x00;
  1846. if (ext_bit)
  1847. phy->service |= 0x80;
  1848. phy->len = cpu_to_le16((u16)count);
  1849. } else {
  1850. phy->service = 0x00;
  1851. phy->len = cpu_to_le16((u16)frame_length);
  1852. }
  1853. }
  1854. /*
  1855. * Description: Read a byte from BASEBAND, by embedded programming
  1856. *
  1857. * Parameters:
  1858. * In:
  1859. * iobase - I/O base address
  1860. * byBBAddr - address of register in Baseband
  1861. * Out:
  1862. * pbyData - data read
  1863. *
  1864. * Return Value: true if succeeded; false if failed.
  1865. *
  1866. */
  1867. bool BBbReadEmbedded(struct vnt_private *priv,
  1868. unsigned char byBBAddr, unsigned char *pbyData)
  1869. {
  1870. void __iomem *iobase = priv->PortOffset;
  1871. unsigned short ww;
  1872. unsigned char byValue;
  1873. /* BB reg offset */
  1874. VNSvOutPortB(iobase + MAC_REG_BBREGADR, byBBAddr);
  1875. /* turn on REGR */
  1876. MACvRegBitsOn(iobase, MAC_REG_BBREGCTL, BBREGCTL_REGR);
  1877. /* W_MAX_TIMEOUT is the timeout period */
  1878. for (ww = 0; ww < W_MAX_TIMEOUT; ww++) {
  1879. VNSvInPortB(iobase + MAC_REG_BBREGCTL, &byValue);
  1880. if (byValue & BBREGCTL_DONE)
  1881. break;
  1882. }
  1883. /* get BB data */
  1884. VNSvInPortB(iobase + MAC_REG_BBREGDATA, pbyData);
  1885. if (ww == W_MAX_TIMEOUT) {
  1886. pr_debug(" DBG_PORT80(0x30)\n");
  1887. return false;
  1888. }
  1889. return true;
  1890. }
  1891. /*
  1892. * Description: Write a Byte to BASEBAND, by embedded programming
  1893. *
  1894. * Parameters:
  1895. * In:
  1896. * iobase - I/O base address
  1897. * byBBAddr - address of register in Baseband
  1898. * byData - data to write
  1899. * Out:
  1900. * none
  1901. *
  1902. * Return Value: true if succeeded; false if failed.
  1903. *
  1904. */
  1905. bool BBbWriteEmbedded(struct vnt_private *priv,
  1906. unsigned char byBBAddr, unsigned char byData)
  1907. {
  1908. void __iomem *iobase = priv->PortOffset;
  1909. unsigned short ww;
  1910. unsigned char byValue;
  1911. /* BB reg offset */
  1912. VNSvOutPortB(iobase + MAC_REG_BBREGADR, byBBAddr);
  1913. /* set BB data */
  1914. VNSvOutPortB(iobase + MAC_REG_BBREGDATA, byData);
  1915. /* turn on BBREGCTL_REGW */
  1916. MACvRegBitsOn(iobase, MAC_REG_BBREGCTL, BBREGCTL_REGW);
  1917. /* W_MAX_TIMEOUT is the timeout period */
  1918. for (ww = 0; ww < W_MAX_TIMEOUT; ww++) {
  1919. VNSvInPortB(iobase + MAC_REG_BBREGCTL, &byValue);
  1920. if (byValue & BBREGCTL_DONE)
  1921. break;
  1922. }
  1923. if (ww == W_MAX_TIMEOUT) {
  1924. pr_debug(" DBG_PORT80(0x31)\n");
  1925. return false;
  1926. }
  1927. return true;
  1928. }
  1929. /*
  1930. * Description: VIA VT3253 Baseband chip init function
  1931. *
  1932. * Parameters:
  1933. * In:
  1934. * iobase - I/O base address
  1935. * byRevId - Revision ID
  1936. * byRFType - RF type
  1937. * Out:
  1938. * none
  1939. *
  1940. * Return Value: true if succeeded; false if failed.
  1941. *
  1942. */
  1943. bool BBbVT3253Init(struct vnt_private *priv)
  1944. {
  1945. bool bResult = true;
  1946. int ii;
  1947. void __iomem *iobase = priv->PortOffset;
  1948. unsigned char byRFType = priv->byRFType;
  1949. unsigned char byLocalID = priv->byLocalID;
  1950. if (byRFType == RF_RFMD2959) {
  1951. if (byLocalID <= REV_ID_VT3253_A1) {
  1952. for (ii = 0; ii < CB_VT3253_INIT_FOR_RFMD; ii++)
  1953. bResult &= BBbWriteEmbedded(priv,
  1954. byVT3253InitTab_RFMD[ii][0],
  1955. byVT3253InitTab_RFMD[ii][1]);
  1956. } else {
  1957. for (ii = 0; ii < CB_VT3253B0_INIT_FOR_RFMD; ii++)
  1958. bResult &= BBbWriteEmbedded(priv,
  1959. byVT3253B0_RFMD[ii][0],
  1960. byVT3253B0_RFMD[ii][1]);
  1961. for (ii = 0; ii < CB_VT3253B0_AGC_FOR_RFMD2959; ii++)
  1962. bResult &= BBbWriteEmbedded(priv,
  1963. byVT3253B0_AGC4_RFMD2959[ii][0],
  1964. byVT3253B0_AGC4_RFMD2959[ii][1]);
  1965. VNSvOutPortD(iobase + MAC_REG_ITRTMSET, 0x23);
  1966. MACvRegBitsOn(iobase, MAC_REG_PAPEDELAY, BIT(0));
  1967. }
  1968. priv->abyBBVGA[0] = 0x18;
  1969. priv->abyBBVGA[1] = 0x0A;
  1970. priv->abyBBVGA[2] = 0x0;
  1971. priv->abyBBVGA[3] = 0x0;
  1972. priv->ldBmThreshold[0] = -70;
  1973. priv->ldBmThreshold[1] = -50;
  1974. priv->ldBmThreshold[2] = 0;
  1975. priv->ldBmThreshold[3] = 0;
  1976. } else if ((byRFType == RF_AIROHA) || (byRFType == RF_AL2230S)) {
  1977. for (ii = 0; ii < CB_VT3253B0_INIT_FOR_AIROHA2230; ii++)
  1978. bResult &= BBbWriteEmbedded(priv,
  1979. byVT3253B0_AIROHA2230[ii][0],
  1980. byVT3253B0_AIROHA2230[ii][1]);
  1981. for (ii = 0; ii < CB_VT3253B0_AGC; ii++)
  1982. bResult &= BBbWriteEmbedded(priv,
  1983. byVT3253B0_AGC[ii][0], byVT3253B0_AGC[ii][1]);
  1984. priv->abyBBVGA[0] = 0x1C;
  1985. priv->abyBBVGA[1] = 0x10;
  1986. priv->abyBBVGA[2] = 0x0;
  1987. priv->abyBBVGA[3] = 0x0;
  1988. priv->ldBmThreshold[0] = -70;
  1989. priv->ldBmThreshold[1] = -48;
  1990. priv->ldBmThreshold[2] = 0;
  1991. priv->ldBmThreshold[3] = 0;
  1992. } else if (byRFType == RF_UW2451) {
  1993. for (ii = 0; ii < CB_VT3253B0_INIT_FOR_UW2451; ii++)
  1994. bResult &= BBbWriteEmbedded(priv,
  1995. byVT3253B0_UW2451[ii][0],
  1996. byVT3253B0_UW2451[ii][1]);
  1997. for (ii = 0; ii < CB_VT3253B0_AGC; ii++)
  1998. bResult &= BBbWriteEmbedded(priv,
  1999. byVT3253B0_AGC[ii][0],
  2000. byVT3253B0_AGC[ii][1]);
  2001. VNSvOutPortB(iobase + MAC_REG_ITRTMSET, 0x23);
  2002. MACvRegBitsOn(iobase, MAC_REG_PAPEDELAY, BIT(0));
  2003. priv->abyBBVGA[0] = 0x14;
  2004. priv->abyBBVGA[1] = 0x0A;
  2005. priv->abyBBVGA[2] = 0x0;
  2006. priv->abyBBVGA[3] = 0x0;
  2007. priv->ldBmThreshold[0] = -60;
  2008. priv->ldBmThreshold[1] = -50;
  2009. priv->ldBmThreshold[2] = 0;
  2010. priv->ldBmThreshold[3] = 0;
  2011. } else if (byRFType == RF_UW2452) {
  2012. for (ii = 0; ii < CB_VT3253B0_INIT_FOR_UW2451; ii++)
  2013. bResult &= BBbWriteEmbedded(priv,
  2014. byVT3253B0_UW2451[ii][0],
  2015. byVT3253B0_UW2451[ii][1]);
  2016. /* Init ANT B select,
  2017. * TX Config CR09 = 0x61->0x45,
  2018. * 0x45->0x41(VC1/VC2 define, make the ANT_A, ANT_B inverted)
  2019. */
  2020. /*bResult &= BBbWriteEmbedded(iobase,0x09,0x41);*/
  2021. /* Init ANT B select,
  2022. * RX Config CR10 = 0x28->0x2A,
  2023. * 0x2A->0x28(VC1/VC2 define,
  2024. * make the ANT_A, ANT_B inverted)
  2025. */
  2026. /*bResult &= BBbWriteEmbedded(iobase,0x0a,0x28);*/
  2027. /* Select VC1/VC2, CR215 = 0x02->0x06 */
  2028. bResult &= BBbWriteEmbedded(priv, 0xd7, 0x06);
  2029. /* {{RobertYu:20050125, request by Jack */
  2030. bResult &= BBbWriteEmbedded(priv, 0x90, 0x20);
  2031. bResult &= BBbWriteEmbedded(priv, 0x97, 0xeb);
  2032. /* }} */
  2033. /* {{RobertYu:20050221, request by Jack */
  2034. bResult &= BBbWriteEmbedded(priv, 0xa6, 0x00);
  2035. bResult &= BBbWriteEmbedded(priv, 0xa8, 0x30);
  2036. /* }} */
  2037. bResult &= BBbWriteEmbedded(priv, 0xb0, 0x58);
  2038. for (ii = 0; ii < CB_VT3253B0_AGC; ii++)
  2039. bResult &= BBbWriteEmbedded(priv,
  2040. byVT3253B0_AGC[ii][0], byVT3253B0_AGC[ii][1]);
  2041. priv->abyBBVGA[0] = 0x14;
  2042. priv->abyBBVGA[1] = 0x0A;
  2043. priv->abyBBVGA[2] = 0x0;
  2044. priv->abyBBVGA[3] = 0x0;
  2045. priv->ldBmThreshold[0] = -60;
  2046. priv->ldBmThreshold[1] = -50;
  2047. priv->ldBmThreshold[2] = 0;
  2048. priv->ldBmThreshold[3] = 0;
  2049. /* }} RobertYu */
  2050. } else if (byRFType == RF_VT3226) {
  2051. for (ii = 0; ii < CB_VT3253B0_INIT_FOR_AIROHA2230; ii++)
  2052. bResult &= BBbWriteEmbedded(priv,
  2053. byVT3253B0_AIROHA2230[ii][0],
  2054. byVT3253B0_AIROHA2230[ii][1]);
  2055. for (ii = 0; ii < CB_VT3253B0_AGC; ii++)
  2056. bResult &= BBbWriteEmbedded(priv,
  2057. byVT3253B0_AGC[ii][0], byVT3253B0_AGC[ii][1]);
  2058. priv->abyBBVGA[0] = 0x1C;
  2059. priv->abyBBVGA[1] = 0x10;
  2060. priv->abyBBVGA[2] = 0x0;
  2061. priv->abyBBVGA[3] = 0x0;
  2062. priv->ldBmThreshold[0] = -70;
  2063. priv->ldBmThreshold[1] = -48;
  2064. priv->ldBmThreshold[2] = 0;
  2065. priv->ldBmThreshold[3] = 0;
  2066. /* Fix VT3226 DFC system timing issue */
  2067. MACvSetRFLE_LatchBase(iobase);
  2068. /* {{ RobertYu: 20050104 */
  2069. } else if (byRFType == RF_AIROHA7230) {
  2070. for (ii = 0; ii < CB_VT3253B0_INIT_FOR_AIROHA2230; ii++)
  2071. bResult &= BBbWriteEmbedded(priv,
  2072. byVT3253B0_AIROHA2230[ii][0],
  2073. byVT3253B0_AIROHA2230[ii][1]);
  2074. /* {{ RobertYu:20050223, request by JerryChung */
  2075. /* Init ANT B select,TX Config CR09 = 0x61->0x45,
  2076. * 0x45->0x41(VC1/VC2 define, make the ANT_A, ANT_B inverted)
  2077. */
  2078. /*bResult &= BBbWriteEmbedded(iobase,0x09,0x41);*/
  2079. /* Init ANT B select,RX Config CR10 = 0x28->0x2A,
  2080. * 0x2A->0x28(VC1/VC2 define, make the ANT_A, ANT_B inverted)
  2081. */
  2082. /*bResult &= BBbWriteEmbedded(iobase,0x0a,0x28);*/
  2083. /* Select VC1/VC2, CR215 = 0x02->0x06 */
  2084. bResult &= BBbWriteEmbedded(priv, 0xd7, 0x06);
  2085. /* }} */
  2086. for (ii = 0; ii < CB_VT3253B0_AGC; ii++)
  2087. bResult &= BBbWriteEmbedded(priv,
  2088. byVT3253B0_AGC[ii][0], byVT3253B0_AGC[ii][1]);
  2089. priv->abyBBVGA[0] = 0x1C;
  2090. priv->abyBBVGA[1] = 0x10;
  2091. priv->abyBBVGA[2] = 0x0;
  2092. priv->abyBBVGA[3] = 0x0;
  2093. priv->ldBmThreshold[0] = -70;
  2094. priv->ldBmThreshold[1] = -48;
  2095. priv->ldBmThreshold[2] = 0;
  2096. priv->ldBmThreshold[3] = 0;
  2097. /* }} RobertYu */
  2098. } else {
  2099. /* No VGA Table now */
  2100. priv->bUpdateBBVGA = false;
  2101. priv->abyBBVGA[0] = 0x1C;
  2102. }
  2103. if (byLocalID > REV_ID_VT3253_A1) {
  2104. BBbWriteEmbedded(priv, 0x04, 0x7F);
  2105. BBbWriteEmbedded(priv, 0x0D, 0x01);
  2106. }
  2107. return bResult;
  2108. }
  2109. /*
  2110. * Description: Set ShortSlotTime mode
  2111. *
  2112. * Parameters:
  2113. * In:
  2114. * priv - Device Structure
  2115. * Out:
  2116. * none
  2117. *
  2118. * Return Value: none
  2119. *
  2120. */
  2121. void
  2122. BBvSetShortSlotTime(struct vnt_private *priv)
  2123. {
  2124. unsigned char byBBRxConf = 0;
  2125. unsigned char byBBVGA = 0;
  2126. BBbReadEmbedded(priv, 0x0A, &byBBRxConf); /* CR10 */
  2127. if (priv->bShortSlotTime)
  2128. byBBRxConf &= 0xDF; /* 1101 1111 */
  2129. else
  2130. byBBRxConf |= 0x20; /* 0010 0000 */
  2131. /* patch for 3253B0 Baseband with Cardbus module */
  2132. BBbReadEmbedded(priv, 0xE7, &byBBVGA);
  2133. if (byBBVGA == priv->abyBBVGA[0])
  2134. byBBRxConf |= 0x20; /* 0010 0000 */
  2135. BBbWriteEmbedded(priv, 0x0A, byBBRxConf); /* CR10 */
  2136. }
  2137. void BBvSetVGAGainOffset(struct vnt_private *priv, unsigned char byData)
  2138. {
  2139. unsigned char byBBRxConf = 0;
  2140. BBbWriteEmbedded(priv, 0xE7, byData);
  2141. BBbReadEmbedded(priv, 0x0A, &byBBRxConf); /* CR10 */
  2142. /* patch for 3253B0 Baseband with Cardbus module */
  2143. if (byData == priv->abyBBVGA[0])
  2144. byBBRxConf |= 0x20; /* 0010 0000 */
  2145. else if (priv->bShortSlotTime)
  2146. byBBRxConf &= 0xDF; /* 1101 1111 */
  2147. else
  2148. byBBRxConf |= 0x20; /* 0010 0000 */
  2149. priv->byBBVGACurrent = byData;
  2150. BBbWriteEmbedded(priv, 0x0A, byBBRxConf); /* CR10 */
  2151. }
  2152. /*
  2153. * Description: Baseband SoftwareReset
  2154. *
  2155. * Parameters:
  2156. * In:
  2157. * iobase - I/O base address
  2158. * Out:
  2159. * none
  2160. *
  2161. * Return Value: none
  2162. *
  2163. */
  2164. void
  2165. BBvSoftwareReset(struct vnt_private *priv)
  2166. {
  2167. BBbWriteEmbedded(priv, 0x50, 0x40);
  2168. BBbWriteEmbedded(priv, 0x50, 0);
  2169. BBbWriteEmbedded(priv, 0x9C, 0x01);
  2170. BBbWriteEmbedded(priv, 0x9C, 0);
  2171. }
  2172. /*
  2173. * Description: Baseband Power Save Mode ON
  2174. *
  2175. * Parameters:
  2176. * In:
  2177. * iobase - I/O base address
  2178. * Out:
  2179. * none
  2180. *
  2181. * Return Value: none
  2182. *
  2183. */
  2184. void
  2185. BBvPowerSaveModeON(struct vnt_private *priv)
  2186. {
  2187. unsigned char byOrgData;
  2188. BBbReadEmbedded(priv, 0x0D, &byOrgData);
  2189. byOrgData |= BIT(0);
  2190. BBbWriteEmbedded(priv, 0x0D, byOrgData);
  2191. }
  2192. /*
  2193. * Description: Baseband Power Save Mode OFF
  2194. *
  2195. * Parameters:
  2196. * In:
  2197. * iobase - I/O base address
  2198. * Out:
  2199. * none
  2200. *
  2201. * Return Value: none
  2202. *
  2203. */
  2204. void
  2205. BBvPowerSaveModeOFF(struct vnt_private *priv)
  2206. {
  2207. unsigned char byOrgData;
  2208. BBbReadEmbedded(priv, 0x0D, &byOrgData);
  2209. byOrgData &= ~(BIT(0));
  2210. BBbWriteEmbedded(priv, 0x0D, byOrgData);
  2211. }
  2212. /*
  2213. * Description: Set Tx Antenna mode
  2214. *
  2215. * Parameters:
  2216. * In:
  2217. * priv - Device Structure
  2218. * byAntennaMode - Antenna Mode
  2219. * Out:
  2220. * none
  2221. *
  2222. * Return Value: none
  2223. *
  2224. */
  2225. void
  2226. BBvSetTxAntennaMode(struct vnt_private *priv, unsigned char byAntennaMode)
  2227. {
  2228. unsigned char byBBTxConf;
  2229. BBbReadEmbedded(priv, 0x09, &byBBTxConf); /* CR09 */
  2230. if (byAntennaMode == ANT_DIVERSITY) {
  2231. /* bit 1 is diversity */
  2232. byBBTxConf |= 0x02;
  2233. } else if (byAntennaMode == ANT_A) {
  2234. /* bit 2 is ANTSEL */
  2235. byBBTxConf &= 0xF9; /* 1111 1001 */
  2236. } else if (byAntennaMode == ANT_B) {
  2237. byBBTxConf &= 0xFD; /* 1111 1101 */
  2238. byBBTxConf |= 0x04;
  2239. }
  2240. BBbWriteEmbedded(priv, 0x09, byBBTxConf); /* CR09 */
  2241. }
  2242. /*
  2243. * Description: Set Rx Antenna mode
  2244. *
  2245. * Parameters:
  2246. * In:
  2247. * priv - Device Structure
  2248. * byAntennaMode - Antenna Mode
  2249. * Out:
  2250. * none
  2251. *
  2252. * Return Value: none
  2253. *
  2254. */
  2255. void
  2256. BBvSetRxAntennaMode(struct vnt_private *priv, unsigned char byAntennaMode)
  2257. {
  2258. unsigned char byBBRxConf;
  2259. BBbReadEmbedded(priv, 0x0A, &byBBRxConf); /* CR10 */
  2260. if (byAntennaMode == ANT_DIVERSITY) {
  2261. byBBRxConf |= 0x01;
  2262. } else if (byAntennaMode == ANT_A) {
  2263. byBBRxConf &= 0xFC; /* 1111 1100 */
  2264. } else if (byAntennaMode == ANT_B) {
  2265. byBBRxConf &= 0xFE; /* 1111 1110 */
  2266. byBBRxConf |= 0x02;
  2267. }
  2268. BBbWriteEmbedded(priv, 0x0A, byBBRxConf); /* CR10 */
  2269. }
  2270. /*
  2271. * Description: BBvSetDeepSleep
  2272. *
  2273. * Parameters:
  2274. * In:
  2275. * priv - Device Structure
  2276. * Out:
  2277. * none
  2278. *
  2279. * Return Value: none
  2280. *
  2281. */
  2282. void
  2283. BBvSetDeepSleep(struct vnt_private *priv, unsigned char byLocalID)
  2284. {
  2285. BBbWriteEmbedded(priv, 0x0C, 0x17); /* CR12 */
  2286. BBbWriteEmbedded(priv, 0x0D, 0xB9); /* CR13 */
  2287. }
  2288. void
  2289. BBvExitDeepSleep(struct vnt_private *priv, unsigned char byLocalID)
  2290. {
  2291. BBbWriteEmbedded(priv, 0x0C, 0x00); /* CR12 */
  2292. BBbWriteEmbedded(priv, 0x0D, 0x01); /* CR13 */
  2293. }