mxl5005s.c 126 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001300230033004300530063007300830093010301130123013301430153016301730183019302030213022302330243025302630273028302930303031303230333034303530363037303830393040304130423043304430453046304730483049305030513052305330543055305630573058305930603061306230633064306530663067306830693070307130723073307430753076307730783079308030813082308330843085308630873088308930903091309230933094309530963097309830993100310131023103310431053106310731083109311031113112311331143115311631173118311931203121312231233124312531263127312831293130313131323133313431353136313731383139314031413142314331443145314631473148314931503151315231533154315531563157315831593160316131623163316431653166316731683169317031713172317331743175317631773178317931803181318231833184318531863187318831893190319131923193319431953196319731983199320032013202320332043205320632073208320932103211321232133214321532163217321832193220322132223223322432253226322732283229323032313232323332343235323632373238323932403241324232433244324532463247324832493250325132523253325432553256325732583259326032613262326332643265326632673268326932703271327232733274327532763277327832793280328132823283328432853286328732883289329032913292329332943295329632973298329933003301330233033304330533063307330833093310331133123313331433153316331733183319332033213322332333243325332633273328332933303331333233333334333533363337333833393340334133423343334433453346334733483349335033513352335333543355335633573358335933603361336233633364336533663367336833693370337133723373337433753376337733783379338033813382338333843385338633873388338933903391339233933394339533963397339833993400340134023403340434053406340734083409341034113412341334143415341634173418341934203421342234233424342534263427342834293430343134323433343434353436343734383439344034413442344334443445344634473448344934503451345234533454345534563457345834593460346134623463346434653466346734683469347034713472347334743475347634773478347934803481348234833484348534863487348834893490349134923493349434953496349734983499350035013502350335043505350635073508350935103511351235133514351535163517351835193520352135223523352435253526352735283529353035313532353335343535353635373538353935403541354235433544354535463547354835493550355135523553355435553556355735583559356035613562356335643565356635673568356935703571357235733574357535763577357835793580358135823583358435853586358735883589359035913592359335943595359635973598359936003601360236033604360536063607360836093610361136123613361436153616361736183619362036213622362336243625362636273628362936303631363236333634363536363637363836393640364136423643364436453646364736483649365036513652365336543655365636573658365936603661366236633664366536663667366836693670367136723673367436753676367736783679368036813682368336843685368636873688368936903691369236933694369536963697369836993700370137023703370437053706370737083709371037113712371337143715371637173718371937203721372237233724372537263727372837293730373137323733373437353736373737383739374037413742374337443745374637473748374937503751375237533754375537563757375837593760376137623763376437653766376737683769377037713772377337743775377637773778377937803781378237833784378537863787378837893790379137923793379437953796379737983799380038013802380338043805380638073808380938103811381238133814381538163817381838193820382138223823382438253826382738283829383038313832383338343835383638373838383938403841384238433844384538463847384838493850385138523853385438553856385738583859386038613862386338643865386638673868386938703871387238733874387538763877387838793880388138823883388438853886388738883889389038913892389338943895389638973898389939003901390239033904390539063907390839093910391139123913391439153916391739183919392039213922392339243925392639273928392939303931393239333934393539363937393839393940394139423943394439453946394739483949395039513952395339543955395639573958395939603961396239633964396539663967396839693970397139723973397439753976397739783979398039813982398339843985398639873988398939903991399239933994399539963997399839994000400140024003400440054006400740084009401040114012401340144015401640174018401940204021402240234024402540264027402840294030403140324033403440354036403740384039404040414042404340444045404640474048404940504051405240534054405540564057405840594060406140624063406440654066406740684069407040714072407340744075407640774078407940804081408240834084408540864087408840894090409140924093409440954096409740984099410041014102410341044105410641074108410941104111411241134114411541164117411841194120
  1. /*
  2. MaxLinear MXL5005S VSB/QAM/DVBT tuner driver
  3. Copyright (C) 2008 MaxLinear
  4. Copyright (C) 2006 Steven Toth <stoth@linuxtv.org>
  5. Functions:
  6. mxl5005s_reset()
  7. mxl5005s_writereg()
  8. mxl5005s_writeregs()
  9. mxl5005s_init()
  10. mxl5005s_reconfigure()
  11. mxl5005s_AssignTunerMode()
  12. mxl5005s_set_params()
  13. mxl5005s_get_frequency()
  14. mxl5005s_get_bandwidth()
  15. mxl5005s_release()
  16. mxl5005s_attach()
  17. Copyright (C) 2008 Realtek
  18. Copyright (C) 2008 Jan Hoogenraad
  19. Functions:
  20. mxl5005s_SetRfFreqHz()
  21. This program is free software; you can redistribute it and/or modify
  22. it under the terms of the GNU General Public License as published by
  23. the Free Software Foundation; either version 2 of the License, or
  24. (at your option) any later version.
  25. This program is distributed in the hope that it will be useful,
  26. but WITHOUT ANY WARRANTY; without even the implied warranty of
  27. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  28. GNU General Public License for more details.
  29. You should have received a copy of the GNU General Public License
  30. along with this program; if not, write to the Free Software
  31. Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
  32. */
  33. /*
  34. History of this driver (Steven Toth):
  35. I was given a public release of a linux driver that included
  36. support for the MaxLinear MXL5005S silicon tuner. Analysis of
  37. the tuner driver showed clearly three things.
  38. 1. The tuner driver didn't support the LinuxTV tuner API
  39. so the code Realtek added had to be removed.
  40. 2. A significant amount of the driver is reference driver code
  41. from MaxLinear, I felt it was important to identify and
  42. preserve this.
  43. 3. New code has to be added to interface correctly with the
  44. LinuxTV API, as a regular kernel module.
  45. Other than the reference driver enum's, I've clearly marked
  46. sections of the code and retained the copyright of the
  47. respective owners.
  48. */
  49. #include <linux/kernel.h>
  50. #include <linux/init.h>
  51. #include <linux/module.h>
  52. #include <linux/string.h>
  53. #include <linux/slab.h>
  54. #include <linux/delay.h>
  55. #include "dvb_frontend.h"
  56. #include "mxl5005s.h"
  57. static int debug;
  58. #define dprintk(level, arg...) do { \
  59. if (level <= debug) \
  60. printk(arg); \
  61. } while (0)
  62. #define TUNER_REGS_NUM 104
  63. #define INITCTRL_NUM 40
  64. #ifdef _MXL_PRODUCTION
  65. #define CHCTRL_NUM 39
  66. #else
  67. #define CHCTRL_NUM 36
  68. #endif
  69. #define MXLCTRL_NUM 189
  70. #define MASTER_CONTROL_ADDR 9
  71. /* Enumeration of Master Control Register State */
  72. enum master_control_state {
  73. MC_LOAD_START = 1,
  74. MC_POWER_DOWN,
  75. MC_SYNTH_RESET,
  76. MC_SEQ_OFF
  77. };
  78. /* Enumeration of MXL5005 Tuner Modulation Type */
  79. enum {
  80. MXL_DEFAULT_MODULATION = 0,
  81. MXL_DVBT,
  82. MXL_ATSC,
  83. MXL_QAM,
  84. MXL_ANALOG_CABLE,
  85. MXL_ANALOG_OTA
  86. };
  87. /* MXL5005 Tuner Register Struct */
  88. struct TunerReg {
  89. u16 Reg_Num; /* Tuner Register Address */
  90. u16 Reg_Val; /* Current sw programmed value waiting to be written */
  91. };
  92. enum {
  93. /* Initialization Control Names */
  94. DN_IQTN_AMP_CUT = 1, /* 1 */
  95. BB_MODE, /* 2 */
  96. BB_BUF, /* 3 */
  97. BB_BUF_OA, /* 4 */
  98. BB_ALPF_BANDSELECT, /* 5 */
  99. BB_IQSWAP, /* 6 */
  100. BB_DLPF_BANDSEL, /* 7 */
  101. RFSYN_CHP_GAIN, /* 8 */
  102. RFSYN_EN_CHP_HIGAIN, /* 9 */
  103. AGC_IF, /* 10 */
  104. AGC_RF, /* 11 */
  105. IF_DIVVAL, /* 12 */
  106. IF_VCO_BIAS, /* 13 */
  107. CHCAL_INT_MOD_IF, /* 14 */
  108. CHCAL_FRAC_MOD_IF, /* 15 */
  109. DRV_RES_SEL, /* 16 */
  110. I_DRIVER, /* 17 */
  111. EN_AAF, /* 18 */
  112. EN_3P, /* 19 */
  113. EN_AUX_3P, /* 20 */
  114. SEL_AAF_BAND, /* 21 */
  115. SEQ_ENCLK16_CLK_OUT, /* 22 */
  116. SEQ_SEL4_16B, /* 23 */
  117. XTAL_CAPSELECT, /* 24 */
  118. IF_SEL_DBL, /* 25 */
  119. RFSYN_R_DIV, /* 26 */
  120. SEQ_EXTSYNTHCALIF, /* 27 */
  121. SEQ_EXTDCCAL, /* 28 */
  122. AGC_EN_RSSI, /* 29 */
  123. RFA_ENCLKRFAGC, /* 30 */
  124. RFA_RSSI_REFH, /* 31 */
  125. RFA_RSSI_REF, /* 32 */
  126. RFA_RSSI_REFL, /* 33 */
  127. RFA_FLR, /* 34 */
  128. RFA_CEIL, /* 35 */
  129. SEQ_EXTIQFSMPULSE, /* 36 */
  130. OVERRIDE_1, /* 37 */
  131. BB_INITSTATE_DLPF_TUNE, /* 38 */
  132. TG_R_DIV, /* 39 */
  133. EN_CHP_LIN_B, /* 40 */
  134. /* Channel Change Control Names */
  135. DN_POLY = 51, /* 51 */
  136. DN_RFGAIN, /* 52 */
  137. DN_CAP_RFLPF, /* 53 */
  138. DN_EN_VHFUHFBAR, /* 54 */
  139. DN_GAIN_ADJUST, /* 55 */
  140. DN_IQTNBUF_AMP, /* 56 */
  141. DN_IQTNGNBFBIAS_BST, /* 57 */
  142. RFSYN_EN_OUTMUX, /* 58 */
  143. RFSYN_SEL_VCO_OUT, /* 59 */
  144. RFSYN_SEL_VCO_HI, /* 60 */
  145. RFSYN_SEL_DIVM, /* 61 */
  146. RFSYN_RF_DIV_BIAS, /* 62 */
  147. DN_SEL_FREQ, /* 63 */
  148. RFSYN_VCO_BIAS, /* 64 */
  149. CHCAL_INT_MOD_RF, /* 65 */
  150. CHCAL_FRAC_MOD_RF, /* 66 */
  151. RFSYN_LPF_R, /* 67 */
  152. CHCAL_EN_INT_RF, /* 68 */
  153. TG_LO_DIVVAL, /* 69 */
  154. TG_LO_SELVAL, /* 70 */
  155. TG_DIV_VAL, /* 71 */
  156. TG_VCO_BIAS, /* 72 */
  157. SEQ_EXTPOWERUP, /* 73 */
  158. OVERRIDE_2, /* 74 */
  159. OVERRIDE_3, /* 75 */
  160. OVERRIDE_4, /* 76 */
  161. SEQ_FSM_PULSE, /* 77 */
  162. GPIO_4B, /* 78 */
  163. GPIO_3B, /* 79 */
  164. GPIO_4, /* 80 */
  165. GPIO_3, /* 81 */
  166. GPIO_1B, /* 82 */
  167. DAC_A_ENABLE, /* 83 */
  168. DAC_B_ENABLE, /* 84 */
  169. DAC_DIN_A, /* 85 */
  170. DAC_DIN_B, /* 86 */
  171. #ifdef _MXL_PRODUCTION
  172. RFSYN_EN_DIV, /* 87 */
  173. RFSYN_DIVM, /* 88 */
  174. DN_BYPASS_AGC_I2C /* 89 */
  175. #endif
  176. };
  177. /*
  178. * The following context is source code provided by MaxLinear.
  179. * MaxLinear source code - Common_MXL.h (?)
  180. */
  181. /* Constants */
  182. #define MXL5005S_REG_WRITING_TABLE_LEN_MAX 104
  183. #define MXL5005S_LATCH_BYTE 0xfe
  184. /* Register address, MSB, and LSB */
  185. #define MXL5005S_BB_IQSWAP_ADDR 59
  186. #define MXL5005S_BB_IQSWAP_MSB 0
  187. #define MXL5005S_BB_IQSWAP_LSB 0
  188. #define MXL5005S_BB_DLPF_BANDSEL_ADDR 53
  189. #define MXL5005S_BB_DLPF_BANDSEL_MSB 4
  190. #define MXL5005S_BB_DLPF_BANDSEL_LSB 3
  191. /* Standard modes */
  192. enum {
  193. MXL5005S_STANDARD_DVBT,
  194. MXL5005S_STANDARD_ATSC,
  195. };
  196. #define MXL5005S_STANDARD_MODE_NUM 2
  197. /* Bandwidth modes */
  198. enum {
  199. MXL5005S_BANDWIDTH_6MHZ = 6000000,
  200. MXL5005S_BANDWIDTH_7MHZ = 7000000,
  201. MXL5005S_BANDWIDTH_8MHZ = 8000000,
  202. };
  203. #define MXL5005S_BANDWIDTH_MODE_NUM 3
  204. /* MXL5005 Tuner Control Struct */
  205. struct TunerControl {
  206. u16 Ctrl_Num; /* Control Number */
  207. u16 size; /* Number of bits to represent Value */
  208. u16 addr[25]; /* Array of Tuner Register Address for each bit pos */
  209. u16 bit[25]; /* Array of bit pos in Reg Addr for each bit pos */
  210. u16 val[25]; /* Binary representation of Value */
  211. };
  212. /* MXL5005 Tuner Struct */
  213. struct mxl5005s_state {
  214. u8 Mode; /* 0: Analog Mode ; 1: Digital Mode */
  215. u8 IF_Mode; /* for Analog Mode, 0: zero IF; 1: low IF */
  216. u32 Chan_Bandwidth; /* filter channel bandwidth (6, 7, 8) */
  217. u32 IF_OUT; /* Desired IF Out Frequency */
  218. u16 IF_OUT_LOAD; /* IF Out Load Resistor (200/300 Ohms) */
  219. u32 RF_IN; /* RF Input Frequency */
  220. u32 Fxtal; /* XTAL Frequency */
  221. u8 AGC_Mode; /* AGC Mode 0: Dual AGC; 1: Single AGC */
  222. u16 TOP; /* Value: take over point */
  223. u8 CLOCK_OUT; /* 0: turn off clk out; 1: turn on clock out */
  224. u8 DIV_OUT; /* 4MHz or 16MHz */
  225. u8 CAPSELECT; /* 0: disable On-Chip pulling cap; 1: enable */
  226. u8 EN_RSSI; /* 0: disable RSSI; 1: enable RSSI */
  227. /* Modulation Type; */
  228. /* 0 - Default; 1 - DVB-T; 2 - ATSC; 3 - QAM; 4 - Analog Cable */
  229. u8 Mod_Type;
  230. /* Tracking Filter Type */
  231. /* 0 - Default; 1 - Off; 2 - Type C; 3 - Type C-H */
  232. u8 TF_Type;
  233. /* Calculated Settings */
  234. u32 RF_LO; /* Synth RF LO Frequency */
  235. u32 IF_LO; /* Synth IF LO Frequency */
  236. u32 TG_LO; /* Synth TG_LO Frequency */
  237. /* Pointers to ControlName Arrays */
  238. u16 Init_Ctrl_Num; /* Number of INIT Control Names */
  239. struct TunerControl
  240. Init_Ctrl[INITCTRL_NUM]; /* INIT Control Names Array Pointer */
  241. u16 CH_Ctrl_Num; /* Number of CH Control Names */
  242. struct TunerControl
  243. CH_Ctrl[CHCTRL_NUM]; /* CH Control Name Array Pointer */
  244. u16 MXL_Ctrl_Num; /* Number of MXL Control Names */
  245. struct TunerControl
  246. MXL_Ctrl[MXLCTRL_NUM]; /* MXL Control Name Array Pointer */
  247. /* Pointer to Tuner Register Array */
  248. u16 TunerRegs_Num; /* Number of Tuner Registers */
  249. struct TunerReg
  250. TunerRegs[TUNER_REGS_NUM]; /* Tuner Register Array Pointer */
  251. /* Linux driver framework specific */
  252. struct mxl5005s_config *config;
  253. struct dvb_frontend *frontend;
  254. struct i2c_adapter *i2c;
  255. /* Cache values */
  256. u32 current_mode;
  257. };
  258. static u16 MXL_GetMasterControl(u8 *MasterReg, int state);
  259. static u16 MXL_ControlWrite(struct dvb_frontend *fe, u16 ControlNum, u32 value);
  260. static u16 MXL_ControlRead(struct dvb_frontend *fe, u16 controlNum, u32 *value);
  261. static void MXL_RegWriteBit(struct dvb_frontend *fe, u8 address, u8 bit,
  262. u8 bitVal);
  263. static u16 MXL_GetCHRegister(struct dvb_frontend *fe, u8 *RegNum,
  264. u8 *RegVal, int *count);
  265. static u32 MXL_Ceiling(u32 value, u32 resolution);
  266. static u16 MXL_RegRead(struct dvb_frontend *fe, u8 RegNum, u8 *RegVal);
  267. static u16 MXL_ControlWrite_Group(struct dvb_frontend *fe, u16 controlNum,
  268. u32 value, u16 controlGroup);
  269. static u16 MXL_SetGPIO(struct dvb_frontend *fe, u8 GPIO_Num, u8 GPIO_Val);
  270. static u16 MXL_GetInitRegister(struct dvb_frontend *fe, u8 *RegNum,
  271. u8 *RegVal, int *count);
  272. static u16 MXL_TuneRF(struct dvb_frontend *fe, u32 RF_Freq);
  273. static void MXL_SynthIFLO_Calc(struct dvb_frontend *fe);
  274. static void MXL_SynthRFTGLO_Calc(struct dvb_frontend *fe);
  275. static u16 MXL_GetCHRegister_ZeroIF(struct dvb_frontend *fe, u8 *RegNum,
  276. u8 *RegVal, int *count);
  277. static int mxl5005s_writeregs(struct dvb_frontend *fe, u8 *addrtable,
  278. u8 *datatable, u8 len);
  279. static u16 MXL_IFSynthInit(struct dvb_frontend *fe);
  280. static int mxl5005s_AssignTunerMode(struct dvb_frontend *fe, u32 mod_type,
  281. u32 bandwidth);
  282. static int mxl5005s_reconfigure(struct dvb_frontend *fe, u32 mod_type,
  283. u32 bandwidth);
  284. /* ----------------------------------------------------------------
  285. * Begin: Custom code salvaged from the Realtek driver.
  286. * Copyright (C) 2008 Realtek
  287. * Copyright (C) 2008 Jan Hoogenraad
  288. * This code is placed under the terms of the GNU General Public License
  289. *
  290. * Released by Realtek under GPLv2.
  291. * Thanks to Realtek for a lot of support we received !
  292. *
  293. * Revision: 080314 - original version
  294. */
  295. static int mxl5005s_SetRfFreqHz(struct dvb_frontend *fe, unsigned long RfFreqHz)
  296. {
  297. struct mxl5005s_state *state = fe->tuner_priv;
  298. unsigned char AddrTable[MXL5005S_REG_WRITING_TABLE_LEN_MAX];
  299. unsigned char ByteTable[MXL5005S_REG_WRITING_TABLE_LEN_MAX];
  300. int TableLen;
  301. u32 IfDivval = 0;
  302. unsigned char MasterControlByte;
  303. dprintk(1, "%s() freq=%ld\n", __func__, RfFreqHz);
  304. /* Set MxL5005S tuner RF frequency according to example code. */
  305. /* Tuner RF frequency setting stage 0 */
  306. MXL_GetMasterControl(ByteTable, MC_SYNTH_RESET);
  307. AddrTable[0] = MASTER_CONTROL_ADDR;
  308. ByteTable[0] |= state->config->AgcMasterByte;
  309. mxl5005s_writeregs(fe, AddrTable, ByteTable, 1);
  310. /* Tuner RF frequency setting stage 1 */
  311. MXL_TuneRF(fe, RfFreqHz);
  312. MXL_ControlRead(fe, IF_DIVVAL, &IfDivval);
  313. MXL_ControlWrite(fe, SEQ_FSM_PULSE, 0);
  314. MXL_ControlWrite(fe, SEQ_EXTPOWERUP, 1);
  315. MXL_ControlWrite(fe, IF_DIVVAL, 8);
  316. MXL_GetCHRegister(fe, AddrTable, ByteTable, &TableLen);
  317. MXL_GetMasterControl(&MasterControlByte, MC_LOAD_START);
  318. AddrTable[TableLen] = MASTER_CONTROL_ADDR ;
  319. ByteTable[TableLen] = MasterControlByte |
  320. state->config->AgcMasterByte;
  321. TableLen += 1;
  322. mxl5005s_writeregs(fe, AddrTable, ByteTable, TableLen);
  323. /* Wait 30 ms. */
  324. msleep(150);
  325. /* Tuner RF frequency setting stage 2 */
  326. MXL_ControlWrite(fe, SEQ_FSM_PULSE, 1);
  327. MXL_ControlWrite(fe, IF_DIVVAL, IfDivval);
  328. MXL_GetCHRegister_ZeroIF(fe, AddrTable, ByteTable, &TableLen);
  329. MXL_GetMasterControl(&MasterControlByte, MC_LOAD_START);
  330. AddrTable[TableLen] = MASTER_CONTROL_ADDR ;
  331. ByteTable[TableLen] = MasterControlByte |
  332. state->config->AgcMasterByte ;
  333. TableLen += 1;
  334. mxl5005s_writeregs(fe, AddrTable, ByteTable, TableLen);
  335. msleep(100);
  336. return 0;
  337. }
  338. /* End: Custom code taken from the Realtek driver */
  339. /* ----------------------------------------------------------------
  340. * Begin: Reference driver code found in the Realtek driver.
  341. * Copyright (C) 2008 MaxLinear
  342. */
  343. static u16 MXL5005_RegisterInit(struct dvb_frontend *fe)
  344. {
  345. struct mxl5005s_state *state = fe->tuner_priv;
  346. state->TunerRegs_Num = TUNER_REGS_NUM ;
  347. state->TunerRegs[0].Reg_Num = 9 ;
  348. state->TunerRegs[0].Reg_Val = 0x40 ;
  349. state->TunerRegs[1].Reg_Num = 11 ;
  350. state->TunerRegs[1].Reg_Val = 0x19 ;
  351. state->TunerRegs[2].Reg_Num = 12 ;
  352. state->TunerRegs[2].Reg_Val = 0x60 ;
  353. state->TunerRegs[3].Reg_Num = 13 ;
  354. state->TunerRegs[3].Reg_Val = 0x00 ;
  355. state->TunerRegs[4].Reg_Num = 14 ;
  356. state->TunerRegs[4].Reg_Val = 0x00 ;
  357. state->TunerRegs[5].Reg_Num = 15 ;
  358. state->TunerRegs[5].Reg_Val = 0xC0 ;
  359. state->TunerRegs[6].Reg_Num = 16 ;
  360. state->TunerRegs[6].Reg_Val = 0x00 ;
  361. state->TunerRegs[7].Reg_Num = 17 ;
  362. state->TunerRegs[7].Reg_Val = 0x00 ;
  363. state->TunerRegs[8].Reg_Num = 18 ;
  364. state->TunerRegs[8].Reg_Val = 0x00 ;
  365. state->TunerRegs[9].Reg_Num = 19 ;
  366. state->TunerRegs[9].Reg_Val = 0x34 ;
  367. state->TunerRegs[10].Reg_Num = 21 ;
  368. state->TunerRegs[10].Reg_Val = 0x00 ;
  369. state->TunerRegs[11].Reg_Num = 22 ;
  370. state->TunerRegs[11].Reg_Val = 0x6B ;
  371. state->TunerRegs[12].Reg_Num = 23 ;
  372. state->TunerRegs[12].Reg_Val = 0x35 ;
  373. state->TunerRegs[13].Reg_Num = 24 ;
  374. state->TunerRegs[13].Reg_Val = 0x70 ;
  375. state->TunerRegs[14].Reg_Num = 25 ;
  376. state->TunerRegs[14].Reg_Val = 0x3E ;
  377. state->TunerRegs[15].Reg_Num = 26 ;
  378. state->TunerRegs[15].Reg_Val = 0x82 ;
  379. state->TunerRegs[16].Reg_Num = 31 ;
  380. state->TunerRegs[16].Reg_Val = 0x00 ;
  381. state->TunerRegs[17].Reg_Num = 32 ;
  382. state->TunerRegs[17].Reg_Val = 0x40 ;
  383. state->TunerRegs[18].Reg_Num = 33 ;
  384. state->TunerRegs[18].Reg_Val = 0x53 ;
  385. state->TunerRegs[19].Reg_Num = 34 ;
  386. state->TunerRegs[19].Reg_Val = 0x81 ;
  387. state->TunerRegs[20].Reg_Num = 35 ;
  388. state->TunerRegs[20].Reg_Val = 0xC9 ;
  389. state->TunerRegs[21].Reg_Num = 36 ;
  390. state->TunerRegs[21].Reg_Val = 0x01 ;
  391. state->TunerRegs[22].Reg_Num = 37 ;
  392. state->TunerRegs[22].Reg_Val = 0x00 ;
  393. state->TunerRegs[23].Reg_Num = 41 ;
  394. state->TunerRegs[23].Reg_Val = 0x00 ;
  395. state->TunerRegs[24].Reg_Num = 42 ;
  396. state->TunerRegs[24].Reg_Val = 0xF8 ;
  397. state->TunerRegs[25].Reg_Num = 43 ;
  398. state->TunerRegs[25].Reg_Val = 0x43 ;
  399. state->TunerRegs[26].Reg_Num = 44 ;
  400. state->TunerRegs[26].Reg_Val = 0x20 ;
  401. state->TunerRegs[27].Reg_Num = 45 ;
  402. state->TunerRegs[27].Reg_Val = 0x80 ;
  403. state->TunerRegs[28].Reg_Num = 46 ;
  404. state->TunerRegs[28].Reg_Val = 0x88 ;
  405. state->TunerRegs[29].Reg_Num = 47 ;
  406. state->TunerRegs[29].Reg_Val = 0x86 ;
  407. state->TunerRegs[30].Reg_Num = 48 ;
  408. state->TunerRegs[30].Reg_Val = 0x00 ;
  409. state->TunerRegs[31].Reg_Num = 49 ;
  410. state->TunerRegs[31].Reg_Val = 0x00 ;
  411. state->TunerRegs[32].Reg_Num = 53 ;
  412. state->TunerRegs[32].Reg_Val = 0x94 ;
  413. state->TunerRegs[33].Reg_Num = 54 ;
  414. state->TunerRegs[33].Reg_Val = 0xFA ;
  415. state->TunerRegs[34].Reg_Num = 55 ;
  416. state->TunerRegs[34].Reg_Val = 0x92 ;
  417. state->TunerRegs[35].Reg_Num = 56 ;
  418. state->TunerRegs[35].Reg_Val = 0x80 ;
  419. state->TunerRegs[36].Reg_Num = 57 ;
  420. state->TunerRegs[36].Reg_Val = 0x41 ;
  421. state->TunerRegs[37].Reg_Num = 58 ;
  422. state->TunerRegs[37].Reg_Val = 0xDB ;
  423. state->TunerRegs[38].Reg_Num = 59 ;
  424. state->TunerRegs[38].Reg_Val = 0x00 ;
  425. state->TunerRegs[39].Reg_Num = 60 ;
  426. state->TunerRegs[39].Reg_Val = 0x00 ;
  427. state->TunerRegs[40].Reg_Num = 61 ;
  428. state->TunerRegs[40].Reg_Val = 0x00 ;
  429. state->TunerRegs[41].Reg_Num = 62 ;
  430. state->TunerRegs[41].Reg_Val = 0x00 ;
  431. state->TunerRegs[42].Reg_Num = 65 ;
  432. state->TunerRegs[42].Reg_Val = 0xF8 ;
  433. state->TunerRegs[43].Reg_Num = 66 ;
  434. state->TunerRegs[43].Reg_Val = 0xE4 ;
  435. state->TunerRegs[44].Reg_Num = 67 ;
  436. state->TunerRegs[44].Reg_Val = 0x90 ;
  437. state->TunerRegs[45].Reg_Num = 68 ;
  438. state->TunerRegs[45].Reg_Val = 0xC0 ;
  439. state->TunerRegs[46].Reg_Num = 69 ;
  440. state->TunerRegs[46].Reg_Val = 0x01 ;
  441. state->TunerRegs[47].Reg_Num = 70 ;
  442. state->TunerRegs[47].Reg_Val = 0x50 ;
  443. state->TunerRegs[48].Reg_Num = 71 ;
  444. state->TunerRegs[48].Reg_Val = 0x06 ;
  445. state->TunerRegs[49].Reg_Num = 72 ;
  446. state->TunerRegs[49].Reg_Val = 0x00 ;
  447. state->TunerRegs[50].Reg_Num = 73 ;
  448. state->TunerRegs[50].Reg_Val = 0x20 ;
  449. state->TunerRegs[51].Reg_Num = 76 ;
  450. state->TunerRegs[51].Reg_Val = 0xBB ;
  451. state->TunerRegs[52].Reg_Num = 77 ;
  452. state->TunerRegs[52].Reg_Val = 0x13 ;
  453. state->TunerRegs[53].Reg_Num = 81 ;
  454. state->TunerRegs[53].Reg_Val = 0x04 ;
  455. state->TunerRegs[54].Reg_Num = 82 ;
  456. state->TunerRegs[54].Reg_Val = 0x75 ;
  457. state->TunerRegs[55].Reg_Num = 83 ;
  458. state->TunerRegs[55].Reg_Val = 0x00 ;
  459. state->TunerRegs[56].Reg_Num = 84 ;
  460. state->TunerRegs[56].Reg_Val = 0x00 ;
  461. state->TunerRegs[57].Reg_Num = 85 ;
  462. state->TunerRegs[57].Reg_Val = 0x00 ;
  463. state->TunerRegs[58].Reg_Num = 91 ;
  464. state->TunerRegs[58].Reg_Val = 0x70 ;
  465. state->TunerRegs[59].Reg_Num = 92 ;
  466. state->TunerRegs[59].Reg_Val = 0x00 ;
  467. state->TunerRegs[60].Reg_Num = 93 ;
  468. state->TunerRegs[60].Reg_Val = 0x00 ;
  469. state->TunerRegs[61].Reg_Num = 94 ;
  470. state->TunerRegs[61].Reg_Val = 0x00 ;
  471. state->TunerRegs[62].Reg_Num = 95 ;
  472. state->TunerRegs[62].Reg_Val = 0x0C ;
  473. state->TunerRegs[63].Reg_Num = 96 ;
  474. state->TunerRegs[63].Reg_Val = 0x00 ;
  475. state->TunerRegs[64].Reg_Num = 97 ;
  476. state->TunerRegs[64].Reg_Val = 0x00 ;
  477. state->TunerRegs[65].Reg_Num = 98 ;
  478. state->TunerRegs[65].Reg_Val = 0xE2 ;
  479. state->TunerRegs[66].Reg_Num = 99 ;
  480. state->TunerRegs[66].Reg_Val = 0x00 ;
  481. state->TunerRegs[67].Reg_Num = 100 ;
  482. state->TunerRegs[67].Reg_Val = 0x00 ;
  483. state->TunerRegs[68].Reg_Num = 101 ;
  484. state->TunerRegs[68].Reg_Val = 0x12 ;
  485. state->TunerRegs[69].Reg_Num = 102 ;
  486. state->TunerRegs[69].Reg_Val = 0x80 ;
  487. state->TunerRegs[70].Reg_Num = 103 ;
  488. state->TunerRegs[70].Reg_Val = 0x32 ;
  489. state->TunerRegs[71].Reg_Num = 104 ;
  490. state->TunerRegs[71].Reg_Val = 0xB4 ;
  491. state->TunerRegs[72].Reg_Num = 105 ;
  492. state->TunerRegs[72].Reg_Val = 0x60 ;
  493. state->TunerRegs[73].Reg_Num = 106 ;
  494. state->TunerRegs[73].Reg_Val = 0x83 ;
  495. state->TunerRegs[74].Reg_Num = 107 ;
  496. state->TunerRegs[74].Reg_Val = 0x84 ;
  497. state->TunerRegs[75].Reg_Num = 108 ;
  498. state->TunerRegs[75].Reg_Val = 0x9C ;
  499. state->TunerRegs[76].Reg_Num = 109 ;
  500. state->TunerRegs[76].Reg_Val = 0x02 ;
  501. state->TunerRegs[77].Reg_Num = 110 ;
  502. state->TunerRegs[77].Reg_Val = 0x81 ;
  503. state->TunerRegs[78].Reg_Num = 111 ;
  504. state->TunerRegs[78].Reg_Val = 0xC0 ;
  505. state->TunerRegs[79].Reg_Num = 112 ;
  506. state->TunerRegs[79].Reg_Val = 0x10 ;
  507. state->TunerRegs[80].Reg_Num = 131 ;
  508. state->TunerRegs[80].Reg_Val = 0x8A ;
  509. state->TunerRegs[81].Reg_Num = 132 ;
  510. state->TunerRegs[81].Reg_Val = 0x10 ;
  511. state->TunerRegs[82].Reg_Num = 133 ;
  512. state->TunerRegs[82].Reg_Val = 0x24 ;
  513. state->TunerRegs[83].Reg_Num = 134 ;
  514. state->TunerRegs[83].Reg_Val = 0x00 ;
  515. state->TunerRegs[84].Reg_Num = 135 ;
  516. state->TunerRegs[84].Reg_Val = 0x00 ;
  517. state->TunerRegs[85].Reg_Num = 136 ;
  518. state->TunerRegs[85].Reg_Val = 0x7E ;
  519. state->TunerRegs[86].Reg_Num = 137 ;
  520. state->TunerRegs[86].Reg_Val = 0x40 ;
  521. state->TunerRegs[87].Reg_Num = 138 ;
  522. state->TunerRegs[87].Reg_Val = 0x38 ;
  523. state->TunerRegs[88].Reg_Num = 146 ;
  524. state->TunerRegs[88].Reg_Val = 0xF6 ;
  525. state->TunerRegs[89].Reg_Num = 147 ;
  526. state->TunerRegs[89].Reg_Val = 0x1A ;
  527. state->TunerRegs[90].Reg_Num = 148 ;
  528. state->TunerRegs[90].Reg_Val = 0x62 ;
  529. state->TunerRegs[91].Reg_Num = 149 ;
  530. state->TunerRegs[91].Reg_Val = 0x33 ;
  531. state->TunerRegs[92].Reg_Num = 150 ;
  532. state->TunerRegs[92].Reg_Val = 0x80 ;
  533. state->TunerRegs[93].Reg_Num = 156 ;
  534. state->TunerRegs[93].Reg_Val = 0x56 ;
  535. state->TunerRegs[94].Reg_Num = 157 ;
  536. state->TunerRegs[94].Reg_Val = 0x17 ;
  537. state->TunerRegs[95].Reg_Num = 158 ;
  538. state->TunerRegs[95].Reg_Val = 0xA9 ;
  539. state->TunerRegs[96].Reg_Num = 159 ;
  540. state->TunerRegs[96].Reg_Val = 0x00 ;
  541. state->TunerRegs[97].Reg_Num = 160 ;
  542. state->TunerRegs[97].Reg_Val = 0x00 ;
  543. state->TunerRegs[98].Reg_Num = 161 ;
  544. state->TunerRegs[98].Reg_Val = 0x00 ;
  545. state->TunerRegs[99].Reg_Num = 162 ;
  546. state->TunerRegs[99].Reg_Val = 0x40 ;
  547. state->TunerRegs[100].Reg_Num = 166 ;
  548. state->TunerRegs[100].Reg_Val = 0xAE ;
  549. state->TunerRegs[101].Reg_Num = 167 ;
  550. state->TunerRegs[101].Reg_Val = 0x1B ;
  551. state->TunerRegs[102].Reg_Num = 168 ;
  552. state->TunerRegs[102].Reg_Val = 0xF2 ;
  553. state->TunerRegs[103].Reg_Num = 195 ;
  554. state->TunerRegs[103].Reg_Val = 0x00 ;
  555. return 0 ;
  556. }
  557. static u16 MXL5005_ControlInit(struct dvb_frontend *fe)
  558. {
  559. struct mxl5005s_state *state = fe->tuner_priv;
  560. state->Init_Ctrl_Num = INITCTRL_NUM;
  561. state->Init_Ctrl[0].Ctrl_Num = DN_IQTN_AMP_CUT ;
  562. state->Init_Ctrl[0].size = 1 ;
  563. state->Init_Ctrl[0].addr[0] = 73;
  564. state->Init_Ctrl[0].bit[0] = 7;
  565. state->Init_Ctrl[0].val[0] = 0;
  566. state->Init_Ctrl[1].Ctrl_Num = BB_MODE ;
  567. state->Init_Ctrl[1].size = 1 ;
  568. state->Init_Ctrl[1].addr[0] = 53;
  569. state->Init_Ctrl[1].bit[0] = 2;
  570. state->Init_Ctrl[1].val[0] = 1;
  571. state->Init_Ctrl[2].Ctrl_Num = BB_BUF ;
  572. state->Init_Ctrl[2].size = 2 ;
  573. state->Init_Ctrl[2].addr[0] = 53;
  574. state->Init_Ctrl[2].bit[0] = 1;
  575. state->Init_Ctrl[2].val[0] = 0;
  576. state->Init_Ctrl[2].addr[1] = 57;
  577. state->Init_Ctrl[2].bit[1] = 0;
  578. state->Init_Ctrl[2].val[1] = 1;
  579. state->Init_Ctrl[3].Ctrl_Num = BB_BUF_OA ;
  580. state->Init_Ctrl[3].size = 1 ;
  581. state->Init_Ctrl[3].addr[0] = 53;
  582. state->Init_Ctrl[3].bit[0] = 0;
  583. state->Init_Ctrl[3].val[0] = 0;
  584. state->Init_Ctrl[4].Ctrl_Num = BB_ALPF_BANDSELECT ;
  585. state->Init_Ctrl[4].size = 3 ;
  586. state->Init_Ctrl[4].addr[0] = 53;
  587. state->Init_Ctrl[4].bit[0] = 5;
  588. state->Init_Ctrl[4].val[0] = 0;
  589. state->Init_Ctrl[4].addr[1] = 53;
  590. state->Init_Ctrl[4].bit[1] = 6;
  591. state->Init_Ctrl[4].val[1] = 0;
  592. state->Init_Ctrl[4].addr[2] = 53;
  593. state->Init_Ctrl[4].bit[2] = 7;
  594. state->Init_Ctrl[4].val[2] = 1;
  595. state->Init_Ctrl[5].Ctrl_Num = BB_IQSWAP ;
  596. state->Init_Ctrl[5].size = 1 ;
  597. state->Init_Ctrl[5].addr[0] = 59;
  598. state->Init_Ctrl[5].bit[0] = 0;
  599. state->Init_Ctrl[5].val[0] = 0;
  600. state->Init_Ctrl[6].Ctrl_Num = BB_DLPF_BANDSEL ;
  601. state->Init_Ctrl[6].size = 2 ;
  602. state->Init_Ctrl[6].addr[0] = 53;
  603. state->Init_Ctrl[6].bit[0] = 3;
  604. state->Init_Ctrl[6].val[0] = 0;
  605. state->Init_Ctrl[6].addr[1] = 53;
  606. state->Init_Ctrl[6].bit[1] = 4;
  607. state->Init_Ctrl[6].val[1] = 1;
  608. state->Init_Ctrl[7].Ctrl_Num = RFSYN_CHP_GAIN ;
  609. state->Init_Ctrl[7].size = 4 ;
  610. state->Init_Ctrl[7].addr[0] = 22;
  611. state->Init_Ctrl[7].bit[0] = 4;
  612. state->Init_Ctrl[7].val[0] = 0;
  613. state->Init_Ctrl[7].addr[1] = 22;
  614. state->Init_Ctrl[7].bit[1] = 5;
  615. state->Init_Ctrl[7].val[1] = 1;
  616. state->Init_Ctrl[7].addr[2] = 22;
  617. state->Init_Ctrl[7].bit[2] = 6;
  618. state->Init_Ctrl[7].val[2] = 1;
  619. state->Init_Ctrl[7].addr[3] = 22;
  620. state->Init_Ctrl[7].bit[3] = 7;
  621. state->Init_Ctrl[7].val[3] = 0;
  622. state->Init_Ctrl[8].Ctrl_Num = RFSYN_EN_CHP_HIGAIN ;
  623. state->Init_Ctrl[8].size = 1 ;
  624. state->Init_Ctrl[8].addr[0] = 22;
  625. state->Init_Ctrl[8].bit[0] = 2;
  626. state->Init_Ctrl[8].val[0] = 0;
  627. state->Init_Ctrl[9].Ctrl_Num = AGC_IF ;
  628. state->Init_Ctrl[9].size = 4 ;
  629. state->Init_Ctrl[9].addr[0] = 76;
  630. state->Init_Ctrl[9].bit[0] = 0;
  631. state->Init_Ctrl[9].val[0] = 1;
  632. state->Init_Ctrl[9].addr[1] = 76;
  633. state->Init_Ctrl[9].bit[1] = 1;
  634. state->Init_Ctrl[9].val[1] = 1;
  635. state->Init_Ctrl[9].addr[2] = 76;
  636. state->Init_Ctrl[9].bit[2] = 2;
  637. state->Init_Ctrl[9].val[2] = 0;
  638. state->Init_Ctrl[9].addr[3] = 76;
  639. state->Init_Ctrl[9].bit[3] = 3;
  640. state->Init_Ctrl[9].val[3] = 1;
  641. state->Init_Ctrl[10].Ctrl_Num = AGC_RF ;
  642. state->Init_Ctrl[10].size = 4 ;
  643. state->Init_Ctrl[10].addr[0] = 76;
  644. state->Init_Ctrl[10].bit[0] = 4;
  645. state->Init_Ctrl[10].val[0] = 1;
  646. state->Init_Ctrl[10].addr[1] = 76;
  647. state->Init_Ctrl[10].bit[1] = 5;
  648. state->Init_Ctrl[10].val[1] = 1;
  649. state->Init_Ctrl[10].addr[2] = 76;
  650. state->Init_Ctrl[10].bit[2] = 6;
  651. state->Init_Ctrl[10].val[2] = 0;
  652. state->Init_Ctrl[10].addr[3] = 76;
  653. state->Init_Ctrl[10].bit[3] = 7;
  654. state->Init_Ctrl[10].val[3] = 1;
  655. state->Init_Ctrl[11].Ctrl_Num = IF_DIVVAL ;
  656. state->Init_Ctrl[11].size = 5 ;
  657. state->Init_Ctrl[11].addr[0] = 43;
  658. state->Init_Ctrl[11].bit[0] = 3;
  659. state->Init_Ctrl[11].val[0] = 0;
  660. state->Init_Ctrl[11].addr[1] = 43;
  661. state->Init_Ctrl[11].bit[1] = 4;
  662. state->Init_Ctrl[11].val[1] = 0;
  663. state->Init_Ctrl[11].addr[2] = 43;
  664. state->Init_Ctrl[11].bit[2] = 5;
  665. state->Init_Ctrl[11].val[2] = 0;
  666. state->Init_Ctrl[11].addr[3] = 43;
  667. state->Init_Ctrl[11].bit[3] = 6;
  668. state->Init_Ctrl[11].val[3] = 1;
  669. state->Init_Ctrl[11].addr[4] = 43;
  670. state->Init_Ctrl[11].bit[4] = 7;
  671. state->Init_Ctrl[11].val[4] = 0;
  672. state->Init_Ctrl[12].Ctrl_Num = IF_VCO_BIAS ;
  673. state->Init_Ctrl[12].size = 6 ;
  674. state->Init_Ctrl[12].addr[0] = 44;
  675. state->Init_Ctrl[12].bit[0] = 2;
  676. state->Init_Ctrl[12].val[0] = 0;
  677. state->Init_Ctrl[12].addr[1] = 44;
  678. state->Init_Ctrl[12].bit[1] = 3;
  679. state->Init_Ctrl[12].val[1] = 0;
  680. state->Init_Ctrl[12].addr[2] = 44;
  681. state->Init_Ctrl[12].bit[2] = 4;
  682. state->Init_Ctrl[12].val[2] = 0;
  683. state->Init_Ctrl[12].addr[3] = 44;
  684. state->Init_Ctrl[12].bit[3] = 5;
  685. state->Init_Ctrl[12].val[3] = 1;
  686. state->Init_Ctrl[12].addr[4] = 44;
  687. state->Init_Ctrl[12].bit[4] = 6;
  688. state->Init_Ctrl[12].val[4] = 0;
  689. state->Init_Ctrl[12].addr[5] = 44;
  690. state->Init_Ctrl[12].bit[5] = 7;
  691. state->Init_Ctrl[12].val[5] = 0;
  692. state->Init_Ctrl[13].Ctrl_Num = CHCAL_INT_MOD_IF ;
  693. state->Init_Ctrl[13].size = 7 ;
  694. state->Init_Ctrl[13].addr[0] = 11;
  695. state->Init_Ctrl[13].bit[0] = 0;
  696. state->Init_Ctrl[13].val[0] = 1;
  697. state->Init_Ctrl[13].addr[1] = 11;
  698. state->Init_Ctrl[13].bit[1] = 1;
  699. state->Init_Ctrl[13].val[1] = 0;
  700. state->Init_Ctrl[13].addr[2] = 11;
  701. state->Init_Ctrl[13].bit[2] = 2;
  702. state->Init_Ctrl[13].val[2] = 0;
  703. state->Init_Ctrl[13].addr[3] = 11;
  704. state->Init_Ctrl[13].bit[3] = 3;
  705. state->Init_Ctrl[13].val[3] = 1;
  706. state->Init_Ctrl[13].addr[4] = 11;
  707. state->Init_Ctrl[13].bit[4] = 4;
  708. state->Init_Ctrl[13].val[4] = 1;
  709. state->Init_Ctrl[13].addr[5] = 11;
  710. state->Init_Ctrl[13].bit[5] = 5;
  711. state->Init_Ctrl[13].val[5] = 0;
  712. state->Init_Ctrl[13].addr[6] = 11;
  713. state->Init_Ctrl[13].bit[6] = 6;
  714. state->Init_Ctrl[13].val[6] = 0;
  715. state->Init_Ctrl[14].Ctrl_Num = CHCAL_FRAC_MOD_IF ;
  716. state->Init_Ctrl[14].size = 16 ;
  717. state->Init_Ctrl[14].addr[0] = 13;
  718. state->Init_Ctrl[14].bit[0] = 0;
  719. state->Init_Ctrl[14].val[0] = 0;
  720. state->Init_Ctrl[14].addr[1] = 13;
  721. state->Init_Ctrl[14].bit[1] = 1;
  722. state->Init_Ctrl[14].val[1] = 0;
  723. state->Init_Ctrl[14].addr[2] = 13;
  724. state->Init_Ctrl[14].bit[2] = 2;
  725. state->Init_Ctrl[14].val[2] = 0;
  726. state->Init_Ctrl[14].addr[3] = 13;
  727. state->Init_Ctrl[14].bit[3] = 3;
  728. state->Init_Ctrl[14].val[3] = 0;
  729. state->Init_Ctrl[14].addr[4] = 13;
  730. state->Init_Ctrl[14].bit[4] = 4;
  731. state->Init_Ctrl[14].val[4] = 0;
  732. state->Init_Ctrl[14].addr[5] = 13;
  733. state->Init_Ctrl[14].bit[5] = 5;
  734. state->Init_Ctrl[14].val[5] = 0;
  735. state->Init_Ctrl[14].addr[6] = 13;
  736. state->Init_Ctrl[14].bit[6] = 6;
  737. state->Init_Ctrl[14].val[6] = 0;
  738. state->Init_Ctrl[14].addr[7] = 13;
  739. state->Init_Ctrl[14].bit[7] = 7;
  740. state->Init_Ctrl[14].val[7] = 0;
  741. state->Init_Ctrl[14].addr[8] = 12;
  742. state->Init_Ctrl[14].bit[8] = 0;
  743. state->Init_Ctrl[14].val[8] = 0;
  744. state->Init_Ctrl[14].addr[9] = 12;
  745. state->Init_Ctrl[14].bit[9] = 1;
  746. state->Init_Ctrl[14].val[9] = 0;
  747. state->Init_Ctrl[14].addr[10] = 12;
  748. state->Init_Ctrl[14].bit[10] = 2;
  749. state->Init_Ctrl[14].val[10] = 0;
  750. state->Init_Ctrl[14].addr[11] = 12;
  751. state->Init_Ctrl[14].bit[11] = 3;
  752. state->Init_Ctrl[14].val[11] = 0;
  753. state->Init_Ctrl[14].addr[12] = 12;
  754. state->Init_Ctrl[14].bit[12] = 4;
  755. state->Init_Ctrl[14].val[12] = 0;
  756. state->Init_Ctrl[14].addr[13] = 12;
  757. state->Init_Ctrl[14].bit[13] = 5;
  758. state->Init_Ctrl[14].val[13] = 1;
  759. state->Init_Ctrl[14].addr[14] = 12;
  760. state->Init_Ctrl[14].bit[14] = 6;
  761. state->Init_Ctrl[14].val[14] = 1;
  762. state->Init_Ctrl[14].addr[15] = 12;
  763. state->Init_Ctrl[14].bit[15] = 7;
  764. state->Init_Ctrl[14].val[15] = 0;
  765. state->Init_Ctrl[15].Ctrl_Num = DRV_RES_SEL ;
  766. state->Init_Ctrl[15].size = 3 ;
  767. state->Init_Ctrl[15].addr[0] = 147;
  768. state->Init_Ctrl[15].bit[0] = 2;
  769. state->Init_Ctrl[15].val[0] = 0;
  770. state->Init_Ctrl[15].addr[1] = 147;
  771. state->Init_Ctrl[15].bit[1] = 3;
  772. state->Init_Ctrl[15].val[1] = 1;
  773. state->Init_Ctrl[15].addr[2] = 147;
  774. state->Init_Ctrl[15].bit[2] = 4;
  775. state->Init_Ctrl[15].val[2] = 1;
  776. state->Init_Ctrl[16].Ctrl_Num = I_DRIVER ;
  777. state->Init_Ctrl[16].size = 2 ;
  778. state->Init_Ctrl[16].addr[0] = 147;
  779. state->Init_Ctrl[16].bit[0] = 0;
  780. state->Init_Ctrl[16].val[0] = 0;
  781. state->Init_Ctrl[16].addr[1] = 147;
  782. state->Init_Ctrl[16].bit[1] = 1;
  783. state->Init_Ctrl[16].val[1] = 1;
  784. state->Init_Ctrl[17].Ctrl_Num = EN_AAF ;
  785. state->Init_Ctrl[17].size = 1 ;
  786. state->Init_Ctrl[17].addr[0] = 147;
  787. state->Init_Ctrl[17].bit[0] = 7;
  788. state->Init_Ctrl[17].val[0] = 0;
  789. state->Init_Ctrl[18].Ctrl_Num = EN_3P ;
  790. state->Init_Ctrl[18].size = 1 ;
  791. state->Init_Ctrl[18].addr[0] = 147;
  792. state->Init_Ctrl[18].bit[0] = 6;
  793. state->Init_Ctrl[18].val[0] = 0;
  794. state->Init_Ctrl[19].Ctrl_Num = EN_AUX_3P ;
  795. state->Init_Ctrl[19].size = 1 ;
  796. state->Init_Ctrl[19].addr[0] = 156;
  797. state->Init_Ctrl[19].bit[0] = 0;
  798. state->Init_Ctrl[19].val[0] = 0;
  799. state->Init_Ctrl[20].Ctrl_Num = SEL_AAF_BAND ;
  800. state->Init_Ctrl[20].size = 1 ;
  801. state->Init_Ctrl[20].addr[0] = 147;
  802. state->Init_Ctrl[20].bit[0] = 5;
  803. state->Init_Ctrl[20].val[0] = 0;
  804. state->Init_Ctrl[21].Ctrl_Num = SEQ_ENCLK16_CLK_OUT ;
  805. state->Init_Ctrl[21].size = 1 ;
  806. state->Init_Ctrl[21].addr[0] = 137;
  807. state->Init_Ctrl[21].bit[0] = 4;
  808. state->Init_Ctrl[21].val[0] = 0;
  809. state->Init_Ctrl[22].Ctrl_Num = SEQ_SEL4_16B ;
  810. state->Init_Ctrl[22].size = 1 ;
  811. state->Init_Ctrl[22].addr[0] = 137;
  812. state->Init_Ctrl[22].bit[0] = 7;
  813. state->Init_Ctrl[22].val[0] = 0;
  814. state->Init_Ctrl[23].Ctrl_Num = XTAL_CAPSELECT ;
  815. state->Init_Ctrl[23].size = 1 ;
  816. state->Init_Ctrl[23].addr[0] = 91;
  817. state->Init_Ctrl[23].bit[0] = 5;
  818. state->Init_Ctrl[23].val[0] = 1;
  819. state->Init_Ctrl[24].Ctrl_Num = IF_SEL_DBL ;
  820. state->Init_Ctrl[24].size = 1 ;
  821. state->Init_Ctrl[24].addr[0] = 43;
  822. state->Init_Ctrl[24].bit[0] = 0;
  823. state->Init_Ctrl[24].val[0] = 1;
  824. state->Init_Ctrl[25].Ctrl_Num = RFSYN_R_DIV ;
  825. state->Init_Ctrl[25].size = 2 ;
  826. state->Init_Ctrl[25].addr[0] = 22;
  827. state->Init_Ctrl[25].bit[0] = 0;
  828. state->Init_Ctrl[25].val[0] = 1;
  829. state->Init_Ctrl[25].addr[1] = 22;
  830. state->Init_Ctrl[25].bit[1] = 1;
  831. state->Init_Ctrl[25].val[1] = 1;
  832. state->Init_Ctrl[26].Ctrl_Num = SEQ_EXTSYNTHCALIF ;
  833. state->Init_Ctrl[26].size = 1 ;
  834. state->Init_Ctrl[26].addr[0] = 134;
  835. state->Init_Ctrl[26].bit[0] = 2;
  836. state->Init_Ctrl[26].val[0] = 0;
  837. state->Init_Ctrl[27].Ctrl_Num = SEQ_EXTDCCAL ;
  838. state->Init_Ctrl[27].size = 1 ;
  839. state->Init_Ctrl[27].addr[0] = 137;
  840. state->Init_Ctrl[27].bit[0] = 3;
  841. state->Init_Ctrl[27].val[0] = 0;
  842. state->Init_Ctrl[28].Ctrl_Num = AGC_EN_RSSI ;
  843. state->Init_Ctrl[28].size = 1 ;
  844. state->Init_Ctrl[28].addr[0] = 77;
  845. state->Init_Ctrl[28].bit[0] = 7;
  846. state->Init_Ctrl[28].val[0] = 0;
  847. state->Init_Ctrl[29].Ctrl_Num = RFA_ENCLKRFAGC ;
  848. state->Init_Ctrl[29].size = 1 ;
  849. state->Init_Ctrl[29].addr[0] = 166;
  850. state->Init_Ctrl[29].bit[0] = 7;
  851. state->Init_Ctrl[29].val[0] = 1;
  852. state->Init_Ctrl[30].Ctrl_Num = RFA_RSSI_REFH ;
  853. state->Init_Ctrl[30].size = 3 ;
  854. state->Init_Ctrl[30].addr[0] = 166;
  855. state->Init_Ctrl[30].bit[0] = 0;
  856. state->Init_Ctrl[30].val[0] = 0;
  857. state->Init_Ctrl[30].addr[1] = 166;
  858. state->Init_Ctrl[30].bit[1] = 1;
  859. state->Init_Ctrl[30].val[1] = 1;
  860. state->Init_Ctrl[30].addr[2] = 166;
  861. state->Init_Ctrl[30].bit[2] = 2;
  862. state->Init_Ctrl[30].val[2] = 1;
  863. state->Init_Ctrl[31].Ctrl_Num = RFA_RSSI_REF ;
  864. state->Init_Ctrl[31].size = 3 ;
  865. state->Init_Ctrl[31].addr[0] = 166;
  866. state->Init_Ctrl[31].bit[0] = 3;
  867. state->Init_Ctrl[31].val[0] = 1;
  868. state->Init_Ctrl[31].addr[1] = 166;
  869. state->Init_Ctrl[31].bit[1] = 4;
  870. state->Init_Ctrl[31].val[1] = 0;
  871. state->Init_Ctrl[31].addr[2] = 166;
  872. state->Init_Ctrl[31].bit[2] = 5;
  873. state->Init_Ctrl[31].val[2] = 1;
  874. state->Init_Ctrl[32].Ctrl_Num = RFA_RSSI_REFL ;
  875. state->Init_Ctrl[32].size = 3 ;
  876. state->Init_Ctrl[32].addr[0] = 167;
  877. state->Init_Ctrl[32].bit[0] = 0;
  878. state->Init_Ctrl[32].val[0] = 1;
  879. state->Init_Ctrl[32].addr[1] = 167;
  880. state->Init_Ctrl[32].bit[1] = 1;
  881. state->Init_Ctrl[32].val[1] = 1;
  882. state->Init_Ctrl[32].addr[2] = 167;
  883. state->Init_Ctrl[32].bit[2] = 2;
  884. state->Init_Ctrl[32].val[2] = 0;
  885. state->Init_Ctrl[33].Ctrl_Num = RFA_FLR ;
  886. state->Init_Ctrl[33].size = 4 ;
  887. state->Init_Ctrl[33].addr[0] = 168;
  888. state->Init_Ctrl[33].bit[0] = 0;
  889. state->Init_Ctrl[33].val[0] = 0;
  890. state->Init_Ctrl[33].addr[1] = 168;
  891. state->Init_Ctrl[33].bit[1] = 1;
  892. state->Init_Ctrl[33].val[1] = 1;
  893. state->Init_Ctrl[33].addr[2] = 168;
  894. state->Init_Ctrl[33].bit[2] = 2;
  895. state->Init_Ctrl[33].val[2] = 0;
  896. state->Init_Ctrl[33].addr[3] = 168;
  897. state->Init_Ctrl[33].bit[3] = 3;
  898. state->Init_Ctrl[33].val[3] = 0;
  899. state->Init_Ctrl[34].Ctrl_Num = RFA_CEIL ;
  900. state->Init_Ctrl[34].size = 4 ;
  901. state->Init_Ctrl[34].addr[0] = 168;
  902. state->Init_Ctrl[34].bit[0] = 4;
  903. state->Init_Ctrl[34].val[0] = 1;
  904. state->Init_Ctrl[34].addr[1] = 168;
  905. state->Init_Ctrl[34].bit[1] = 5;
  906. state->Init_Ctrl[34].val[1] = 1;
  907. state->Init_Ctrl[34].addr[2] = 168;
  908. state->Init_Ctrl[34].bit[2] = 6;
  909. state->Init_Ctrl[34].val[2] = 1;
  910. state->Init_Ctrl[34].addr[3] = 168;
  911. state->Init_Ctrl[34].bit[3] = 7;
  912. state->Init_Ctrl[34].val[3] = 1;
  913. state->Init_Ctrl[35].Ctrl_Num = SEQ_EXTIQFSMPULSE ;
  914. state->Init_Ctrl[35].size = 1 ;
  915. state->Init_Ctrl[35].addr[0] = 135;
  916. state->Init_Ctrl[35].bit[0] = 0;
  917. state->Init_Ctrl[35].val[0] = 0;
  918. state->Init_Ctrl[36].Ctrl_Num = OVERRIDE_1 ;
  919. state->Init_Ctrl[36].size = 1 ;
  920. state->Init_Ctrl[36].addr[0] = 56;
  921. state->Init_Ctrl[36].bit[0] = 3;
  922. state->Init_Ctrl[36].val[0] = 0;
  923. state->Init_Ctrl[37].Ctrl_Num = BB_INITSTATE_DLPF_TUNE ;
  924. state->Init_Ctrl[37].size = 7 ;
  925. state->Init_Ctrl[37].addr[0] = 59;
  926. state->Init_Ctrl[37].bit[0] = 1;
  927. state->Init_Ctrl[37].val[0] = 0;
  928. state->Init_Ctrl[37].addr[1] = 59;
  929. state->Init_Ctrl[37].bit[1] = 2;
  930. state->Init_Ctrl[37].val[1] = 0;
  931. state->Init_Ctrl[37].addr[2] = 59;
  932. state->Init_Ctrl[37].bit[2] = 3;
  933. state->Init_Ctrl[37].val[2] = 0;
  934. state->Init_Ctrl[37].addr[3] = 59;
  935. state->Init_Ctrl[37].bit[3] = 4;
  936. state->Init_Ctrl[37].val[3] = 0;
  937. state->Init_Ctrl[37].addr[4] = 59;
  938. state->Init_Ctrl[37].bit[4] = 5;
  939. state->Init_Ctrl[37].val[4] = 0;
  940. state->Init_Ctrl[37].addr[5] = 59;
  941. state->Init_Ctrl[37].bit[5] = 6;
  942. state->Init_Ctrl[37].val[5] = 0;
  943. state->Init_Ctrl[37].addr[6] = 59;
  944. state->Init_Ctrl[37].bit[6] = 7;
  945. state->Init_Ctrl[37].val[6] = 0;
  946. state->Init_Ctrl[38].Ctrl_Num = TG_R_DIV ;
  947. state->Init_Ctrl[38].size = 6 ;
  948. state->Init_Ctrl[38].addr[0] = 32;
  949. state->Init_Ctrl[38].bit[0] = 2;
  950. state->Init_Ctrl[38].val[0] = 0;
  951. state->Init_Ctrl[38].addr[1] = 32;
  952. state->Init_Ctrl[38].bit[1] = 3;
  953. state->Init_Ctrl[38].val[1] = 0;
  954. state->Init_Ctrl[38].addr[2] = 32;
  955. state->Init_Ctrl[38].bit[2] = 4;
  956. state->Init_Ctrl[38].val[2] = 0;
  957. state->Init_Ctrl[38].addr[3] = 32;
  958. state->Init_Ctrl[38].bit[3] = 5;
  959. state->Init_Ctrl[38].val[3] = 0;
  960. state->Init_Ctrl[38].addr[4] = 32;
  961. state->Init_Ctrl[38].bit[4] = 6;
  962. state->Init_Ctrl[38].val[4] = 1;
  963. state->Init_Ctrl[38].addr[5] = 32;
  964. state->Init_Ctrl[38].bit[5] = 7;
  965. state->Init_Ctrl[38].val[5] = 0;
  966. state->Init_Ctrl[39].Ctrl_Num = EN_CHP_LIN_B ;
  967. state->Init_Ctrl[39].size = 1 ;
  968. state->Init_Ctrl[39].addr[0] = 25;
  969. state->Init_Ctrl[39].bit[0] = 3;
  970. state->Init_Ctrl[39].val[0] = 1;
  971. state->CH_Ctrl_Num = CHCTRL_NUM ;
  972. state->CH_Ctrl[0].Ctrl_Num = DN_POLY ;
  973. state->CH_Ctrl[0].size = 2 ;
  974. state->CH_Ctrl[0].addr[0] = 68;
  975. state->CH_Ctrl[0].bit[0] = 6;
  976. state->CH_Ctrl[0].val[0] = 1;
  977. state->CH_Ctrl[0].addr[1] = 68;
  978. state->CH_Ctrl[0].bit[1] = 7;
  979. state->CH_Ctrl[0].val[1] = 1;
  980. state->CH_Ctrl[1].Ctrl_Num = DN_RFGAIN ;
  981. state->CH_Ctrl[1].size = 2 ;
  982. state->CH_Ctrl[1].addr[0] = 70;
  983. state->CH_Ctrl[1].bit[0] = 6;
  984. state->CH_Ctrl[1].val[0] = 1;
  985. state->CH_Ctrl[1].addr[1] = 70;
  986. state->CH_Ctrl[1].bit[1] = 7;
  987. state->CH_Ctrl[1].val[1] = 0;
  988. state->CH_Ctrl[2].Ctrl_Num = DN_CAP_RFLPF ;
  989. state->CH_Ctrl[2].size = 9 ;
  990. state->CH_Ctrl[2].addr[0] = 69;
  991. state->CH_Ctrl[2].bit[0] = 5;
  992. state->CH_Ctrl[2].val[0] = 0;
  993. state->CH_Ctrl[2].addr[1] = 69;
  994. state->CH_Ctrl[2].bit[1] = 6;
  995. state->CH_Ctrl[2].val[1] = 0;
  996. state->CH_Ctrl[2].addr[2] = 69;
  997. state->CH_Ctrl[2].bit[2] = 7;
  998. state->CH_Ctrl[2].val[2] = 0;
  999. state->CH_Ctrl[2].addr[3] = 68;
  1000. state->CH_Ctrl[2].bit[3] = 0;
  1001. state->CH_Ctrl[2].val[3] = 0;
  1002. state->CH_Ctrl[2].addr[4] = 68;
  1003. state->CH_Ctrl[2].bit[4] = 1;
  1004. state->CH_Ctrl[2].val[4] = 0;
  1005. state->CH_Ctrl[2].addr[5] = 68;
  1006. state->CH_Ctrl[2].bit[5] = 2;
  1007. state->CH_Ctrl[2].val[5] = 0;
  1008. state->CH_Ctrl[2].addr[6] = 68;
  1009. state->CH_Ctrl[2].bit[6] = 3;
  1010. state->CH_Ctrl[2].val[6] = 0;
  1011. state->CH_Ctrl[2].addr[7] = 68;
  1012. state->CH_Ctrl[2].bit[7] = 4;
  1013. state->CH_Ctrl[2].val[7] = 0;
  1014. state->CH_Ctrl[2].addr[8] = 68;
  1015. state->CH_Ctrl[2].bit[8] = 5;
  1016. state->CH_Ctrl[2].val[8] = 0;
  1017. state->CH_Ctrl[3].Ctrl_Num = DN_EN_VHFUHFBAR ;
  1018. state->CH_Ctrl[3].size = 1 ;
  1019. state->CH_Ctrl[3].addr[0] = 70;
  1020. state->CH_Ctrl[3].bit[0] = 5;
  1021. state->CH_Ctrl[3].val[0] = 0;
  1022. state->CH_Ctrl[4].Ctrl_Num = DN_GAIN_ADJUST ;
  1023. state->CH_Ctrl[4].size = 3 ;
  1024. state->CH_Ctrl[4].addr[0] = 73;
  1025. state->CH_Ctrl[4].bit[0] = 4;
  1026. state->CH_Ctrl[4].val[0] = 0;
  1027. state->CH_Ctrl[4].addr[1] = 73;
  1028. state->CH_Ctrl[4].bit[1] = 5;
  1029. state->CH_Ctrl[4].val[1] = 1;
  1030. state->CH_Ctrl[4].addr[2] = 73;
  1031. state->CH_Ctrl[4].bit[2] = 6;
  1032. state->CH_Ctrl[4].val[2] = 0;
  1033. state->CH_Ctrl[5].Ctrl_Num = DN_IQTNBUF_AMP ;
  1034. state->CH_Ctrl[5].size = 4 ;
  1035. state->CH_Ctrl[5].addr[0] = 70;
  1036. state->CH_Ctrl[5].bit[0] = 0;
  1037. state->CH_Ctrl[5].val[0] = 0;
  1038. state->CH_Ctrl[5].addr[1] = 70;
  1039. state->CH_Ctrl[5].bit[1] = 1;
  1040. state->CH_Ctrl[5].val[1] = 0;
  1041. state->CH_Ctrl[5].addr[2] = 70;
  1042. state->CH_Ctrl[5].bit[2] = 2;
  1043. state->CH_Ctrl[5].val[2] = 0;
  1044. state->CH_Ctrl[5].addr[3] = 70;
  1045. state->CH_Ctrl[5].bit[3] = 3;
  1046. state->CH_Ctrl[5].val[3] = 0;
  1047. state->CH_Ctrl[6].Ctrl_Num = DN_IQTNGNBFBIAS_BST ;
  1048. state->CH_Ctrl[6].size = 1 ;
  1049. state->CH_Ctrl[6].addr[0] = 70;
  1050. state->CH_Ctrl[6].bit[0] = 4;
  1051. state->CH_Ctrl[6].val[0] = 1;
  1052. state->CH_Ctrl[7].Ctrl_Num = RFSYN_EN_OUTMUX ;
  1053. state->CH_Ctrl[7].size = 1 ;
  1054. state->CH_Ctrl[7].addr[0] = 111;
  1055. state->CH_Ctrl[7].bit[0] = 4;
  1056. state->CH_Ctrl[7].val[0] = 0;
  1057. state->CH_Ctrl[8].Ctrl_Num = RFSYN_SEL_VCO_OUT ;
  1058. state->CH_Ctrl[8].size = 1 ;
  1059. state->CH_Ctrl[8].addr[0] = 111;
  1060. state->CH_Ctrl[8].bit[0] = 7;
  1061. state->CH_Ctrl[8].val[0] = 1;
  1062. state->CH_Ctrl[9].Ctrl_Num = RFSYN_SEL_VCO_HI ;
  1063. state->CH_Ctrl[9].size = 1 ;
  1064. state->CH_Ctrl[9].addr[0] = 111;
  1065. state->CH_Ctrl[9].bit[0] = 6;
  1066. state->CH_Ctrl[9].val[0] = 1;
  1067. state->CH_Ctrl[10].Ctrl_Num = RFSYN_SEL_DIVM ;
  1068. state->CH_Ctrl[10].size = 1 ;
  1069. state->CH_Ctrl[10].addr[0] = 111;
  1070. state->CH_Ctrl[10].bit[0] = 5;
  1071. state->CH_Ctrl[10].val[0] = 0;
  1072. state->CH_Ctrl[11].Ctrl_Num = RFSYN_RF_DIV_BIAS ;
  1073. state->CH_Ctrl[11].size = 2 ;
  1074. state->CH_Ctrl[11].addr[0] = 110;
  1075. state->CH_Ctrl[11].bit[0] = 0;
  1076. state->CH_Ctrl[11].val[0] = 1;
  1077. state->CH_Ctrl[11].addr[1] = 110;
  1078. state->CH_Ctrl[11].bit[1] = 1;
  1079. state->CH_Ctrl[11].val[1] = 0;
  1080. state->CH_Ctrl[12].Ctrl_Num = DN_SEL_FREQ ;
  1081. state->CH_Ctrl[12].size = 3 ;
  1082. state->CH_Ctrl[12].addr[0] = 69;
  1083. state->CH_Ctrl[12].bit[0] = 2;
  1084. state->CH_Ctrl[12].val[0] = 0;
  1085. state->CH_Ctrl[12].addr[1] = 69;
  1086. state->CH_Ctrl[12].bit[1] = 3;
  1087. state->CH_Ctrl[12].val[1] = 0;
  1088. state->CH_Ctrl[12].addr[2] = 69;
  1089. state->CH_Ctrl[12].bit[2] = 4;
  1090. state->CH_Ctrl[12].val[2] = 0;
  1091. state->CH_Ctrl[13].Ctrl_Num = RFSYN_VCO_BIAS ;
  1092. state->CH_Ctrl[13].size = 6 ;
  1093. state->CH_Ctrl[13].addr[0] = 110;
  1094. state->CH_Ctrl[13].bit[0] = 2;
  1095. state->CH_Ctrl[13].val[0] = 0;
  1096. state->CH_Ctrl[13].addr[1] = 110;
  1097. state->CH_Ctrl[13].bit[1] = 3;
  1098. state->CH_Ctrl[13].val[1] = 0;
  1099. state->CH_Ctrl[13].addr[2] = 110;
  1100. state->CH_Ctrl[13].bit[2] = 4;
  1101. state->CH_Ctrl[13].val[2] = 0;
  1102. state->CH_Ctrl[13].addr[3] = 110;
  1103. state->CH_Ctrl[13].bit[3] = 5;
  1104. state->CH_Ctrl[13].val[3] = 0;
  1105. state->CH_Ctrl[13].addr[4] = 110;
  1106. state->CH_Ctrl[13].bit[4] = 6;
  1107. state->CH_Ctrl[13].val[4] = 0;
  1108. state->CH_Ctrl[13].addr[5] = 110;
  1109. state->CH_Ctrl[13].bit[5] = 7;
  1110. state->CH_Ctrl[13].val[5] = 1;
  1111. state->CH_Ctrl[14].Ctrl_Num = CHCAL_INT_MOD_RF ;
  1112. state->CH_Ctrl[14].size = 7 ;
  1113. state->CH_Ctrl[14].addr[0] = 14;
  1114. state->CH_Ctrl[14].bit[0] = 0;
  1115. state->CH_Ctrl[14].val[0] = 0;
  1116. state->CH_Ctrl[14].addr[1] = 14;
  1117. state->CH_Ctrl[14].bit[1] = 1;
  1118. state->CH_Ctrl[14].val[1] = 0;
  1119. state->CH_Ctrl[14].addr[2] = 14;
  1120. state->CH_Ctrl[14].bit[2] = 2;
  1121. state->CH_Ctrl[14].val[2] = 0;
  1122. state->CH_Ctrl[14].addr[3] = 14;
  1123. state->CH_Ctrl[14].bit[3] = 3;
  1124. state->CH_Ctrl[14].val[3] = 0;
  1125. state->CH_Ctrl[14].addr[4] = 14;
  1126. state->CH_Ctrl[14].bit[4] = 4;
  1127. state->CH_Ctrl[14].val[4] = 0;
  1128. state->CH_Ctrl[14].addr[5] = 14;
  1129. state->CH_Ctrl[14].bit[5] = 5;
  1130. state->CH_Ctrl[14].val[5] = 0;
  1131. state->CH_Ctrl[14].addr[6] = 14;
  1132. state->CH_Ctrl[14].bit[6] = 6;
  1133. state->CH_Ctrl[14].val[6] = 0;
  1134. state->CH_Ctrl[15].Ctrl_Num = CHCAL_FRAC_MOD_RF ;
  1135. state->CH_Ctrl[15].size = 18 ;
  1136. state->CH_Ctrl[15].addr[0] = 17;
  1137. state->CH_Ctrl[15].bit[0] = 6;
  1138. state->CH_Ctrl[15].val[0] = 0;
  1139. state->CH_Ctrl[15].addr[1] = 17;
  1140. state->CH_Ctrl[15].bit[1] = 7;
  1141. state->CH_Ctrl[15].val[1] = 0;
  1142. state->CH_Ctrl[15].addr[2] = 16;
  1143. state->CH_Ctrl[15].bit[2] = 0;
  1144. state->CH_Ctrl[15].val[2] = 0;
  1145. state->CH_Ctrl[15].addr[3] = 16;
  1146. state->CH_Ctrl[15].bit[3] = 1;
  1147. state->CH_Ctrl[15].val[3] = 0;
  1148. state->CH_Ctrl[15].addr[4] = 16;
  1149. state->CH_Ctrl[15].bit[4] = 2;
  1150. state->CH_Ctrl[15].val[4] = 0;
  1151. state->CH_Ctrl[15].addr[5] = 16;
  1152. state->CH_Ctrl[15].bit[5] = 3;
  1153. state->CH_Ctrl[15].val[5] = 0;
  1154. state->CH_Ctrl[15].addr[6] = 16;
  1155. state->CH_Ctrl[15].bit[6] = 4;
  1156. state->CH_Ctrl[15].val[6] = 0;
  1157. state->CH_Ctrl[15].addr[7] = 16;
  1158. state->CH_Ctrl[15].bit[7] = 5;
  1159. state->CH_Ctrl[15].val[7] = 0;
  1160. state->CH_Ctrl[15].addr[8] = 16;
  1161. state->CH_Ctrl[15].bit[8] = 6;
  1162. state->CH_Ctrl[15].val[8] = 0;
  1163. state->CH_Ctrl[15].addr[9] = 16;
  1164. state->CH_Ctrl[15].bit[9] = 7;
  1165. state->CH_Ctrl[15].val[9] = 0;
  1166. state->CH_Ctrl[15].addr[10] = 15;
  1167. state->CH_Ctrl[15].bit[10] = 0;
  1168. state->CH_Ctrl[15].val[10] = 0;
  1169. state->CH_Ctrl[15].addr[11] = 15;
  1170. state->CH_Ctrl[15].bit[11] = 1;
  1171. state->CH_Ctrl[15].val[11] = 0;
  1172. state->CH_Ctrl[15].addr[12] = 15;
  1173. state->CH_Ctrl[15].bit[12] = 2;
  1174. state->CH_Ctrl[15].val[12] = 0;
  1175. state->CH_Ctrl[15].addr[13] = 15;
  1176. state->CH_Ctrl[15].bit[13] = 3;
  1177. state->CH_Ctrl[15].val[13] = 0;
  1178. state->CH_Ctrl[15].addr[14] = 15;
  1179. state->CH_Ctrl[15].bit[14] = 4;
  1180. state->CH_Ctrl[15].val[14] = 0;
  1181. state->CH_Ctrl[15].addr[15] = 15;
  1182. state->CH_Ctrl[15].bit[15] = 5;
  1183. state->CH_Ctrl[15].val[15] = 0;
  1184. state->CH_Ctrl[15].addr[16] = 15;
  1185. state->CH_Ctrl[15].bit[16] = 6;
  1186. state->CH_Ctrl[15].val[16] = 1;
  1187. state->CH_Ctrl[15].addr[17] = 15;
  1188. state->CH_Ctrl[15].bit[17] = 7;
  1189. state->CH_Ctrl[15].val[17] = 1;
  1190. state->CH_Ctrl[16].Ctrl_Num = RFSYN_LPF_R ;
  1191. state->CH_Ctrl[16].size = 5 ;
  1192. state->CH_Ctrl[16].addr[0] = 112;
  1193. state->CH_Ctrl[16].bit[0] = 0;
  1194. state->CH_Ctrl[16].val[0] = 0;
  1195. state->CH_Ctrl[16].addr[1] = 112;
  1196. state->CH_Ctrl[16].bit[1] = 1;
  1197. state->CH_Ctrl[16].val[1] = 0;
  1198. state->CH_Ctrl[16].addr[2] = 112;
  1199. state->CH_Ctrl[16].bit[2] = 2;
  1200. state->CH_Ctrl[16].val[2] = 0;
  1201. state->CH_Ctrl[16].addr[3] = 112;
  1202. state->CH_Ctrl[16].bit[3] = 3;
  1203. state->CH_Ctrl[16].val[3] = 0;
  1204. state->CH_Ctrl[16].addr[4] = 112;
  1205. state->CH_Ctrl[16].bit[4] = 4;
  1206. state->CH_Ctrl[16].val[4] = 1;
  1207. state->CH_Ctrl[17].Ctrl_Num = CHCAL_EN_INT_RF ;
  1208. state->CH_Ctrl[17].size = 1 ;
  1209. state->CH_Ctrl[17].addr[0] = 14;
  1210. state->CH_Ctrl[17].bit[0] = 7;
  1211. state->CH_Ctrl[17].val[0] = 0;
  1212. state->CH_Ctrl[18].Ctrl_Num = TG_LO_DIVVAL ;
  1213. state->CH_Ctrl[18].size = 4 ;
  1214. state->CH_Ctrl[18].addr[0] = 107;
  1215. state->CH_Ctrl[18].bit[0] = 3;
  1216. state->CH_Ctrl[18].val[0] = 0;
  1217. state->CH_Ctrl[18].addr[1] = 107;
  1218. state->CH_Ctrl[18].bit[1] = 4;
  1219. state->CH_Ctrl[18].val[1] = 0;
  1220. state->CH_Ctrl[18].addr[2] = 107;
  1221. state->CH_Ctrl[18].bit[2] = 5;
  1222. state->CH_Ctrl[18].val[2] = 0;
  1223. state->CH_Ctrl[18].addr[3] = 107;
  1224. state->CH_Ctrl[18].bit[3] = 6;
  1225. state->CH_Ctrl[18].val[3] = 0;
  1226. state->CH_Ctrl[19].Ctrl_Num = TG_LO_SELVAL ;
  1227. state->CH_Ctrl[19].size = 3 ;
  1228. state->CH_Ctrl[19].addr[0] = 107;
  1229. state->CH_Ctrl[19].bit[0] = 7;
  1230. state->CH_Ctrl[19].val[0] = 1;
  1231. state->CH_Ctrl[19].addr[1] = 106;
  1232. state->CH_Ctrl[19].bit[1] = 0;
  1233. state->CH_Ctrl[19].val[1] = 1;
  1234. state->CH_Ctrl[19].addr[2] = 106;
  1235. state->CH_Ctrl[19].bit[2] = 1;
  1236. state->CH_Ctrl[19].val[2] = 1;
  1237. state->CH_Ctrl[20].Ctrl_Num = TG_DIV_VAL ;
  1238. state->CH_Ctrl[20].size = 11 ;
  1239. state->CH_Ctrl[20].addr[0] = 109;
  1240. state->CH_Ctrl[20].bit[0] = 2;
  1241. state->CH_Ctrl[20].val[0] = 0;
  1242. state->CH_Ctrl[20].addr[1] = 109;
  1243. state->CH_Ctrl[20].bit[1] = 3;
  1244. state->CH_Ctrl[20].val[1] = 0;
  1245. state->CH_Ctrl[20].addr[2] = 109;
  1246. state->CH_Ctrl[20].bit[2] = 4;
  1247. state->CH_Ctrl[20].val[2] = 0;
  1248. state->CH_Ctrl[20].addr[3] = 109;
  1249. state->CH_Ctrl[20].bit[3] = 5;
  1250. state->CH_Ctrl[20].val[3] = 0;
  1251. state->CH_Ctrl[20].addr[4] = 109;
  1252. state->CH_Ctrl[20].bit[4] = 6;
  1253. state->CH_Ctrl[20].val[4] = 0;
  1254. state->CH_Ctrl[20].addr[5] = 109;
  1255. state->CH_Ctrl[20].bit[5] = 7;
  1256. state->CH_Ctrl[20].val[5] = 0;
  1257. state->CH_Ctrl[20].addr[6] = 108;
  1258. state->CH_Ctrl[20].bit[6] = 0;
  1259. state->CH_Ctrl[20].val[6] = 0;
  1260. state->CH_Ctrl[20].addr[7] = 108;
  1261. state->CH_Ctrl[20].bit[7] = 1;
  1262. state->CH_Ctrl[20].val[7] = 0;
  1263. state->CH_Ctrl[20].addr[8] = 108;
  1264. state->CH_Ctrl[20].bit[8] = 2;
  1265. state->CH_Ctrl[20].val[8] = 1;
  1266. state->CH_Ctrl[20].addr[9] = 108;
  1267. state->CH_Ctrl[20].bit[9] = 3;
  1268. state->CH_Ctrl[20].val[9] = 1;
  1269. state->CH_Ctrl[20].addr[10] = 108;
  1270. state->CH_Ctrl[20].bit[10] = 4;
  1271. state->CH_Ctrl[20].val[10] = 1;
  1272. state->CH_Ctrl[21].Ctrl_Num = TG_VCO_BIAS ;
  1273. state->CH_Ctrl[21].size = 6 ;
  1274. state->CH_Ctrl[21].addr[0] = 106;
  1275. state->CH_Ctrl[21].bit[0] = 2;
  1276. state->CH_Ctrl[21].val[0] = 0;
  1277. state->CH_Ctrl[21].addr[1] = 106;
  1278. state->CH_Ctrl[21].bit[1] = 3;
  1279. state->CH_Ctrl[21].val[1] = 0;
  1280. state->CH_Ctrl[21].addr[2] = 106;
  1281. state->CH_Ctrl[21].bit[2] = 4;
  1282. state->CH_Ctrl[21].val[2] = 0;
  1283. state->CH_Ctrl[21].addr[3] = 106;
  1284. state->CH_Ctrl[21].bit[3] = 5;
  1285. state->CH_Ctrl[21].val[3] = 0;
  1286. state->CH_Ctrl[21].addr[4] = 106;
  1287. state->CH_Ctrl[21].bit[4] = 6;
  1288. state->CH_Ctrl[21].val[4] = 0;
  1289. state->CH_Ctrl[21].addr[5] = 106;
  1290. state->CH_Ctrl[21].bit[5] = 7;
  1291. state->CH_Ctrl[21].val[5] = 1;
  1292. state->CH_Ctrl[22].Ctrl_Num = SEQ_EXTPOWERUP ;
  1293. state->CH_Ctrl[22].size = 1 ;
  1294. state->CH_Ctrl[22].addr[0] = 138;
  1295. state->CH_Ctrl[22].bit[0] = 4;
  1296. state->CH_Ctrl[22].val[0] = 1;
  1297. state->CH_Ctrl[23].Ctrl_Num = OVERRIDE_2 ;
  1298. state->CH_Ctrl[23].size = 1 ;
  1299. state->CH_Ctrl[23].addr[0] = 17;
  1300. state->CH_Ctrl[23].bit[0] = 5;
  1301. state->CH_Ctrl[23].val[0] = 0;
  1302. state->CH_Ctrl[24].Ctrl_Num = OVERRIDE_3 ;
  1303. state->CH_Ctrl[24].size = 1 ;
  1304. state->CH_Ctrl[24].addr[0] = 111;
  1305. state->CH_Ctrl[24].bit[0] = 3;
  1306. state->CH_Ctrl[24].val[0] = 0;
  1307. state->CH_Ctrl[25].Ctrl_Num = OVERRIDE_4 ;
  1308. state->CH_Ctrl[25].size = 1 ;
  1309. state->CH_Ctrl[25].addr[0] = 112;
  1310. state->CH_Ctrl[25].bit[0] = 7;
  1311. state->CH_Ctrl[25].val[0] = 0;
  1312. state->CH_Ctrl[26].Ctrl_Num = SEQ_FSM_PULSE ;
  1313. state->CH_Ctrl[26].size = 1 ;
  1314. state->CH_Ctrl[26].addr[0] = 136;
  1315. state->CH_Ctrl[26].bit[0] = 7;
  1316. state->CH_Ctrl[26].val[0] = 0;
  1317. state->CH_Ctrl[27].Ctrl_Num = GPIO_4B ;
  1318. state->CH_Ctrl[27].size = 1 ;
  1319. state->CH_Ctrl[27].addr[0] = 149;
  1320. state->CH_Ctrl[27].bit[0] = 7;
  1321. state->CH_Ctrl[27].val[0] = 0;
  1322. state->CH_Ctrl[28].Ctrl_Num = GPIO_3B ;
  1323. state->CH_Ctrl[28].size = 1 ;
  1324. state->CH_Ctrl[28].addr[0] = 149;
  1325. state->CH_Ctrl[28].bit[0] = 6;
  1326. state->CH_Ctrl[28].val[0] = 0;
  1327. state->CH_Ctrl[29].Ctrl_Num = GPIO_4 ;
  1328. state->CH_Ctrl[29].size = 1 ;
  1329. state->CH_Ctrl[29].addr[0] = 149;
  1330. state->CH_Ctrl[29].bit[0] = 5;
  1331. state->CH_Ctrl[29].val[0] = 1;
  1332. state->CH_Ctrl[30].Ctrl_Num = GPIO_3 ;
  1333. state->CH_Ctrl[30].size = 1 ;
  1334. state->CH_Ctrl[30].addr[0] = 149;
  1335. state->CH_Ctrl[30].bit[0] = 4;
  1336. state->CH_Ctrl[30].val[0] = 1;
  1337. state->CH_Ctrl[31].Ctrl_Num = GPIO_1B ;
  1338. state->CH_Ctrl[31].size = 1 ;
  1339. state->CH_Ctrl[31].addr[0] = 149;
  1340. state->CH_Ctrl[31].bit[0] = 3;
  1341. state->CH_Ctrl[31].val[0] = 0;
  1342. state->CH_Ctrl[32].Ctrl_Num = DAC_A_ENABLE ;
  1343. state->CH_Ctrl[32].size = 1 ;
  1344. state->CH_Ctrl[32].addr[0] = 93;
  1345. state->CH_Ctrl[32].bit[0] = 1;
  1346. state->CH_Ctrl[32].val[0] = 0;
  1347. state->CH_Ctrl[33].Ctrl_Num = DAC_B_ENABLE ;
  1348. state->CH_Ctrl[33].size = 1 ;
  1349. state->CH_Ctrl[33].addr[0] = 93;
  1350. state->CH_Ctrl[33].bit[0] = 0;
  1351. state->CH_Ctrl[33].val[0] = 0;
  1352. state->CH_Ctrl[34].Ctrl_Num = DAC_DIN_A ;
  1353. state->CH_Ctrl[34].size = 6 ;
  1354. state->CH_Ctrl[34].addr[0] = 92;
  1355. state->CH_Ctrl[34].bit[0] = 2;
  1356. state->CH_Ctrl[34].val[0] = 0;
  1357. state->CH_Ctrl[34].addr[1] = 92;
  1358. state->CH_Ctrl[34].bit[1] = 3;
  1359. state->CH_Ctrl[34].val[1] = 0;
  1360. state->CH_Ctrl[34].addr[2] = 92;
  1361. state->CH_Ctrl[34].bit[2] = 4;
  1362. state->CH_Ctrl[34].val[2] = 0;
  1363. state->CH_Ctrl[34].addr[3] = 92;
  1364. state->CH_Ctrl[34].bit[3] = 5;
  1365. state->CH_Ctrl[34].val[3] = 0;
  1366. state->CH_Ctrl[34].addr[4] = 92;
  1367. state->CH_Ctrl[34].bit[4] = 6;
  1368. state->CH_Ctrl[34].val[4] = 0;
  1369. state->CH_Ctrl[34].addr[5] = 92;
  1370. state->CH_Ctrl[34].bit[5] = 7;
  1371. state->CH_Ctrl[34].val[5] = 0;
  1372. state->CH_Ctrl[35].Ctrl_Num = DAC_DIN_B ;
  1373. state->CH_Ctrl[35].size = 6 ;
  1374. state->CH_Ctrl[35].addr[0] = 93;
  1375. state->CH_Ctrl[35].bit[0] = 2;
  1376. state->CH_Ctrl[35].val[0] = 0;
  1377. state->CH_Ctrl[35].addr[1] = 93;
  1378. state->CH_Ctrl[35].bit[1] = 3;
  1379. state->CH_Ctrl[35].val[1] = 0;
  1380. state->CH_Ctrl[35].addr[2] = 93;
  1381. state->CH_Ctrl[35].bit[2] = 4;
  1382. state->CH_Ctrl[35].val[2] = 0;
  1383. state->CH_Ctrl[35].addr[3] = 93;
  1384. state->CH_Ctrl[35].bit[3] = 5;
  1385. state->CH_Ctrl[35].val[3] = 0;
  1386. state->CH_Ctrl[35].addr[4] = 93;
  1387. state->CH_Ctrl[35].bit[4] = 6;
  1388. state->CH_Ctrl[35].val[4] = 0;
  1389. state->CH_Ctrl[35].addr[5] = 93;
  1390. state->CH_Ctrl[35].bit[5] = 7;
  1391. state->CH_Ctrl[35].val[5] = 0;
  1392. #ifdef _MXL_PRODUCTION
  1393. state->CH_Ctrl[36].Ctrl_Num = RFSYN_EN_DIV ;
  1394. state->CH_Ctrl[36].size = 1 ;
  1395. state->CH_Ctrl[36].addr[0] = 109;
  1396. state->CH_Ctrl[36].bit[0] = 1;
  1397. state->CH_Ctrl[36].val[0] = 1;
  1398. state->CH_Ctrl[37].Ctrl_Num = RFSYN_DIVM ;
  1399. state->CH_Ctrl[37].size = 2 ;
  1400. state->CH_Ctrl[37].addr[0] = 112;
  1401. state->CH_Ctrl[37].bit[0] = 5;
  1402. state->CH_Ctrl[37].val[0] = 0;
  1403. state->CH_Ctrl[37].addr[1] = 112;
  1404. state->CH_Ctrl[37].bit[1] = 6;
  1405. state->CH_Ctrl[37].val[1] = 0;
  1406. state->CH_Ctrl[38].Ctrl_Num = DN_BYPASS_AGC_I2C ;
  1407. state->CH_Ctrl[38].size = 1 ;
  1408. state->CH_Ctrl[38].addr[0] = 65;
  1409. state->CH_Ctrl[38].bit[0] = 1;
  1410. state->CH_Ctrl[38].val[0] = 0;
  1411. #endif
  1412. return 0 ;
  1413. }
  1414. static void InitTunerControls(struct dvb_frontend *fe)
  1415. {
  1416. MXL5005_RegisterInit(fe);
  1417. MXL5005_ControlInit(fe);
  1418. #ifdef _MXL_INTERNAL
  1419. MXL5005_MXLControlInit(fe);
  1420. #endif
  1421. }
  1422. static u16 MXL5005_TunerConfig(struct dvb_frontend *fe,
  1423. u8 Mode, /* 0: Analog Mode ; 1: Digital Mode */
  1424. u8 IF_mode, /* for Analog Mode, 0: zero IF; 1: low IF */
  1425. u32 Bandwidth, /* filter channel bandwidth (6, 7, 8) */
  1426. u32 IF_out, /* Desired IF Out Frequency */
  1427. u32 Fxtal, /* XTAL Frequency */
  1428. u8 AGC_Mode, /* AGC Mode - Dual AGC: 0, Single AGC: 1 */
  1429. u16 TOP, /* 0: Dual AGC; Value: take over point */
  1430. u16 IF_OUT_LOAD, /* IF Out Load Resistor (200 / 300 Ohms) */
  1431. u8 CLOCK_OUT, /* 0: turn off clk out; 1: turn on clock out */
  1432. u8 DIV_OUT, /* 0: Div-1; 1: Div-4 */
  1433. u8 CAPSELECT, /* 0: disable On-Chip pulling cap; 1: enable */
  1434. u8 EN_RSSI, /* 0: disable RSSI; 1: enable RSSI */
  1435. /* Modulation Type; */
  1436. /* 0 - Default; 1 - DVB-T; 2 - ATSC; 3 - QAM; 4 - Analog Cable */
  1437. u8 Mod_Type,
  1438. /* Tracking Filter */
  1439. /* 0 - Default; 1 - Off; 2 - Type C; 3 - Type C-H */
  1440. u8 TF_Type
  1441. )
  1442. {
  1443. struct mxl5005s_state *state = fe->tuner_priv;
  1444. state->Mode = Mode;
  1445. state->IF_Mode = IF_mode;
  1446. state->Chan_Bandwidth = Bandwidth;
  1447. state->IF_OUT = IF_out;
  1448. state->Fxtal = Fxtal;
  1449. state->AGC_Mode = AGC_Mode;
  1450. state->TOP = TOP;
  1451. state->IF_OUT_LOAD = IF_OUT_LOAD;
  1452. state->CLOCK_OUT = CLOCK_OUT;
  1453. state->DIV_OUT = DIV_OUT;
  1454. state->CAPSELECT = CAPSELECT;
  1455. state->EN_RSSI = EN_RSSI;
  1456. state->Mod_Type = Mod_Type;
  1457. state->TF_Type = TF_Type;
  1458. /* Initialize all the controls and registers */
  1459. InitTunerControls(fe);
  1460. /* Synthesizer LO frequency calculation */
  1461. MXL_SynthIFLO_Calc(fe);
  1462. return 0;
  1463. }
  1464. static void MXL_SynthIFLO_Calc(struct dvb_frontend *fe)
  1465. {
  1466. struct mxl5005s_state *state = fe->tuner_priv;
  1467. if (state->Mode == 1) /* Digital Mode */
  1468. state->IF_LO = state->IF_OUT;
  1469. else /* Analog Mode */ {
  1470. if (state->IF_Mode == 0) /* Analog Zero IF mode */
  1471. state->IF_LO = state->IF_OUT + 400000;
  1472. else /* Analog Low IF mode */
  1473. state->IF_LO = state->IF_OUT + state->Chan_Bandwidth/2;
  1474. }
  1475. }
  1476. static void MXL_SynthRFTGLO_Calc(struct dvb_frontend *fe)
  1477. {
  1478. struct mxl5005s_state *state = fe->tuner_priv;
  1479. if (state->Mode == 1) /* Digital Mode */ {
  1480. /* remove 20.48MHz setting for 2.6.10 */
  1481. state->RF_LO = state->RF_IN;
  1482. /* change for 2.6.6 */
  1483. state->TG_LO = state->RF_IN - 750000;
  1484. } else /* Analog Mode */ {
  1485. if (state->IF_Mode == 0) /* Analog Zero IF mode */ {
  1486. state->RF_LO = state->RF_IN - 400000;
  1487. state->TG_LO = state->RF_IN - 1750000;
  1488. } else /* Analog Low IF mode */ {
  1489. state->RF_LO = state->RF_IN - state->Chan_Bandwidth/2;
  1490. state->TG_LO = state->RF_IN -
  1491. state->Chan_Bandwidth + 500000;
  1492. }
  1493. }
  1494. }
  1495. static u16 MXL_OverwriteICDefault(struct dvb_frontend *fe)
  1496. {
  1497. u16 status = 0;
  1498. status += MXL_ControlWrite(fe, OVERRIDE_1, 1);
  1499. status += MXL_ControlWrite(fe, OVERRIDE_2, 1);
  1500. status += MXL_ControlWrite(fe, OVERRIDE_3, 1);
  1501. status += MXL_ControlWrite(fe, OVERRIDE_4, 1);
  1502. return status;
  1503. }
  1504. static u16 MXL_BlockInit(struct dvb_frontend *fe)
  1505. {
  1506. struct mxl5005s_state *state = fe->tuner_priv;
  1507. u16 status = 0;
  1508. status += MXL_OverwriteICDefault(fe);
  1509. /* Downconverter Control Dig Ana */
  1510. status += MXL_ControlWrite(fe, DN_IQTN_AMP_CUT, state->Mode ? 1 : 0);
  1511. /* Filter Control Dig Ana */
  1512. status += MXL_ControlWrite(fe, BB_MODE, state->Mode ? 0 : 1);
  1513. status += MXL_ControlWrite(fe, BB_BUF, state->Mode ? 3 : 2);
  1514. status += MXL_ControlWrite(fe, BB_BUF_OA, state->Mode ? 1 : 0);
  1515. status += MXL_ControlWrite(fe, BB_IQSWAP, state->Mode ? 0 : 1);
  1516. status += MXL_ControlWrite(fe, BB_INITSTATE_DLPF_TUNE, 0);
  1517. /* Initialize Low-Pass Filter */
  1518. if (state->Mode) { /* Digital Mode */
  1519. switch (state->Chan_Bandwidth) {
  1520. case 8000000:
  1521. status += MXL_ControlWrite(fe, BB_DLPF_BANDSEL, 0);
  1522. break;
  1523. case 7000000:
  1524. status += MXL_ControlWrite(fe, BB_DLPF_BANDSEL, 2);
  1525. break;
  1526. case 6000000:
  1527. status += MXL_ControlWrite(fe,
  1528. BB_DLPF_BANDSEL, 3);
  1529. break;
  1530. }
  1531. } else { /* Analog Mode */
  1532. switch (state->Chan_Bandwidth) {
  1533. case 8000000: /* Low Zero */
  1534. status += MXL_ControlWrite(fe, BB_ALPF_BANDSELECT,
  1535. (state->IF_Mode ? 0 : 3));
  1536. break;
  1537. case 7000000:
  1538. status += MXL_ControlWrite(fe, BB_ALPF_BANDSELECT,
  1539. (state->IF_Mode ? 1 : 4));
  1540. break;
  1541. case 6000000:
  1542. status += MXL_ControlWrite(fe, BB_ALPF_BANDSELECT,
  1543. (state->IF_Mode ? 2 : 5));
  1544. break;
  1545. }
  1546. }
  1547. /* Charge Pump Control Dig Ana */
  1548. status += MXL_ControlWrite(fe, RFSYN_CHP_GAIN, state->Mode ? 5 : 8);
  1549. status += MXL_ControlWrite(fe,
  1550. RFSYN_EN_CHP_HIGAIN, state->Mode ? 1 : 1);
  1551. status += MXL_ControlWrite(fe, EN_CHP_LIN_B, state->Mode ? 0 : 0);
  1552. /* AGC TOP Control */
  1553. if (state->AGC_Mode == 0) /* Dual AGC */ {
  1554. status += MXL_ControlWrite(fe, AGC_IF, 15);
  1555. status += MXL_ControlWrite(fe, AGC_RF, 15);
  1556. } else /* Single AGC Mode Dig Ana */
  1557. status += MXL_ControlWrite(fe, AGC_RF, state->Mode ? 15 : 12);
  1558. if (state->TOP == 55) /* TOP == 5.5 */
  1559. status += MXL_ControlWrite(fe, AGC_IF, 0x0);
  1560. if (state->TOP == 72) /* TOP == 7.2 */
  1561. status += MXL_ControlWrite(fe, AGC_IF, 0x1);
  1562. if (state->TOP == 92) /* TOP == 9.2 */
  1563. status += MXL_ControlWrite(fe, AGC_IF, 0x2);
  1564. if (state->TOP == 110) /* TOP == 11.0 */
  1565. status += MXL_ControlWrite(fe, AGC_IF, 0x3);
  1566. if (state->TOP == 129) /* TOP == 12.9 */
  1567. status += MXL_ControlWrite(fe, AGC_IF, 0x4);
  1568. if (state->TOP == 147) /* TOP == 14.7 */
  1569. status += MXL_ControlWrite(fe, AGC_IF, 0x5);
  1570. if (state->TOP == 168) /* TOP == 16.8 */
  1571. status += MXL_ControlWrite(fe, AGC_IF, 0x6);
  1572. if (state->TOP == 194) /* TOP == 19.4 */
  1573. status += MXL_ControlWrite(fe, AGC_IF, 0x7);
  1574. if (state->TOP == 212) /* TOP == 21.2 */
  1575. status += MXL_ControlWrite(fe, AGC_IF, 0x9);
  1576. if (state->TOP == 232) /* TOP == 23.2 */
  1577. status += MXL_ControlWrite(fe, AGC_IF, 0xA);
  1578. if (state->TOP == 252) /* TOP == 25.2 */
  1579. status += MXL_ControlWrite(fe, AGC_IF, 0xB);
  1580. if (state->TOP == 271) /* TOP == 27.1 */
  1581. status += MXL_ControlWrite(fe, AGC_IF, 0xC);
  1582. if (state->TOP == 292) /* TOP == 29.2 */
  1583. status += MXL_ControlWrite(fe, AGC_IF, 0xD);
  1584. if (state->TOP == 317) /* TOP == 31.7 */
  1585. status += MXL_ControlWrite(fe, AGC_IF, 0xE);
  1586. if (state->TOP == 349) /* TOP == 34.9 */
  1587. status += MXL_ControlWrite(fe, AGC_IF, 0xF);
  1588. /* IF Synthesizer Control */
  1589. status += MXL_IFSynthInit(fe);
  1590. /* IF UpConverter Control */
  1591. if (state->IF_OUT_LOAD == 200) {
  1592. status += MXL_ControlWrite(fe, DRV_RES_SEL, 6);
  1593. status += MXL_ControlWrite(fe, I_DRIVER, 2);
  1594. }
  1595. if (state->IF_OUT_LOAD == 300) {
  1596. status += MXL_ControlWrite(fe, DRV_RES_SEL, 4);
  1597. status += MXL_ControlWrite(fe, I_DRIVER, 1);
  1598. }
  1599. /* Anti-Alias Filtering Control
  1600. * initialise Anti-Aliasing Filter
  1601. */
  1602. if (state->Mode) { /* Digital Mode */
  1603. if (state->IF_OUT >= 4000000UL && state->IF_OUT <= 6280000UL) {
  1604. status += MXL_ControlWrite(fe, EN_AAF, 1);
  1605. status += MXL_ControlWrite(fe, EN_3P, 1);
  1606. status += MXL_ControlWrite(fe, EN_AUX_3P, 1);
  1607. status += MXL_ControlWrite(fe, SEL_AAF_BAND, 0);
  1608. }
  1609. if ((state->IF_OUT == 36125000UL) ||
  1610. (state->IF_OUT == 36150000UL)) {
  1611. status += MXL_ControlWrite(fe, EN_AAF, 1);
  1612. status += MXL_ControlWrite(fe, EN_3P, 1);
  1613. status += MXL_ControlWrite(fe, EN_AUX_3P, 1);
  1614. status += MXL_ControlWrite(fe, SEL_AAF_BAND, 1);
  1615. }
  1616. if (state->IF_OUT > 36150000UL) {
  1617. status += MXL_ControlWrite(fe, EN_AAF, 0);
  1618. status += MXL_ControlWrite(fe, EN_3P, 1);
  1619. status += MXL_ControlWrite(fe, EN_AUX_3P, 1);
  1620. status += MXL_ControlWrite(fe, SEL_AAF_BAND, 1);
  1621. }
  1622. } else { /* Analog Mode */
  1623. if (state->IF_OUT >= 4000000UL && state->IF_OUT <= 5000000UL) {
  1624. status += MXL_ControlWrite(fe, EN_AAF, 1);
  1625. status += MXL_ControlWrite(fe, EN_3P, 1);
  1626. status += MXL_ControlWrite(fe, EN_AUX_3P, 1);
  1627. status += MXL_ControlWrite(fe, SEL_AAF_BAND, 0);
  1628. }
  1629. if (state->IF_OUT > 5000000UL) {
  1630. status += MXL_ControlWrite(fe, EN_AAF, 0);
  1631. status += MXL_ControlWrite(fe, EN_3P, 0);
  1632. status += MXL_ControlWrite(fe, EN_AUX_3P, 0);
  1633. status += MXL_ControlWrite(fe, SEL_AAF_BAND, 0);
  1634. }
  1635. }
  1636. /* Demod Clock Out */
  1637. if (state->CLOCK_OUT)
  1638. status += MXL_ControlWrite(fe, SEQ_ENCLK16_CLK_OUT, 1);
  1639. else
  1640. status += MXL_ControlWrite(fe, SEQ_ENCLK16_CLK_OUT, 0);
  1641. if (state->DIV_OUT == 1)
  1642. status += MXL_ControlWrite(fe, SEQ_SEL4_16B, 1);
  1643. if (state->DIV_OUT == 0)
  1644. status += MXL_ControlWrite(fe, SEQ_SEL4_16B, 0);
  1645. /* Crystal Control */
  1646. if (state->CAPSELECT)
  1647. status += MXL_ControlWrite(fe, XTAL_CAPSELECT, 1);
  1648. else
  1649. status += MXL_ControlWrite(fe, XTAL_CAPSELECT, 0);
  1650. if (state->Fxtal >= 12000000UL && state->Fxtal <= 16000000UL)
  1651. status += MXL_ControlWrite(fe, IF_SEL_DBL, 1);
  1652. if (state->Fxtal > 16000000UL && state->Fxtal <= 32000000UL)
  1653. status += MXL_ControlWrite(fe, IF_SEL_DBL, 0);
  1654. if (state->Fxtal >= 12000000UL && state->Fxtal <= 22000000UL)
  1655. status += MXL_ControlWrite(fe, RFSYN_R_DIV, 3);
  1656. if (state->Fxtal > 22000000UL && state->Fxtal <= 32000000UL)
  1657. status += MXL_ControlWrite(fe, RFSYN_R_DIV, 0);
  1658. /* Misc Controls */
  1659. if (state->Mode == 0 && state->IF_Mode == 1) /* Analog LowIF mode */
  1660. status += MXL_ControlWrite(fe, SEQ_EXTIQFSMPULSE, 0);
  1661. else
  1662. status += MXL_ControlWrite(fe, SEQ_EXTIQFSMPULSE, 1);
  1663. /* status += MXL_ControlRead(fe, IF_DIVVAL, &IF_DIVVAL_Val); */
  1664. /* Set TG_R_DIV */
  1665. status += MXL_ControlWrite(fe, TG_R_DIV,
  1666. MXL_Ceiling(state->Fxtal, 1000000));
  1667. /* Apply Default value to BB_INITSTATE_DLPF_TUNE */
  1668. /* RSSI Control */
  1669. if (state->EN_RSSI) {
  1670. status += MXL_ControlWrite(fe, SEQ_EXTSYNTHCALIF, 1);
  1671. status += MXL_ControlWrite(fe, SEQ_EXTDCCAL, 1);
  1672. status += MXL_ControlWrite(fe, AGC_EN_RSSI, 1);
  1673. status += MXL_ControlWrite(fe, RFA_ENCLKRFAGC, 1);
  1674. /* RSSI reference point */
  1675. status += MXL_ControlWrite(fe, RFA_RSSI_REF, 2);
  1676. status += MXL_ControlWrite(fe, RFA_RSSI_REFH, 3);
  1677. status += MXL_ControlWrite(fe, RFA_RSSI_REFL, 1);
  1678. /* TOP point */
  1679. status += MXL_ControlWrite(fe, RFA_FLR, 0);
  1680. status += MXL_ControlWrite(fe, RFA_CEIL, 12);
  1681. }
  1682. /* Modulation type bit settings
  1683. * Override the control values preset
  1684. */
  1685. if (state->Mod_Type == MXL_DVBT) /* DVB-T Mode */ {
  1686. state->AGC_Mode = 1; /* Single AGC Mode */
  1687. /* Enable RSSI */
  1688. status += MXL_ControlWrite(fe, SEQ_EXTSYNTHCALIF, 1);
  1689. status += MXL_ControlWrite(fe, SEQ_EXTDCCAL, 1);
  1690. status += MXL_ControlWrite(fe, AGC_EN_RSSI, 1);
  1691. status += MXL_ControlWrite(fe, RFA_ENCLKRFAGC, 1);
  1692. /* RSSI reference point */
  1693. status += MXL_ControlWrite(fe, RFA_RSSI_REF, 3);
  1694. status += MXL_ControlWrite(fe, RFA_RSSI_REFH, 5);
  1695. status += MXL_ControlWrite(fe, RFA_RSSI_REFL, 1);
  1696. /* TOP point */
  1697. status += MXL_ControlWrite(fe, RFA_FLR, 2);
  1698. status += MXL_ControlWrite(fe, RFA_CEIL, 13);
  1699. if (state->IF_OUT <= 6280000UL) /* Low IF */
  1700. status += MXL_ControlWrite(fe, BB_IQSWAP, 0);
  1701. else /* High IF */
  1702. status += MXL_ControlWrite(fe, BB_IQSWAP, 1);
  1703. }
  1704. if (state->Mod_Type == MXL_ATSC) /* ATSC Mode */ {
  1705. state->AGC_Mode = 1; /* Single AGC Mode */
  1706. /* Enable RSSI */
  1707. status += MXL_ControlWrite(fe, SEQ_EXTSYNTHCALIF, 1);
  1708. status += MXL_ControlWrite(fe, SEQ_EXTDCCAL, 1);
  1709. status += MXL_ControlWrite(fe, AGC_EN_RSSI, 1);
  1710. status += MXL_ControlWrite(fe, RFA_ENCLKRFAGC, 1);
  1711. /* RSSI reference point */
  1712. status += MXL_ControlWrite(fe, RFA_RSSI_REF, 2);
  1713. status += MXL_ControlWrite(fe, RFA_RSSI_REFH, 4);
  1714. status += MXL_ControlWrite(fe, RFA_RSSI_REFL, 1);
  1715. /* TOP point */
  1716. status += MXL_ControlWrite(fe, RFA_FLR, 2);
  1717. status += MXL_ControlWrite(fe, RFA_CEIL, 13);
  1718. status += MXL_ControlWrite(fe, BB_INITSTATE_DLPF_TUNE, 1);
  1719. /* Low Zero */
  1720. status += MXL_ControlWrite(fe, RFSYN_CHP_GAIN, 5);
  1721. if (state->IF_OUT <= 6280000UL) /* Low IF */
  1722. status += MXL_ControlWrite(fe, BB_IQSWAP, 0);
  1723. else /* High IF */
  1724. status += MXL_ControlWrite(fe, BB_IQSWAP, 1);
  1725. }
  1726. if (state->Mod_Type == MXL_QAM) /* QAM Mode */ {
  1727. state->Mode = MXL_DIGITAL_MODE;
  1728. /* state->AGC_Mode = 1; */ /* Single AGC Mode */
  1729. /* Disable RSSI */ /* change here for v2.6.5 */
  1730. status += MXL_ControlWrite(fe, SEQ_EXTSYNTHCALIF, 1);
  1731. status += MXL_ControlWrite(fe, SEQ_EXTDCCAL, 1);
  1732. status += MXL_ControlWrite(fe, AGC_EN_RSSI, 0);
  1733. status += MXL_ControlWrite(fe, RFA_ENCLKRFAGC, 1);
  1734. /* RSSI reference point */
  1735. status += MXL_ControlWrite(fe, RFA_RSSI_REFH, 5);
  1736. status += MXL_ControlWrite(fe, RFA_RSSI_REF, 3);
  1737. status += MXL_ControlWrite(fe, RFA_RSSI_REFL, 2);
  1738. /* change here for v2.6.5 */
  1739. status += MXL_ControlWrite(fe, RFSYN_CHP_GAIN, 3);
  1740. if (state->IF_OUT <= 6280000UL) /* Low IF */
  1741. status += MXL_ControlWrite(fe, BB_IQSWAP, 0);
  1742. else /* High IF */
  1743. status += MXL_ControlWrite(fe, BB_IQSWAP, 1);
  1744. status += MXL_ControlWrite(fe, RFSYN_CHP_GAIN, 2);
  1745. }
  1746. if (state->Mod_Type == MXL_ANALOG_CABLE) {
  1747. /* Analog Cable Mode */
  1748. /* state->Mode = MXL_DIGITAL_MODE; */
  1749. state->AGC_Mode = 1; /* Single AGC Mode */
  1750. /* Disable RSSI */
  1751. status += MXL_ControlWrite(fe, SEQ_EXTSYNTHCALIF, 1);
  1752. status += MXL_ControlWrite(fe, SEQ_EXTDCCAL, 1);
  1753. status += MXL_ControlWrite(fe, AGC_EN_RSSI, 0);
  1754. status += MXL_ControlWrite(fe, RFA_ENCLKRFAGC, 1);
  1755. /* change for 2.6.3 */
  1756. status += MXL_ControlWrite(fe, AGC_IF, 1);
  1757. status += MXL_ControlWrite(fe, AGC_RF, 15);
  1758. status += MXL_ControlWrite(fe, BB_IQSWAP, 1);
  1759. }
  1760. if (state->Mod_Type == MXL_ANALOG_OTA) {
  1761. /* Analog OTA Terrestrial mode add for 2.6.7 */
  1762. /* state->Mode = MXL_ANALOG_MODE; */
  1763. /* Enable RSSI */
  1764. status += MXL_ControlWrite(fe, SEQ_EXTSYNTHCALIF, 1);
  1765. status += MXL_ControlWrite(fe, SEQ_EXTDCCAL, 1);
  1766. status += MXL_ControlWrite(fe, AGC_EN_RSSI, 1);
  1767. status += MXL_ControlWrite(fe, RFA_ENCLKRFAGC, 1);
  1768. /* RSSI reference point */
  1769. status += MXL_ControlWrite(fe, RFA_RSSI_REFH, 5);
  1770. status += MXL_ControlWrite(fe, RFA_RSSI_REF, 3);
  1771. status += MXL_ControlWrite(fe, RFA_RSSI_REFL, 2);
  1772. status += MXL_ControlWrite(fe, RFSYN_CHP_GAIN, 3);
  1773. status += MXL_ControlWrite(fe, BB_IQSWAP, 1);
  1774. }
  1775. /* RSSI disable */
  1776. if (state->EN_RSSI == 0) {
  1777. status += MXL_ControlWrite(fe, SEQ_EXTSYNTHCALIF, 1);
  1778. status += MXL_ControlWrite(fe, SEQ_EXTDCCAL, 1);
  1779. status += MXL_ControlWrite(fe, AGC_EN_RSSI, 0);
  1780. status += MXL_ControlWrite(fe, RFA_ENCLKRFAGC, 1);
  1781. }
  1782. return status;
  1783. }
  1784. static u16 MXL_IFSynthInit(struct dvb_frontend *fe)
  1785. {
  1786. struct mxl5005s_state *state = fe->tuner_priv;
  1787. u16 status = 0 ;
  1788. u32 Fref = 0 ;
  1789. u32 Kdbl, intModVal ;
  1790. u32 fracModVal ;
  1791. Kdbl = 2 ;
  1792. if (state->Fxtal >= 12000000UL && state->Fxtal <= 16000000UL)
  1793. Kdbl = 2 ;
  1794. if (state->Fxtal > 16000000UL && state->Fxtal <= 32000000UL)
  1795. Kdbl = 1 ;
  1796. /* IF Synthesizer Control */
  1797. if (state->Mode == 0 && state->IF_Mode == 1) /* Analog Low IF mode */ {
  1798. if (state->IF_LO == 41000000UL) {
  1799. status += MXL_ControlWrite(fe, IF_DIVVAL, 0x08);
  1800. status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x0C);
  1801. Fref = 328000000UL ;
  1802. }
  1803. if (state->IF_LO == 47000000UL) {
  1804. status += MXL_ControlWrite(fe, IF_DIVVAL, 0x08);
  1805. status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08);
  1806. Fref = 376000000UL ;
  1807. }
  1808. if (state->IF_LO == 54000000UL) {
  1809. status += MXL_ControlWrite(fe, IF_DIVVAL, 0x10);
  1810. status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x0C);
  1811. Fref = 324000000UL ;
  1812. }
  1813. if (state->IF_LO == 60000000UL) {
  1814. status += MXL_ControlWrite(fe, IF_DIVVAL, 0x10);
  1815. status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08);
  1816. Fref = 360000000UL ;
  1817. }
  1818. if (state->IF_LO == 39250000UL) {
  1819. status += MXL_ControlWrite(fe, IF_DIVVAL, 0x08);
  1820. status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x0C);
  1821. Fref = 314000000UL ;
  1822. }
  1823. if (state->IF_LO == 39650000UL) {
  1824. status += MXL_ControlWrite(fe, IF_DIVVAL, 0x08);
  1825. status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x0C);
  1826. Fref = 317200000UL ;
  1827. }
  1828. if (state->IF_LO == 40150000UL) {
  1829. status += MXL_ControlWrite(fe, IF_DIVVAL, 0x08);
  1830. status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x0C);
  1831. Fref = 321200000UL ;
  1832. }
  1833. if (state->IF_LO == 40650000UL) {
  1834. status += MXL_ControlWrite(fe, IF_DIVVAL, 0x08);
  1835. status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x0C);
  1836. Fref = 325200000UL ;
  1837. }
  1838. }
  1839. if (state->Mode || (state->Mode == 0 && state->IF_Mode == 0)) {
  1840. if (state->IF_LO == 57000000UL) {
  1841. status += MXL_ControlWrite(fe, IF_DIVVAL, 0x10);
  1842. status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08);
  1843. Fref = 342000000UL ;
  1844. }
  1845. if (state->IF_LO == 44000000UL) {
  1846. status += MXL_ControlWrite(fe, IF_DIVVAL, 0x08);
  1847. status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08);
  1848. Fref = 352000000UL ;
  1849. }
  1850. if (state->IF_LO == 43750000UL) {
  1851. status += MXL_ControlWrite(fe, IF_DIVVAL, 0x08);
  1852. status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08);
  1853. Fref = 350000000UL ;
  1854. }
  1855. if (state->IF_LO == 36650000UL) {
  1856. status += MXL_ControlWrite(fe, IF_DIVVAL, 0x04);
  1857. status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08);
  1858. Fref = 366500000UL ;
  1859. }
  1860. if (state->IF_LO == 36150000UL) {
  1861. status += MXL_ControlWrite(fe, IF_DIVVAL, 0x04);
  1862. status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08);
  1863. Fref = 361500000UL ;
  1864. }
  1865. if (state->IF_LO == 36000000UL) {
  1866. status += MXL_ControlWrite(fe, IF_DIVVAL, 0x04);
  1867. status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08);
  1868. Fref = 360000000UL ;
  1869. }
  1870. if (state->IF_LO == 35250000UL) {
  1871. status += MXL_ControlWrite(fe, IF_DIVVAL, 0x04);
  1872. status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08);
  1873. Fref = 352500000UL ;
  1874. }
  1875. if (state->IF_LO == 34750000UL) {
  1876. status += MXL_ControlWrite(fe, IF_DIVVAL, 0x04);
  1877. status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08);
  1878. Fref = 347500000UL ;
  1879. }
  1880. if (state->IF_LO == 6280000UL) {
  1881. status += MXL_ControlWrite(fe, IF_DIVVAL, 0x07);
  1882. status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08);
  1883. Fref = 376800000UL ;
  1884. }
  1885. if (state->IF_LO == 5000000UL) {
  1886. status += MXL_ControlWrite(fe, IF_DIVVAL, 0x09);
  1887. status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08);
  1888. Fref = 360000000UL ;
  1889. }
  1890. if (state->IF_LO == 4500000UL) {
  1891. status += MXL_ControlWrite(fe, IF_DIVVAL, 0x06);
  1892. status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08);
  1893. Fref = 360000000UL ;
  1894. }
  1895. if (state->IF_LO == 4570000UL) {
  1896. status += MXL_ControlWrite(fe, IF_DIVVAL, 0x06);
  1897. status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08);
  1898. Fref = 365600000UL ;
  1899. }
  1900. if (state->IF_LO == 4000000UL) {
  1901. status += MXL_ControlWrite(fe, IF_DIVVAL, 0x05);
  1902. status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08);
  1903. Fref = 360000000UL ;
  1904. }
  1905. if (state->IF_LO == 57400000UL) {
  1906. status += MXL_ControlWrite(fe, IF_DIVVAL, 0x10);
  1907. status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08);
  1908. Fref = 344400000UL ;
  1909. }
  1910. if (state->IF_LO == 44400000UL) {
  1911. status += MXL_ControlWrite(fe, IF_DIVVAL, 0x08);
  1912. status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08);
  1913. Fref = 355200000UL ;
  1914. }
  1915. if (state->IF_LO == 44150000UL) {
  1916. status += MXL_ControlWrite(fe, IF_DIVVAL, 0x08);
  1917. status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08);
  1918. Fref = 353200000UL ;
  1919. }
  1920. if (state->IF_LO == 37050000UL) {
  1921. status += MXL_ControlWrite(fe, IF_DIVVAL, 0x04);
  1922. status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08);
  1923. Fref = 370500000UL ;
  1924. }
  1925. if (state->IF_LO == 36550000UL) {
  1926. status += MXL_ControlWrite(fe, IF_DIVVAL, 0x04);
  1927. status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08);
  1928. Fref = 365500000UL ;
  1929. }
  1930. if (state->IF_LO == 36125000UL) {
  1931. status += MXL_ControlWrite(fe, IF_DIVVAL, 0x04);
  1932. status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08);
  1933. Fref = 361250000UL ;
  1934. }
  1935. if (state->IF_LO == 6000000UL) {
  1936. status += MXL_ControlWrite(fe, IF_DIVVAL, 0x07);
  1937. status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08);
  1938. Fref = 360000000UL ;
  1939. }
  1940. if (state->IF_LO == 5400000UL) {
  1941. status += MXL_ControlWrite(fe, IF_DIVVAL, 0x07);
  1942. status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x0C);
  1943. Fref = 324000000UL ;
  1944. }
  1945. if (state->IF_LO == 5380000UL) {
  1946. status += MXL_ControlWrite(fe, IF_DIVVAL, 0x07);
  1947. status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x0C);
  1948. Fref = 322800000UL ;
  1949. }
  1950. if (state->IF_LO == 5200000UL) {
  1951. status += MXL_ControlWrite(fe, IF_DIVVAL, 0x09);
  1952. status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08);
  1953. Fref = 374400000UL ;
  1954. }
  1955. if (state->IF_LO == 4900000UL) {
  1956. status += MXL_ControlWrite(fe, IF_DIVVAL, 0x09);
  1957. status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08);
  1958. Fref = 352800000UL ;
  1959. }
  1960. if (state->IF_LO == 4400000UL) {
  1961. status += MXL_ControlWrite(fe, IF_DIVVAL, 0x06);
  1962. status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08);
  1963. Fref = 352000000UL ;
  1964. }
  1965. if (state->IF_LO == 4063000UL) /* add for 2.6.8 */ {
  1966. status += MXL_ControlWrite(fe, IF_DIVVAL, 0x05);
  1967. status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08);
  1968. Fref = 365670000UL ;
  1969. }
  1970. }
  1971. /* CHCAL_INT_MOD_IF */
  1972. /* CHCAL_FRAC_MOD_IF */
  1973. intModVal = Fref / (state->Fxtal * Kdbl/2);
  1974. status += MXL_ControlWrite(fe, CHCAL_INT_MOD_IF, intModVal);
  1975. fracModVal = (2<<15)*(Fref/1000 - (state->Fxtal/1000 * Kdbl/2) *
  1976. intModVal);
  1977. fracModVal = fracModVal / ((state->Fxtal * Kdbl/2)/1000);
  1978. status += MXL_ControlWrite(fe, CHCAL_FRAC_MOD_IF, fracModVal);
  1979. return status ;
  1980. }
  1981. static u16 MXL_TuneRF(struct dvb_frontend *fe, u32 RF_Freq)
  1982. {
  1983. struct mxl5005s_state *state = fe->tuner_priv;
  1984. u16 status = 0;
  1985. u32 divider_val, E3, E4, E5, E5A;
  1986. u32 Fmax, Fmin, FmaxBin, FminBin;
  1987. u32 Kdbl_RF = 2;
  1988. u32 tg_divval;
  1989. u32 tg_lo;
  1990. u32 Fref_TG;
  1991. u32 Fvco;
  1992. state->RF_IN = RF_Freq;
  1993. MXL_SynthRFTGLO_Calc(fe);
  1994. if (state->Fxtal >= 12000000UL && state->Fxtal <= 22000000UL)
  1995. Kdbl_RF = 2;
  1996. if (state->Fxtal > 22000000 && state->Fxtal <= 32000000)
  1997. Kdbl_RF = 1;
  1998. /* Downconverter Controls
  1999. * Look-Up Table Implementation for:
  2000. * DN_POLY
  2001. * DN_RFGAIN
  2002. * DN_CAP_RFLPF
  2003. * DN_EN_VHFUHFBAR
  2004. * DN_GAIN_ADJUST
  2005. * Change the boundary reference from RF_IN to RF_LO
  2006. */
  2007. if (state->RF_LO < 40000000UL)
  2008. return -1;
  2009. if (state->RF_LO >= 40000000UL && state->RF_LO <= 75000000UL) {
  2010. status += MXL_ControlWrite(fe, DN_POLY, 2);
  2011. status += MXL_ControlWrite(fe, DN_RFGAIN, 3);
  2012. status += MXL_ControlWrite(fe, DN_CAP_RFLPF, 423);
  2013. status += MXL_ControlWrite(fe, DN_EN_VHFUHFBAR, 1);
  2014. status += MXL_ControlWrite(fe, DN_GAIN_ADJUST, 1);
  2015. }
  2016. if (state->RF_LO > 75000000UL && state->RF_LO <= 100000000UL) {
  2017. status += MXL_ControlWrite(fe, DN_POLY, 3);
  2018. status += MXL_ControlWrite(fe, DN_RFGAIN, 3);
  2019. status += MXL_ControlWrite(fe, DN_CAP_RFLPF, 222);
  2020. status += MXL_ControlWrite(fe, DN_EN_VHFUHFBAR, 1);
  2021. status += MXL_ControlWrite(fe, DN_GAIN_ADJUST, 1);
  2022. }
  2023. if (state->RF_LO > 100000000UL && state->RF_LO <= 150000000UL) {
  2024. status += MXL_ControlWrite(fe, DN_POLY, 3);
  2025. status += MXL_ControlWrite(fe, DN_RFGAIN, 3);
  2026. status += MXL_ControlWrite(fe, DN_CAP_RFLPF, 147);
  2027. status += MXL_ControlWrite(fe, DN_EN_VHFUHFBAR, 1);
  2028. status += MXL_ControlWrite(fe, DN_GAIN_ADJUST, 2);
  2029. }
  2030. if (state->RF_LO > 150000000UL && state->RF_LO <= 200000000UL) {
  2031. status += MXL_ControlWrite(fe, DN_POLY, 3);
  2032. status += MXL_ControlWrite(fe, DN_RFGAIN, 3);
  2033. status += MXL_ControlWrite(fe, DN_CAP_RFLPF, 9);
  2034. status += MXL_ControlWrite(fe, DN_EN_VHFUHFBAR, 1);
  2035. status += MXL_ControlWrite(fe, DN_GAIN_ADJUST, 2);
  2036. }
  2037. if (state->RF_LO > 200000000UL && state->RF_LO <= 300000000UL) {
  2038. status += MXL_ControlWrite(fe, DN_POLY, 3);
  2039. status += MXL_ControlWrite(fe, DN_RFGAIN, 3);
  2040. status += MXL_ControlWrite(fe, DN_CAP_RFLPF, 0);
  2041. status += MXL_ControlWrite(fe, DN_EN_VHFUHFBAR, 1);
  2042. status += MXL_ControlWrite(fe, DN_GAIN_ADJUST, 3);
  2043. }
  2044. if (state->RF_LO > 300000000UL && state->RF_LO <= 650000000UL) {
  2045. status += MXL_ControlWrite(fe, DN_POLY, 3);
  2046. status += MXL_ControlWrite(fe, DN_RFGAIN, 1);
  2047. status += MXL_ControlWrite(fe, DN_CAP_RFLPF, 0);
  2048. status += MXL_ControlWrite(fe, DN_EN_VHFUHFBAR, 0);
  2049. status += MXL_ControlWrite(fe, DN_GAIN_ADJUST, 3);
  2050. }
  2051. if (state->RF_LO > 650000000UL && state->RF_LO <= 900000000UL) {
  2052. status += MXL_ControlWrite(fe, DN_POLY, 3);
  2053. status += MXL_ControlWrite(fe, DN_RFGAIN, 2);
  2054. status += MXL_ControlWrite(fe, DN_CAP_RFLPF, 0);
  2055. status += MXL_ControlWrite(fe, DN_EN_VHFUHFBAR, 0);
  2056. status += MXL_ControlWrite(fe, DN_GAIN_ADJUST, 3);
  2057. }
  2058. if (state->RF_LO > 900000000UL)
  2059. return -1;
  2060. /* DN_IQTNBUF_AMP */
  2061. /* DN_IQTNGNBFBIAS_BST */
  2062. if (state->RF_LO >= 40000000UL && state->RF_LO <= 75000000UL) {
  2063. status += MXL_ControlWrite(fe, DN_IQTNBUF_AMP, 1);
  2064. status += MXL_ControlWrite(fe, DN_IQTNGNBFBIAS_BST, 0);
  2065. }
  2066. if (state->RF_LO > 75000000UL && state->RF_LO <= 100000000UL) {
  2067. status += MXL_ControlWrite(fe, DN_IQTNBUF_AMP, 1);
  2068. status += MXL_ControlWrite(fe, DN_IQTNGNBFBIAS_BST, 0);
  2069. }
  2070. if (state->RF_LO > 100000000UL && state->RF_LO <= 150000000UL) {
  2071. status += MXL_ControlWrite(fe, DN_IQTNBUF_AMP, 1);
  2072. status += MXL_ControlWrite(fe, DN_IQTNGNBFBIAS_BST, 0);
  2073. }
  2074. if (state->RF_LO > 150000000UL && state->RF_LO <= 200000000UL) {
  2075. status += MXL_ControlWrite(fe, DN_IQTNBUF_AMP, 1);
  2076. status += MXL_ControlWrite(fe, DN_IQTNGNBFBIAS_BST, 0);
  2077. }
  2078. if (state->RF_LO > 200000000UL && state->RF_LO <= 300000000UL) {
  2079. status += MXL_ControlWrite(fe, DN_IQTNBUF_AMP, 1);
  2080. status += MXL_ControlWrite(fe, DN_IQTNGNBFBIAS_BST, 0);
  2081. }
  2082. if (state->RF_LO > 300000000UL && state->RF_LO <= 400000000UL) {
  2083. status += MXL_ControlWrite(fe, DN_IQTNBUF_AMP, 1);
  2084. status += MXL_ControlWrite(fe, DN_IQTNGNBFBIAS_BST, 0);
  2085. }
  2086. if (state->RF_LO > 400000000UL && state->RF_LO <= 450000000UL) {
  2087. status += MXL_ControlWrite(fe, DN_IQTNBUF_AMP, 1);
  2088. status += MXL_ControlWrite(fe, DN_IQTNGNBFBIAS_BST, 0);
  2089. }
  2090. if (state->RF_LO > 450000000UL && state->RF_LO <= 500000000UL) {
  2091. status += MXL_ControlWrite(fe, DN_IQTNBUF_AMP, 1);
  2092. status += MXL_ControlWrite(fe, DN_IQTNGNBFBIAS_BST, 0);
  2093. }
  2094. if (state->RF_LO > 500000000UL && state->RF_LO <= 550000000UL) {
  2095. status += MXL_ControlWrite(fe, DN_IQTNBUF_AMP, 1);
  2096. status += MXL_ControlWrite(fe, DN_IQTNGNBFBIAS_BST, 0);
  2097. }
  2098. if (state->RF_LO > 550000000UL && state->RF_LO <= 600000000UL) {
  2099. status += MXL_ControlWrite(fe, DN_IQTNBUF_AMP, 1);
  2100. status += MXL_ControlWrite(fe, DN_IQTNGNBFBIAS_BST, 0);
  2101. }
  2102. if (state->RF_LO > 600000000UL && state->RF_LO <= 650000000UL) {
  2103. status += MXL_ControlWrite(fe, DN_IQTNBUF_AMP, 1);
  2104. status += MXL_ControlWrite(fe, DN_IQTNGNBFBIAS_BST, 0);
  2105. }
  2106. if (state->RF_LO > 650000000UL && state->RF_LO <= 700000000UL) {
  2107. status += MXL_ControlWrite(fe, DN_IQTNBUF_AMP, 1);
  2108. status += MXL_ControlWrite(fe, DN_IQTNGNBFBIAS_BST, 0);
  2109. }
  2110. if (state->RF_LO > 700000000UL && state->RF_LO <= 750000000UL) {
  2111. status += MXL_ControlWrite(fe, DN_IQTNBUF_AMP, 1);
  2112. status += MXL_ControlWrite(fe, DN_IQTNGNBFBIAS_BST, 0);
  2113. }
  2114. if (state->RF_LO > 750000000UL && state->RF_LO <= 800000000UL) {
  2115. status += MXL_ControlWrite(fe, DN_IQTNBUF_AMP, 1);
  2116. status += MXL_ControlWrite(fe, DN_IQTNGNBFBIAS_BST, 0);
  2117. }
  2118. if (state->RF_LO > 800000000UL && state->RF_LO <= 850000000UL) {
  2119. status += MXL_ControlWrite(fe, DN_IQTNBUF_AMP, 10);
  2120. status += MXL_ControlWrite(fe, DN_IQTNGNBFBIAS_BST, 1);
  2121. }
  2122. if (state->RF_LO > 850000000UL && state->RF_LO <= 900000000UL) {
  2123. status += MXL_ControlWrite(fe, DN_IQTNBUF_AMP, 10);
  2124. status += MXL_ControlWrite(fe, DN_IQTNGNBFBIAS_BST, 1);
  2125. }
  2126. /*
  2127. * Set RF Synth and LO Path Control
  2128. *
  2129. * Look-Up table implementation for:
  2130. * RFSYN_EN_OUTMUX
  2131. * RFSYN_SEL_VCO_OUT
  2132. * RFSYN_SEL_VCO_HI
  2133. * RFSYN_SEL_DIVM
  2134. * RFSYN_RF_DIV_BIAS
  2135. * DN_SEL_FREQ
  2136. *
  2137. * Set divider_val, Fmax, Fmix to use in Equations
  2138. */
  2139. FminBin = 28000000UL ;
  2140. FmaxBin = 42500000UL ;
  2141. if (state->RF_LO >= 40000000UL && state->RF_LO <= FmaxBin) {
  2142. status += MXL_ControlWrite(fe, RFSYN_EN_OUTMUX, 1);
  2143. status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_OUT, 0);
  2144. status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 0);
  2145. status += MXL_ControlWrite(fe, RFSYN_SEL_DIVM, 0);
  2146. status += MXL_ControlWrite(fe, RFSYN_RF_DIV_BIAS, 1);
  2147. status += MXL_ControlWrite(fe, DN_SEL_FREQ, 1);
  2148. divider_val = 64 ;
  2149. Fmax = FmaxBin ;
  2150. Fmin = FminBin ;
  2151. }
  2152. FminBin = 42500000UL ;
  2153. FmaxBin = 56000000UL ;
  2154. if (state->RF_LO > FminBin && state->RF_LO <= FmaxBin) {
  2155. status += MXL_ControlWrite(fe, RFSYN_EN_OUTMUX, 1);
  2156. status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_OUT, 0);
  2157. status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 1);
  2158. status += MXL_ControlWrite(fe, RFSYN_SEL_DIVM, 0);
  2159. status += MXL_ControlWrite(fe, RFSYN_RF_DIV_BIAS, 1);
  2160. status += MXL_ControlWrite(fe, DN_SEL_FREQ, 1);
  2161. divider_val = 64 ;
  2162. Fmax = FmaxBin ;
  2163. Fmin = FminBin ;
  2164. }
  2165. FminBin = 56000000UL ;
  2166. FmaxBin = 85000000UL ;
  2167. if (state->RF_LO > FminBin && state->RF_LO <= FmaxBin) {
  2168. status += MXL_ControlWrite(fe, RFSYN_EN_OUTMUX, 0);
  2169. status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_OUT, 1);
  2170. status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 0);
  2171. status += MXL_ControlWrite(fe, RFSYN_SEL_DIVM, 0);
  2172. status += MXL_ControlWrite(fe, RFSYN_RF_DIV_BIAS, 1);
  2173. status += MXL_ControlWrite(fe, DN_SEL_FREQ, 1);
  2174. divider_val = 32 ;
  2175. Fmax = FmaxBin ;
  2176. Fmin = FminBin ;
  2177. }
  2178. FminBin = 85000000UL ;
  2179. FmaxBin = 112000000UL ;
  2180. if (state->RF_LO > FminBin && state->RF_LO <= FmaxBin) {
  2181. status += MXL_ControlWrite(fe, RFSYN_EN_OUTMUX, 0);
  2182. status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_OUT, 1);
  2183. status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 1);
  2184. status += MXL_ControlWrite(fe, RFSYN_SEL_DIVM, 0);
  2185. status += MXL_ControlWrite(fe, RFSYN_RF_DIV_BIAS, 1);
  2186. status += MXL_ControlWrite(fe, DN_SEL_FREQ, 1);
  2187. divider_val = 32 ;
  2188. Fmax = FmaxBin ;
  2189. Fmin = FminBin ;
  2190. }
  2191. FminBin = 112000000UL ;
  2192. FmaxBin = 170000000UL ;
  2193. if (state->RF_LO > FminBin && state->RF_LO <= FmaxBin) {
  2194. status += MXL_ControlWrite(fe, RFSYN_EN_OUTMUX, 0);
  2195. status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_OUT, 1);
  2196. status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 0);
  2197. status += MXL_ControlWrite(fe, RFSYN_SEL_DIVM, 0);
  2198. status += MXL_ControlWrite(fe, RFSYN_RF_DIV_BIAS, 1);
  2199. status += MXL_ControlWrite(fe, DN_SEL_FREQ, 2);
  2200. divider_val = 16 ;
  2201. Fmax = FmaxBin ;
  2202. Fmin = FminBin ;
  2203. }
  2204. FminBin = 170000000UL ;
  2205. FmaxBin = 225000000UL ;
  2206. if (state->RF_LO > FminBin && state->RF_LO <= FmaxBin) {
  2207. status += MXL_ControlWrite(fe, RFSYN_EN_OUTMUX, 0);
  2208. status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_OUT, 1);
  2209. status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 1);
  2210. status += MXL_ControlWrite(fe, RFSYN_SEL_DIVM, 0);
  2211. status += MXL_ControlWrite(fe, RFSYN_RF_DIV_BIAS, 1);
  2212. status += MXL_ControlWrite(fe, DN_SEL_FREQ, 2);
  2213. divider_val = 16 ;
  2214. Fmax = FmaxBin ;
  2215. Fmin = FminBin ;
  2216. }
  2217. FminBin = 225000000UL ;
  2218. FmaxBin = 300000000UL ;
  2219. if (state->RF_LO > FminBin && state->RF_LO <= FmaxBin) {
  2220. status += MXL_ControlWrite(fe, RFSYN_EN_OUTMUX, 0);
  2221. status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_OUT, 1);
  2222. status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 0);
  2223. status += MXL_ControlWrite(fe, RFSYN_SEL_DIVM, 0);
  2224. status += MXL_ControlWrite(fe, RFSYN_RF_DIV_BIAS, 1);
  2225. status += MXL_ControlWrite(fe, DN_SEL_FREQ, 4);
  2226. divider_val = 8 ;
  2227. Fmax = 340000000UL ;
  2228. Fmin = FminBin ;
  2229. }
  2230. FminBin = 300000000UL ;
  2231. FmaxBin = 340000000UL ;
  2232. if (state->RF_LO > FminBin && state->RF_LO <= FmaxBin) {
  2233. status += MXL_ControlWrite(fe, RFSYN_EN_OUTMUX, 1);
  2234. status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_OUT, 0);
  2235. status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 0);
  2236. status += MXL_ControlWrite(fe, RFSYN_SEL_DIVM, 0);
  2237. status += MXL_ControlWrite(fe, RFSYN_RF_DIV_BIAS, 1);
  2238. status += MXL_ControlWrite(fe, DN_SEL_FREQ, 0);
  2239. divider_val = 8 ;
  2240. Fmax = FmaxBin ;
  2241. Fmin = 225000000UL ;
  2242. }
  2243. FminBin = 340000000UL ;
  2244. FmaxBin = 450000000UL ;
  2245. if (state->RF_LO > FminBin && state->RF_LO <= FmaxBin) {
  2246. status += MXL_ControlWrite(fe, RFSYN_EN_OUTMUX, 1);
  2247. status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_OUT, 0);
  2248. status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 1);
  2249. status += MXL_ControlWrite(fe, RFSYN_SEL_DIVM, 0);
  2250. status += MXL_ControlWrite(fe, RFSYN_RF_DIV_BIAS, 2);
  2251. status += MXL_ControlWrite(fe, DN_SEL_FREQ, 0);
  2252. divider_val = 8 ;
  2253. Fmax = FmaxBin ;
  2254. Fmin = FminBin ;
  2255. }
  2256. FminBin = 450000000UL ;
  2257. FmaxBin = 680000000UL ;
  2258. if (state->RF_LO > FminBin && state->RF_LO <= FmaxBin) {
  2259. status += MXL_ControlWrite(fe, RFSYN_EN_OUTMUX, 0);
  2260. status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_OUT, 1);
  2261. status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 0);
  2262. status += MXL_ControlWrite(fe, RFSYN_SEL_DIVM, 1);
  2263. status += MXL_ControlWrite(fe, RFSYN_RF_DIV_BIAS, 1);
  2264. status += MXL_ControlWrite(fe, DN_SEL_FREQ, 0);
  2265. divider_val = 4 ;
  2266. Fmax = FmaxBin ;
  2267. Fmin = FminBin ;
  2268. }
  2269. FminBin = 680000000UL ;
  2270. FmaxBin = 900000000UL ;
  2271. if (state->RF_LO > FminBin && state->RF_LO <= FmaxBin) {
  2272. status += MXL_ControlWrite(fe, RFSYN_EN_OUTMUX, 0);
  2273. status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_OUT, 1);
  2274. status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 1);
  2275. status += MXL_ControlWrite(fe, RFSYN_SEL_DIVM, 1);
  2276. status += MXL_ControlWrite(fe, RFSYN_RF_DIV_BIAS, 1);
  2277. status += MXL_ControlWrite(fe, DN_SEL_FREQ, 0);
  2278. divider_val = 4 ;
  2279. Fmax = FmaxBin ;
  2280. Fmin = FminBin ;
  2281. }
  2282. /* CHCAL_INT_MOD_RF
  2283. * CHCAL_FRAC_MOD_RF
  2284. * RFSYN_LPF_R
  2285. * CHCAL_EN_INT_RF
  2286. */
  2287. /* Equation E3 RFSYN_VCO_BIAS */
  2288. E3 = (((Fmax-state->RF_LO)/1000)*32)/((Fmax-Fmin)/1000) + 8 ;
  2289. status += MXL_ControlWrite(fe, RFSYN_VCO_BIAS, E3);
  2290. /* Equation E4 CHCAL_INT_MOD_RF */
  2291. E4 = (state->RF_LO*divider_val/1000)/(2*state->Fxtal*Kdbl_RF/1000);
  2292. MXL_ControlWrite(fe, CHCAL_INT_MOD_RF, E4);
  2293. /* Equation E5 CHCAL_FRAC_MOD_RF CHCAL_EN_INT_RF */
  2294. E5 = ((2<<17)*(state->RF_LO/10000*divider_val -
  2295. (E4*(2*state->Fxtal*Kdbl_RF)/10000))) /
  2296. (2*state->Fxtal*Kdbl_RF/10000);
  2297. status += MXL_ControlWrite(fe, CHCAL_FRAC_MOD_RF, E5);
  2298. /* Equation E5A RFSYN_LPF_R */
  2299. E5A = (((Fmax - state->RF_LO)/1000)*4/((Fmax-Fmin)/1000)) + 1 ;
  2300. status += MXL_ControlWrite(fe, RFSYN_LPF_R, E5A);
  2301. /* Euqation E5B CHCAL_EN_INIT_RF */
  2302. status += MXL_ControlWrite(fe, CHCAL_EN_INT_RF, ((E5 == 0) ? 1 : 0));
  2303. /*if (E5 == 0)
  2304. * status += MXL_ControlWrite(fe, CHCAL_EN_INT_RF, 1);
  2305. *else
  2306. * status += MXL_ControlWrite(fe, CHCAL_FRAC_MOD_RF, E5);
  2307. */
  2308. /*
  2309. * Set TG Synth
  2310. *
  2311. * Look-Up table implementation for:
  2312. * TG_LO_DIVVAL
  2313. * TG_LO_SELVAL
  2314. *
  2315. * Set divider_val, Fmax, Fmix to use in Equations
  2316. */
  2317. if (state->TG_LO < 33000000UL)
  2318. return -1;
  2319. FminBin = 33000000UL ;
  2320. FmaxBin = 50000000UL ;
  2321. if (state->TG_LO >= FminBin && state->TG_LO <= FmaxBin) {
  2322. status += MXL_ControlWrite(fe, TG_LO_DIVVAL, 0x6);
  2323. status += MXL_ControlWrite(fe, TG_LO_SELVAL, 0x0);
  2324. divider_val = 36 ;
  2325. Fmax = FmaxBin ;
  2326. Fmin = FminBin ;
  2327. }
  2328. FminBin = 50000000UL ;
  2329. FmaxBin = 67000000UL ;
  2330. if (state->TG_LO > FminBin && state->TG_LO <= FmaxBin) {
  2331. status += MXL_ControlWrite(fe, TG_LO_DIVVAL, 0x1);
  2332. status += MXL_ControlWrite(fe, TG_LO_SELVAL, 0x0);
  2333. divider_val = 24 ;
  2334. Fmax = FmaxBin ;
  2335. Fmin = FminBin ;
  2336. }
  2337. FminBin = 67000000UL ;
  2338. FmaxBin = 100000000UL ;
  2339. if (state->TG_LO > FminBin && state->TG_LO <= FmaxBin) {
  2340. status += MXL_ControlWrite(fe, TG_LO_DIVVAL, 0xC);
  2341. status += MXL_ControlWrite(fe, TG_LO_SELVAL, 0x2);
  2342. divider_val = 18 ;
  2343. Fmax = FmaxBin ;
  2344. Fmin = FminBin ;
  2345. }
  2346. FminBin = 100000000UL ;
  2347. FmaxBin = 150000000UL ;
  2348. if (state->TG_LO > FminBin && state->TG_LO <= FmaxBin) {
  2349. status += MXL_ControlWrite(fe, TG_LO_DIVVAL, 0x8);
  2350. status += MXL_ControlWrite(fe, TG_LO_SELVAL, 0x2);
  2351. divider_val = 12 ;
  2352. Fmax = FmaxBin ;
  2353. Fmin = FminBin ;
  2354. }
  2355. FminBin = 150000000UL ;
  2356. FmaxBin = 200000000UL ;
  2357. if (state->TG_LO > FminBin && state->TG_LO <= FmaxBin) {
  2358. status += MXL_ControlWrite(fe, TG_LO_DIVVAL, 0x0);
  2359. status += MXL_ControlWrite(fe, TG_LO_SELVAL, 0x2);
  2360. divider_val = 8 ;
  2361. Fmax = FmaxBin ;
  2362. Fmin = FminBin ;
  2363. }
  2364. FminBin = 200000000UL ;
  2365. FmaxBin = 300000000UL ;
  2366. if (state->TG_LO > FminBin && state->TG_LO <= FmaxBin) {
  2367. status += MXL_ControlWrite(fe, TG_LO_DIVVAL, 0x8);
  2368. status += MXL_ControlWrite(fe, TG_LO_SELVAL, 0x3);
  2369. divider_val = 6 ;
  2370. Fmax = FmaxBin ;
  2371. Fmin = FminBin ;
  2372. }
  2373. FminBin = 300000000UL ;
  2374. FmaxBin = 400000000UL ;
  2375. if (state->TG_LO > FminBin && state->TG_LO <= FmaxBin) {
  2376. status += MXL_ControlWrite(fe, TG_LO_DIVVAL, 0x0);
  2377. status += MXL_ControlWrite(fe, TG_LO_SELVAL, 0x3);
  2378. divider_val = 4 ;
  2379. Fmax = FmaxBin ;
  2380. Fmin = FminBin ;
  2381. }
  2382. FminBin = 400000000UL ;
  2383. FmaxBin = 600000000UL ;
  2384. if (state->TG_LO > FminBin && state->TG_LO <= FmaxBin) {
  2385. status += MXL_ControlWrite(fe, TG_LO_DIVVAL, 0x8);
  2386. status += MXL_ControlWrite(fe, TG_LO_SELVAL, 0x7);
  2387. divider_val = 3 ;
  2388. Fmax = FmaxBin ;
  2389. Fmin = FminBin ;
  2390. }
  2391. FminBin = 600000000UL ;
  2392. FmaxBin = 900000000UL ;
  2393. if (state->TG_LO > FminBin && state->TG_LO <= FmaxBin) {
  2394. status += MXL_ControlWrite(fe, TG_LO_DIVVAL, 0x0);
  2395. status += MXL_ControlWrite(fe, TG_LO_SELVAL, 0x7);
  2396. divider_val = 2 ;
  2397. Fmax = FmaxBin ;
  2398. Fmin = FminBin ;
  2399. }
  2400. /* TG_DIV_VAL */
  2401. tg_divval = (state->TG_LO*divider_val/100000) *
  2402. (MXL_Ceiling(state->Fxtal, 1000000) * 100) /
  2403. (state->Fxtal/1000);
  2404. status += MXL_ControlWrite(fe, TG_DIV_VAL, tg_divval);
  2405. if (state->TG_LO > 600000000UL)
  2406. status += MXL_ControlWrite(fe, TG_DIV_VAL, tg_divval + 1);
  2407. Fmax = 1800000000UL ;
  2408. Fmin = 1200000000UL ;
  2409. /* prevent overflow of 32 bit unsigned integer, use
  2410. * following equation. Edit for v2.6.4
  2411. */
  2412. /* Fref_TF = Fref_TG * 1000 */
  2413. Fref_TG = (state->Fxtal/1000) / MXL_Ceiling(state->Fxtal, 1000000);
  2414. /* Fvco = Fvco/10 */
  2415. Fvco = (state->TG_LO/10000) * divider_val * Fref_TG;
  2416. tg_lo = (((Fmax/10 - Fvco)/100)*32) / ((Fmax-Fmin)/1000)+8;
  2417. /* below equation is same as above but much harder to debug.
  2418. *
  2419. * static u32 MXL_GetXtalInt(u32 Xtal_Freq)
  2420. * {
  2421. * if ((Xtal_Freq % 1000000) == 0)
  2422. * return (Xtal_Freq / 10000);
  2423. * else
  2424. * return (((Xtal_Freq / 1000000) + 1)*100);
  2425. * }
  2426. *
  2427. * u32 Xtal_Int = MXL_GetXtalInt(state->Fxtal);
  2428. * tg_lo = ( ((Fmax/10000 * Xtal_Int)/100) -
  2429. * ((state->TG_LO/10000)*divider_val *
  2430. * (state->Fxtal/10000)/100) )*32/((Fmax-Fmin)/10000 *
  2431. * Xtal_Int/100) + 8;
  2432. */
  2433. status += MXL_ControlWrite(fe, TG_VCO_BIAS , tg_lo);
  2434. /* add for 2.6.5 Special setting for QAM */
  2435. if (state->Mod_Type == MXL_QAM) {
  2436. if (state->config->qam_gain != 0)
  2437. status += MXL_ControlWrite(fe, RFSYN_CHP_GAIN,
  2438. state->config->qam_gain);
  2439. else if (state->RF_IN < 680000000)
  2440. status += MXL_ControlWrite(fe, RFSYN_CHP_GAIN, 3);
  2441. else
  2442. status += MXL_ControlWrite(fe, RFSYN_CHP_GAIN, 2);
  2443. }
  2444. /* Off Chip Tracking Filter Control */
  2445. if (state->TF_Type == MXL_TF_OFF) {
  2446. /* Tracking Filter Off State; turn off all the banks */
  2447. status += MXL_ControlWrite(fe, DAC_A_ENABLE, 0);
  2448. status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0);
  2449. status += MXL_SetGPIO(fe, 3, 1); /* Bank1 Off */
  2450. status += MXL_SetGPIO(fe, 1, 1); /* Bank2 Off */
  2451. status += MXL_SetGPIO(fe, 4, 1); /* Bank3 Off */
  2452. }
  2453. if (state->TF_Type == MXL_TF_C) /* Tracking Filter type C */ {
  2454. status += MXL_ControlWrite(fe, DAC_B_ENABLE, 1);
  2455. status += MXL_ControlWrite(fe, DAC_DIN_A, 0);
  2456. if (state->RF_IN >= 43000000 && state->RF_IN < 150000000) {
  2457. status += MXL_ControlWrite(fe, DAC_A_ENABLE, 0);
  2458. status += MXL_ControlWrite(fe, DAC_DIN_B, 0);
  2459. status += MXL_SetGPIO(fe, 3, 0);
  2460. status += MXL_SetGPIO(fe, 1, 1);
  2461. status += MXL_SetGPIO(fe, 4, 1);
  2462. }
  2463. if (state->RF_IN >= 150000000 && state->RF_IN < 280000000) {
  2464. status += MXL_ControlWrite(fe, DAC_A_ENABLE, 0);
  2465. status += MXL_ControlWrite(fe, DAC_DIN_B, 0);
  2466. status += MXL_SetGPIO(fe, 3, 1);
  2467. status += MXL_SetGPIO(fe, 1, 0);
  2468. status += MXL_SetGPIO(fe, 4, 1);
  2469. }
  2470. if (state->RF_IN >= 280000000 && state->RF_IN < 360000000) {
  2471. status += MXL_ControlWrite(fe, DAC_A_ENABLE, 0);
  2472. status += MXL_ControlWrite(fe, DAC_DIN_B, 0);
  2473. status += MXL_SetGPIO(fe, 3, 1);
  2474. status += MXL_SetGPIO(fe, 1, 0);
  2475. status += MXL_SetGPIO(fe, 4, 0);
  2476. }
  2477. if (state->RF_IN >= 360000000 && state->RF_IN < 560000000) {
  2478. status += MXL_ControlWrite(fe, DAC_A_ENABLE, 0);
  2479. status += MXL_ControlWrite(fe, DAC_DIN_B, 0);
  2480. status += MXL_SetGPIO(fe, 3, 1);
  2481. status += MXL_SetGPIO(fe, 1, 1);
  2482. status += MXL_SetGPIO(fe, 4, 0);
  2483. }
  2484. if (state->RF_IN >= 560000000 && state->RF_IN < 580000000) {
  2485. status += MXL_ControlWrite(fe, DAC_A_ENABLE, 1);
  2486. status += MXL_ControlWrite(fe, DAC_DIN_B, 29);
  2487. status += MXL_SetGPIO(fe, 3, 1);
  2488. status += MXL_SetGPIO(fe, 1, 1);
  2489. status += MXL_SetGPIO(fe, 4, 0);
  2490. }
  2491. if (state->RF_IN >= 580000000 && state->RF_IN < 630000000) {
  2492. status += MXL_ControlWrite(fe, DAC_A_ENABLE, 1);
  2493. status += MXL_ControlWrite(fe, DAC_DIN_B, 0);
  2494. status += MXL_SetGPIO(fe, 3, 1);
  2495. status += MXL_SetGPIO(fe, 1, 1);
  2496. status += MXL_SetGPIO(fe, 4, 0);
  2497. }
  2498. if (state->RF_IN >= 630000000 && state->RF_IN < 700000000) {
  2499. status += MXL_ControlWrite(fe, DAC_A_ENABLE, 1);
  2500. status += MXL_ControlWrite(fe, DAC_DIN_B, 16);
  2501. status += MXL_SetGPIO(fe, 3, 1);
  2502. status += MXL_SetGPIO(fe, 1, 1);
  2503. status += MXL_SetGPIO(fe, 4, 1);
  2504. }
  2505. if (state->RF_IN >= 700000000 && state->RF_IN < 760000000) {
  2506. status += MXL_ControlWrite(fe, DAC_A_ENABLE, 1);
  2507. status += MXL_ControlWrite(fe, DAC_DIN_B, 7);
  2508. status += MXL_SetGPIO(fe, 3, 1);
  2509. status += MXL_SetGPIO(fe, 1, 1);
  2510. status += MXL_SetGPIO(fe, 4, 1);
  2511. }
  2512. if (state->RF_IN >= 760000000 && state->RF_IN <= 900000000) {
  2513. status += MXL_ControlWrite(fe, DAC_A_ENABLE, 1);
  2514. status += MXL_ControlWrite(fe, DAC_DIN_B, 0);
  2515. status += MXL_SetGPIO(fe, 3, 1);
  2516. status += MXL_SetGPIO(fe, 1, 1);
  2517. status += MXL_SetGPIO(fe, 4, 1);
  2518. }
  2519. }
  2520. if (state->TF_Type == MXL_TF_C_H) {
  2521. /* Tracking Filter type C-H for Hauppauge only */
  2522. status += MXL_ControlWrite(fe, DAC_DIN_A, 0);
  2523. if (state->RF_IN >= 43000000 && state->RF_IN < 150000000) {
  2524. status += MXL_ControlWrite(fe, DAC_A_ENABLE, 0);
  2525. status += MXL_SetGPIO(fe, 4, 0);
  2526. status += MXL_SetGPIO(fe, 3, 1);
  2527. status += MXL_SetGPIO(fe, 1, 1);
  2528. }
  2529. if (state->RF_IN >= 150000000 && state->RF_IN < 280000000) {
  2530. status += MXL_ControlWrite(fe, DAC_A_ENABLE, 0);
  2531. status += MXL_SetGPIO(fe, 4, 1);
  2532. status += MXL_SetGPIO(fe, 3, 0);
  2533. status += MXL_SetGPIO(fe, 1, 1);
  2534. }
  2535. if (state->RF_IN >= 280000000 && state->RF_IN < 360000000) {
  2536. status += MXL_ControlWrite(fe, DAC_A_ENABLE, 0);
  2537. status += MXL_SetGPIO(fe, 4, 1);
  2538. status += MXL_SetGPIO(fe, 3, 0);
  2539. status += MXL_SetGPIO(fe, 1, 0);
  2540. }
  2541. if (state->RF_IN >= 360000000 && state->RF_IN < 560000000) {
  2542. status += MXL_ControlWrite(fe, DAC_A_ENABLE, 0);
  2543. status += MXL_SetGPIO(fe, 4, 1);
  2544. status += MXL_SetGPIO(fe, 3, 1);
  2545. status += MXL_SetGPIO(fe, 1, 0);
  2546. }
  2547. if (state->RF_IN >= 560000000 && state->RF_IN < 580000000) {
  2548. status += MXL_ControlWrite(fe, DAC_A_ENABLE, 1);
  2549. status += MXL_SetGPIO(fe, 4, 1);
  2550. status += MXL_SetGPIO(fe, 3, 1);
  2551. status += MXL_SetGPIO(fe, 1, 0);
  2552. }
  2553. if (state->RF_IN >= 580000000 && state->RF_IN < 630000000) {
  2554. status += MXL_ControlWrite(fe, DAC_A_ENABLE, 1);
  2555. status += MXL_SetGPIO(fe, 4, 1);
  2556. status += MXL_SetGPIO(fe, 3, 1);
  2557. status += MXL_SetGPIO(fe, 1, 0);
  2558. }
  2559. if (state->RF_IN >= 630000000 && state->RF_IN < 700000000) {
  2560. status += MXL_ControlWrite(fe, DAC_A_ENABLE, 1);
  2561. status += MXL_SetGPIO(fe, 4, 1);
  2562. status += MXL_SetGPIO(fe, 3, 1);
  2563. status += MXL_SetGPIO(fe, 1, 1);
  2564. }
  2565. if (state->RF_IN >= 700000000 && state->RF_IN < 760000000) {
  2566. status += MXL_ControlWrite(fe, DAC_A_ENABLE, 1);
  2567. status += MXL_SetGPIO(fe, 4, 1);
  2568. status += MXL_SetGPIO(fe, 3, 1);
  2569. status += MXL_SetGPIO(fe, 1, 1);
  2570. }
  2571. if (state->RF_IN >= 760000000 && state->RF_IN <= 900000000) {
  2572. status += MXL_ControlWrite(fe, DAC_A_ENABLE, 1);
  2573. status += MXL_SetGPIO(fe, 4, 1);
  2574. status += MXL_SetGPIO(fe, 3, 1);
  2575. status += MXL_SetGPIO(fe, 1, 1);
  2576. }
  2577. }
  2578. if (state->TF_Type == MXL_TF_D) { /* Tracking Filter type D */
  2579. status += MXL_ControlWrite(fe, DAC_DIN_B, 0);
  2580. if (state->RF_IN >= 43000000 && state->RF_IN < 174000000) {
  2581. status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0);
  2582. status += MXL_SetGPIO(fe, 4, 0);
  2583. status += MXL_SetGPIO(fe, 1, 1);
  2584. status += MXL_SetGPIO(fe, 3, 1);
  2585. }
  2586. if (state->RF_IN >= 174000000 && state->RF_IN < 250000000) {
  2587. status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0);
  2588. status += MXL_SetGPIO(fe, 4, 0);
  2589. status += MXL_SetGPIO(fe, 1, 0);
  2590. status += MXL_SetGPIO(fe, 3, 1);
  2591. }
  2592. if (state->RF_IN >= 250000000 && state->RF_IN < 310000000) {
  2593. status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0);
  2594. status += MXL_SetGPIO(fe, 4, 1);
  2595. status += MXL_SetGPIO(fe, 1, 0);
  2596. status += MXL_SetGPIO(fe, 3, 1);
  2597. }
  2598. if (state->RF_IN >= 310000000 && state->RF_IN < 360000000) {
  2599. status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0);
  2600. status += MXL_SetGPIO(fe, 4, 1);
  2601. status += MXL_SetGPIO(fe, 1, 0);
  2602. status += MXL_SetGPIO(fe, 3, 0);
  2603. }
  2604. if (state->RF_IN >= 360000000 && state->RF_IN < 470000000) {
  2605. status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0);
  2606. status += MXL_SetGPIO(fe, 4, 1);
  2607. status += MXL_SetGPIO(fe, 1, 1);
  2608. status += MXL_SetGPIO(fe, 3, 0);
  2609. }
  2610. if (state->RF_IN >= 470000000 && state->RF_IN < 640000000) {
  2611. status += MXL_ControlWrite(fe, DAC_B_ENABLE, 1);
  2612. status += MXL_SetGPIO(fe, 4, 1);
  2613. status += MXL_SetGPIO(fe, 1, 1);
  2614. status += MXL_SetGPIO(fe, 3, 0);
  2615. }
  2616. if (state->RF_IN >= 640000000 && state->RF_IN <= 900000000) {
  2617. status += MXL_ControlWrite(fe, DAC_B_ENABLE, 1);
  2618. status += MXL_SetGPIO(fe, 4, 1);
  2619. status += MXL_SetGPIO(fe, 1, 1);
  2620. status += MXL_SetGPIO(fe, 3, 1);
  2621. }
  2622. }
  2623. if (state->TF_Type == MXL_TF_D_L) {
  2624. /* Tracking Filter type D-L for Lumanate ONLY change 2.6.3 */
  2625. status += MXL_ControlWrite(fe, DAC_DIN_A, 0);
  2626. /* if UHF and terrestrial => Turn off Tracking Filter */
  2627. if (state->RF_IN >= 471000000 &&
  2628. (state->RF_IN - 471000000)%6000000 != 0) {
  2629. /* Turn off all the banks */
  2630. status += MXL_SetGPIO(fe, 3, 1);
  2631. status += MXL_SetGPIO(fe, 1, 1);
  2632. status += MXL_SetGPIO(fe, 4, 1);
  2633. status += MXL_ControlWrite(fe, DAC_A_ENABLE, 0);
  2634. status += MXL_ControlWrite(fe, AGC_IF, 10);
  2635. } else {
  2636. /* if VHF or cable => Turn on Tracking Filter */
  2637. if (state->RF_IN >= 43000000 &&
  2638. state->RF_IN < 140000000) {
  2639. status += MXL_ControlWrite(fe, DAC_A_ENABLE, 0);
  2640. status += MXL_SetGPIO(fe, 4, 1);
  2641. status += MXL_SetGPIO(fe, 1, 1);
  2642. status += MXL_SetGPIO(fe, 3, 0);
  2643. }
  2644. if (state->RF_IN >= 140000000 &&
  2645. state->RF_IN < 240000000) {
  2646. status += MXL_ControlWrite(fe, DAC_A_ENABLE, 0);
  2647. status += MXL_SetGPIO(fe, 4, 1);
  2648. status += MXL_SetGPIO(fe, 1, 0);
  2649. status += MXL_SetGPIO(fe, 3, 0);
  2650. }
  2651. if (state->RF_IN >= 240000000 &&
  2652. state->RF_IN < 340000000) {
  2653. status += MXL_ControlWrite(fe, DAC_A_ENABLE, 0);
  2654. status += MXL_SetGPIO(fe, 4, 0);
  2655. status += MXL_SetGPIO(fe, 1, 1);
  2656. status += MXL_SetGPIO(fe, 3, 0);
  2657. }
  2658. if (state->RF_IN >= 340000000 &&
  2659. state->RF_IN < 430000000) {
  2660. status += MXL_ControlWrite(fe, DAC_A_ENABLE, 0);
  2661. status += MXL_SetGPIO(fe, 4, 0);
  2662. status += MXL_SetGPIO(fe, 1, 0);
  2663. status += MXL_SetGPIO(fe, 3, 1);
  2664. }
  2665. if (state->RF_IN >= 430000000 &&
  2666. state->RF_IN < 470000000) {
  2667. status += MXL_ControlWrite(fe, DAC_A_ENABLE, 1);
  2668. status += MXL_SetGPIO(fe, 4, 1);
  2669. status += MXL_SetGPIO(fe, 1, 0);
  2670. status += MXL_SetGPIO(fe, 3, 1);
  2671. }
  2672. if (state->RF_IN >= 470000000 &&
  2673. state->RF_IN < 570000000) {
  2674. status += MXL_ControlWrite(fe, DAC_A_ENABLE, 1);
  2675. status += MXL_SetGPIO(fe, 4, 0);
  2676. status += MXL_SetGPIO(fe, 1, 0);
  2677. status += MXL_SetGPIO(fe, 3, 1);
  2678. }
  2679. if (state->RF_IN >= 570000000 &&
  2680. state->RF_IN < 620000000) {
  2681. status += MXL_ControlWrite(fe, DAC_A_ENABLE, 0);
  2682. status += MXL_SetGPIO(fe, 4, 0);
  2683. status += MXL_SetGPIO(fe, 1, 1);
  2684. status += MXL_SetGPIO(fe, 3, 1);
  2685. }
  2686. if (state->RF_IN >= 620000000 &&
  2687. state->RF_IN < 760000000) {
  2688. status += MXL_ControlWrite(fe, DAC_A_ENABLE, 1);
  2689. status += MXL_SetGPIO(fe, 4, 0);
  2690. status += MXL_SetGPIO(fe, 1, 1);
  2691. status += MXL_SetGPIO(fe, 3, 1);
  2692. }
  2693. if (state->RF_IN >= 760000000 &&
  2694. state->RF_IN <= 900000000) {
  2695. status += MXL_ControlWrite(fe, DAC_A_ENABLE, 1);
  2696. status += MXL_SetGPIO(fe, 4, 1);
  2697. status += MXL_SetGPIO(fe, 1, 1);
  2698. status += MXL_SetGPIO(fe, 3, 1);
  2699. }
  2700. }
  2701. }
  2702. if (state->TF_Type == MXL_TF_E) /* Tracking Filter type E */ {
  2703. status += MXL_ControlWrite(fe, DAC_DIN_B, 0);
  2704. if (state->RF_IN >= 43000000 && state->RF_IN < 174000000) {
  2705. status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0);
  2706. status += MXL_SetGPIO(fe, 4, 0);
  2707. status += MXL_SetGPIO(fe, 1, 1);
  2708. status += MXL_SetGPIO(fe, 3, 1);
  2709. }
  2710. if (state->RF_IN >= 174000000 && state->RF_IN < 250000000) {
  2711. status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0);
  2712. status += MXL_SetGPIO(fe, 4, 0);
  2713. status += MXL_SetGPIO(fe, 1, 0);
  2714. status += MXL_SetGPIO(fe, 3, 1);
  2715. }
  2716. if (state->RF_IN >= 250000000 && state->RF_IN < 310000000) {
  2717. status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0);
  2718. status += MXL_SetGPIO(fe, 4, 1);
  2719. status += MXL_SetGPIO(fe, 1, 0);
  2720. status += MXL_SetGPIO(fe, 3, 1);
  2721. }
  2722. if (state->RF_IN >= 310000000 && state->RF_IN < 360000000) {
  2723. status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0);
  2724. status += MXL_SetGPIO(fe, 4, 1);
  2725. status += MXL_SetGPIO(fe, 1, 0);
  2726. status += MXL_SetGPIO(fe, 3, 0);
  2727. }
  2728. if (state->RF_IN >= 360000000 && state->RF_IN < 470000000) {
  2729. status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0);
  2730. status += MXL_SetGPIO(fe, 4, 1);
  2731. status += MXL_SetGPIO(fe, 1, 1);
  2732. status += MXL_SetGPIO(fe, 3, 0);
  2733. }
  2734. if (state->RF_IN >= 470000000 && state->RF_IN < 640000000) {
  2735. status += MXL_ControlWrite(fe, DAC_B_ENABLE, 1);
  2736. status += MXL_SetGPIO(fe, 4, 1);
  2737. status += MXL_SetGPIO(fe, 1, 1);
  2738. status += MXL_SetGPIO(fe, 3, 0);
  2739. }
  2740. if (state->RF_IN >= 640000000 && state->RF_IN <= 900000000) {
  2741. status += MXL_ControlWrite(fe, DAC_B_ENABLE, 1);
  2742. status += MXL_SetGPIO(fe, 4, 1);
  2743. status += MXL_SetGPIO(fe, 1, 1);
  2744. status += MXL_SetGPIO(fe, 3, 1);
  2745. }
  2746. }
  2747. if (state->TF_Type == MXL_TF_F) {
  2748. /* Tracking Filter type F */
  2749. status += MXL_ControlWrite(fe, DAC_DIN_B, 0);
  2750. if (state->RF_IN >= 43000000 && state->RF_IN < 160000000) {
  2751. status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0);
  2752. status += MXL_SetGPIO(fe, 4, 0);
  2753. status += MXL_SetGPIO(fe, 1, 1);
  2754. status += MXL_SetGPIO(fe, 3, 1);
  2755. }
  2756. if (state->RF_IN >= 160000000 && state->RF_IN < 210000000) {
  2757. status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0);
  2758. status += MXL_SetGPIO(fe, 4, 0);
  2759. status += MXL_SetGPIO(fe, 1, 0);
  2760. status += MXL_SetGPIO(fe, 3, 1);
  2761. }
  2762. if (state->RF_IN >= 210000000 && state->RF_IN < 300000000) {
  2763. status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0);
  2764. status += MXL_SetGPIO(fe, 4, 1);
  2765. status += MXL_SetGPIO(fe, 1, 0);
  2766. status += MXL_SetGPIO(fe, 3, 1);
  2767. }
  2768. if (state->RF_IN >= 300000000 && state->RF_IN < 390000000) {
  2769. status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0);
  2770. status += MXL_SetGPIO(fe, 4, 1);
  2771. status += MXL_SetGPIO(fe, 1, 0);
  2772. status += MXL_SetGPIO(fe, 3, 0);
  2773. }
  2774. if (state->RF_IN >= 390000000 && state->RF_IN < 515000000) {
  2775. status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0);
  2776. status += MXL_SetGPIO(fe, 4, 1);
  2777. status += MXL_SetGPIO(fe, 1, 1);
  2778. status += MXL_SetGPIO(fe, 3, 0);
  2779. }
  2780. if (state->RF_IN >= 515000000 && state->RF_IN < 650000000) {
  2781. status += MXL_ControlWrite(fe, DAC_B_ENABLE, 1);
  2782. status += MXL_SetGPIO(fe, 4, 1);
  2783. status += MXL_SetGPIO(fe, 1, 1);
  2784. status += MXL_SetGPIO(fe, 3, 0);
  2785. }
  2786. if (state->RF_IN >= 650000000 && state->RF_IN <= 900000000) {
  2787. status += MXL_ControlWrite(fe, DAC_B_ENABLE, 1);
  2788. status += MXL_SetGPIO(fe, 4, 1);
  2789. status += MXL_SetGPIO(fe, 1, 1);
  2790. status += MXL_SetGPIO(fe, 3, 1);
  2791. }
  2792. }
  2793. if (state->TF_Type == MXL_TF_E_2) {
  2794. /* Tracking Filter type E_2 */
  2795. status += MXL_ControlWrite(fe, DAC_DIN_B, 0);
  2796. if (state->RF_IN >= 43000000 && state->RF_IN < 174000000) {
  2797. status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0);
  2798. status += MXL_SetGPIO(fe, 4, 0);
  2799. status += MXL_SetGPIO(fe, 1, 1);
  2800. status += MXL_SetGPIO(fe, 3, 1);
  2801. }
  2802. if (state->RF_IN >= 174000000 && state->RF_IN < 250000000) {
  2803. status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0);
  2804. status += MXL_SetGPIO(fe, 4, 0);
  2805. status += MXL_SetGPIO(fe, 1, 0);
  2806. status += MXL_SetGPIO(fe, 3, 1);
  2807. }
  2808. if (state->RF_IN >= 250000000 && state->RF_IN < 350000000) {
  2809. status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0);
  2810. status += MXL_SetGPIO(fe, 4, 1);
  2811. status += MXL_SetGPIO(fe, 1, 0);
  2812. status += MXL_SetGPIO(fe, 3, 1);
  2813. }
  2814. if (state->RF_IN >= 350000000 && state->RF_IN < 400000000) {
  2815. status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0);
  2816. status += MXL_SetGPIO(fe, 4, 1);
  2817. status += MXL_SetGPIO(fe, 1, 0);
  2818. status += MXL_SetGPIO(fe, 3, 0);
  2819. }
  2820. if (state->RF_IN >= 400000000 && state->RF_IN < 570000000) {
  2821. status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0);
  2822. status += MXL_SetGPIO(fe, 4, 1);
  2823. status += MXL_SetGPIO(fe, 1, 1);
  2824. status += MXL_SetGPIO(fe, 3, 0);
  2825. }
  2826. if (state->RF_IN >= 570000000 && state->RF_IN < 770000000) {
  2827. status += MXL_ControlWrite(fe, DAC_B_ENABLE, 1);
  2828. status += MXL_SetGPIO(fe, 4, 1);
  2829. status += MXL_SetGPIO(fe, 1, 1);
  2830. status += MXL_SetGPIO(fe, 3, 0);
  2831. }
  2832. if (state->RF_IN >= 770000000 && state->RF_IN <= 900000000) {
  2833. status += MXL_ControlWrite(fe, DAC_B_ENABLE, 1);
  2834. status += MXL_SetGPIO(fe, 4, 1);
  2835. status += MXL_SetGPIO(fe, 1, 1);
  2836. status += MXL_SetGPIO(fe, 3, 1);
  2837. }
  2838. }
  2839. if (state->TF_Type == MXL_TF_G) {
  2840. /* Tracking Filter type G add for v2.6.8 */
  2841. status += MXL_ControlWrite(fe, DAC_DIN_B, 0);
  2842. if (state->RF_IN >= 50000000 && state->RF_IN < 190000000) {
  2843. status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0);
  2844. status += MXL_SetGPIO(fe, 4, 0);
  2845. status += MXL_SetGPIO(fe, 1, 1);
  2846. status += MXL_SetGPIO(fe, 3, 1);
  2847. }
  2848. if (state->RF_IN >= 190000000 && state->RF_IN < 280000000) {
  2849. status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0);
  2850. status += MXL_SetGPIO(fe, 4, 0);
  2851. status += MXL_SetGPIO(fe, 1, 0);
  2852. status += MXL_SetGPIO(fe, 3, 1);
  2853. }
  2854. if (state->RF_IN >= 280000000 && state->RF_IN < 350000000) {
  2855. status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0);
  2856. status += MXL_SetGPIO(fe, 4, 1);
  2857. status += MXL_SetGPIO(fe, 1, 0);
  2858. status += MXL_SetGPIO(fe, 3, 1);
  2859. }
  2860. if (state->RF_IN >= 350000000 && state->RF_IN < 400000000) {
  2861. status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0);
  2862. status += MXL_SetGPIO(fe, 4, 1);
  2863. status += MXL_SetGPIO(fe, 1, 0);
  2864. status += MXL_SetGPIO(fe, 3, 0);
  2865. }
  2866. if (state->RF_IN >= 400000000 && state->RF_IN < 470000000) {
  2867. status += MXL_ControlWrite(fe, DAC_B_ENABLE, 1);
  2868. status += MXL_SetGPIO(fe, 4, 1);
  2869. status += MXL_SetGPIO(fe, 1, 0);
  2870. status += MXL_SetGPIO(fe, 3, 1);
  2871. }
  2872. if (state->RF_IN >= 470000000 && state->RF_IN < 640000000) {
  2873. status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0);
  2874. status += MXL_SetGPIO(fe, 4, 1);
  2875. status += MXL_SetGPIO(fe, 1, 1);
  2876. status += MXL_SetGPIO(fe, 3, 0);
  2877. }
  2878. if (state->RF_IN >= 640000000 && state->RF_IN < 820000000) {
  2879. status += MXL_ControlWrite(fe, DAC_B_ENABLE, 1);
  2880. status += MXL_SetGPIO(fe, 4, 1);
  2881. status += MXL_SetGPIO(fe, 1, 1);
  2882. status += MXL_SetGPIO(fe, 3, 0);
  2883. }
  2884. if (state->RF_IN >= 820000000 && state->RF_IN <= 900000000) {
  2885. status += MXL_ControlWrite(fe, DAC_B_ENABLE, 1);
  2886. status += MXL_SetGPIO(fe, 4, 1);
  2887. status += MXL_SetGPIO(fe, 1, 1);
  2888. status += MXL_SetGPIO(fe, 3, 1);
  2889. }
  2890. }
  2891. if (state->TF_Type == MXL_TF_E_NA) {
  2892. /* Tracking Filter type E-NA for Empia ONLY change for 2.6.8 */
  2893. status += MXL_ControlWrite(fe, DAC_DIN_B, 0);
  2894. /* if UHF and terrestrial=> Turn off Tracking Filter */
  2895. if (state->RF_IN >= 471000000 &&
  2896. (state->RF_IN - 471000000)%6000000 != 0) {
  2897. /* Turn off all the banks */
  2898. status += MXL_SetGPIO(fe, 3, 1);
  2899. status += MXL_SetGPIO(fe, 1, 1);
  2900. status += MXL_SetGPIO(fe, 4, 1);
  2901. status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0);
  2902. /* 2.6.12 Turn on RSSI */
  2903. status += MXL_ControlWrite(fe, SEQ_EXTSYNTHCALIF, 1);
  2904. status += MXL_ControlWrite(fe, SEQ_EXTDCCAL, 1);
  2905. status += MXL_ControlWrite(fe, AGC_EN_RSSI, 1);
  2906. status += MXL_ControlWrite(fe, RFA_ENCLKRFAGC, 1);
  2907. /* RSSI reference point */
  2908. status += MXL_ControlWrite(fe, RFA_RSSI_REFH, 5);
  2909. status += MXL_ControlWrite(fe, RFA_RSSI_REF, 3);
  2910. status += MXL_ControlWrite(fe, RFA_RSSI_REFL, 2);
  2911. /* following parameter is from analog OTA mode,
  2912. * can be change to seek better performance */
  2913. status += MXL_ControlWrite(fe, RFSYN_CHP_GAIN, 3);
  2914. } else {
  2915. /* if VHF or Cable => Turn on Tracking Filter */
  2916. /* 2.6.12 Turn off RSSI */
  2917. status += MXL_ControlWrite(fe, AGC_EN_RSSI, 0);
  2918. /* change back from above condition */
  2919. status += MXL_ControlWrite(fe, RFSYN_CHP_GAIN, 5);
  2920. if (state->RF_IN >= 43000000 && state->RF_IN < 174000000) {
  2921. status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0);
  2922. status += MXL_SetGPIO(fe, 4, 0);
  2923. status += MXL_SetGPIO(fe, 1, 1);
  2924. status += MXL_SetGPIO(fe, 3, 1);
  2925. }
  2926. if (state->RF_IN >= 174000000 && state->RF_IN < 250000000) {
  2927. status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0);
  2928. status += MXL_SetGPIO(fe, 4, 0);
  2929. status += MXL_SetGPIO(fe, 1, 0);
  2930. status += MXL_SetGPIO(fe, 3, 1);
  2931. }
  2932. if (state->RF_IN >= 250000000 && state->RF_IN < 350000000) {
  2933. status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0);
  2934. status += MXL_SetGPIO(fe, 4, 1);
  2935. status += MXL_SetGPIO(fe, 1, 0);
  2936. status += MXL_SetGPIO(fe, 3, 1);
  2937. }
  2938. if (state->RF_IN >= 350000000 && state->RF_IN < 400000000) {
  2939. status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0);
  2940. status += MXL_SetGPIO(fe, 4, 1);
  2941. status += MXL_SetGPIO(fe, 1, 0);
  2942. status += MXL_SetGPIO(fe, 3, 0);
  2943. }
  2944. if (state->RF_IN >= 400000000 && state->RF_IN < 570000000) {
  2945. status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0);
  2946. status += MXL_SetGPIO(fe, 4, 1);
  2947. status += MXL_SetGPIO(fe, 1, 1);
  2948. status += MXL_SetGPIO(fe, 3, 0);
  2949. }
  2950. if (state->RF_IN >= 570000000 && state->RF_IN < 770000000) {
  2951. status += MXL_ControlWrite(fe, DAC_B_ENABLE, 1);
  2952. status += MXL_SetGPIO(fe, 4, 1);
  2953. status += MXL_SetGPIO(fe, 1, 1);
  2954. status += MXL_SetGPIO(fe, 3, 0);
  2955. }
  2956. if (state->RF_IN >= 770000000 && state->RF_IN <= 900000000) {
  2957. status += MXL_ControlWrite(fe, DAC_B_ENABLE, 1);
  2958. status += MXL_SetGPIO(fe, 4, 1);
  2959. status += MXL_SetGPIO(fe, 1, 1);
  2960. status += MXL_SetGPIO(fe, 3, 1);
  2961. }
  2962. }
  2963. }
  2964. return status ;
  2965. }
  2966. static u16 MXL_SetGPIO(struct dvb_frontend *fe, u8 GPIO_Num, u8 GPIO_Val)
  2967. {
  2968. u16 status = 0;
  2969. if (GPIO_Num == 1)
  2970. status += MXL_ControlWrite(fe, GPIO_1B, GPIO_Val ? 0 : 1);
  2971. /* GPIO2 is not available */
  2972. if (GPIO_Num == 3) {
  2973. if (GPIO_Val == 1) {
  2974. status += MXL_ControlWrite(fe, GPIO_3, 0);
  2975. status += MXL_ControlWrite(fe, GPIO_3B, 0);
  2976. }
  2977. if (GPIO_Val == 0) {
  2978. status += MXL_ControlWrite(fe, GPIO_3, 1);
  2979. status += MXL_ControlWrite(fe, GPIO_3B, 1);
  2980. }
  2981. if (GPIO_Val == 3) { /* tri-state */
  2982. status += MXL_ControlWrite(fe, GPIO_3, 0);
  2983. status += MXL_ControlWrite(fe, GPIO_3B, 1);
  2984. }
  2985. }
  2986. if (GPIO_Num == 4) {
  2987. if (GPIO_Val == 1) {
  2988. status += MXL_ControlWrite(fe, GPIO_4, 0);
  2989. status += MXL_ControlWrite(fe, GPIO_4B, 0);
  2990. }
  2991. if (GPIO_Val == 0) {
  2992. status += MXL_ControlWrite(fe, GPIO_4, 1);
  2993. status += MXL_ControlWrite(fe, GPIO_4B, 1);
  2994. }
  2995. if (GPIO_Val == 3) { /* tri-state */
  2996. status += MXL_ControlWrite(fe, GPIO_4, 0);
  2997. status += MXL_ControlWrite(fe, GPIO_4B, 1);
  2998. }
  2999. }
  3000. return status;
  3001. }
  3002. static u16 MXL_ControlWrite(struct dvb_frontend *fe, u16 ControlNum, u32 value)
  3003. {
  3004. u16 status = 0;
  3005. /* Will write ALL Matching Control Name */
  3006. /* Write Matching INIT Control */
  3007. status += MXL_ControlWrite_Group(fe, ControlNum, value, 1);
  3008. /* Write Matching CH Control */
  3009. status += MXL_ControlWrite_Group(fe, ControlNum, value, 2);
  3010. #ifdef _MXL_INTERNAL
  3011. /* Write Matching MXL Control */
  3012. status += MXL_ControlWrite_Group(fe, ControlNum, value, 3);
  3013. #endif
  3014. return status;
  3015. }
  3016. static u16 MXL_ControlWrite_Group(struct dvb_frontend *fe, u16 controlNum,
  3017. u32 value, u16 controlGroup)
  3018. {
  3019. struct mxl5005s_state *state = fe->tuner_priv;
  3020. u16 i, j, k;
  3021. u32 highLimit;
  3022. u32 ctrlVal;
  3023. if (controlGroup == 1) /* Initial Control */ {
  3024. for (i = 0; i < state->Init_Ctrl_Num; i++) {
  3025. if (controlNum == state->Init_Ctrl[i].Ctrl_Num) {
  3026. highLimit = 1 << state->Init_Ctrl[i].size;
  3027. if (value < highLimit) {
  3028. for (j = 0; j < state->Init_Ctrl[i].size; j++) {
  3029. state->Init_Ctrl[i].val[j] = (u8)((value >> j) & 0x01);
  3030. MXL_RegWriteBit(fe, (u8)(state->Init_Ctrl[i].addr[j]),
  3031. (u8)(state->Init_Ctrl[i].bit[j]),
  3032. (u8)((value>>j) & 0x01));
  3033. }
  3034. ctrlVal = 0;
  3035. for (k = 0; k < state->Init_Ctrl[i].size; k++)
  3036. ctrlVal += state->Init_Ctrl[i].val[k] * (1 << k);
  3037. } else
  3038. return -1;
  3039. }
  3040. }
  3041. }
  3042. if (controlGroup == 2) /* Chan change Control */ {
  3043. for (i = 0; i < state->CH_Ctrl_Num; i++) {
  3044. if (controlNum == state->CH_Ctrl[i].Ctrl_Num) {
  3045. highLimit = 1 << state->CH_Ctrl[i].size;
  3046. if (value < highLimit) {
  3047. for (j = 0; j < state->CH_Ctrl[i].size; j++) {
  3048. state->CH_Ctrl[i].val[j] = (u8)((value >> j) & 0x01);
  3049. MXL_RegWriteBit(fe, (u8)(state->CH_Ctrl[i].addr[j]),
  3050. (u8)(state->CH_Ctrl[i].bit[j]),
  3051. (u8)((value>>j) & 0x01));
  3052. }
  3053. ctrlVal = 0;
  3054. for (k = 0; k < state->CH_Ctrl[i].size; k++)
  3055. ctrlVal += state->CH_Ctrl[i].val[k] * (1 << k);
  3056. } else
  3057. return -1;
  3058. }
  3059. }
  3060. }
  3061. #ifdef _MXL_INTERNAL
  3062. if (controlGroup == 3) /* Maxlinear Control */ {
  3063. for (i = 0; i < state->MXL_Ctrl_Num; i++) {
  3064. if (controlNum == state->MXL_Ctrl[i].Ctrl_Num) {
  3065. highLimit = (1 << state->MXL_Ctrl[i].size);
  3066. if (value < highLimit) {
  3067. for (j = 0; j < state->MXL_Ctrl[i].size; j++) {
  3068. state->MXL_Ctrl[i].val[j] = (u8)((value >> j) & 0x01);
  3069. MXL_RegWriteBit(fe, (u8)(state->MXL_Ctrl[i].addr[j]),
  3070. (u8)(state->MXL_Ctrl[i].bit[j]),
  3071. (u8)((value>>j) & 0x01));
  3072. }
  3073. ctrlVal = 0;
  3074. for (k = 0; k < state->MXL_Ctrl[i].size; k++)
  3075. ctrlVal += state->
  3076. MXL_Ctrl[i].val[k] *
  3077. (1 << k);
  3078. } else
  3079. return -1;
  3080. }
  3081. }
  3082. }
  3083. #endif
  3084. return 0 ; /* successful return */
  3085. }
  3086. static u16 MXL_RegRead(struct dvb_frontend *fe, u8 RegNum, u8 *RegVal)
  3087. {
  3088. struct mxl5005s_state *state = fe->tuner_priv;
  3089. int i ;
  3090. for (i = 0; i < 104; i++) {
  3091. if (RegNum == state->TunerRegs[i].Reg_Num) {
  3092. *RegVal = (u8)(state->TunerRegs[i].Reg_Val);
  3093. return 0;
  3094. }
  3095. }
  3096. return 1;
  3097. }
  3098. static u16 MXL_ControlRead(struct dvb_frontend *fe, u16 controlNum, u32 *value)
  3099. {
  3100. struct mxl5005s_state *state = fe->tuner_priv;
  3101. u32 ctrlVal ;
  3102. u16 i, k ;
  3103. for (i = 0; i < state->Init_Ctrl_Num ; i++) {
  3104. if (controlNum == state->Init_Ctrl[i].Ctrl_Num) {
  3105. ctrlVal = 0;
  3106. for (k = 0; k < state->Init_Ctrl[i].size; k++)
  3107. ctrlVal += state->Init_Ctrl[i].val[k] * (1<<k);
  3108. *value = ctrlVal;
  3109. return 0;
  3110. }
  3111. }
  3112. for (i = 0; i < state->CH_Ctrl_Num ; i++) {
  3113. if (controlNum == state->CH_Ctrl[i].Ctrl_Num) {
  3114. ctrlVal = 0;
  3115. for (k = 0; k < state->CH_Ctrl[i].size; k++)
  3116. ctrlVal += state->CH_Ctrl[i].val[k] * (1 << k);
  3117. *value = ctrlVal;
  3118. return 0;
  3119. }
  3120. }
  3121. #ifdef _MXL_INTERNAL
  3122. for (i = 0; i < state->MXL_Ctrl_Num ; i++) {
  3123. if (controlNum == state->MXL_Ctrl[i].Ctrl_Num) {
  3124. ctrlVal = 0;
  3125. for (k = 0; k < state->MXL_Ctrl[i].size; k++)
  3126. ctrlVal += state->MXL_Ctrl[i].val[k] * (1<<k);
  3127. *value = ctrlVal;
  3128. return 0;
  3129. }
  3130. }
  3131. #endif
  3132. return 1;
  3133. }
  3134. static void MXL_RegWriteBit(struct dvb_frontend *fe, u8 address, u8 bit,
  3135. u8 bitVal)
  3136. {
  3137. struct mxl5005s_state *state = fe->tuner_priv;
  3138. int i ;
  3139. const u8 AND_MAP[8] = {
  3140. 0xFE, 0xFD, 0xFB, 0xF7,
  3141. 0xEF, 0xDF, 0xBF, 0x7F } ;
  3142. const u8 OR_MAP[8] = {
  3143. 0x01, 0x02, 0x04, 0x08,
  3144. 0x10, 0x20, 0x40, 0x80 } ;
  3145. for (i = 0; i < state->TunerRegs_Num; i++) {
  3146. if (state->TunerRegs[i].Reg_Num == address) {
  3147. if (bitVal)
  3148. state->TunerRegs[i].Reg_Val |= OR_MAP[bit];
  3149. else
  3150. state->TunerRegs[i].Reg_Val &= AND_MAP[bit];
  3151. break ;
  3152. }
  3153. }
  3154. }
  3155. static u32 MXL_Ceiling(u32 value, u32 resolution)
  3156. {
  3157. return value / resolution + (value % resolution > 0 ? 1 : 0);
  3158. }
  3159. /* Retrieve the Initialzation Registers */
  3160. static u16 MXL_GetInitRegister(struct dvb_frontend *fe, u8 *RegNum,
  3161. u8 *RegVal, int *count)
  3162. {
  3163. u16 status = 0;
  3164. int i ;
  3165. u8 RegAddr[] = {
  3166. 11, 12, 13, 22, 32, 43, 44, 53, 56, 59, 73,
  3167. 76, 77, 91, 134, 135, 137, 147,
  3168. 156, 166, 167, 168, 25 };
  3169. *count = ARRAY_SIZE(RegAddr);
  3170. status += MXL_BlockInit(fe);
  3171. for (i = 0 ; i < *count; i++) {
  3172. RegNum[i] = RegAddr[i];
  3173. status += MXL_RegRead(fe, RegNum[i], &RegVal[i]);
  3174. }
  3175. return status;
  3176. }
  3177. static u16 MXL_GetCHRegister(struct dvb_frontend *fe, u8 *RegNum, u8 *RegVal,
  3178. int *count)
  3179. {
  3180. u16 status = 0;
  3181. int i ;
  3182. /* add 77, 166, 167, 168 register for 2.6.12 */
  3183. #ifdef _MXL_PRODUCTION
  3184. u8 RegAddr[] = {14, 15, 16, 17, 22, 43, 65, 68, 69, 70, 73, 92, 93, 106,
  3185. 107, 108, 109, 110, 111, 112, 136, 138, 149, 77, 166, 167, 168 } ;
  3186. #else
  3187. u8 RegAddr[] = {14, 15, 16, 17, 22, 43, 68, 69, 70, 73, 92, 93, 106,
  3188. 107, 108, 109, 110, 111, 112, 136, 138, 149, 77, 166, 167, 168 } ;
  3189. /*
  3190. u8 RegAddr[171];
  3191. for (i = 0; i <= 170; i++)
  3192. RegAddr[i] = i;
  3193. */
  3194. #endif
  3195. *count = ARRAY_SIZE(RegAddr);
  3196. for (i = 0 ; i < *count; i++) {
  3197. RegNum[i] = RegAddr[i];
  3198. status += MXL_RegRead(fe, RegNum[i], &RegVal[i]);
  3199. }
  3200. return status;
  3201. }
  3202. static u16 MXL_GetCHRegister_ZeroIF(struct dvb_frontend *fe, u8 *RegNum,
  3203. u8 *RegVal, int *count)
  3204. {
  3205. u16 status = 0;
  3206. int i;
  3207. u8 RegAddr[] = {43, 136};
  3208. *count = ARRAY_SIZE(RegAddr);
  3209. for (i = 0; i < *count; i++) {
  3210. RegNum[i] = RegAddr[i];
  3211. status += MXL_RegRead(fe, RegNum[i], &RegVal[i]);
  3212. }
  3213. return status;
  3214. }
  3215. static u16 MXL_GetMasterControl(u8 *MasterReg, int state)
  3216. {
  3217. if (state == 1) /* Load_Start */
  3218. *MasterReg = 0xF3;
  3219. if (state == 2) /* Power_Down */
  3220. *MasterReg = 0x41;
  3221. if (state == 3) /* Synth_Reset */
  3222. *MasterReg = 0xB1;
  3223. if (state == 4) /* Seq_Off */
  3224. *MasterReg = 0xF1;
  3225. return 0;
  3226. }
  3227. #ifdef _MXL_PRODUCTION
  3228. static u16 MXL_VCORange_Test(struct dvb_frontend *fe, int VCO_Range)
  3229. {
  3230. struct mxl5005s_state *state = fe->tuner_priv;
  3231. u16 status = 0 ;
  3232. if (VCO_Range == 1) {
  3233. status += MXL_ControlWrite(fe, RFSYN_EN_DIV, 1);
  3234. status += MXL_ControlWrite(fe, RFSYN_EN_OUTMUX, 0);
  3235. status += MXL_ControlWrite(fe, RFSYN_SEL_DIVM, 0);
  3236. status += MXL_ControlWrite(fe, RFSYN_DIVM, 1);
  3237. status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_OUT, 1);
  3238. status += MXL_ControlWrite(fe, RFSYN_RF_DIV_BIAS, 1);
  3239. status += MXL_ControlWrite(fe, DN_SEL_FREQ, 0);
  3240. if (state->Mode == 0 && state->IF_Mode == 1) {
  3241. /* Analog Low IF Mode */
  3242. status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 1);
  3243. status += MXL_ControlWrite(fe, RFSYN_VCO_BIAS, 8);
  3244. status += MXL_ControlWrite(fe, CHCAL_INT_MOD_RF, 56);
  3245. status += MXL_ControlWrite(fe,
  3246. CHCAL_FRAC_MOD_RF, 180224);
  3247. }
  3248. if (state->Mode == 0 && state->IF_Mode == 0) {
  3249. /* Analog Zero IF Mode */
  3250. status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 1);
  3251. status += MXL_ControlWrite(fe, RFSYN_VCO_BIAS, 8);
  3252. status += MXL_ControlWrite(fe, CHCAL_INT_MOD_RF, 56);
  3253. status += MXL_ControlWrite(fe,
  3254. CHCAL_FRAC_MOD_RF, 222822);
  3255. }
  3256. if (state->Mode == 1) /* Digital Mode */ {
  3257. status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 1);
  3258. status += MXL_ControlWrite(fe, RFSYN_VCO_BIAS, 8);
  3259. status += MXL_ControlWrite(fe, CHCAL_INT_MOD_RF, 56);
  3260. status += MXL_ControlWrite(fe,
  3261. CHCAL_FRAC_MOD_RF, 229376);
  3262. }
  3263. }
  3264. if (VCO_Range == 2) {
  3265. status += MXL_ControlWrite(fe, RFSYN_EN_DIV, 1);
  3266. status += MXL_ControlWrite(fe, RFSYN_EN_OUTMUX, 0);
  3267. status += MXL_ControlWrite(fe, RFSYN_SEL_DIVM, 0);
  3268. status += MXL_ControlWrite(fe, RFSYN_DIVM, 1);
  3269. status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_OUT, 1);
  3270. status += MXL_ControlWrite(fe, RFSYN_RF_DIV_BIAS, 1);
  3271. status += MXL_ControlWrite(fe, DN_SEL_FREQ, 0);
  3272. status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 1);
  3273. status += MXL_ControlWrite(fe, RFSYN_VCO_BIAS, 40);
  3274. status += MXL_ControlWrite(fe, CHCAL_INT_MOD_RF, 41);
  3275. if (state->Mode == 0 && state->IF_Mode == 1) {
  3276. /* Analog Low IF Mode */
  3277. status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 1);
  3278. status += MXL_ControlWrite(fe, RFSYN_VCO_BIAS, 40);
  3279. status += MXL_ControlWrite(fe, CHCAL_INT_MOD_RF, 42);
  3280. status += MXL_ControlWrite(fe,
  3281. CHCAL_FRAC_MOD_RF, 206438);
  3282. }
  3283. if (state->Mode == 0 && state->IF_Mode == 0) {
  3284. /* Analog Zero IF Mode */
  3285. status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 1);
  3286. status += MXL_ControlWrite(fe, RFSYN_VCO_BIAS, 40);
  3287. status += MXL_ControlWrite(fe, CHCAL_INT_MOD_RF, 42);
  3288. status += MXL_ControlWrite(fe,
  3289. CHCAL_FRAC_MOD_RF, 206438);
  3290. }
  3291. if (state->Mode == 1) /* Digital Mode */ {
  3292. status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 1);
  3293. status += MXL_ControlWrite(fe, RFSYN_VCO_BIAS, 40);
  3294. status += MXL_ControlWrite(fe, CHCAL_INT_MOD_RF, 41);
  3295. status += MXL_ControlWrite(fe,
  3296. CHCAL_FRAC_MOD_RF, 16384);
  3297. }
  3298. }
  3299. if (VCO_Range == 3) {
  3300. status += MXL_ControlWrite(fe, RFSYN_EN_DIV, 1);
  3301. status += MXL_ControlWrite(fe, RFSYN_EN_OUTMUX, 0);
  3302. status += MXL_ControlWrite(fe, RFSYN_SEL_DIVM, 0);
  3303. status += MXL_ControlWrite(fe, RFSYN_DIVM, 1);
  3304. status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_OUT, 1);
  3305. status += MXL_ControlWrite(fe, RFSYN_RF_DIV_BIAS, 1);
  3306. status += MXL_ControlWrite(fe, DN_SEL_FREQ, 0);
  3307. status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 0);
  3308. status += MXL_ControlWrite(fe, RFSYN_VCO_BIAS, 8);
  3309. status += MXL_ControlWrite(fe, CHCAL_INT_MOD_RF, 42);
  3310. if (state->Mode == 0 && state->IF_Mode == 1) {
  3311. /* Analog Low IF Mode */
  3312. status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 0);
  3313. status += MXL_ControlWrite(fe, RFSYN_VCO_BIAS, 8);
  3314. status += MXL_ControlWrite(fe, CHCAL_INT_MOD_RF, 44);
  3315. status += MXL_ControlWrite(fe,
  3316. CHCAL_FRAC_MOD_RF, 173670);
  3317. }
  3318. if (state->Mode == 0 && state->IF_Mode == 0) {
  3319. /* Analog Zero IF Mode */
  3320. status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 0);
  3321. status += MXL_ControlWrite(fe, RFSYN_VCO_BIAS, 8);
  3322. status += MXL_ControlWrite(fe, CHCAL_INT_MOD_RF, 44);
  3323. status += MXL_ControlWrite(fe,
  3324. CHCAL_FRAC_MOD_RF, 173670);
  3325. }
  3326. if (state->Mode == 1) /* Digital Mode */ {
  3327. status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 0);
  3328. status += MXL_ControlWrite(fe, RFSYN_VCO_BIAS, 8);
  3329. status += MXL_ControlWrite(fe, CHCAL_INT_MOD_RF, 42);
  3330. status += MXL_ControlWrite(fe,
  3331. CHCAL_FRAC_MOD_RF, 245760);
  3332. }
  3333. }
  3334. if (VCO_Range == 4) {
  3335. status += MXL_ControlWrite(fe, RFSYN_EN_DIV, 1);
  3336. status += MXL_ControlWrite(fe, RFSYN_EN_OUTMUX, 0);
  3337. status += MXL_ControlWrite(fe, RFSYN_SEL_DIVM, 0);
  3338. status += MXL_ControlWrite(fe, RFSYN_DIVM, 1);
  3339. status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_OUT, 1);
  3340. status += MXL_ControlWrite(fe, RFSYN_RF_DIV_BIAS, 1);
  3341. status += MXL_ControlWrite(fe, DN_SEL_FREQ, 0);
  3342. status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 0);
  3343. status += MXL_ControlWrite(fe, RFSYN_VCO_BIAS, 40);
  3344. status += MXL_ControlWrite(fe, CHCAL_INT_MOD_RF, 27);
  3345. if (state->Mode == 0 && state->IF_Mode == 1) {
  3346. /* Analog Low IF Mode */
  3347. status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 0);
  3348. status += MXL_ControlWrite(fe, RFSYN_VCO_BIAS, 40);
  3349. status += MXL_ControlWrite(fe, CHCAL_INT_MOD_RF, 27);
  3350. status += MXL_ControlWrite(fe,
  3351. CHCAL_FRAC_MOD_RF, 206438);
  3352. }
  3353. if (state->Mode == 0 && state->IF_Mode == 0) {
  3354. /* Analog Zero IF Mode */
  3355. status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 0);
  3356. status += MXL_ControlWrite(fe, RFSYN_VCO_BIAS, 40);
  3357. status += MXL_ControlWrite(fe, CHCAL_INT_MOD_RF, 27);
  3358. status += MXL_ControlWrite(fe,
  3359. CHCAL_FRAC_MOD_RF, 206438);
  3360. }
  3361. if (state->Mode == 1) /* Digital Mode */ {
  3362. status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 0);
  3363. status += MXL_ControlWrite(fe, RFSYN_VCO_BIAS, 40);
  3364. status += MXL_ControlWrite(fe, CHCAL_INT_MOD_RF, 27);
  3365. status += MXL_ControlWrite(fe,
  3366. CHCAL_FRAC_MOD_RF, 212992);
  3367. }
  3368. }
  3369. return status;
  3370. }
  3371. static u16 MXL_Hystersis_Test(struct dvb_frontend *fe, int Hystersis)
  3372. {
  3373. struct mxl5005s_state *state = fe->tuner_priv;
  3374. u16 status = 0;
  3375. if (Hystersis == 1)
  3376. status += MXL_ControlWrite(fe, DN_BYPASS_AGC_I2C, 1);
  3377. return status;
  3378. }
  3379. #endif
  3380. /* End: Reference driver code found in the Realtek driver that
  3381. * is copyright MaxLinear */
  3382. /* ----------------------------------------------------------------
  3383. * Begin: Everything after here is new code to adapt the
  3384. * proprietary Realtek driver into a Linux API tuner.
  3385. * Copyright (C) 2008 Steven Toth <stoth@linuxtv.org>
  3386. */
  3387. static int mxl5005s_reset(struct dvb_frontend *fe)
  3388. {
  3389. struct mxl5005s_state *state = fe->tuner_priv;
  3390. int ret = 0;
  3391. u8 buf[2] = { 0xff, 0x00 };
  3392. struct i2c_msg msg = { .addr = state->config->i2c_address, .flags = 0,
  3393. .buf = buf, .len = 2 };
  3394. dprintk(2, "%s()\n", __func__);
  3395. if (fe->ops.i2c_gate_ctrl)
  3396. fe->ops.i2c_gate_ctrl(fe, 1);
  3397. if (i2c_transfer(state->i2c, &msg, 1) != 1) {
  3398. printk(KERN_WARNING "mxl5005s I2C reset failed\n");
  3399. ret = -EREMOTEIO;
  3400. }
  3401. if (fe->ops.i2c_gate_ctrl)
  3402. fe->ops.i2c_gate_ctrl(fe, 0);
  3403. return ret;
  3404. }
  3405. /* Write a single byte to a single reg, latch the value if required by
  3406. * following the transaction with the latch byte.
  3407. */
  3408. static int mxl5005s_writereg(struct dvb_frontend *fe, u8 reg, u8 val, int latch)
  3409. {
  3410. struct mxl5005s_state *state = fe->tuner_priv;
  3411. u8 buf[3] = { reg, val, MXL5005S_LATCH_BYTE };
  3412. struct i2c_msg msg = { .addr = state->config->i2c_address, .flags = 0,
  3413. .buf = buf, .len = 3 };
  3414. if (latch == 0)
  3415. msg.len = 2;
  3416. dprintk(2, "%s(0x%x, 0x%x, 0x%x)\n", __func__, reg, val, msg.addr);
  3417. if (i2c_transfer(state->i2c, &msg, 1) != 1) {
  3418. printk(KERN_WARNING "mxl5005s I2C write failed\n");
  3419. return -EREMOTEIO;
  3420. }
  3421. return 0;
  3422. }
  3423. static int mxl5005s_writeregs(struct dvb_frontend *fe, u8 *addrtable,
  3424. u8 *datatable, u8 len)
  3425. {
  3426. int ret = 0, i;
  3427. if (fe->ops.i2c_gate_ctrl)
  3428. fe->ops.i2c_gate_ctrl(fe, 1);
  3429. for (i = 0 ; i < len-1; i++) {
  3430. ret = mxl5005s_writereg(fe, addrtable[i], datatable[i], 0);
  3431. if (ret < 0)
  3432. break;
  3433. }
  3434. ret = mxl5005s_writereg(fe, addrtable[i], datatable[i], 1);
  3435. if (fe->ops.i2c_gate_ctrl)
  3436. fe->ops.i2c_gate_ctrl(fe, 0);
  3437. return ret;
  3438. }
  3439. static int mxl5005s_init(struct dvb_frontend *fe)
  3440. {
  3441. struct mxl5005s_state *state = fe->tuner_priv;
  3442. dprintk(1, "%s()\n", __func__);
  3443. state->current_mode = MXL_QAM;
  3444. return mxl5005s_reconfigure(fe, MXL_QAM, MXL5005S_BANDWIDTH_6MHZ);
  3445. }
  3446. static int mxl5005s_reconfigure(struct dvb_frontend *fe, u32 mod_type,
  3447. u32 bandwidth)
  3448. {
  3449. struct mxl5005s_state *state = fe->tuner_priv;
  3450. u8 AddrTable[MXL5005S_REG_WRITING_TABLE_LEN_MAX];
  3451. u8 ByteTable[MXL5005S_REG_WRITING_TABLE_LEN_MAX];
  3452. int TableLen;
  3453. dprintk(1, "%s(type=%d, bw=%d)\n", __func__, mod_type, bandwidth);
  3454. mxl5005s_reset(fe);
  3455. /* Tuner initialization stage 0 */
  3456. MXL_GetMasterControl(ByteTable, MC_SYNTH_RESET);
  3457. AddrTable[0] = MASTER_CONTROL_ADDR;
  3458. ByteTable[0] |= state->config->AgcMasterByte;
  3459. mxl5005s_writeregs(fe, AddrTable, ByteTable, 1);
  3460. mxl5005s_AssignTunerMode(fe, mod_type, bandwidth);
  3461. /* Tuner initialization stage 1 */
  3462. MXL_GetInitRegister(fe, AddrTable, ByteTable, &TableLen);
  3463. mxl5005s_writeregs(fe, AddrTable, ByteTable, TableLen);
  3464. return 0;
  3465. }
  3466. static int mxl5005s_AssignTunerMode(struct dvb_frontend *fe, u32 mod_type,
  3467. u32 bandwidth)
  3468. {
  3469. struct mxl5005s_state *state = fe->tuner_priv;
  3470. struct mxl5005s_config *c = state->config;
  3471. InitTunerControls(fe);
  3472. /* Set MxL5005S parameters. */
  3473. MXL5005_TunerConfig(
  3474. fe,
  3475. c->mod_mode,
  3476. c->if_mode,
  3477. bandwidth,
  3478. c->if_freq,
  3479. c->xtal_freq,
  3480. c->agc_mode,
  3481. c->top,
  3482. c->output_load,
  3483. c->clock_out,
  3484. c->div_out,
  3485. c->cap_select,
  3486. c->rssi_enable,
  3487. mod_type,
  3488. c->tracking_filter);
  3489. return 0;
  3490. }
  3491. static int mxl5005s_set_params(struct dvb_frontend *fe)
  3492. {
  3493. struct mxl5005s_state *state = fe->tuner_priv;
  3494. struct dtv_frontend_properties *c = &fe->dtv_property_cache;
  3495. u32 delsys = c->delivery_system;
  3496. u32 bw = c->bandwidth_hz;
  3497. u32 req_mode, req_bw = 0;
  3498. int ret;
  3499. dprintk(1, "%s()\n", __func__);
  3500. switch (delsys) {
  3501. case SYS_ATSC:
  3502. req_mode = MXL_ATSC;
  3503. req_bw = MXL5005S_BANDWIDTH_6MHZ;
  3504. break;
  3505. case SYS_DVBC_ANNEX_B:
  3506. req_mode = MXL_QAM;
  3507. req_bw = MXL5005S_BANDWIDTH_6MHZ;
  3508. break;
  3509. default: /* Assume DVB-T */
  3510. req_mode = MXL_DVBT;
  3511. switch (bw) {
  3512. case 6000000:
  3513. req_bw = MXL5005S_BANDWIDTH_6MHZ;
  3514. break;
  3515. case 7000000:
  3516. req_bw = MXL5005S_BANDWIDTH_7MHZ;
  3517. break;
  3518. case 8000000:
  3519. case 0:
  3520. req_bw = MXL5005S_BANDWIDTH_8MHZ;
  3521. break;
  3522. default:
  3523. return -EINVAL;
  3524. }
  3525. }
  3526. /* Change tuner for new modulation type if reqd */
  3527. if (req_mode != state->current_mode ||
  3528. req_bw != state->Chan_Bandwidth) {
  3529. state->current_mode = req_mode;
  3530. ret = mxl5005s_reconfigure(fe, req_mode, req_bw);
  3531. } else
  3532. ret = 0;
  3533. if (ret == 0) {
  3534. dprintk(1, "%s() freq=%d\n", __func__, c->frequency);
  3535. ret = mxl5005s_SetRfFreqHz(fe, c->frequency);
  3536. }
  3537. return ret;
  3538. }
  3539. static int mxl5005s_get_frequency(struct dvb_frontend *fe, u32 *frequency)
  3540. {
  3541. struct mxl5005s_state *state = fe->tuner_priv;
  3542. dprintk(1, "%s()\n", __func__);
  3543. *frequency = state->RF_IN;
  3544. return 0;
  3545. }
  3546. static int mxl5005s_get_bandwidth(struct dvb_frontend *fe, u32 *bandwidth)
  3547. {
  3548. struct mxl5005s_state *state = fe->tuner_priv;
  3549. dprintk(1, "%s()\n", __func__);
  3550. *bandwidth = state->Chan_Bandwidth;
  3551. return 0;
  3552. }
  3553. static int mxl5005s_get_if_frequency(struct dvb_frontend *fe, u32 *frequency)
  3554. {
  3555. struct mxl5005s_state *state = fe->tuner_priv;
  3556. dprintk(1, "%s()\n", __func__);
  3557. *frequency = state->IF_OUT;
  3558. return 0;
  3559. }
  3560. static int mxl5005s_release(struct dvb_frontend *fe)
  3561. {
  3562. dprintk(1, "%s()\n", __func__);
  3563. kfree(fe->tuner_priv);
  3564. fe->tuner_priv = NULL;
  3565. return 0;
  3566. }
  3567. static const struct dvb_tuner_ops mxl5005s_tuner_ops = {
  3568. .info = {
  3569. .name = "MaxLinear MXL5005S",
  3570. .frequency_min = 48000000,
  3571. .frequency_max = 860000000,
  3572. .frequency_step = 50000,
  3573. },
  3574. .release = mxl5005s_release,
  3575. .init = mxl5005s_init,
  3576. .set_params = mxl5005s_set_params,
  3577. .get_frequency = mxl5005s_get_frequency,
  3578. .get_bandwidth = mxl5005s_get_bandwidth,
  3579. .get_if_frequency = mxl5005s_get_if_frequency,
  3580. };
  3581. struct dvb_frontend *mxl5005s_attach(struct dvb_frontend *fe,
  3582. struct i2c_adapter *i2c,
  3583. struct mxl5005s_config *config)
  3584. {
  3585. struct mxl5005s_state *state = NULL;
  3586. dprintk(1, "%s()\n", __func__);
  3587. state = kzalloc(sizeof(struct mxl5005s_state), GFP_KERNEL);
  3588. if (state == NULL)
  3589. return NULL;
  3590. state->frontend = fe;
  3591. state->config = config;
  3592. state->i2c = i2c;
  3593. printk(KERN_INFO "MXL5005S: Attached at address 0x%02x\n",
  3594. config->i2c_address);
  3595. memcpy(&fe->ops.tuner_ops, &mxl5005s_tuner_ops,
  3596. sizeof(struct dvb_tuner_ops));
  3597. fe->tuner_priv = state;
  3598. return fe;
  3599. }
  3600. EXPORT_SYMBOL(mxl5005s_attach);
  3601. MODULE_DESCRIPTION("MaxLinear MXL5005S silicon tuner driver");
  3602. MODULE_AUTHOR("Steven Toth");
  3603. MODULE_LICENSE("GPL");