baseband.c 68 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730273127322733273427352736273727382739274027412742274327442745274627472748274927502751275227532754275527562757275827592760276127622763276427652766276727682769277027712772277327742775277627772778277927802781278227832784278527862787278827892790279127922793279427952796279727982799280028012802280328042805280628072808280928102811281228132814281528162817281828192820282128222823282428252826282728282829283028312832283328342835283628372838283928402841284228432844284528462847284828492850285128522853285428552856285728582859286028612862286328642865286628672868286928702871287228732874287528762877287828792880288128822883288428852886288728882889289028912892289328942895289628972898289929002901290229032904290529062907290829092910291129122913291429152916291729182919292029212922292329242925292629272928292929302931293229332934293529362937293829392940294129422943294429452946294729482949295029512952295329542955295629572958295929602961296229632964296529662967296829692970297129722973297429752976
  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 parameter for baseband Tx
  31. * BBbReadEmbeded - Embeded read baseband register via MAC
  32. * BBbWriteEmbeded - Embeded write baseband register via MAC
  33. * BBbIsRegBitsOn - Test if baseband register bits on
  34. * BBbIsRegBitsOff - Test if baseband register bits off
  35. * BBbVT3253Init - VIA VT3253 baseband chip init code
  36. * BBvReadAllRegs - Read All Baseband Registers
  37. * BBvLoopbackOn - Turn on BaseBand Loopback mode
  38. * BBvLoopbackOff - Turn off BaseBand Loopback mode
  39. *
  40. * Revision History:
  41. * 06-10-2003 Bryan YC Fan: Re-write codes to support VT3253 spec.
  42. * 08-07-2003 Bryan YC Fan: Add MAXIM2827/2825 and RFMD2959 support.
  43. * 08-26-2003 Kyle Hsu : Modify BBuGetFrameTime() and BBvCaculateParameter().
  44. * cancel the setting of MAC_REG_SOFTPWRCTL on BBbVT3253Init().
  45. * Add the comments.
  46. * 09-01-2003 Bryan YC Fan: RF & BB tables updated.
  47. * Modified BBvLoopbackOn & BBvLoopbackOff().
  48. *
  49. *
  50. */
  51. #include "tmacro.h"
  52. #include "tether.h"
  53. #include "mac.h"
  54. #include "baseband.h"
  55. #include "srom.h"
  56. #include "rf.h"
  57. /*--------------------- Static Definitions -------------------------*/
  58. //static int msglevel =MSG_LEVEL_DEBUG;
  59. static int msglevel =MSG_LEVEL_INFO;
  60. //#define PLICE_DEBUG
  61. /*--------------------- Static Classes ----------------------------*/
  62. /*--------------------- Static Variables --------------------------*/
  63. /*--------------------- Static Functions --------------------------*/
  64. /*--------------------- Export Variables --------------------------*/
  65. /*--------------------- Static Definitions -------------------------*/
  66. /*--------------------- Static Classes ----------------------------*/
  67. /*--------------------- Static Variables --------------------------*/
  68. #define CB_VT3253_INIT_FOR_RFMD 446
  69. unsigned char byVT3253InitTab_RFMD[CB_VT3253_INIT_FOR_RFMD][2] = {
  70. {0x00, 0x30},
  71. {0x01, 0x00},
  72. {0x02, 0x00},
  73. {0x03, 0x00},
  74. {0x04, 0x00},
  75. {0x05, 0x00},
  76. {0x06, 0x00},
  77. {0x07, 0x00},
  78. {0x08, 0x70},
  79. {0x09, 0x45},
  80. {0x0a, 0x2a},
  81. {0x0b, 0x76},
  82. {0x0c, 0x00},
  83. {0x0d, 0x01},
  84. {0x0e, 0x80},
  85. {0x0f, 0x00},
  86. {0x10, 0x00},
  87. {0x11, 0x00},
  88. {0x12, 0x00},
  89. {0x13, 0x00},
  90. {0x14, 0x00},
  91. {0x15, 0x00},
  92. {0x16, 0x00},
  93. {0x17, 0x00},
  94. {0x18, 0x00},
  95. {0x19, 0x00},
  96. {0x1a, 0x00},
  97. {0x1b, 0x9d},
  98. {0x1c, 0x05},
  99. {0x1d, 0x00},
  100. {0x1e, 0x00},
  101. {0x1f, 0x00},
  102. {0x20, 0x00},
  103. {0x21, 0x00},
  104. {0x22, 0x00},
  105. {0x23, 0x00},
  106. {0x24, 0x00},
  107. {0x25, 0x4a},
  108. {0x26, 0x00},
  109. {0x27, 0x00},
  110. {0x28, 0x00},
  111. {0x29, 0x00},
  112. {0x2a, 0x00},
  113. {0x2b, 0x00},
  114. {0x2c, 0x00},
  115. {0x2d, 0xa8},
  116. {0x2e, 0x1a},
  117. {0x2f, 0x0c},
  118. {0x30, 0x26},
  119. {0x31, 0x5b},
  120. {0x32, 0x00},
  121. {0x33, 0x00},
  122. {0x34, 0x00},
  123. {0x35, 0x00},
  124. {0x36, 0xaa},
  125. {0x37, 0xaa},
  126. {0x38, 0xff},
  127. {0x39, 0xff},
  128. {0x3a, 0x00},
  129. {0x3b, 0x00},
  130. {0x3c, 0x00},
  131. {0x3d, 0x0d},
  132. {0x3e, 0x51},
  133. {0x3f, 0x04},
  134. {0x40, 0x00},
  135. {0x41, 0x08},
  136. {0x42, 0x00},
  137. {0x43, 0x08},
  138. {0x44, 0x06},
  139. {0x45, 0x14},
  140. {0x46, 0x05},
  141. {0x47, 0x08},
  142. {0x48, 0x00},
  143. {0x49, 0x00},
  144. {0x4a, 0x00},
  145. {0x4b, 0x00},
  146. {0x4c, 0x09},
  147. {0x4d, 0x80},
  148. {0x4e, 0x00},
  149. {0x4f, 0xc5},
  150. {0x50, 0x14},
  151. {0x51, 0x19},
  152. {0x52, 0x00},
  153. {0x53, 0x00},
  154. {0x54, 0x00},
  155. {0x55, 0x00},
  156. {0x56, 0x00},
  157. {0x57, 0x00},
  158. {0x58, 0x00},
  159. {0x59, 0xb0},
  160. {0x5a, 0x00},
  161. {0x5b, 0x00},
  162. {0x5c, 0x00},
  163. {0x5d, 0x00},
  164. {0x5e, 0x00},
  165. {0x5f, 0x00},
  166. {0x60, 0x44},
  167. {0x61, 0x04},
  168. {0x62, 0x00},
  169. {0x63, 0x00},
  170. {0x64, 0x00},
  171. {0x65, 0x00},
  172. {0x66, 0x04},
  173. {0x67, 0xb7},
  174. {0x68, 0x00},
  175. {0x69, 0x00},
  176. {0x6a, 0x00},
  177. {0x6b, 0x00},
  178. {0x6c, 0x00},
  179. {0x6d, 0x03},
  180. {0x6e, 0x01},
  181. {0x6f, 0x00},
  182. {0x70, 0x00},
  183. {0x71, 0x00},
  184. {0x72, 0x00},
  185. {0x73, 0x00},
  186. {0x74, 0x00},
  187. {0x75, 0x00},
  188. {0x76, 0x00},
  189. {0x77, 0x00},
  190. {0x78, 0x00},
  191. {0x79, 0x00},
  192. {0x7a, 0x00},
  193. {0x7b, 0x00},
  194. {0x7c, 0x00},
  195. {0x7d, 0x00},
  196. {0x7e, 0x00},
  197. {0x7f, 0x00},
  198. {0x80, 0x0b},
  199. {0x81, 0x00},
  200. {0x82, 0x3c},
  201. {0x83, 0x00},
  202. {0x84, 0x00},
  203. {0x85, 0x00},
  204. {0x86, 0x00},
  205. {0x87, 0x00},
  206. {0x88, 0x08},
  207. {0x89, 0x00},
  208. {0x8a, 0x08},
  209. {0x8b, 0xa6},
  210. {0x8c, 0x84},
  211. {0x8d, 0x47},
  212. {0x8e, 0xbb},
  213. {0x8f, 0x02},
  214. {0x90, 0x21},
  215. {0x91, 0x0c},
  216. {0x92, 0x04},
  217. {0x93, 0x22},
  218. {0x94, 0x00},
  219. {0x95, 0x00},
  220. {0x96, 0x00},
  221. {0x97, 0xeb},
  222. {0x98, 0x00},
  223. {0x99, 0x00},
  224. {0x9a, 0x00},
  225. {0x9b, 0x00},
  226. {0x9c, 0x00},
  227. {0x9d, 0x00},
  228. {0x9e, 0x00},
  229. {0x9f, 0x00},
  230. {0xa0, 0x00},
  231. {0xa1, 0x00},
  232. {0xa2, 0x00},
  233. {0xa3, 0x00},
  234. {0xa4, 0x00},
  235. {0xa5, 0x00},
  236. {0xa6, 0x10},
  237. {0xa7, 0x04},
  238. {0xa8, 0x10},
  239. {0xa9, 0x00},
  240. {0xaa, 0x8f},
  241. {0xab, 0x00},
  242. {0xac, 0x00},
  243. {0xad, 0x00},
  244. {0xae, 0x00},
  245. {0xaf, 0x80},
  246. {0xb0, 0x38},
  247. {0xb1, 0x00},
  248. {0xb2, 0x00},
  249. {0xb3, 0x00},
  250. {0xb4, 0xee},
  251. {0xb5, 0xff},
  252. {0xb6, 0x10},
  253. {0xb7, 0x00},
  254. {0xb8, 0x00},
  255. {0xb9, 0x00},
  256. {0xba, 0x00},
  257. {0xbb, 0x03},
  258. {0xbc, 0x00},
  259. {0xbd, 0x00},
  260. {0xbe, 0x00},
  261. {0xbf, 0x00},
  262. {0xc0, 0x10},
  263. {0xc1, 0x10},
  264. {0xc2, 0x18},
  265. {0xc3, 0x20},
  266. {0xc4, 0x10},
  267. {0xc5, 0x00},
  268. {0xc6, 0x22},
  269. {0xc7, 0x14},
  270. {0xc8, 0x0f},
  271. {0xc9, 0x08},
  272. {0xca, 0xa4},
  273. {0xcb, 0xa7},
  274. {0xcc, 0x3c},
  275. {0xcd, 0x10},
  276. {0xce, 0x20},
  277. {0xcf, 0x00},
  278. {0xd0, 0x00},
  279. {0xd1, 0x10},
  280. {0xd2, 0x00},
  281. {0xd3, 0x00},
  282. {0xd4, 0x10},
  283. {0xd5, 0x33},
  284. {0xd6, 0x70},
  285. {0xd7, 0x01},
  286. {0xd8, 0x00},
  287. {0xd9, 0x00},
  288. {0xda, 0x00},
  289. {0xdb, 0x00},
  290. {0xdc, 0x00},
  291. {0xdd, 0x00},
  292. {0xde, 0x00},
  293. {0xdf, 0x00},
  294. {0xe0, 0x00},
  295. {0xe1, 0x00},
  296. {0xe2, 0xcc},
  297. {0xe3, 0x04},
  298. {0xe4, 0x08},
  299. {0xe5, 0x10},
  300. {0xe6, 0x00},
  301. {0xe7, 0x0e},
  302. {0xe8, 0x88},
  303. {0xe9, 0xd4},
  304. {0xea, 0x05},
  305. {0xeb, 0xf0},
  306. {0xec, 0x79},
  307. {0xed, 0x0f},
  308. {0xee, 0x04},
  309. {0xef, 0x04},
  310. {0xf0, 0x00},
  311. {0xf1, 0x00},
  312. {0xf2, 0x00},
  313. {0xf3, 0x00},
  314. {0xf4, 0x00},
  315. {0xf5, 0x00},
  316. {0xf6, 0x00},
  317. {0xf7, 0x00},
  318. {0xf8, 0x00},
  319. {0xf9, 0x00},
  320. {0xF0, 0x00},
  321. {0xF1, 0xF8},
  322. {0xF0, 0x80},
  323. {0xF0, 0x00},
  324. {0xF1, 0xF4},
  325. {0xF0, 0x81},
  326. {0xF0, 0x01},
  327. {0xF1, 0xF0},
  328. {0xF0, 0x82},
  329. {0xF0, 0x02},
  330. {0xF1, 0xEC},
  331. {0xF0, 0x83},
  332. {0xF0, 0x03},
  333. {0xF1, 0xE8},
  334. {0xF0, 0x84},
  335. {0xF0, 0x04},
  336. {0xF1, 0xE4},
  337. {0xF0, 0x85},
  338. {0xF0, 0x05},
  339. {0xF1, 0xE0},
  340. {0xF0, 0x86},
  341. {0xF0, 0x06},
  342. {0xF1, 0xDC},
  343. {0xF0, 0x87},
  344. {0xF0, 0x07},
  345. {0xF1, 0xD8},
  346. {0xF0, 0x88},
  347. {0xF0, 0x08},
  348. {0xF1, 0xD4},
  349. {0xF0, 0x89},
  350. {0xF0, 0x09},
  351. {0xF1, 0xD0},
  352. {0xF0, 0x8A},
  353. {0xF0, 0x0A},
  354. {0xF1, 0xCC},
  355. {0xF0, 0x8B},
  356. {0xF0, 0x0B},
  357. {0xF1, 0xC8},
  358. {0xF0, 0x8C},
  359. {0xF0, 0x0C},
  360. {0xF1, 0xC4},
  361. {0xF0, 0x8D},
  362. {0xF0, 0x0D},
  363. {0xF1, 0xC0},
  364. {0xF0, 0x8E},
  365. {0xF0, 0x0E},
  366. {0xF1, 0xBC},
  367. {0xF0, 0x8F},
  368. {0xF0, 0x0F},
  369. {0xF1, 0xB8},
  370. {0xF0, 0x90},
  371. {0xF0, 0x10},
  372. {0xF1, 0xB4},
  373. {0xF0, 0x91},
  374. {0xF0, 0x11},
  375. {0xF1, 0xB0},
  376. {0xF0, 0x92},
  377. {0xF0, 0x12},
  378. {0xF1, 0xAC},
  379. {0xF0, 0x93},
  380. {0xF0, 0x13},
  381. {0xF1, 0xA8},
  382. {0xF0, 0x94},
  383. {0xF0, 0x14},
  384. {0xF1, 0xA4},
  385. {0xF0, 0x95},
  386. {0xF0, 0x15},
  387. {0xF1, 0xA0},
  388. {0xF0, 0x96},
  389. {0xF0, 0x16},
  390. {0xF1, 0x9C},
  391. {0xF0, 0x97},
  392. {0xF0, 0x17},
  393. {0xF1, 0x98},
  394. {0xF0, 0x98},
  395. {0xF0, 0x18},
  396. {0xF1, 0x94},
  397. {0xF0, 0x99},
  398. {0xF0, 0x19},
  399. {0xF1, 0x90},
  400. {0xF0, 0x9A},
  401. {0xF0, 0x1A},
  402. {0xF1, 0x8C},
  403. {0xF0, 0x9B},
  404. {0xF0, 0x1B},
  405. {0xF1, 0x88},
  406. {0xF0, 0x9C},
  407. {0xF0, 0x1C},
  408. {0xF1, 0x84},
  409. {0xF0, 0x9D},
  410. {0xF0, 0x1D},
  411. {0xF1, 0x80},
  412. {0xF0, 0x9E},
  413. {0xF0, 0x1E},
  414. {0xF1, 0x7C},
  415. {0xF0, 0x9F},
  416. {0xF0, 0x1F},
  417. {0xF1, 0x78},
  418. {0xF0, 0xA0},
  419. {0xF0, 0x20},
  420. {0xF1, 0x74},
  421. {0xF0, 0xA1},
  422. {0xF0, 0x21},
  423. {0xF1, 0x70},
  424. {0xF0, 0xA2},
  425. {0xF0, 0x22},
  426. {0xF1, 0x6C},
  427. {0xF0, 0xA3},
  428. {0xF0, 0x23},
  429. {0xF1, 0x68},
  430. {0xF0, 0xA4},
  431. {0xF0, 0x24},
  432. {0xF1, 0x64},
  433. {0xF0, 0xA5},
  434. {0xF0, 0x25},
  435. {0xF1, 0x60},
  436. {0xF0, 0xA6},
  437. {0xF0, 0x26},
  438. {0xF1, 0x5C},
  439. {0xF0, 0xA7},
  440. {0xF0, 0x27},
  441. {0xF1, 0x58},
  442. {0xF0, 0xA8},
  443. {0xF0, 0x28},
  444. {0xF1, 0x54},
  445. {0xF0, 0xA9},
  446. {0xF0, 0x29},
  447. {0xF1, 0x50},
  448. {0xF0, 0xAA},
  449. {0xF0, 0x2A},
  450. {0xF1, 0x4C},
  451. {0xF0, 0xAB},
  452. {0xF0, 0x2B},
  453. {0xF1, 0x48},
  454. {0xF0, 0xAC},
  455. {0xF0, 0x2C},
  456. {0xF1, 0x44},
  457. {0xF0, 0xAD},
  458. {0xF0, 0x2D},
  459. {0xF1, 0x40},
  460. {0xF0, 0xAE},
  461. {0xF0, 0x2E},
  462. {0xF1, 0x3C},
  463. {0xF0, 0xAF},
  464. {0xF0, 0x2F},
  465. {0xF1, 0x38},
  466. {0xF0, 0xB0},
  467. {0xF0, 0x30},
  468. {0xF1, 0x34},
  469. {0xF0, 0xB1},
  470. {0xF0, 0x31},
  471. {0xF1, 0x30},
  472. {0xF0, 0xB2},
  473. {0xF0, 0x32},
  474. {0xF1, 0x2C},
  475. {0xF0, 0xB3},
  476. {0xF0, 0x33},
  477. {0xF1, 0x28},
  478. {0xF0, 0xB4},
  479. {0xF0, 0x34},
  480. {0xF1, 0x24},
  481. {0xF0, 0xB5},
  482. {0xF0, 0x35},
  483. {0xF1, 0x20},
  484. {0xF0, 0xB6},
  485. {0xF0, 0x36},
  486. {0xF1, 0x1C},
  487. {0xF0, 0xB7},
  488. {0xF0, 0x37},
  489. {0xF1, 0x18},
  490. {0xF0, 0xB8},
  491. {0xF0, 0x38},
  492. {0xF1, 0x14},
  493. {0xF0, 0xB9},
  494. {0xF0, 0x39},
  495. {0xF1, 0x10},
  496. {0xF0, 0xBA},
  497. {0xF0, 0x3A},
  498. {0xF1, 0x0C},
  499. {0xF0, 0xBB},
  500. {0xF0, 0x3B},
  501. {0xF1, 0x08},
  502. {0xF0, 0x00},
  503. {0xF0, 0x3C},
  504. {0xF1, 0x04},
  505. {0xF0, 0xBD},
  506. {0xF0, 0x3D},
  507. {0xF1, 0x00},
  508. {0xF0, 0xBE},
  509. {0xF0, 0x3E},
  510. {0xF1, 0x00},
  511. {0xF0, 0xBF},
  512. {0xF0, 0x3F},
  513. {0xF1, 0x00},
  514. {0xF0, 0xC0},
  515. {0xF0, 0x00},
  516. };
  517. #define CB_VT3253B0_INIT_FOR_RFMD 256
  518. unsigned char byVT3253B0_RFMD[CB_VT3253B0_INIT_FOR_RFMD][2] = {
  519. {0x00, 0x31},
  520. {0x01, 0x00},
  521. {0x02, 0x00},
  522. {0x03, 0x00},
  523. {0x04, 0x00},
  524. {0x05, 0x81},
  525. {0x06, 0x00},
  526. {0x07, 0x00},
  527. {0x08, 0x38},
  528. {0x09, 0x45},
  529. {0x0a, 0x2a},
  530. {0x0b, 0x76},
  531. {0x0c, 0x00},
  532. {0x0d, 0x00},
  533. {0x0e, 0x80},
  534. {0x0f, 0x00},
  535. {0x10, 0x00},
  536. {0x11, 0x00},
  537. {0x12, 0x00},
  538. {0x13, 0x00},
  539. {0x14, 0x00},
  540. {0x15, 0x00},
  541. {0x16, 0x00},
  542. {0x17, 0x00},
  543. {0x18, 0x00},
  544. {0x19, 0x00},
  545. {0x1a, 0x00},
  546. {0x1b, 0x8e},
  547. {0x1c, 0x06},
  548. {0x1d, 0x00},
  549. {0x1e, 0x00},
  550. {0x1f, 0x00},
  551. {0x20, 0x00},
  552. {0x21, 0x00},
  553. {0x22, 0x00},
  554. {0x23, 0x00},
  555. {0x24, 0x00},
  556. {0x25, 0x4a},
  557. {0x26, 0x00},
  558. {0x27, 0x00},
  559. {0x28, 0x00},
  560. {0x29, 0x00},
  561. {0x2a, 0x00},
  562. {0x2b, 0x00},
  563. {0x2c, 0x00},
  564. {0x2d, 0x34},
  565. {0x2e, 0x18},
  566. {0x2f, 0x0c},
  567. {0x30, 0x26},
  568. {0x31, 0x5b},
  569. {0x32, 0x00},
  570. {0x33, 0x00},
  571. {0x34, 0x00},
  572. {0x35, 0x00},
  573. {0x36, 0xaa},
  574. {0x37, 0xaa},
  575. {0x38, 0xff},
  576. {0x39, 0xff},
  577. {0x3a, 0xf8},
  578. {0x3b, 0x00},
  579. {0x3c, 0x00},
  580. {0x3d, 0x09},
  581. {0x3e, 0x0d},
  582. {0x3f, 0x04},
  583. {0x40, 0x00},
  584. {0x41, 0x08},
  585. {0x42, 0x00},
  586. {0x43, 0x08},
  587. {0x44, 0x08},
  588. {0x45, 0x14},
  589. {0x46, 0x05},
  590. {0x47, 0x08},
  591. {0x48, 0x00},
  592. {0x49, 0x00},
  593. {0x4a, 0x00},
  594. {0x4b, 0x00},
  595. {0x4c, 0x09},
  596. {0x4d, 0x80},
  597. {0x4e, 0x00},
  598. {0x4f, 0xc5},
  599. {0x50, 0x14},
  600. {0x51, 0x19},
  601. {0x52, 0x00},
  602. {0x53, 0x00},
  603. {0x54, 0x00},
  604. {0x55, 0x00},
  605. {0x56, 0x00},
  606. {0x57, 0x00},
  607. {0x58, 0x00},
  608. {0x59, 0xb0},
  609. {0x5a, 0x00},
  610. {0x5b, 0x00},
  611. {0x5c, 0x00},
  612. {0x5d, 0x00},
  613. {0x5e, 0x00},
  614. {0x5f, 0x00},
  615. {0x60, 0x39},
  616. {0x61, 0x83},
  617. {0x62, 0x00},
  618. {0x63, 0x00},
  619. {0x64, 0x00},
  620. {0x65, 0x00},
  621. {0x66, 0xc0},
  622. {0x67, 0x49},
  623. {0x68, 0x00},
  624. {0x69, 0x00},
  625. {0x6a, 0x00},
  626. {0x6b, 0x00},
  627. {0x6c, 0x00},
  628. {0x6d, 0x03},
  629. {0x6e, 0x01},
  630. {0x6f, 0x00},
  631. {0x70, 0x00},
  632. {0x71, 0x00},
  633. {0x72, 0x00},
  634. {0x73, 0x00},
  635. {0x74, 0x00},
  636. {0x75, 0x00},
  637. {0x76, 0x00},
  638. {0x77, 0x00},
  639. {0x78, 0x00},
  640. {0x79, 0x00},
  641. {0x7a, 0x00},
  642. {0x7b, 0x00},
  643. {0x7c, 0x00},
  644. {0x7d, 0x00},
  645. {0x7e, 0x00},
  646. {0x7f, 0x00},
  647. {0x80, 0x89},
  648. {0x81, 0x00},
  649. {0x82, 0x0e},
  650. {0x83, 0x00},
  651. {0x84, 0x00},
  652. {0x85, 0x00},
  653. {0x86, 0x00},
  654. {0x87, 0x00},
  655. {0x88, 0x08},
  656. {0x89, 0x00},
  657. {0x8a, 0x0e},
  658. {0x8b, 0xa7},
  659. {0x8c, 0x88},
  660. {0x8d, 0x47},
  661. {0x8e, 0xaa},
  662. {0x8f, 0x02},
  663. {0x90, 0x23},
  664. {0x91, 0x0c},
  665. {0x92, 0x06},
  666. {0x93, 0x08},
  667. {0x94, 0x00},
  668. {0x95, 0x00},
  669. {0x96, 0x00},
  670. {0x97, 0xeb},
  671. {0x98, 0x00},
  672. {0x99, 0x00},
  673. {0x9a, 0x00},
  674. {0x9b, 0x00},
  675. {0x9c, 0x00},
  676. {0x9d, 0x00},
  677. {0x9e, 0x00},
  678. {0x9f, 0x00},
  679. {0xa0, 0x00},
  680. {0xa1, 0x00},
  681. {0xa2, 0x00},
  682. {0xa3, 0xcd},
  683. {0xa4, 0x07},
  684. {0xa5, 0x33},
  685. {0xa6, 0x18},
  686. {0xa7, 0x00},
  687. {0xa8, 0x18},
  688. {0xa9, 0x00},
  689. {0xaa, 0x28},
  690. {0xab, 0x00},
  691. {0xac, 0x00},
  692. {0xad, 0x00},
  693. {0xae, 0x00},
  694. {0xaf, 0x18},
  695. {0xb0, 0x38},
  696. {0xb1, 0x30},
  697. {0xb2, 0x00},
  698. {0xb3, 0x00},
  699. {0xb4, 0x00},
  700. {0xb5, 0x00},
  701. {0xb6, 0x84},
  702. {0xb7, 0xfd},
  703. {0xb8, 0x00},
  704. {0xb9, 0x00},
  705. {0xba, 0x00},
  706. {0xbb, 0x03},
  707. {0xbc, 0x00},
  708. {0xbd, 0x00},
  709. {0xbe, 0x00},
  710. {0xbf, 0x00},
  711. {0xc0, 0x10},
  712. {0xc1, 0x20},
  713. {0xc2, 0x18},
  714. {0xc3, 0x20},
  715. {0xc4, 0x10},
  716. {0xc5, 0x2c},
  717. {0xc6, 0x1e},
  718. {0xc7, 0x10},
  719. {0xc8, 0x12},
  720. {0xc9, 0x01},
  721. {0xca, 0x6f},
  722. {0xcb, 0xa7},
  723. {0xcc, 0x3c},
  724. {0xcd, 0x10},
  725. {0xce, 0x00},
  726. {0xcf, 0x22},
  727. {0xd0, 0x00},
  728. {0xd1, 0x10},
  729. {0xd2, 0x00},
  730. {0xd3, 0x00},
  731. {0xd4, 0x10},
  732. {0xd5, 0x33},
  733. {0xd6, 0x80},
  734. {0xd7, 0x21},
  735. {0xd8, 0x00},
  736. {0xd9, 0x00},
  737. {0xda, 0x00},
  738. {0xdb, 0x00},
  739. {0xdc, 0x00},
  740. {0xdd, 0x00},
  741. {0xde, 0x00},
  742. {0xdf, 0x00},
  743. {0xe0, 0x00},
  744. {0xe1, 0xB3},
  745. {0xe2, 0x00},
  746. {0xe3, 0x00},
  747. {0xe4, 0x00},
  748. {0xe5, 0x10},
  749. {0xe6, 0x00},
  750. {0xe7, 0x18},
  751. {0xe8, 0x08},
  752. {0xe9, 0xd4},
  753. {0xea, 0x00},
  754. {0xeb, 0xff},
  755. {0xec, 0x79},
  756. {0xed, 0x10},
  757. {0xee, 0x30},
  758. {0xef, 0x02},
  759. {0xf0, 0x00},
  760. {0xf1, 0x09},
  761. {0xf2, 0x00},
  762. {0xf3, 0x00},
  763. {0xf4, 0x00},
  764. {0xf5, 0x00},
  765. {0xf6, 0x00},
  766. {0xf7, 0x00},
  767. {0xf8, 0x00},
  768. {0xf9, 0x00},
  769. {0xfa, 0x00},
  770. {0xfb, 0x00},
  771. {0xfc, 0x00},
  772. {0xfd, 0x00},
  773. {0xfe, 0x00},
  774. {0xff, 0x00},
  775. };
  776. #define CB_VT3253B0_AGC_FOR_RFMD2959 195
  777. // For RFMD2959
  778. unsigned char byVT3253B0_AGC4_RFMD2959[CB_VT3253B0_AGC_FOR_RFMD2959][2] = {
  779. {0xF0, 0x00},
  780. {0xF1, 0x3E},
  781. {0xF0, 0x80},
  782. {0xF0, 0x00},
  783. {0xF1, 0x3E},
  784. {0xF0, 0x81},
  785. {0xF0, 0x01},
  786. {0xF1, 0x3E},
  787. {0xF0, 0x82},
  788. {0xF0, 0x02},
  789. {0xF1, 0x3E},
  790. {0xF0, 0x83},
  791. {0xF0, 0x03},
  792. {0xF1, 0x3B},
  793. {0xF0, 0x84},
  794. {0xF0, 0x04},
  795. {0xF1, 0x39},
  796. {0xF0, 0x85},
  797. {0xF0, 0x05},
  798. {0xF1, 0x38},
  799. {0xF0, 0x86},
  800. {0xF0, 0x06},
  801. {0xF1, 0x37},
  802. {0xF0, 0x87},
  803. {0xF0, 0x07},
  804. {0xF1, 0x36},
  805. {0xF0, 0x88},
  806. {0xF0, 0x08},
  807. {0xF1, 0x35},
  808. {0xF0, 0x89},
  809. {0xF0, 0x09},
  810. {0xF1, 0x35},
  811. {0xF0, 0x8A},
  812. {0xF0, 0x0A},
  813. {0xF1, 0x34},
  814. {0xF0, 0x8B},
  815. {0xF0, 0x0B},
  816. {0xF1, 0x34},
  817. {0xF0, 0x8C},
  818. {0xF0, 0x0C},
  819. {0xF1, 0x33},
  820. {0xF0, 0x8D},
  821. {0xF0, 0x0D},
  822. {0xF1, 0x32},
  823. {0xF0, 0x8E},
  824. {0xF0, 0x0E},
  825. {0xF1, 0x31},
  826. {0xF0, 0x8F},
  827. {0xF0, 0x0F},
  828. {0xF1, 0x30},
  829. {0xF0, 0x90},
  830. {0xF0, 0x10},
  831. {0xF1, 0x2F},
  832. {0xF0, 0x91},
  833. {0xF0, 0x11},
  834. {0xF1, 0x2F},
  835. {0xF0, 0x92},
  836. {0xF0, 0x12},
  837. {0xF1, 0x2E},
  838. {0xF0, 0x93},
  839. {0xF0, 0x13},
  840. {0xF1, 0x2D},
  841. {0xF0, 0x94},
  842. {0xF0, 0x14},
  843. {0xF1, 0x2C},
  844. {0xF0, 0x95},
  845. {0xF0, 0x15},
  846. {0xF1, 0x2B},
  847. {0xF0, 0x96},
  848. {0xF0, 0x16},
  849. {0xF1, 0x2B},
  850. {0xF0, 0x97},
  851. {0xF0, 0x17},
  852. {0xF1, 0x2A},
  853. {0xF0, 0x98},
  854. {0xF0, 0x18},
  855. {0xF1, 0x29},
  856. {0xF0, 0x99},
  857. {0xF0, 0x19},
  858. {0xF1, 0x28},
  859. {0xF0, 0x9A},
  860. {0xF0, 0x1A},
  861. {0xF1, 0x27},
  862. {0xF0, 0x9B},
  863. {0xF0, 0x1B},
  864. {0xF1, 0x26},
  865. {0xF0, 0x9C},
  866. {0xF0, 0x1C},
  867. {0xF1, 0x25},
  868. {0xF0, 0x9D},
  869. {0xF0, 0x1D},
  870. {0xF1, 0x24},
  871. {0xF0, 0x9E},
  872. {0xF0, 0x1E},
  873. {0xF1, 0x24},
  874. {0xF0, 0x9F},
  875. {0xF0, 0x1F},
  876. {0xF1, 0x23},
  877. {0xF0, 0xA0},
  878. {0xF0, 0x20},
  879. {0xF1, 0x22},
  880. {0xF0, 0xA1},
  881. {0xF0, 0x21},
  882. {0xF1, 0x21},
  883. {0xF0, 0xA2},
  884. {0xF0, 0x22},
  885. {0xF1, 0x20},
  886. {0xF0, 0xA3},
  887. {0xF0, 0x23},
  888. {0xF1, 0x20},
  889. {0xF0, 0xA4},
  890. {0xF0, 0x24},
  891. {0xF1, 0x1F},
  892. {0xF0, 0xA5},
  893. {0xF0, 0x25},
  894. {0xF1, 0x1E},
  895. {0xF0, 0xA6},
  896. {0xF0, 0x26},
  897. {0xF1, 0x1D},
  898. {0xF0, 0xA7},
  899. {0xF0, 0x27},
  900. {0xF1, 0x1C},
  901. {0xF0, 0xA8},
  902. {0xF0, 0x28},
  903. {0xF1, 0x1B},
  904. {0xF0, 0xA9},
  905. {0xF0, 0x29},
  906. {0xF1, 0x1B},
  907. {0xF0, 0xAA},
  908. {0xF0, 0x2A},
  909. {0xF1, 0x1A},
  910. {0xF0, 0xAB},
  911. {0xF0, 0x2B},
  912. {0xF1, 0x1A},
  913. {0xF0, 0xAC},
  914. {0xF0, 0x2C},
  915. {0xF1, 0x19},
  916. {0xF0, 0xAD},
  917. {0xF0, 0x2D},
  918. {0xF1, 0x18},
  919. {0xF0, 0xAE},
  920. {0xF0, 0x2E},
  921. {0xF1, 0x17},
  922. {0xF0, 0xAF},
  923. {0xF0, 0x2F},
  924. {0xF1, 0x16},
  925. {0xF0, 0xB0},
  926. {0xF0, 0x30},
  927. {0xF1, 0x15},
  928. {0xF0, 0xB1},
  929. {0xF0, 0x31},
  930. {0xF1, 0x15},
  931. {0xF0, 0xB2},
  932. {0xF0, 0x32},
  933. {0xF1, 0x15},
  934. {0xF0, 0xB3},
  935. {0xF0, 0x33},
  936. {0xF1, 0x14},
  937. {0xF0, 0xB4},
  938. {0xF0, 0x34},
  939. {0xF1, 0x13},
  940. {0xF0, 0xB5},
  941. {0xF0, 0x35},
  942. {0xF1, 0x12},
  943. {0xF0, 0xB6},
  944. {0xF0, 0x36},
  945. {0xF1, 0x11},
  946. {0xF0, 0xB7},
  947. {0xF0, 0x37},
  948. {0xF1, 0x10},
  949. {0xF0, 0xB8},
  950. {0xF0, 0x38},
  951. {0xF1, 0x0F},
  952. {0xF0, 0xB9},
  953. {0xF0, 0x39},
  954. {0xF1, 0x0E},
  955. {0xF0, 0xBA},
  956. {0xF0, 0x3A},
  957. {0xF1, 0x0D},
  958. {0xF0, 0xBB},
  959. {0xF0, 0x3B},
  960. {0xF1, 0x0C},
  961. {0xF0, 0xBC},
  962. {0xF0, 0x3C},
  963. {0xF1, 0x0B},
  964. {0xF0, 0xBD},
  965. {0xF0, 0x3D},
  966. {0xF1, 0x0B},
  967. {0xF0, 0xBE},
  968. {0xF0, 0x3E},
  969. {0xF1, 0x0A},
  970. {0xF0, 0xBF},
  971. {0xF0, 0x3F},
  972. {0xF1, 0x09},
  973. {0xF0, 0x00},
  974. };
  975. #define CB_VT3253B0_INIT_FOR_AIROHA2230 256
  976. // For AIROHA
  977. unsigned char byVT3253B0_AIROHA2230[CB_VT3253B0_INIT_FOR_AIROHA2230][2] = {
  978. {0x00, 0x31},
  979. {0x01, 0x00},
  980. {0x02, 0x00},
  981. {0x03, 0x00},
  982. {0x04, 0x00},
  983. {0x05, 0x80},
  984. {0x06, 0x00},
  985. {0x07, 0x00},
  986. {0x08, 0x70},
  987. {0x09, 0x41},
  988. {0x0a, 0x2A},
  989. {0x0b, 0x76},
  990. {0x0c, 0x00},
  991. {0x0d, 0x00},
  992. {0x0e, 0x80},
  993. {0x0f, 0x00},
  994. {0x10, 0x00},
  995. {0x11, 0x00},
  996. {0x12, 0x00},
  997. {0x13, 0x00},
  998. {0x14, 0x00},
  999. {0x15, 0x00},
  1000. {0x16, 0x00},
  1001. {0x17, 0x00},
  1002. {0x18, 0x00},
  1003. {0x19, 0x00},
  1004. {0x1a, 0x00},
  1005. {0x1b, 0x8f},
  1006. {0x1c, 0x09},
  1007. {0x1d, 0x00},
  1008. {0x1e, 0x00},
  1009. {0x1f, 0x00},
  1010. {0x20, 0x00},
  1011. {0x21, 0x00},
  1012. {0x22, 0x00},
  1013. {0x23, 0x00},
  1014. {0x24, 0x00},
  1015. {0x25, 0x4a},
  1016. {0x26, 0x00},
  1017. {0x27, 0x00},
  1018. {0x28, 0x00},
  1019. {0x29, 0x00},
  1020. {0x2a, 0x00},
  1021. {0x2b, 0x00},
  1022. {0x2c, 0x00},
  1023. {0x2d, 0x4a},
  1024. {0x2e, 0x00},
  1025. {0x2f, 0x0a},
  1026. {0x30, 0x26},
  1027. {0x31, 0x5b},
  1028. {0x32, 0x00},
  1029. {0x33, 0x00},
  1030. {0x34, 0x00},
  1031. {0x35, 0x00},
  1032. {0x36, 0xaa},
  1033. {0x37, 0xaa},
  1034. {0x38, 0xff},
  1035. {0x39, 0xff},
  1036. {0x3a, 0x79},
  1037. {0x3b, 0x00},
  1038. {0x3c, 0x00},
  1039. {0x3d, 0x0b},
  1040. {0x3e, 0x48},
  1041. {0x3f, 0x04},
  1042. {0x40, 0x00},
  1043. {0x41, 0x08},
  1044. {0x42, 0x00},
  1045. {0x43, 0x08},
  1046. {0x44, 0x08},
  1047. {0x45, 0x14},
  1048. {0x46, 0x05},
  1049. {0x47, 0x09},
  1050. {0x48, 0x00},
  1051. {0x49, 0x00},
  1052. {0x4a, 0x00},
  1053. {0x4b, 0x00},
  1054. {0x4c, 0x09},
  1055. {0x4d, 0x73},
  1056. {0x4e, 0x00},
  1057. {0x4f, 0xc5},
  1058. {0x50, 0x15},
  1059. {0x51, 0x19},
  1060. {0x52, 0x00},
  1061. {0x53, 0x00},
  1062. {0x54, 0x00},
  1063. {0x55, 0x00},
  1064. {0x56, 0x00},
  1065. {0x57, 0x00},
  1066. {0x58, 0x00},
  1067. {0x59, 0xb0},
  1068. {0x5a, 0x00},
  1069. {0x5b, 0x00},
  1070. {0x5c, 0x00},
  1071. {0x5d, 0x00},
  1072. {0x5e, 0x00},
  1073. {0x5f, 0x00},
  1074. {0x60, 0xe4},
  1075. {0x61, 0x80},
  1076. {0x62, 0x00},
  1077. {0x63, 0x00},
  1078. {0x64, 0x00},
  1079. {0x65, 0x00},
  1080. {0x66, 0x98},
  1081. {0x67, 0x0a},
  1082. {0x68, 0x00},
  1083. {0x69, 0x00},
  1084. {0x6a, 0x00},
  1085. {0x6b, 0x00},
  1086. //{0x6c, 0x80},
  1087. {0x6c, 0x00}, //RobertYu:20050125, request by JJSue
  1088. {0x6d, 0x03},
  1089. {0x6e, 0x01},
  1090. {0x6f, 0x00},
  1091. {0x70, 0x00},
  1092. {0x71, 0x00},
  1093. {0x72, 0x00},
  1094. {0x73, 0x00},
  1095. {0x74, 0x00},
  1096. {0x75, 0x00},
  1097. {0x76, 0x00},
  1098. {0x77, 0x00},
  1099. {0x78, 0x00},
  1100. {0x79, 0x00},
  1101. {0x7a, 0x00},
  1102. {0x7b, 0x00},
  1103. {0x7c, 0x00},
  1104. {0x7d, 0x00},
  1105. {0x7e, 0x00},
  1106. {0x7f, 0x00},
  1107. {0x80, 0x8c},
  1108. {0x81, 0x01},
  1109. {0x82, 0x09},
  1110. {0x83, 0x00},
  1111. {0x84, 0x00},
  1112. {0x85, 0x00},
  1113. {0x86, 0x00},
  1114. {0x87, 0x00},
  1115. {0x88, 0x08},
  1116. {0x89, 0x00},
  1117. {0x8a, 0x0f},
  1118. {0x8b, 0xb7},
  1119. {0x8c, 0x88},
  1120. {0x8d, 0x47},
  1121. {0x8e, 0xaa},
  1122. {0x8f, 0x02},
  1123. {0x90, 0x22},
  1124. {0x91, 0x00},
  1125. {0x92, 0x00},
  1126. {0x93, 0x00},
  1127. {0x94, 0x00},
  1128. {0x95, 0x00},
  1129. {0x96, 0x00},
  1130. {0x97, 0xeb},
  1131. {0x98, 0x00},
  1132. {0x99, 0x00},
  1133. {0x9a, 0x00},
  1134. {0x9b, 0x00},
  1135. {0x9c, 0x00},
  1136. {0x9d, 0x00},
  1137. {0x9e, 0x00},
  1138. {0x9f, 0x01},
  1139. {0xa0, 0x00},
  1140. {0xa1, 0x00},
  1141. {0xa2, 0x00},
  1142. {0xa3, 0x00},
  1143. {0xa4, 0x00},
  1144. {0xa5, 0x00},
  1145. {0xa6, 0x10},
  1146. {0xa7, 0x00},
  1147. {0xa8, 0x18},
  1148. {0xa9, 0x00},
  1149. {0xaa, 0x00},
  1150. {0xab, 0x00},
  1151. {0xac, 0x00},
  1152. {0xad, 0x00},
  1153. {0xae, 0x00},
  1154. {0xaf, 0x18},
  1155. {0xb0, 0x38},
  1156. {0xb1, 0x30},
  1157. {0xb2, 0x00},
  1158. {0xb3, 0x00},
  1159. {0xb4, 0xff},
  1160. {0xb5, 0x0f},
  1161. {0xb6, 0xe4},
  1162. {0xb7, 0xe2},
  1163. {0xb8, 0x00},
  1164. {0xb9, 0x00},
  1165. {0xba, 0x00},
  1166. {0xbb, 0x03},
  1167. {0xbc, 0x01},
  1168. {0xbd, 0x00},
  1169. {0xbe, 0x00},
  1170. {0xbf, 0x00},
  1171. {0xc0, 0x18},
  1172. {0xc1, 0x20},
  1173. {0xc2, 0x07},
  1174. {0xc3, 0x18},
  1175. {0xc4, 0xff},
  1176. {0xc5, 0x2c},
  1177. {0xc6, 0x0c},
  1178. {0xc7, 0x0a},
  1179. {0xc8, 0x0e},
  1180. {0xc9, 0x01},
  1181. {0xca, 0x68},
  1182. {0xcb, 0xa7},
  1183. {0xcc, 0x3c},
  1184. {0xcd, 0x10},
  1185. {0xce, 0x00},
  1186. {0xcf, 0x25},
  1187. {0xd0, 0x40},
  1188. {0xd1, 0x12},
  1189. {0xd2, 0x00},
  1190. {0xd3, 0x00},
  1191. {0xd4, 0x10},
  1192. {0xd5, 0x28},
  1193. {0xd6, 0x80},
  1194. {0xd7, 0x2A},
  1195. {0xd8, 0x00},
  1196. {0xd9, 0x00},
  1197. {0xda, 0x00},
  1198. {0xdb, 0x00},
  1199. {0xdc, 0x00},
  1200. {0xdd, 0x00},
  1201. {0xde, 0x00},
  1202. {0xdf, 0x00},
  1203. {0xe0, 0x00},
  1204. {0xe1, 0xB3},
  1205. {0xe2, 0x00},
  1206. {0xe3, 0x00},
  1207. {0xe4, 0x00},
  1208. {0xe5, 0x10},
  1209. {0xe6, 0x00},
  1210. {0xe7, 0x1C},
  1211. {0xe8, 0x00},
  1212. {0xe9, 0xf4},
  1213. {0xea, 0x00},
  1214. {0xeb, 0xff},
  1215. {0xec, 0x79},
  1216. {0xed, 0x20},
  1217. {0xee, 0x30},
  1218. {0xef, 0x01},
  1219. {0xf0, 0x00},
  1220. {0xf1, 0x3e},
  1221. {0xf2, 0x00},
  1222. {0xf3, 0x00},
  1223. {0xf4, 0x00},
  1224. {0xf5, 0x00},
  1225. {0xf6, 0x00},
  1226. {0xf7, 0x00},
  1227. {0xf8, 0x00},
  1228. {0xf9, 0x00},
  1229. {0xfa, 0x00},
  1230. {0xfb, 0x00},
  1231. {0xfc, 0x00},
  1232. {0xfd, 0x00},
  1233. {0xfe, 0x00},
  1234. {0xff, 0x00},
  1235. };
  1236. #define CB_VT3253B0_INIT_FOR_UW2451 256
  1237. //For UW2451
  1238. unsigned char byVT3253B0_UW2451[CB_VT3253B0_INIT_FOR_UW2451][2] = {
  1239. {0x00, 0x31},
  1240. {0x01, 0x00},
  1241. {0x02, 0x00},
  1242. {0x03, 0x00},
  1243. {0x04, 0x00},
  1244. {0x05, 0x81},
  1245. {0x06, 0x00},
  1246. {0x07, 0x00},
  1247. {0x08, 0x38},
  1248. {0x09, 0x45},
  1249. {0x0a, 0x28},
  1250. {0x0b, 0x76},
  1251. {0x0c, 0x00},
  1252. {0x0d, 0x00},
  1253. {0x0e, 0x80},
  1254. {0x0f, 0x00},
  1255. {0x10, 0x00},
  1256. {0x11, 0x00},
  1257. {0x12, 0x00},
  1258. {0x13, 0x00},
  1259. {0x14, 0x00},
  1260. {0x15, 0x00},
  1261. {0x16, 0x00},
  1262. {0x17, 0x00},
  1263. {0x18, 0x00},
  1264. {0x19, 0x00},
  1265. {0x1a, 0x00},
  1266. {0x1b, 0x8f},
  1267. {0x1c, 0x0f},
  1268. {0x1d, 0x00},
  1269. {0x1e, 0x00},
  1270. {0x1f, 0x00},
  1271. {0x20, 0x00},
  1272. {0x21, 0x00},
  1273. {0x22, 0x00},
  1274. {0x23, 0x00},
  1275. {0x24, 0x00},
  1276. {0x25, 0x4a},
  1277. {0x26, 0x00},
  1278. {0x27, 0x00},
  1279. {0x28, 0x00},
  1280. {0x29, 0x00},
  1281. {0x2a, 0x00},
  1282. {0x2b, 0x00},
  1283. {0x2c, 0x00},
  1284. {0x2d, 0x18},
  1285. {0x2e, 0x00},
  1286. {0x2f, 0x0a},
  1287. {0x30, 0x26},
  1288. {0x31, 0x5b},
  1289. {0x32, 0x00},
  1290. {0x33, 0x00},
  1291. {0x34, 0x00},
  1292. {0x35, 0x00},
  1293. {0x36, 0xaa},
  1294. {0x37, 0xaa},
  1295. {0x38, 0xff},
  1296. {0x39, 0xff},
  1297. {0x3a, 0x00},
  1298. {0x3b, 0x00},
  1299. {0x3c, 0x00},
  1300. {0x3d, 0x03},
  1301. {0x3e, 0x1d},
  1302. {0x3f, 0x04},
  1303. {0x40, 0x00},
  1304. {0x41, 0x08},
  1305. {0x42, 0x00},
  1306. {0x43, 0x08},
  1307. {0x44, 0x08},
  1308. {0x45, 0x14},
  1309. {0x46, 0x05},
  1310. {0x47, 0x09},
  1311. {0x48, 0x00},
  1312. {0x49, 0x00},
  1313. {0x4a, 0x00},
  1314. {0x4b, 0x00},
  1315. {0x4c, 0x09},
  1316. {0x4d, 0x90},
  1317. {0x4e, 0x00},
  1318. {0x4f, 0xc5},
  1319. {0x50, 0x15},
  1320. {0x51, 0x19},
  1321. {0x52, 0x00},
  1322. {0x53, 0x00},
  1323. {0x54, 0x00},
  1324. {0x55, 0x00},
  1325. {0x56, 0x00},
  1326. {0x57, 0x00},
  1327. {0x58, 0x00},
  1328. {0x59, 0xb0},
  1329. {0x5a, 0x00},
  1330. {0x5b, 0x00},
  1331. {0x5c, 0x00},
  1332. {0x5d, 0x00},
  1333. {0x5e, 0x00},
  1334. {0x5f, 0x00},
  1335. {0x60, 0xb3},
  1336. {0x61, 0x81},
  1337. {0x62, 0x00},
  1338. {0x63, 0x00},
  1339. {0x64, 0x00},
  1340. {0x65, 0x00},
  1341. {0x66, 0x57},
  1342. {0x67, 0x6c},
  1343. {0x68, 0x00},
  1344. {0x69, 0x00},
  1345. {0x6a, 0x00},
  1346. {0x6b, 0x00},
  1347. //{0x6c, 0x80},
  1348. {0x6c, 0x00}, //RobertYu:20050125, request by JJSue
  1349. {0x6d, 0x03},
  1350. {0x6e, 0x01},
  1351. {0x6f, 0x00},
  1352. {0x70, 0x00},
  1353. {0x71, 0x00},
  1354. {0x72, 0x00},
  1355. {0x73, 0x00},
  1356. {0x74, 0x00},
  1357. {0x75, 0x00},
  1358. {0x76, 0x00},
  1359. {0x77, 0x00},
  1360. {0x78, 0x00},
  1361. {0x79, 0x00},
  1362. {0x7a, 0x00},
  1363. {0x7b, 0x00},
  1364. {0x7c, 0x00},
  1365. {0x7d, 0x00},
  1366. {0x7e, 0x00},
  1367. {0x7f, 0x00},
  1368. {0x80, 0x8c},
  1369. {0x81, 0x00},
  1370. {0x82, 0x0e},
  1371. {0x83, 0x00},
  1372. {0x84, 0x00},
  1373. {0x85, 0x00},
  1374. {0x86, 0x00},
  1375. {0x87, 0x00},
  1376. {0x88, 0x08},
  1377. {0x89, 0x00},
  1378. {0x8a, 0x0e},
  1379. {0x8b, 0xa7},
  1380. {0x8c, 0x88},
  1381. {0x8d, 0x47},
  1382. {0x8e, 0xaa},
  1383. {0x8f, 0x02},
  1384. {0x90, 0x00},
  1385. {0x91, 0x00},
  1386. {0x92, 0x00},
  1387. {0x93, 0x00},
  1388. {0x94, 0x00},
  1389. {0x95, 0x00},
  1390. {0x96, 0x00},
  1391. {0x97, 0xe3},
  1392. {0x98, 0x00},
  1393. {0x99, 0x00},
  1394. {0x9a, 0x00},
  1395. {0x9b, 0x00},
  1396. {0x9c, 0x00},
  1397. {0x9d, 0x00},
  1398. {0x9e, 0x00},
  1399. {0x9f, 0x00},
  1400. {0xa0, 0x00},
  1401. {0xa1, 0x00},
  1402. {0xa2, 0x00},
  1403. {0xa3, 0x00},
  1404. {0xa4, 0x00},
  1405. {0xa5, 0x00},
  1406. {0xa6, 0x10},
  1407. {0xa7, 0x00},
  1408. {0xa8, 0x18},
  1409. {0xa9, 0x00},
  1410. {0xaa, 0x00},
  1411. {0xab, 0x00},
  1412. {0xac, 0x00},
  1413. {0xad, 0x00},
  1414. {0xae, 0x00},
  1415. {0xaf, 0x18},
  1416. {0xb0, 0x18},
  1417. {0xb1, 0x30},
  1418. {0xb2, 0x00},
  1419. {0xb3, 0x00},
  1420. {0xb4, 0x00},
  1421. {0xb5, 0x00},
  1422. {0xb6, 0x00},
  1423. {0xb7, 0x00},
  1424. {0xb8, 0x00},
  1425. {0xb9, 0x00},
  1426. {0xba, 0x00},
  1427. {0xbb, 0x03},
  1428. {0xbc, 0x01},
  1429. {0xbd, 0x00},
  1430. {0xbe, 0x00},
  1431. {0xbf, 0x00},
  1432. {0xc0, 0x10},
  1433. {0xc1, 0x20},
  1434. {0xc2, 0x00},
  1435. {0xc3, 0x20},
  1436. {0xc4, 0x00},
  1437. {0xc5, 0x2c},
  1438. {0xc6, 0x1c},
  1439. {0xc7, 0x10},
  1440. {0xc8, 0x10},
  1441. {0xc9, 0x01},
  1442. {0xca, 0x68},
  1443. {0xcb, 0xa7},
  1444. {0xcc, 0x3c},
  1445. {0xcd, 0x09},
  1446. {0xce, 0x00},
  1447. {0xcf, 0x20},
  1448. {0xd0, 0x40},
  1449. {0xd1, 0x10},
  1450. {0xd2, 0x00},
  1451. {0xd3, 0x00},
  1452. {0xd4, 0x20},
  1453. {0xd5, 0x28},
  1454. {0xd6, 0xa0},
  1455. {0xd7, 0x2a},
  1456. {0xd8, 0x00},
  1457. {0xd9, 0x00},
  1458. {0xda, 0x00},
  1459. {0xdb, 0x00},
  1460. {0xdc, 0x00},
  1461. {0xdd, 0x00},
  1462. {0xde, 0x00},
  1463. {0xdf, 0x00},
  1464. {0xe0, 0x00},
  1465. {0xe1, 0xd3},
  1466. {0xe2, 0xc0},
  1467. {0xe3, 0x00},
  1468. {0xe4, 0x00},
  1469. {0xe5, 0x10},
  1470. {0xe6, 0x00},
  1471. {0xe7, 0x12},
  1472. {0xe8, 0x12},
  1473. {0xe9, 0x34},
  1474. {0xea, 0x00},
  1475. {0xeb, 0xff},
  1476. {0xec, 0x79},
  1477. {0xed, 0x20},
  1478. {0xee, 0x30},
  1479. {0xef, 0x01},
  1480. {0xf0, 0x00},
  1481. {0xf1, 0x3e},
  1482. {0xf2, 0x00},
  1483. {0xf3, 0x00},
  1484. {0xf4, 0x00},
  1485. {0xf5, 0x00},
  1486. {0xf6, 0x00},
  1487. {0xf7, 0x00},
  1488. {0xf8, 0x00},
  1489. {0xf9, 0x00},
  1490. {0xfa, 0x00},
  1491. {0xfb, 0x00},
  1492. {0xfc, 0x00},
  1493. {0xfd, 0x00},
  1494. {0xfe, 0x00},
  1495. {0xff, 0x00},
  1496. };
  1497. #define CB_VT3253B0_AGC 193
  1498. // For AIROHA
  1499. unsigned char byVT3253B0_AGC[CB_VT3253B0_AGC][2] = {
  1500. {0xF0, 0x00},
  1501. {0xF1, 0x00},
  1502. {0xF0, 0x80},
  1503. {0xF0, 0x01},
  1504. {0xF1, 0x00},
  1505. {0xF0, 0x81},
  1506. {0xF0, 0x02},
  1507. {0xF1, 0x02},
  1508. {0xF0, 0x82},
  1509. {0xF0, 0x03},
  1510. {0xF1, 0x04},
  1511. {0xF0, 0x83},
  1512. {0xF0, 0x03},
  1513. {0xF1, 0x04},
  1514. {0xF0, 0x84},
  1515. {0xF0, 0x04},
  1516. {0xF1, 0x06},
  1517. {0xF0, 0x85},
  1518. {0xF0, 0x05},
  1519. {0xF1, 0x06},
  1520. {0xF0, 0x86},
  1521. {0xF0, 0x06},
  1522. {0xF1, 0x06},
  1523. {0xF0, 0x87},
  1524. {0xF0, 0x07},
  1525. {0xF1, 0x08},
  1526. {0xF0, 0x88},
  1527. {0xF0, 0x08},
  1528. {0xF1, 0x08},
  1529. {0xF0, 0x89},
  1530. {0xF0, 0x09},
  1531. {0xF1, 0x0A},
  1532. {0xF0, 0x8A},
  1533. {0xF0, 0x0A},
  1534. {0xF1, 0x0A},
  1535. {0xF0, 0x8B},
  1536. {0xF0, 0x0B},
  1537. {0xF1, 0x0C},
  1538. {0xF0, 0x8C},
  1539. {0xF0, 0x0C},
  1540. {0xF1, 0x0C},
  1541. {0xF0, 0x8D},
  1542. {0xF0, 0x0D},
  1543. {0xF1, 0x0E},
  1544. {0xF0, 0x8E},
  1545. {0xF0, 0x0E},
  1546. {0xF1, 0x0E},
  1547. {0xF0, 0x8F},
  1548. {0xF0, 0x0F},
  1549. {0xF1, 0x10},
  1550. {0xF0, 0x90},
  1551. {0xF0, 0x10},
  1552. {0xF1, 0x10},
  1553. {0xF0, 0x91},
  1554. {0xF0, 0x11},
  1555. {0xF1, 0x12},
  1556. {0xF0, 0x92},
  1557. {0xF0, 0x12},
  1558. {0xF1, 0x12},
  1559. {0xF0, 0x93},
  1560. {0xF0, 0x13},
  1561. {0xF1, 0x14},
  1562. {0xF0, 0x94},
  1563. {0xF0, 0x14},
  1564. {0xF1, 0x14},
  1565. {0xF0, 0x95},
  1566. {0xF0, 0x15},
  1567. {0xF1, 0x16},
  1568. {0xF0, 0x96},
  1569. {0xF0, 0x16},
  1570. {0xF1, 0x16},
  1571. {0xF0, 0x97},
  1572. {0xF0, 0x17},
  1573. {0xF1, 0x18},
  1574. {0xF0, 0x98},
  1575. {0xF0, 0x18},
  1576. {0xF1, 0x18},
  1577. {0xF0, 0x99},
  1578. {0xF0, 0x19},
  1579. {0xF1, 0x1A},
  1580. {0xF0, 0x9A},
  1581. {0xF0, 0x1A},
  1582. {0xF1, 0x1A},
  1583. {0xF0, 0x9B},
  1584. {0xF0, 0x1B},
  1585. {0xF1, 0x1C},
  1586. {0xF0, 0x9C},
  1587. {0xF0, 0x1C},
  1588. {0xF1, 0x1C},
  1589. {0xF0, 0x9D},
  1590. {0xF0, 0x1D},
  1591. {0xF1, 0x1E},
  1592. {0xF0, 0x9E},
  1593. {0xF0, 0x1E},
  1594. {0xF1, 0x1E},
  1595. {0xF0, 0x9F},
  1596. {0xF0, 0x1F},
  1597. {0xF1, 0x20},
  1598. {0xF0, 0xA0},
  1599. {0xF0, 0x20},
  1600. {0xF1, 0x20},
  1601. {0xF0, 0xA1},
  1602. {0xF0, 0x21},
  1603. {0xF1, 0x22},
  1604. {0xF0, 0xA2},
  1605. {0xF0, 0x22},
  1606. {0xF1, 0x22},
  1607. {0xF0, 0xA3},
  1608. {0xF0, 0x23},
  1609. {0xF1, 0x24},
  1610. {0xF0, 0xA4},
  1611. {0xF0, 0x24},
  1612. {0xF1, 0x24},
  1613. {0xF0, 0xA5},
  1614. {0xF0, 0x25},
  1615. {0xF1, 0x26},
  1616. {0xF0, 0xA6},
  1617. {0xF0, 0x26},
  1618. {0xF1, 0x26},
  1619. {0xF0, 0xA7},
  1620. {0xF0, 0x27},
  1621. {0xF1, 0x28},
  1622. {0xF0, 0xA8},
  1623. {0xF0, 0x28},
  1624. {0xF1, 0x28},
  1625. {0xF0, 0xA9},
  1626. {0xF0, 0x29},
  1627. {0xF1, 0x2A},
  1628. {0xF0, 0xAA},
  1629. {0xF0, 0x2A},
  1630. {0xF1, 0x2A},
  1631. {0xF0, 0xAB},
  1632. {0xF0, 0x2B},
  1633. {0xF1, 0x2C},
  1634. {0xF0, 0xAC},
  1635. {0xF0, 0x2C},
  1636. {0xF1, 0x2C},
  1637. {0xF0, 0xAD},
  1638. {0xF0, 0x2D},
  1639. {0xF1, 0x2E},
  1640. {0xF0, 0xAE},
  1641. {0xF0, 0x2E},
  1642. {0xF1, 0x2E},
  1643. {0xF0, 0xAF},
  1644. {0xF0, 0x2F},
  1645. {0xF1, 0x30},
  1646. {0xF0, 0xB0},
  1647. {0xF0, 0x30},
  1648. {0xF1, 0x30},
  1649. {0xF0, 0xB1},
  1650. {0xF0, 0x31},
  1651. {0xF1, 0x32},
  1652. {0xF0, 0xB2},
  1653. {0xF0, 0x32},
  1654. {0xF1, 0x32},
  1655. {0xF0, 0xB3},
  1656. {0xF0, 0x33},
  1657. {0xF1, 0x34},
  1658. {0xF0, 0xB4},
  1659. {0xF0, 0x34},
  1660. {0xF1, 0x34},
  1661. {0xF0, 0xB5},
  1662. {0xF0, 0x35},
  1663. {0xF1, 0x36},
  1664. {0xF0, 0xB6},
  1665. {0xF0, 0x36},
  1666. {0xF1, 0x36},
  1667. {0xF0, 0xB7},
  1668. {0xF0, 0x37},
  1669. {0xF1, 0x38},
  1670. {0xF0, 0xB8},
  1671. {0xF0, 0x38},
  1672. {0xF1, 0x38},
  1673. {0xF0, 0xB9},
  1674. {0xF0, 0x39},
  1675. {0xF1, 0x3A},
  1676. {0xF0, 0xBA},
  1677. {0xF0, 0x3A},
  1678. {0xF1, 0x3A},
  1679. {0xF0, 0xBB},
  1680. {0xF0, 0x3B},
  1681. {0xF1, 0x3C},
  1682. {0xF0, 0xBC},
  1683. {0xF0, 0x3C},
  1684. {0xF1, 0x3C},
  1685. {0xF0, 0xBD},
  1686. {0xF0, 0x3D},
  1687. {0xF1, 0x3E},
  1688. {0xF0, 0xBE},
  1689. {0xF0, 0x3E},
  1690. {0xF1, 0x3E},
  1691. {0xF0, 0xBF},
  1692. {0xF0, 0x00},
  1693. };
  1694. const unsigned short awcFrameTime[MAX_RATE] =
  1695. {10, 20, 55, 110, 24, 36, 48, 72, 96, 144, 192, 216};
  1696. /*--------------------- Static Functions --------------------------*/
  1697. static
  1698. unsigned long
  1699. s_ulGetRatio(PSDevice pDevice);
  1700. static
  1701. void
  1702. s_vChangeAntenna(
  1703. PSDevice pDevice
  1704. );
  1705. static
  1706. void
  1707. s_vChangeAntenna (
  1708. PSDevice pDevice
  1709. )
  1710. {
  1711. #ifdef PLICE_DEBUG
  1712. //printk("Enter s_vChangeAntenna:original RxMode is %d,TxMode is %d\n",pDevice->byRxAntennaMode,pDevice->byTxAntennaMode);
  1713. #endif
  1714. if ( pDevice->dwRxAntennaSel == 0) {
  1715. pDevice->dwRxAntennaSel=1;
  1716. if (pDevice->bTxRxAntInv == true)
  1717. BBvSetRxAntennaMode(pDevice->PortOffset, ANT_A);
  1718. else
  1719. BBvSetRxAntennaMode(pDevice->PortOffset, ANT_B);
  1720. } else {
  1721. pDevice->dwRxAntennaSel=0;
  1722. if (pDevice->bTxRxAntInv == true)
  1723. BBvSetRxAntennaMode(pDevice->PortOffset, ANT_B);
  1724. else
  1725. BBvSetRxAntennaMode(pDevice->PortOffset, ANT_A);
  1726. }
  1727. if ( pDevice->dwTxAntennaSel == 0) {
  1728. pDevice->dwTxAntennaSel=1;
  1729. BBvSetTxAntennaMode(pDevice->PortOffset, ANT_B);
  1730. } else {
  1731. pDevice->dwTxAntennaSel=0;
  1732. BBvSetTxAntennaMode(pDevice->PortOffset, ANT_A);
  1733. }
  1734. }
  1735. /*--------------------- Export Variables --------------------------*/
  1736. /*
  1737. * Description: Calculate data frame transmitting time
  1738. *
  1739. * Parameters:
  1740. * In:
  1741. * byPreambleType - Preamble Type
  1742. * byPktType - PK_TYPE_11A, PK_TYPE_11B, PK_TYPE_11GB, PK_TYPE_11GA
  1743. * cbFrameLength - Baseband Type
  1744. * wRate - Tx Rate
  1745. * Out:
  1746. *
  1747. * Return Value: FrameTime
  1748. *
  1749. */
  1750. unsigned int
  1751. BBuGetFrameTime (
  1752. unsigned char byPreambleType,
  1753. unsigned char byPktType,
  1754. unsigned int cbFrameLength,
  1755. unsigned short wRate
  1756. )
  1757. {
  1758. unsigned int uFrameTime;
  1759. unsigned int uPreamble;
  1760. unsigned int uTmp;
  1761. unsigned int uRateIdx = (unsigned int) wRate;
  1762. unsigned int uRate = 0;
  1763. if (uRateIdx > RATE_54M) {
  1764. ASSERT(0);
  1765. return 0;
  1766. }
  1767. uRate = (unsigned int) awcFrameTime[uRateIdx];
  1768. if (uRateIdx <= 3) { //CCK mode
  1769. if (byPreambleType == 1) {//Short
  1770. uPreamble = 96;
  1771. } else {
  1772. uPreamble = 192;
  1773. }
  1774. uFrameTime = (cbFrameLength * 80) / uRate; //?????
  1775. uTmp = (uFrameTime * uRate) / 80;
  1776. if (cbFrameLength != uTmp) {
  1777. uFrameTime ++;
  1778. }
  1779. return (uPreamble + uFrameTime);
  1780. }
  1781. else {
  1782. uFrameTime = (cbFrameLength * 8 + 22) / uRate; //????????
  1783. uTmp = ((uFrameTime * uRate) - 22) / 8;
  1784. if(cbFrameLength != uTmp) {
  1785. uFrameTime ++;
  1786. }
  1787. uFrameTime = uFrameTime * 4; //???????
  1788. if(byPktType != PK_TYPE_11A) {
  1789. uFrameTime += 6; //??????
  1790. }
  1791. return (20 + uFrameTime); //??????
  1792. }
  1793. }
  1794. /*
  1795. * Description: Caculate Length, Service, and Signal fields of Phy for Tx
  1796. *
  1797. * Parameters:
  1798. * In:
  1799. * pDevice - Device Structure
  1800. * cbFrameLength - Tx Frame Length
  1801. * wRate - Tx Rate
  1802. * Out:
  1803. * pwPhyLen - pointer to Phy Length field
  1804. * pbyPhySrv - pointer to Phy Service field
  1805. * pbyPhySgn - pointer to Phy Signal field
  1806. *
  1807. * Return Value: none
  1808. *
  1809. */
  1810. void
  1811. BBvCaculateParameter (
  1812. PSDevice pDevice,
  1813. unsigned int cbFrameLength,
  1814. unsigned short wRate,
  1815. unsigned char byPacketType,
  1816. unsigned short *pwPhyLen,
  1817. unsigned char *pbyPhySrv,
  1818. unsigned char *pbyPhySgn
  1819. )
  1820. {
  1821. unsigned int cbBitCount;
  1822. unsigned int cbUsCount = 0;
  1823. unsigned int cbTmp;
  1824. bool bExtBit;
  1825. unsigned char byPreambleType = pDevice->byPreambleType;
  1826. bool bCCK = pDevice->bCCK;
  1827. cbBitCount = cbFrameLength * 8;
  1828. bExtBit = false;
  1829. switch (wRate) {
  1830. case RATE_1M :
  1831. cbUsCount = cbBitCount;
  1832. *pbyPhySgn = 0x00;
  1833. break;
  1834. case RATE_2M :
  1835. cbUsCount = cbBitCount / 2;
  1836. if (byPreambleType == 1)
  1837. *pbyPhySgn = 0x09;
  1838. else // long preamble
  1839. *pbyPhySgn = 0x01;
  1840. break;
  1841. case RATE_5M :
  1842. if (bCCK == false)
  1843. cbBitCount ++;
  1844. cbUsCount = (cbBitCount * 10) / 55;
  1845. cbTmp = (cbUsCount * 55) / 10;
  1846. if (cbTmp != cbBitCount)
  1847. cbUsCount ++;
  1848. if (byPreambleType == 1)
  1849. *pbyPhySgn = 0x0a;
  1850. else // long preamble
  1851. *pbyPhySgn = 0x02;
  1852. break;
  1853. case RATE_11M :
  1854. if (bCCK == false)
  1855. cbBitCount ++;
  1856. cbUsCount = cbBitCount / 11;
  1857. cbTmp = cbUsCount * 11;
  1858. if (cbTmp != cbBitCount) {
  1859. cbUsCount ++;
  1860. if ((cbBitCount - cbTmp) <= 3)
  1861. bExtBit = true;
  1862. }
  1863. if (byPreambleType == 1)
  1864. *pbyPhySgn = 0x0b;
  1865. else // long preamble
  1866. *pbyPhySgn = 0x03;
  1867. break;
  1868. case RATE_6M :
  1869. if(byPacketType == PK_TYPE_11A) {//11a, 5GHZ
  1870. *pbyPhySgn = 0x9B; //1001 1011
  1871. }
  1872. else {//11g, 2.4GHZ
  1873. *pbyPhySgn = 0x8B; //1000 1011
  1874. }
  1875. break;
  1876. case RATE_9M :
  1877. if(byPacketType == PK_TYPE_11A) {//11a, 5GHZ
  1878. *pbyPhySgn = 0x9F; //1001 1111
  1879. }
  1880. else {//11g, 2.4GHZ
  1881. *pbyPhySgn = 0x8F; //1000 1111
  1882. }
  1883. break;
  1884. case RATE_12M :
  1885. if(byPacketType == PK_TYPE_11A) {//11a, 5GHZ
  1886. *pbyPhySgn = 0x9A; //1001 1010
  1887. }
  1888. else {//11g, 2.4GHZ
  1889. *pbyPhySgn = 0x8A; //1000 1010
  1890. }
  1891. break;
  1892. case RATE_18M :
  1893. if(byPacketType == PK_TYPE_11A) {//11a, 5GHZ
  1894. *pbyPhySgn = 0x9E; //1001 1110
  1895. }
  1896. else {//11g, 2.4GHZ
  1897. *pbyPhySgn = 0x8E; //1000 1110
  1898. }
  1899. break;
  1900. case RATE_24M :
  1901. if(byPacketType == PK_TYPE_11A) {//11a, 5GHZ
  1902. *pbyPhySgn = 0x99; //1001 1001
  1903. }
  1904. else {//11g, 2.4GHZ
  1905. *pbyPhySgn = 0x89; //1000 1001
  1906. }
  1907. break;
  1908. case RATE_36M :
  1909. if(byPacketType == PK_TYPE_11A) {//11a, 5GHZ
  1910. *pbyPhySgn = 0x9D; //1001 1101
  1911. }
  1912. else {//11g, 2.4GHZ
  1913. *pbyPhySgn = 0x8D; //1000 1101
  1914. }
  1915. break;
  1916. case RATE_48M :
  1917. if(byPacketType == PK_TYPE_11A) {//11a, 5GHZ
  1918. *pbyPhySgn = 0x98; //1001 1000
  1919. }
  1920. else {//11g, 2.4GHZ
  1921. *pbyPhySgn = 0x88; //1000 1000
  1922. }
  1923. break;
  1924. case RATE_54M :
  1925. if (byPacketType == PK_TYPE_11A) {//11a, 5GHZ
  1926. *pbyPhySgn = 0x9C; //1001 1100
  1927. }
  1928. else {//11g, 2.4GHZ
  1929. *pbyPhySgn = 0x8C; //1000 1100
  1930. }
  1931. break;
  1932. default :
  1933. if (byPacketType == PK_TYPE_11A) {//11a, 5GHZ
  1934. *pbyPhySgn = 0x9C; //1001 1100
  1935. }
  1936. else {//11g, 2.4GHZ
  1937. *pbyPhySgn = 0x8C; //1000 1100
  1938. }
  1939. break;
  1940. }
  1941. if (byPacketType == PK_TYPE_11B) {
  1942. *pbyPhySrv = 0x00;
  1943. if (bExtBit)
  1944. *pbyPhySrv = *pbyPhySrv | 0x80;
  1945. *pwPhyLen = (unsigned short)cbUsCount;
  1946. }
  1947. else {
  1948. *pbyPhySrv = 0x00;
  1949. *pwPhyLen = (unsigned short)cbFrameLength;
  1950. }
  1951. }
  1952. /*
  1953. * Description: Read a byte from BASEBAND, by embeded programming
  1954. *
  1955. * Parameters:
  1956. * In:
  1957. * dwIoBase - I/O base address
  1958. * byBBAddr - address of register in Baseband
  1959. * Out:
  1960. * pbyData - data read
  1961. *
  1962. * Return Value: true if succeeded; false if failed.
  1963. *
  1964. */
  1965. bool BBbReadEmbeded (unsigned long dwIoBase, unsigned char byBBAddr, unsigned char *pbyData)
  1966. {
  1967. unsigned short ww;
  1968. unsigned char byValue;
  1969. // BB reg offset
  1970. VNSvOutPortB(dwIoBase + MAC_REG_BBREGADR, byBBAddr);
  1971. // turn on REGR
  1972. MACvRegBitsOn(dwIoBase, MAC_REG_BBREGCTL, BBREGCTL_REGR);
  1973. // W_MAX_TIMEOUT is the timeout period
  1974. for (ww = 0; ww < W_MAX_TIMEOUT; ww++) {
  1975. VNSvInPortB(dwIoBase + MAC_REG_BBREGCTL, &byValue);
  1976. if (byValue & BBREGCTL_DONE)
  1977. break;
  1978. }
  1979. // get BB data
  1980. VNSvInPortB(dwIoBase + MAC_REG_BBREGDATA, pbyData);
  1981. if (ww == W_MAX_TIMEOUT) {
  1982. DBG_PORT80(0x30);
  1983. DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" DBG_PORT80(0x30)\n");
  1984. return false;
  1985. }
  1986. return true;
  1987. }
  1988. /*
  1989. * Description: Write a Byte to BASEBAND, by embeded programming
  1990. *
  1991. * Parameters:
  1992. * In:
  1993. * dwIoBase - I/O base address
  1994. * byBBAddr - address of register in Baseband
  1995. * byData - data to write
  1996. * Out:
  1997. * none
  1998. *
  1999. * Return Value: true if succeeded; false if failed.
  2000. *
  2001. */
  2002. bool BBbWriteEmbeded (unsigned long dwIoBase, unsigned char byBBAddr, unsigned char byData)
  2003. {
  2004. unsigned short ww;
  2005. unsigned char byValue;
  2006. // BB reg offset
  2007. VNSvOutPortB(dwIoBase + MAC_REG_BBREGADR, byBBAddr);
  2008. // set BB data
  2009. VNSvOutPortB(dwIoBase + MAC_REG_BBREGDATA, byData);
  2010. // turn on BBREGCTL_REGW
  2011. MACvRegBitsOn(dwIoBase, MAC_REG_BBREGCTL, BBREGCTL_REGW);
  2012. // W_MAX_TIMEOUT is the timeout period
  2013. for (ww = 0; ww < W_MAX_TIMEOUT; ww++) {
  2014. VNSvInPortB(dwIoBase + MAC_REG_BBREGCTL, &byValue);
  2015. if (byValue & BBREGCTL_DONE)
  2016. break;
  2017. }
  2018. if (ww == W_MAX_TIMEOUT) {
  2019. DBG_PORT80(0x31);
  2020. DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" DBG_PORT80(0x31)\n");
  2021. return false;
  2022. }
  2023. return true;
  2024. }
  2025. /*
  2026. * Description: Test if all bits are set for the Baseband register
  2027. *
  2028. * Parameters:
  2029. * In:
  2030. * dwIoBase - I/O base address
  2031. * byBBAddr - address of register in Baseband
  2032. * byTestBits - TestBits
  2033. * Out:
  2034. * none
  2035. *
  2036. * Return Value: true if all TestBits are set; false otherwise.
  2037. *
  2038. */
  2039. bool BBbIsRegBitsOn (unsigned long dwIoBase, unsigned char byBBAddr, unsigned char byTestBits)
  2040. {
  2041. unsigned char byOrgData;
  2042. BBbReadEmbeded(dwIoBase, byBBAddr, &byOrgData);
  2043. return (byOrgData & byTestBits) == byTestBits;
  2044. }
  2045. /*
  2046. * Description: Test if all bits are clear for the Baseband register
  2047. *
  2048. * Parameters:
  2049. * In:
  2050. * dwIoBase - I/O base address
  2051. * byBBAddr - address of register in Baseband
  2052. * byTestBits - TestBits
  2053. * Out:
  2054. * none
  2055. *
  2056. * Return Value: true if all TestBits are clear; false otherwise.
  2057. *
  2058. */
  2059. bool BBbIsRegBitsOff (unsigned long dwIoBase, unsigned char byBBAddr, unsigned char byTestBits)
  2060. {
  2061. unsigned char byOrgData;
  2062. BBbReadEmbeded(dwIoBase, byBBAddr, &byOrgData);
  2063. return (byOrgData & byTestBits) == 0;
  2064. }
  2065. /*
  2066. * Description: VIA VT3253 Baseband chip init function
  2067. *
  2068. * Parameters:
  2069. * In:
  2070. * dwIoBase - I/O base address
  2071. * byRevId - Revision ID
  2072. * byRFType - RF type
  2073. * Out:
  2074. * none
  2075. *
  2076. * Return Value: true if succeeded; false if failed.
  2077. *
  2078. */
  2079. bool BBbVT3253Init (PSDevice pDevice)
  2080. {
  2081. bool bResult = true;
  2082. int ii;
  2083. unsigned long dwIoBase = pDevice->PortOffset;
  2084. unsigned char byRFType = pDevice->byRFType;
  2085. unsigned char byLocalID = pDevice->byLocalID;
  2086. if (byRFType == RF_RFMD2959) {
  2087. if (byLocalID <= REV_ID_VT3253_A1) {
  2088. for (ii = 0; ii < CB_VT3253_INIT_FOR_RFMD; ii++) {
  2089. bResult &= BBbWriteEmbeded(dwIoBase,byVT3253InitTab_RFMD[ii][0],byVT3253InitTab_RFMD[ii][1]);
  2090. }
  2091. } else {
  2092. for (ii = 0; ii < CB_VT3253B0_INIT_FOR_RFMD; ii++) {
  2093. bResult &= BBbWriteEmbeded(dwIoBase,byVT3253B0_RFMD[ii][0],byVT3253B0_RFMD[ii][1]);
  2094. }
  2095. for (ii = 0; ii < CB_VT3253B0_AGC_FOR_RFMD2959; ii++) {
  2096. bResult &= BBbWriteEmbeded(dwIoBase,byVT3253B0_AGC4_RFMD2959[ii][0],byVT3253B0_AGC4_RFMD2959[ii][1]);
  2097. }
  2098. VNSvOutPortD(dwIoBase + MAC_REG_ITRTMSET, 0x23);
  2099. MACvRegBitsOn(dwIoBase, MAC_REG_PAPEDELAY, BIT0);
  2100. }
  2101. pDevice->abyBBVGA[0] = 0x18;
  2102. pDevice->abyBBVGA[1] = 0x0A;
  2103. pDevice->abyBBVGA[2] = 0x0;
  2104. pDevice->abyBBVGA[3] = 0x0;
  2105. pDevice->ldBmThreshold[0] = -70;
  2106. pDevice->ldBmThreshold[1] = -50;
  2107. pDevice->ldBmThreshold[2] = 0;
  2108. pDevice->ldBmThreshold[3] = 0;
  2109. } else if ((byRFType == RF_AIROHA) || (byRFType == RF_AL2230S) ) {
  2110. for (ii = 0; ii < CB_VT3253B0_INIT_FOR_AIROHA2230; ii++) {
  2111. bResult &= BBbWriteEmbeded(dwIoBase,byVT3253B0_AIROHA2230[ii][0],byVT3253B0_AIROHA2230[ii][1]);
  2112. }
  2113. for (ii = 0; ii < CB_VT3253B0_AGC; ii++) {
  2114. bResult &= BBbWriteEmbeded(dwIoBase,byVT3253B0_AGC[ii][0],byVT3253B0_AGC[ii][1]);
  2115. }
  2116. pDevice->abyBBVGA[0] = 0x1C;
  2117. pDevice->abyBBVGA[1] = 0x10;
  2118. pDevice->abyBBVGA[2] = 0x0;
  2119. pDevice->abyBBVGA[3] = 0x0;
  2120. pDevice->ldBmThreshold[0] = -70;
  2121. pDevice->ldBmThreshold[1] = -48;
  2122. pDevice->ldBmThreshold[2] = 0;
  2123. pDevice->ldBmThreshold[3] = 0;
  2124. } else if (byRFType == RF_UW2451) {
  2125. for (ii = 0; ii < CB_VT3253B0_INIT_FOR_UW2451; ii++) {
  2126. bResult &= BBbWriteEmbeded(dwIoBase,byVT3253B0_UW2451[ii][0],byVT3253B0_UW2451[ii][1]);
  2127. }
  2128. for (ii = 0; ii < CB_VT3253B0_AGC; ii++) {
  2129. bResult &= BBbWriteEmbeded(dwIoBase,byVT3253B0_AGC[ii][0],byVT3253B0_AGC[ii][1]);
  2130. }
  2131. VNSvOutPortB(dwIoBase + MAC_REG_ITRTMSET, 0x23);
  2132. MACvRegBitsOn(dwIoBase, MAC_REG_PAPEDELAY, BIT0);
  2133. pDevice->abyBBVGA[0] = 0x14;
  2134. pDevice->abyBBVGA[1] = 0x0A;
  2135. pDevice->abyBBVGA[2] = 0x0;
  2136. pDevice->abyBBVGA[3] = 0x0;
  2137. pDevice->ldBmThreshold[0] = -60;
  2138. pDevice->ldBmThreshold[1] = -50;
  2139. pDevice->ldBmThreshold[2] = 0;
  2140. pDevice->ldBmThreshold[3] = 0;
  2141. } else if (byRFType == RF_UW2452) {
  2142. for (ii = 0; ii < CB_VT3253B0_INIT_FOR_UW2451; ii++) {
  2143. bResult &= BBbWriteEmbeded(dwIoBase,byVT3253B0_UW2451[ii][0],byVT3253B0_UW2451[ii][1]);
  2144. }
  2145. // Init ANT B select,TX Config CR09 = 0x61->0x45, 0x45->0x41(VC1/VC2 define, make the ANT_A, ANT_B inverted)
  2146. //bResult &= BBbWriteEmbeded(dwIoBase,0x09,0x41);
  2147. // Init ANT B select,RX Config CR10 = 0x28->0x2A, 0x2A->0x28(VC1/VC2 define, make the ANT_A, ANT_B inverted)
  2148. //bResult &= BBbWriteEmbeded(dwIoBase,0x0a,0x28);
  2149. // Select VC1/VC2, CR215 = 0x02->0x06
  2150. bResult &= BBbWriteEmbeded(dwIoBase,0xd7,0x06);
  2151. //{{RobertYu:20050125, request by Jack
  2152. bResult &= BBbWriteEmbeded(dwIoBase,0x90,0x20);
  2153. bResult &= BBbWriteEmbeded(dwIoBase,0x97,0xeb);
  2154. //}}
  2155. //{{RobertYu:20050221, request by Jack
  2156. bResult &= BBbWriteEmbeded(dwIoBase,0xa6,0x00);
  2157. bResult &= BBbWriteEmbeded(dwIoBase,0xa8,0x30);
  2158. //}}
  2159. bResult &= BBbWriteEmbeded(dwIoBase,0xb0,0x58);
  2160. for (ii = 0; ii < CB_VT3253B0_AGC; ii++) {
  2161. bResult &= BBbWriteEmbeded(dwIoBase,byVT3253B0_AGC[ii][0],byVT3253B0_AGC[ii][1]);
  2162. }
  2163. //VNSvOutPortB(dwIoBase + MAC_REG_ITRTMSET, 0x23); // RobertYu: 20050104, 20050131 disable PA_Delay
  2164. //MACvRegBitsOn(dwIoBase, MAC_REG_PAPEDELAY, BIT0); // RobertYu: 20050104, 20050131 disable PA_Delay
  2165. pDevice->abyBBVGA[0] = 0x14;
  2166. pDevice->abyBBVGA[1] = 0x0A;
  2167. pDevice->abyBBVGA[2] = 0x0;
  2168. pDevice->abyBBVGA[3] = 0x0;
  2169. pDevice->ldBmThreshold[0] = -60;
  2170. pDevice->ldBmThreshold[1] = -50;
  2171. pDevice->ldBmThreshold[2] = 0;
  2172. pDevice->ldBmThreshold[3] = 0;
  2173. //}} RobertYu
  2174. } else if (byRFType == RF_VT3226) {
  2175. for (ii = 0; ii < CB_VT3253B0_INIT_FOR_AIROHA2230; ii++) {
  2176. bResult &= BBbWriteEmbeded(dwIoBase,byVT3253B0_AIROHA2230[ii][0],byVT3253B0_AIROHA2230[ii][1]);
  2177. }
  2178. for (ii = 0; ii < CB_VT3253B0_AGC; ii++) {
  2179. bResult &= BBbWriteEmbeded(dwIoBase,byVT3253B0_AGC[ii][0],byVT3253B0_AGC[ii][1]);
  2180. }
  2181. pDevice->abyBBVGA[0] = 0x1C;
  2182. pDevice->abyBBVGA[1] = 0x10;
  2183. pDevice->abyBBVGA[2] = 0x0;
  2184. pDevice->abyBBVGA[3] = 0x0;
  2185. pDevice->ldBmThreshold[0] = -70;
  2186. pDevice->ldBmThreshold[1] = -48;
  2187. pDevice->ldBmThreshold[2] = 0;
  2188. pDevice->ldBmThreshold[3] = 0;
  2189. // Fix VT3226 DFC system timing issue
  2190. MACvSetRFLE_LatchBase(dwIoBase);
  2191. //{{ RobertYu: 20050104
  2192. } else if (byRFType == RF_AIROHA7230) {
  2193. for (ii = 0; ii < CB_VT3253B0_INIT_FOR_AIROHA2230; ii++) {
  2194. bResult &= BBbWriteEmbeded(dwIoBase,byVT3253B0_AIROHA2230[ii][0],byVT3253B0_AIROHA2230[ii][1]);
  2195. }
  2196. //{{ RobertYu:20050223, request by JerryChung
  2197. // Init ANT B select,TX Config CR09 = 0x61->0x45, 0x45->0x41(VC1/VC2 define, make the ANT_A, ANT_B inverted)
  2198. //bResult &= BBbWriteEmbeded(dwIoBase,0x09,0x41);
  2199. // Init ANT B select,RX Config CR10 = 0x28->0x2A, 0x2A->0x28(VC1/VC2 define, make the ANT_A, ANT_B inverted)
  2200. //bResult &= BBbWriteEmbeded(dwIoBase,0x0a,0x28);
  2201. // Select VC1/VC2, CR215 = 0x02->0x06
  2202. bResult &= BBbWriteEmbeded(dwIoBase,0xd7,0x06);
  2203. //}}
  2204. for (ii = 0; ii < CB_VT3253B0_AGC; ii++) {
  2205. bResult &= BBbWriteEmbeded(dwIoBase,byVT3253B0_AGC[ii][0],byVT3253B0_AGC[ii][1]);
  2206. }
  2207. pDevice->abyBBVGA[0] = 0x1C;
  2208. pDevice->abyBBVGA[1] = 0x10;
  2209. pDevice->abyBBVGA[2] = 0x0;
  2210. pDevice->abyBBVGA[3] = 0x0;
  2211. pDevice->ldBmThreshold[0] = -70;
  2212. pDevice->ldBmThreshold[1] = -48;
  2213. pDevice->ldBmThreshold[2] = 0;
  2214. pDevice->ldBmThreshold[3] = 0;
  2215. //}} RobertYu
  2216. } else {
  2217. // No VGA Table now
  2218. pDevice->bUpdateBBVGA = false;
  2219. pDevice->abyBBVGA[0] = 0x1C;
  2220. }
  2221. if (byLocalID > REV_ID_VT3253_A1) {
  2222. BBbWriteEmbeded(dwIoBase, 0x04, 0x7F);
  2223. BBbWriteEmbeded(dwIoBase, 0x0D, 0x01);
  2224. }
  2225. return bResult;
  2226. }
  2227. /*
  2228. * Description: Read All Baseband Registers
  2229. *
  2230. * Parameters:
  2231. * In:
  2232. * dwIoBase - I/O base address
  2233. * pbyBBRegs - Point to struct that stores Baseband Registers
  2234. * Out:
  2235. * none
  2236. *
  2237. * Return Value: none
  2238. *
  2239. */
  2240. void BBvReadAllRegs (unsigned long dwIoBase, unsigned char *pbyBBRegs)
  2241. {
  2242. int ii;
  2243. unsigned char byBase = 1;
  2244. for (ii = 0; ii < BB_MAX_CONTEXT_SIZE; ii++) {
  2245. BBbReadEmbeded(dwIoBase, (unsigned char)(ii*byBase), pbyBBRegs);
  2246. pbyBBRegs += byBase;
  2247. }
  2248. }
  2249. /*
  2250. * Description: Turn on BaseBand Loopback mode
  2251. *
  2252. * Parameters:
  2253. * In:
  2254. * dwIoBase - I/O base address
  2255. * bCCK - If CCK is set
  2256. * Out:
  2257. * none
  2258. *
  2259. * Return Value: none
  2260. *
  2261. */
  2262. void BBvLoopbackOn (PSDevice pDevice)
  2263. {
  2264. unsigned char byData;
  2265. unsigned long dwIoBase = pDevice->PortOffset;
  2266. //CR C9 = 0x00
  2267. BBbReadEmbeded(dwIoBase, 0xC9, &pDevice->byBBCRc9);//CR201
  2268. BBbWriteEmbeded(dwIoBase, 0xC9, 0);
  2269. BBbReadEmbeded(dwIoBase, 0x4D, &pDevice->byBBCR4d);//CR77
  2270. BBbWriteEmbeded(dwIoBase, 0x4D, 0x90);
  2271. //CR 88 = 0x02(CCK), 0x03(OFDM)
  2272. BBbReadEmbeded(dwIoBase, 0x88, &pDevice->byBBCR88);//CR136
  2273. if (pDevice->uConnectionRate <= RATE_11M) { //CCK
  2274. // Enable internal digital loopback: CR33 |= 0000 0001
  2275. BBbReadEmbeded(dwIoBase, 0x21, &byData);//CR33
  2276. BBbWriteEmbeded(dwIoBase, 0x21, (unsigned char)(byData | 0x01));//CR33
  2277. // CR154 = 0x00
  2278. BBbWriteEmbeded(dwIoBase, 0x9A, 0); //CR154
  2279. BBbWriteEmbeded(dwIoBase, 0x88, 0x02);//CR239
  2280. }
  2281. else { //OFDM
  2282. // Enable internal digital loopback:CR154 |= 0000 0001
  2283. BBbReadEmbeded(dwIoBase, 0x9A, &byData);//CR154
  2284. BBbWriteEmbeded(dwIoBase, 0x9A, (unsigned char)(byData | 0x01));//CR154
  2285. // CR33 = 0x00
  2286. BBbWriteEmbeded(dwIoBase, 0x21, 0); //CR33
  2287. BBbWriteEmbeded(dwIoBase, 0x88, 0x03);//CR239
  2288. }
  2289. //CR14 = 0x00
  2290. BBbWriteEmbeded(dwIoBase, 0x0E, 0);//CR14
  2291. // Disable TX_IQUN
  2292. BBbReadEmbeded(pDevice->PortOffset, 0x09, &pDevice->byBBCR09);
  2293. BBbWriteEmbeded(pDevice->PortOffset, 0x09, (unsigned char)(pDevice->byBBCR09 & 0xDE));
  2294. }
  2295. /*
  2296. * Description: Turn off BaseBand Loopback mode
  2297. *
  2298. * Parameters:
  2299. * In:
  2300. * pDevice - Device Structure
  2301. *
  2302. * Out:
  2303. * none
  2304. *
  2305. * Return Value: none
  2306. *
  2307. */
  2308. void BBvLoopbackOff (PSDevice pDevice)
  2309. {
  2310. unsigned char byData;
  2311. unsigned long dwIoBase = pDevice->PortOffset;
  2312. BBbWriteEmbeded(dwIoBase, 0xC9, pDevice->byBBCRc9);//CR201
  2313. BBbWriteEmbeded(dwIoBase, 0x88, pDevice->byBBCR88);//CR136
  2314. BBbWriteEmbeded(dwIoBase, 0x09, pDevice->byBBCR09);//CR136
  2315. BBbWriteEmbeded(dwIoBase, 0x4D, pDevice->byBBCR4d);//CR77
  2316. if (pDevice->uConnectionRate <= RATE_11M) { // CCK
  2317. // Set the CR33 Bit2 to disable internal Loopback.
  2318. BBbReadEmbeded(dwIoBase, 0x21, &byData);//CR33
  2319. BBbWriteEmbeded(dwIoBase, 0x21, (unsigned char)(byData & 0xFE));//CR33
  2320. }
  2321. else { // OFDM
  2322. BBbReadEmbeded(dwIoBase, 0x9A, &byData);//CR154
  2323. BBbWriteEmbeded(dwIoBase, 0x9A, (unsigned char)(byData & 0xFE));//CR154
  2324. }
  2325. BBbReadEmbeded(dwIoBase, 0x0E, &byData);//CR14
  2326. BBbWriteEmbeded(dwIoBase, 0x0E, (unsigned char)(byData | 0x80));//CR14
  2327. }
  2328. /*
  2329. * Description: Set ShortSlotTime mode
  2330. *
  2331. * Parameters:
  2332. * In:
  2333. * pDevice - Device Structure
  2334. * Out:
  2335. * none
  2336. *
  2337. * Return Value: none
  2338. *
  2339. */
  2340. void
  2341. BBvSetShortSlotTime (PSDevice pDevice)
  2342. {
  2343. unsigned char byBBRxConf=0;
  2344. unsigned char byBBVGA=0;
  2345. BBbReadEmbeded(pDevice->PortOffset, 0x0A, &byBBRxConf);//CR10
  2346. if (pDevice->bShortSlotTime) {
  2347. byBBRxConf &= 0xDF;//1101 1111
  2348. } else {
  2349. byBBRxConf |= 0x20;//0010 0000
  2350. }
  2351. // patch for 3253B0 Baseband with Cardbus module
  2352. BBbReadEmbeded(pDevice->PortOffset, 0xE7, &byBBVGA);
  2353. if (byBBVGA == pDevice->abyBBVGA[0]) {
  2354. byBBRxConf |= 0x20;//0010 0000
  2355. }
  2356. BBbWriteEmbeded(pDevice->PortOffset, 0x0A, byBBRxConf);//CR10
  2357. }
  2358. void BBvSetVGAGainOffset(PSDevice pDevice, unsigned char byData)
  2359. {
  2360. unsigned char byBBRxConf=0;
  2361. BBbWriteEmbeded(pDevice->PortOffset, 0xE7, byData);
  2362. BBbReadEmbeded(pDevice->PortOffset, 0x0A, &byBBRxConf);//CR10
  2363. // patch for 3253B0 Baseband with Cardbus module
  2364. if (byData == pDevice->abyBBVGA[0]) {
  2365. byBBRxConf |= 0x20;//0010 0000
  2366. } else if (pDevice->bShortSlotTime) {
  2367. byBBRxConf &= 0xDF;//1101 1111
  2368. } else {
  2369. byBBRxConf |= 0x20;//0010 0000
  2370. }
  2371. pDevice->byBBVGACurrent = byData;
  2372. BBbWriteEmbeded(pDevice->PortOffset, 0x0A, byBBRxConf);//CR10
  2373. }
  2374. /*
  2375. * Description: Baseband SoftwareReset
  2376. *
  2377. * Parameters:
  2378. * In:
  2379. * dwIoBase - I/O base address
  2380. * Out:
  2381. * none
  2382. *
  2383. * Return Value: none
  2384. *
  2385. */
  2386. void
  2387. BBvSoftwareReset (unsigned long dwIoBase)
  2388. {
  2389. BBbWriteEmbeded(dwIoBase, 0x50, 0x40);
  2390. BBbWriteEmbeded(dwIoBase, 0x50, 0);
  2391. BBbWriteEmbeded(dwIoBase, 0x9C, 0x01);
  2392. BBbWriteEmbeded(dwIoBase, 0x9C, 0);
  2393. }
  2394. /*
  2395. * Description: Baseband Power Save Mode ON
  2396. *
  2397. * Parameters:
  2398. * In:
  2399. * dwIoBase - I/O base address
  2400. * Out:
  2401. * none
  2402. *
  2403. * Return Value: none
  2404. *
  2405. */
  2406. void
  2407. BBvPowerSaveModeON (unsigned long dwIoBase)
  2408. {
  2409. unsigned char byOrgData;
  2410. BBbReadEmbeded(dwIoBase, 0x0D, &byOrgData);
  2411. byOrgData |= BIT0;
  2412. BBbWriteEmbeded(dwIoBase, 0x0D, byOrgData);
  2413. }
  2414. /*
  2415. * Description: Baseband Power Save Mode OFF
  2416. *
  2417. * Parameters:
  2418. * In:
  2419. * dwIoBase - I/O base address
  2420. * Out:
  2421. * none
  2422. *
  2423. * Return Value: none
  2424. *
  2425. */
  2426. void
  2427. BBvPowerSaveModeOFF (unsigned long dwIoBase)
  2428. {
  2429. unsigned char byOrgData;
  2430. BBbReadEmbeded(dwIoBase, 0x0D, &byOrgData);
  2431. byOrgData &= ~(BIT0);
  2432. BBbWriteEmbeded(dwIoBase, 0x0D, byOrgData);
  2433. }
  2434. /*
  2435. * Description: Set Tx Antenna mode
  2436. *
  2437. * Parameters:
  2438. * In:
  2439. * pDevice - Device Structure
  2440. * byAntennaMode - Antenna Mode
  2441. * Out:
  2442. * none
  2443. *
  2444. * Return Value: none
  2445. *
  2446. */
  2447. void
  2448. BBvSetTxAntennaMode (unsigned long dwIoBase, unsigned char byAntennaMode)
  2449. {
  2450. unsigned char byBBTxConf;
  2451. #ifdef PLICE_DEBUG
  2452. //printk("Enter BBvSetTxAntennaMode\n");
  2453. #endif
  2454. BBbReadEmbeded(dwIoBase, 0x09, &byBBTxConf);//CR09
  2455. if (byAntennaMode == ANT_DIVERSITY) {
  2456. // bit 1 is diversity
  2457. byBBTxConf |= 0x02;
  2458. } else if (byAntennaMode == ANT_A) {
  2459. // bit 2 is ANTSEL
  2460. byBBTxConf &= 0xF9; // 1111 1001
  2461. } else if (byAntennaMode == ANT_B) {
  2462. #ifdef PLICE_DEBUG
  2463. //printk("BBvSetTxAntennaMode:ANT_B\n");
  2464. #endif
  2465. byBBTxConf &= 0xFD; // 1111 1101
  2466. byBBTxConf |= 0x04;
  2467. }
  2468. BBbWriteEmbeded(dwIoBase, 0x09, byBBTxConf);//CR09
  2469. }
  2470. /*
  2471. * Description: Set Rx Antenna mode
  2472. *
  2473. * Parameters:
  2474. * In:
  2475. * pDevice - Device Structure
  2476. * byAntennaMode - Antenna Mode
  2477. * Out:
  2478. * none
  2479. *
  2480. * Return Value: none
  2481. *
  2482. */
  2483. void
  2484. BBvSetRxAntennaMode (unsigned long dwIoBase, unsigned char byAntennaMode)
  2485. {
  2486. unsigned char byBBRxConf;
  2487. BBbReadEmbeded(dwIoBase, 0x0A, &byBBRxConf);//CR10
  2488. if (byAntennaMode == ANT_DIVERSITY) {
  2489. byBBRxConf |= 0x01;
  2490. } else if (byAntennaMode == ANT_A) {
  2491. byBBRxConf &= 0xFC; // 1111 1100
  2492. } else if (byAntennaMode == ANT_B) {
  2493. byBBRxConf &= 0xFE; // 1111 1110
  2494. byBBRxConf |= 0x02;
  2495. }
  2496. BBbWriteEmbeded(dwIoBase, 0x0A, byBBRxConf);//CR10
  2497. }
  2498. /*
  2499. * Description: BBvSetDeepSleep
  2500. *
  2501. * Parameters:
  2502. * In:
  2503. * pDevice - Device Structure
  2504. * Out:
  2505. * none
  2506. *
  2507. * Return Value: none
  2508. *
  2509. */
  2510. void
  2511. BBvSetDeepSleep (unsigned long dwIoBase, unsigned char byLocalID)
  2512. {
  2513. BBbWriteEmbeded(dwIoBase, 0x0C, 0x17);//CR12
  2514. BBbWriteEmbeded(dwIoBase, 0x0D, 0xB9);//CR13
  2515. }
  2516. void
  2517. BBvExitDeepSleep (unsigned long dwIoBase, unsigned char byLocalID)
  2518. {
  2519. BBbWriteEmbeded(dwIoBase, 0x0C, 0x00);//CR12
  2520. BBbWriteEmbeded(dwIoBase, 0x0D, 0x01);//CR13
  2521. }
  2522. static
  2523. unsigned long
  2524. s_ulGetRatio (PSDevice pDevice)
  2525. {
  2526. unsigned long ulRatio = 0;
  2527. unsigned long ulMaxPacket;
  2528. unsigned long ulPacketNum;
  2529. //This is a thousand-ratio
  2530. ulMaxPacket = pDevice->uNumSQ3[RATE_54M];
  2531. if ( pDevice->uNumSQ3[RATE_54M] != 0 ) {
  2532. ulPacketNum = pDevice->uNumSQ3[RATE_54M];
  2533. ulRatio = (ulPacketNum * 1000 / pDevice->uDiversityCnt);
  2534. //ulRatio = (pDevice->uNumSQ3[RATE_54M] * 1000 / pDevice->uDiversityCnt);
  2535. ulRatio += TOP_RATE_54M;
  2536. }
  2537. if ( pDevice->uNumSQ3[RATE_48M] > ulMaxPacket ) {
  2538. ulPacketNum = pDevice->uNumSQ3[RATE_54M] + pDevice->uNumSQ3[RATE_48M];
  2539. ulRatio = (ulPacketNum * 1000 / pDevice->uDiversityCnt);
  2540. //ulRatio = (pDevice->uNumSQ3[RATE_48M] * 1000 / pDevice->uDiversityCnt);
  2541. ulRatio += TOP_RATE_48M;
  2542. ulMaxPacket = pDevice->uNumSQ3[RATE_48M];
  2543. }
  2544. if ( pDevice->uNumSQ3[RATE_36M] > ulMaxPacket ) {
  2545. ulPacketNum = pDevice->uNumSQ3[RATE_54M] + pDevice->uNumSQ3[RATE_48M] +
  2546. pDevice->uNumSQ3[RATE_36M];
  2547. ulRatio = (ulPacketNum * 1000 / pDevice->uDiversityCnt);
  2548. //ulRatio = (pDevice->uNumSQ3[RATE_36M] * 1000 / pDevice->uDiversityCnt);
  2549. ulRatio += TOP_RATE_36M;
  2550. ulMaxPacket = pDevice->uNumSQ3[RATE_36M];
  2551. }
  2552. if ( pDevice->uNumSQ3[RATE_24M] > ulMaxPacket ) {
  2553. ulPacketNum = pDevice->uNumSQ3[RATE_54M] + pDevice->uNumSQ3[RATE_48M] +
  2554. pDevice->uNumSQ3[RATE_36M] + pDevice->uNumSQ3[RATE_24M];
  2555. ulRatio = (ulPacketNum * 1000 / pDevice->uDiversityCnt);
  2556. //ulRatio = (pDevice->uNumSQ3[RATE_24M] * 1000 / pDevice->uDiversityCnt);
  2557. ulRatio += TOP_RATE_24M;
  2558. ulMaxPacket = pDevice->uNumSQ3[RATE_24M];
  2559. }
  2560. if ( pDevice->uNumSQ3[RATE_18M] > ulMaxPacket ) {
  2561. ulPacketNum = pDevice->uNumSQ3[RATE_54M] + pDevice->uNumSQ3[RATE_48M] +
  2562. pDevice->uNumSQ3[RATE_36M] + pDevice->uNumSQ3[RATE_24M] +
  2563. pDevice->uNumSQ3[RATE_18M];
  2564. ulRatio = (ulPacketNum * 1000 / pDevice->uDiversityCnt);
  2565. //ulRatio = (pDevice->uNumSQ3[RATE_18M] * 1000 / pDevice->uDiversityCnt);
  2566. ulRatio += TOP_RATE_18M;
  2567. ulMaxPacket = pDevice->uNumSQ3[RATE_18M];
  2568. }
  2569. if ( pDevice->uNumSQ3[RATE_12M] > ulMaxPacket ) {
  2570. ulPacketNum = pDevice->uNumSQ3[RATE_54M] + pDevice->uNumSQ3[RATE_48M] +
  2571. pDevice->uNumSQ3[RATE_36M] + pDevice->uNumSQ3[RATE_24M] +
  2572. pDevice->uNumSQ3[RATE_18M] + pDevice->uNumSQ3[RATE_12M];
  2573. ulRatio = (ulPacketNum * 1000 / pDevice->uDiversityCnt);
  2574. //ulRatio = (pDevice->uNumSQ3[RATE_12M] * 1000 / pDevice->uDiversityCnt);
  2575. ulRatio += TOP_RATE_12M;
  2576. ulMaxPacket = pDevice->uNumSQ3[RATE_12M];
  2577. }
  2578. if ( pDevice->uNumSQ3[RATE_11M] > ulMaxPacket ) {
  2579. ulPacketNum = pDevice->uDiversityCnt - pDevice->uNumSQ3[RATE_1M] -
  2580. pDevice->uNumSQ3[RATE_2M] - pDevice->uNumSQ3[RATE_5M] -
  2581. pDevice->uNumSQ3[RATE_6M] - pDevice->uNumSQ3[RATE_9M];
  2582. ulRatio = (ulPacketNum * 1000 / pDevice->uDiversityCnt);
  2583. //ulRatio = (pDevice->uNumSQ3[RATE_11M] * 1000 / pDevice->uDiversityCnt);
  2584. ulRatio += TOP_RATE_11M;
  2585. ulMaxPacket = pDevice->uNumSQ3[RATE_11M];
  2586. }
  2587. if ( pDevice->uNumSQ3[RATE_9M] > ulMaxPacket ) {
  2588. ulPacketNum = pDevice->uDiversityCnt - pDevice->uNumSQ3[RATE_1M] -
  2589. pDevice->uNumSQ3[RATE_2M] - pDevice->uNumSQ3[RATE_5M] -
  2590. pDevice->uNumSQ3[RATE_6M];
  2591. ulRatio = (ulPacketNum * 1000 / pDevice->uDiversityCnt);
  2592. //ulRatio = (pDevice->uNumSQ3[RATE_9M] * 1000 / pDevice->uDiversityCnt);
  2593. ulRatio += TOP_RATE_9M;
  2594. ulMaxPacket = pDevice->uNumSQ3[RATE_9M];
  2595. }
  2596. if ( pDevice->uNumSQ3[RATE_6M] > ulMaxPacket ) {
  2597. ulPacketNum = pDevice->uDiversityCnt - pDevice->uNumSQ3[RATE_1M] -
  2598. pDevice->uNumSQ3[RATE_2M] - pDevice->uNumSQ3[RATE_5M];
  2599. ulRatio = (ulPacketNum * 1000 / pDevice->uDiversityCnt);
  2600. //ulRatio = (pDevice->uNumSQ3[RATE_6M] * 1000 / pDevice->uDiversityCnt);
  2601. ulRatio += TOP_RATE_6M;
  2602. ulMaxPacket = pDevice->uNumSQ3[RATE_6M];
  2603. }
  2604. if ( pDevice->uNumSQ3[RATE_5M] > ulMaxPacket ) {
  2605. ulPacketNum = pDevice->uDiversityCnt - pDevice->uNumSQ3[RATE_1M] -
  2606. pDevice->uNumSQ3[RATE_2M];
  2607. ulRatio = (ulPacketNum * 1000 / pDevice->uDiversityCnt);
  2608. //ulRatio = (pDevice->uNumSQ3[RATE_5M] * 1000 / pDevice->uDiversityCnt);
  2609. ulRatio += TOP_RATE_55M;
  2610. ulMaxPacket = pDevice->uNumSQ3[RATE_5M];
  2611. }
  2612. if ( pDevice->uNumSQ3[RATE_2M] > ulMaxPacket ) {
  2613. ulPacketNum = pDevice->uDiversityCnt - pDevice->uNumSQ3[RATE_1M];
  2614. ulRatio = (ulPacketNum * 1000 / pDevice->uDiversityCnt);
  2615. //ulRatio = (pDevice->uNumSQ3[RATE_2M] * 1000 / pDevice->uDiversityCnt);
  2616. ulRatio += TOP_RATE_2M;
  2617. ulMaxPacket = pDevice->uNumSQ3[RATE_2M];
  2618. }
  2619. if ( pDevice->uNumSQ3[RATE_1M] > ulMaxPacket ) {
  2620. ulPacketNum = pDevice->uDiversityCnt;
  2621. ulRatio = (ulPacketNum * 1000 / pDevice->uDiversityCnt);
  2622. //ulRatio = (pDevice->uNumSQ3[RATE_1M] * 1000 / pDevice->uDiversityCnt);
  2623. ulRatio += TOP_RATE_1M;
  2624. }
  2625. return ulRatio;
  2626. }
  2627. void
  2628. BBvClearAntDivSQ3Value (PSDevice pDevice)
  2629. {
  2630. unsigned int ii;
  2631. pDevice->uDiversityCnt = 0;
  2632. for (ii = 0; ii < MAX_RATE; ii++) {
  2633. pDevice->uNumSQ3[ii] = 0;
  2634. }
  2635. }
  2636. /*
  2637. * Description: Antenna Diversity
  2638. *
  2639. * Parameters:
  2640. * In:
  2641. * pDevice - Device Structure
  2642. * byRSR - RSR from received packet
  2643. * bySQ3 - SQ3 value from received packet
  2644. * Out:
  2645. * none
  2646. *
  2647. * Return Value: none
  2648. *
  2649. */
  2650. void
  2651. BBvAntennaDiversity (PSDevice pDevice, unsigned char byRxRate, unsigned char bySQ3)
  2652. {
  2653. if ((byRxRate >= MAX_RATE) || (pDevice->wAntDiversityMaxRate >= MAX_RATE)) {
  2654. return;
  2655. }
  2656. pDevice->uDiversityCnt++;
  2657. // DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "pDevice->uDiversityCnt = %d\n", (int)pDevice->uDiversityCnt);
  2658. pDevice->uNumSQ3[byRxRate]++;
  2659. if (pDevice->byAntennaState == 0) {
  2660. if (pDevice->uDiversityCnt > pDevice->ulDiversityNValue) {
  2661. DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO"ulDiversityNValue=[%d],54M-[%d]\n",
  2662. (int)pDevice->ulDiversityNValue, (int)pDevice->uNumSQ3[(int)pDevice->wAntDiversityMaxRate]);
  2663. if (pDevice->uNumSQ3[pDevice->wAntDiversityMaxRate] < pDevice->uDiversityCnt/2) {
  2664. pDevice->ulRatio_State0 = s_ulGetRatio(pDevice);
  2665. DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO"SQ3_State0, rate = [%08x]\n", (int)pDevice->ulRatio_State0);
  2666. if ( pDevice->byTMax == 0 )
  2667. return;
  2668. DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO"1.[%08x], uNumSQ3[%d]=%d, %d\n",
  2669. (int)pDevice->ulRatio_State0, (int)pDevice->wAntDiversityMaxRate,
  2670. (int)pDevice->uNumSQ3[(int)pDevice->wAntDiversityMaxRate], (int)pDevice->uDiversityCnt);
  2671. #ifdef PLICE_DEBUG
  2672. //printk("BBvAntennaDiversity1:call s_vChangeAntenna\n");
  2673. #endif
  2674. s_vChangeAntenna(pDevice);
  2675. pDevice->byAntennaState = 1;
  2676. del_timer(&pDevice->TimerSQ3Tmax3);
  2677. del_timer(&pDevice->TimerSQ3Tmax2);
  2678. pDevice->TimerSQ3Tmax1.expires = RUN_AT(pDevice->byTMax * HZ);
  2679. add_timer(&pDevice->TimerSQ3Tmax1);
  2680. } else {
  2681. pDevice->TimerSQ3Tmax3.expires = RUN_AT(pDevice->byTMax3 * HZ);
  2682. add_timer(&pDevice->TimerSQ3Tmax3);
  2683. }
  2684. BBvClearAntDivSQ3Value(pDevice);
  2685. }
  2686. } else { //byAntennaState == 1
  2687. if (pDevice->uDiversityCnt > pDevice->ulDiversityMValue) {
  2688. del_timer(&pDevice->TimerSQ3Tmax1);
  2689. pDevice->ulRatio_State1 = s_ulGetRatio(pDevice);
  2690. DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO"RX:SQ3_State1, rate0 = %08x,rate1 = %08x\n",
  2691. (int)pDevice->ulRatio_State0,(int)pDevice->ulRatio_State1);
  2692. if (pDevice->ulRatio_State1 < pDevice->ulRatio_State0) {
  2693. DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO"2.[%08x][%08x], uNumSQ3[%d]=%d, %d\n",
  2694. (int)pDevice->ulRatio_State0, (int)pDevice->ulRatio_State1,
  2695. (int)pDevice->wAntDiversityMaxRate,
  2696. (int)pDevice->uNumSQ3[(int)pDevice->wAntDiversityMaxRate], (int)pDevice->uDiversityCnt);
  2697. #ifdef PLICE_DEBUG
  2698. //printk("BBvAntennaDiversity2:call s_vChangeAntenna\n");
  2699. #endif
  2700. s_vChangeAntenna(pDevice);
  2701. pDevice->TimerSQ3Tmax3.expires = RUN_AT(pDevice->byTMax3 * HZ);
  2702. pDevice->TimerSQ3Tmax2.expires = RUN_AT(pDevice->byTMax2 * HZ);
  2703. add_timer(&pDevice->TimerSQ3Tmax3);
  2704. add_timer(&pDevice->TimerSQ3Tmax2);
  2705. }
  2706. pDevice->byAntennaState = 0;
  2707. BBvClearAntDivSQ3Value(pDevice);
  2708. }
  2709. } //byAntennaState
  2710. }
  2711. /*+
  2712. *
  2713. * Description:
  2714. * Timer for SQ3 antenna diversity
  2715. *
  2716. * Parameters:
  2717. * In:
  2718. * Out:
  2719. * none
  2720. *
  2721. * Return Value: none
  2722. *
  2723. -*/
  2724. void
  2725. TimerSQ3CallBack (
  2726. void *hDeviceContext
  2727. )
  2728. {
  2729. PSDevice pDevice = (PSDevice)hDeviceContext;
  2730. DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO"TimerSQ3CallBack...");
  2731. spin_lock_irq(&pDevice->lock);
  2732. DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO"3.[%08x][%08x], %d\n",(int)pDevice->ulRatio_State0, (int)pDevice->ulRatio_State1, (int)pDevice->uDiversityCnt);
  2733. #ifdef PLICE_DEBUG
  2734. //printk("TimerSQ3CallBack1:call s_vChangeAntenna\n");
  2735. #endif
  2736. s_vChangeAntenna(pDevice);
  2737. pDevice->byAntennaState = 0;
  2738. BBvClearAntDivSQ3Value(pDevice);
  2739. pDevice->TimerSQ3Tmax3.expires = RUN_AT(pDevice->byTMax3 * HZ);
  2740. pDevice->TimerSQ3Tmax2.expires = RUN_AT(pDevice->byTMax2 * HZ);
  2741. add_timer(&pDevice->TimerSQ3Tmax3);
  2742. add_timer(&pDevice->TimerSQ3Tmax2);
  2743. spin_unlock_irq(&pDevice->lock);
  2744. return;
  2745. }
  2746. /*+
  2747. *
  2748. * Description:
  2749. * Timer for SQ3 antenna diversity
  2750. *
  2751. * Parameters:
  2752. * In:
  2753. * pvSysSpec1
  2754. * hDeviceContext - Pointer to the adapter
  2755. * pvSysSpec2
  2756. * pvSysSpec3
  2757. * Out:
  2758. * none
  2759. *
  2760. * Return Value: none
  2761. *
  2762. -*/
  2763. void
  2764. TimerState1CallBack (
  2765. void *hDeviceContext
  2766. )
  2767. {
  2768. PSDevice pDevice = (PSDevice)hDeviceContext;
  2769. DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO"TimerState1CallBack...");
  2770. spin_lock_irq(&pDevice->lock);
  2771. if (pDevice->uDiversityCnt < pDevice->ulDiversityMValue/100) {
  2772. #ifdef PLICE_DEBUG
  2773. //printk("TimerSQ3CallBack2:call s_vChangeAntenna\n");
  2774. #endif
  2775. s_vChangeAntenna(pDevice);
  2776. pDevice->TimerSQ3Tmax3.expires = RUN_AT(pDevice->byTMax3 * HZ);
  2777. pDevice->TimerSQ3Tmax2.expires = RUN_AT(pDevice->byTMax2 * HZ);
  2778. add_timer(&pDevice->TimerSQ3Tmax3);
  2779. add_timer(&pDevice->TimerSQ3Tmax2);
  2780. } else {
  2781. pDevice->ulRatio_State1 = s_ulGetRatio(pDevice);
  2782. DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO"SQ3_State1, rate0 = %08x,rate1 = %08x\n",
  2783. (int)pDevice->ulRatio_State0,(int)pDevice->ulRatio_State1);
  2784. if ( pDevice->ulRatio_State1 < pDevice->ulRatio_State0 ) {
  2785. DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO"2.[%08x][%08x], uNumSQ3[%d]=%d, %d\n",
  2786. (int)pDevice->ulRatio_State0, (int)pDevice->ulRatio_State1,
  2787. (int)pDevice->wAntDiversityMaxRate,
  2788. (int)pDevice->uNumSQ3[(int)pDevice->wAntDiversityMaxRate], (int)pDevice->uDiversityCnt);
  2789. #ifdef PLICE_DEBUG
  2790. //printk("TimerSQ3CallBack3:call s_vChangeAntenna\n");
  2791. #endif
  2792. s_vChangeAntenna(pDevice);
  2793. pDevice->TimerSQ3Tmax3.expires = RUN_AT(pDevice->byTMax3 * HZ);
  2794. pDevice->TimerSQ3Tmax2.expires = RUN_AT(pDevice->byTMax2 * HZ);
  2795. add_timer(&pDevice->TimerSQ3Tmax3);
  2796. add_timer(&pDevice->TimerSQ3Tmax2);
  2797. }
  2798. }
  2799. pDevice->byAntennaState = 0;
  2800. BBvClearAntDivSQ3Value(pDevice);
  2801. spin_unlock_irq(&pDevice->lock);
  2802. return;
  2803. }