baseband.c 43 KB

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