tuner_e4000.c 40 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070
  1. /*
  2. * Elonics E4000 tuner driver, taken from the kernel driver that can be found
  3. * on http://linux.terratec.de/tv_en.html
  4. *
  5. * This driver is a mess, and should be replaced by the osmo-sdr E4000 driver
  6. *
  7. */
  8. #include <stdint.h>
  9. #include "i2c.h"
  10. #include "tuner_e4000.h"
  11. #define FUNCTION_ERROR 1
  12. #define FUNCTION_SUCCESS 0
  13. #define NO_USE 0
  14. #define LEN_2_BYTE 2
  15. #define I2C_BUFFER_LEN 128
  16. #define YES 1
  17. #define NO 0
  18. #define CRYSTAL_FREQ 28800000
  19. /* glue functions to rtl-sdr code */
  20. int
  21. I2CReadByte(
  22. void *pTuner,
  23. unsigned char NoUse,
  24. unsigned char RegAddr,
  25. unsigned char *pReadingByte
  26. )
  27. {
  28. uint8_t data = RegAddr;
  29. if (rtlsdr_i2c_write((rtlsdr_dev_t *)pTuner, E4K_I2C_ADDR, &data, 1) < 0)
  30. return E4000_I2C_FAIL;
  31. if (rtlsdr_i2c_read((rtlsdr_dev_t *)pTuner, E4K_I2C_ADDR, &data, 1) < 0)
  32. return E4000_I2C_FAIL;
  33. *pReadingByte = data;
  34. return E4000_I2C_SUCCESS;
  35. }
  36. int
  37. I2CWriteByte(void *pTuner,
  38. unsigned char NoUse,
  39. unsigned char RegAddr,
  40. unsigned char WritingByte
  41. )
  42. {
  43. uint8_t data[2];
  44. data[0] = RegAddr;
  45. data[1] = WritingByte;
  46. if (rtlsdr_i2c_write((rtlsdr_dev_t *)pTuner, E4K_I2C_ADDR, data, 2) < 0)
  47. return E4000_I2C_FAIL;
  48. return E4000_I2C_SUCCESS;
  49. }
  50. int
  51. I2CWriteArray(
  52. void *pTuner,
  53. unsigned char NoUse,
  54. unsigned char RegStartAddr,
  55. unsigned char ByteNum,
  56. unsigned char *pWritingBytes
  57. )
  58. {
  59. unsigned int i;
  60. uint8_t WritingBuffer[I2C_BUFFER_LEN];
  61. WritingBuffer[0] = RegStartAddr;
  62. for(i = 0; i < ByteNum; i++)
  63. WritingBuffer[1 + i] = pWritingBytes[i];
  64. if (rtlsdr_i2c_write((rtlsdr_dev_t *)pTuner, E4K_I2C_ADDR, WritingBuffer, ByteNum + 1) < 0)
  65. return E4000_I2C_FAIL;
  66. return E4000_I2C_SUCCESS;
  67. }
  68. /**
  69. @see TUNER_FP_INITIALIZE
  70. */
  71. int
  72. e4000_Initialize(void *pTuner
  73. )
  74. {
  75. // Initialize tuner.
  76. // Note: Call E4000 source code functions.
  77. if(tunerreset(pTuner) != E4000_1_SUCCESS)
  78. goto error_status_execute_function;
  79. if(Tunerclock(pTuner) != E4000_1_SUCCESS)
  80. goto error_status_execute_function;
  81. if(Qpeak(pTuner) != E4000_1_SUCCESS)
  82. goto error_status_execute_function;
  83. if(DCoffloop(pTuner) != E4000_1_SUCCESS)
  84. goto error_status_execute_function;
  85. if(GainControlinit(pTuner) != E4000_1_SUCCESS)
  86. goto error_status_execute_function;
  87. return FUNCTION_SUCCESS;
  88. error_status_execute_function:
  89. return FUNCTION_ERROR;
  90. }
  91. /**
  92. @see TUNER_FP_SET_RF_FREQ_HZ
  93. */
  94. int
  95. e4000_SetRfFreqHz(
  96. void *pTuner,
  97. unsigned long RfFreqHz
  98. )
  99. {
  100. // E4000_EXTRA_MODULE *pExtra;
  101. int RfFreqKhz;
  102. int CrystalFreqKhz;
  103. int CrystalFreqHz = CRYSTAL_FREQ;
  104. // Set tuner RF frequency in KHz.
  105. // Note: 1. RfFreqKhz = round(RfFreqHz / 1000)
  106. // CrystalFreqKhz = round(CrystalFreqHz / 1000)
  107. // 2. Call E4000 source code functions.
  108. RfFreqKhz = (int)((RfFreqHz + 500) / 1000);
  109. CrystalFreqKhz = (int)((CrystalFreqHz + 500) / 1000);
  110. if(Gainmanual(pTuner) != E4000_1_SUCCESS)
  111. goto error_status_execute_function;
  112. if(E4000_gain_freq(pTuner, RfFreqKhz) != E4000_1_SUCCESS)
  113. goto error_status_execute_function;
  114. if(PLL(pTuner, CrystalFreqKhz, RfFreqKhz) != E4000_1_SUCCESS)
  115. goto error_status_execute_function;
  116. if(LNAfilter(pTuner, RfFreqKhz) != E4000_1_SUCCESS)
  117. goto error_status_execute_function;
  118. if(freqband(pTuner, RfFreqKhz) != E4000_1_SUCCESS)
  119. goto error_status_execute_function;
  120. if(DCoffLUT(pTuner) != E4000_1_SUCCESS)
  121. goto error_status_execute_function;
  122. if(GainControlauto(pTuner) != E4000_1_SUCCESS)
  123. goto error_status_execute_function;
  124. return FUNCTION_SUCCESS;
  125. error_status_execute_function:
  126. return FUNCTION_ERROR;
  127. }
  128. /**
  129. @brief Set E4000 tuner bandwidth.
  130. */
  131. int
  132. e4000_SetBandwidthHz(
  133. void *pTuner,
  134. unsigned long BandwidthHz
  135. )
  136. {
  137. // E4000_EXTRA_MODULE *pExtra;
  138. int BandwidthKhz;
  139. int CrystalFreqKhz;
  140. int CrystalFreqHz = CRYSTAL_FREQ;
  141. // Get tuner extra module.
  142. // pExtra = &(pTuner->Extra.E4000);
  143. // Set tuner bandwidth Hz.
  144. // Note: 1. BandwidthKhz = round(BandwidthHz / 1000)
  145. // CrystalFreqKhz = round(CrystalFreqHz / 1000)
  146. // 2. Call E4000 source code functions.
  147. BandwidthKhz = (int)((BandwidthHz + 500) / 1000);
  148. CrystalFreqKhz = (int)((CrystalFreqHz + 500) / 1000);
  149. if(IFfilter(pTuner, BandwidthKhz, CrystalFreqKhz) != E4000_1_SUCCESS)
  150. goto error_status_execute_function;
  151. return FUNCTION_SUCCESS;
  152. error_status_execute_function:
  153. return FUNCTION_ERROR;
  154. }
  155. // The following context is source code provided by Elonics.
  156. // Elonics source code - E4000_API_rev2_04_realtek.cpp
  157. //****************************************************************************/
  158. //
  159. // Filename E4000_initialisation.c
  160. // Revision 2.04
  161. //
  162. // Description:
  163. // Initialisation script for the Elonics E4000 revC tuner
  164. //
  165. // Copyright (c) Elonics Ltd
  166. //
  167. // Any software supplied free of charge for use with elonics
  168. // evaluation kits is supplied without warranty and for
  169. // evaluation purposes only. Incorporation of any of this
  170. // code into products for open sale is permitted but only at
  171. // the user's own risk. Elonics accepts no liability for the
  172. // integrity of this software whatsoever.
  173. //
  174. //
  175. //****************************************************************************/
  176. //#include <stdio.h>
  177. //#include <stdlib.h>
  178. //
  179. // User defined variable definitions
  180. //
  181. /*
  182. int Ref_clk = 26000; // Reference clock frequency(kHz).
  183. int Freq = 590000; // RF Frequency (kHz)
  184. int bandwidth = 8000; //RF channel bandwith (kHz)
  185. */
  186. //
  187. // API defined variable definitions
  188. //int VCO_freq;
  189. //unsigned char writearray[5];
  190. //unsigned char read1[1];
  191. //int status;
  192. //
  193. //
  194. // function definitions
  195. //
  196. /*
  197. int tunerreset ();
  198. int Tunerclock();
  199. int filtercal();
  200. int Qpeak();
  201. int PLL(int Ref_clk, int Freq);
  202. int LNAfilter(int Freq);
  203. int IFfilter(int bandwidth, int Ref_clk);
  204. int freqband(int Freq);
  205. int DCoffLUT();
  206. int DCoffloop();
  207. int commonmode();
  208. int GainControlinit();
  209. */
  210. //
  211. //****************************************************************************
  212. // --- Public functions ------------------------------------------------------
  213. /****************************************************************************\
  214. * Function: tunerreset
  215. *
  216. * Detailed Description:
  217. * The function resets the E4000 tuner. (Register 0x00).
  218. *
  219. \****************************************************************************/
  220. int tunerreset(void *pTuner)
  221. {
  222. unsigned char writearray[5];
  223. int status;
  224. writearray[0] = 64;
  225. // For dummy I2C command, don't check executing status.
  226. status=I2CWriteByte (pTuner, 200,2,writearray[0]);
  227. status=I2CWriteByte (pTuner, 200,2,writearray[0]);
  228. //printf("\nRegister 0=%d", writearray[0]);
  229. if(status != E4000_I2C_SUCCESS)
  230. {
  231. return E4000_1_FAIL;
  232. }
  233. writearray[0] = 0;
  234. status=I2CWriteByte (pTuner, 200,9,writearray[0]);
  235. if(status != E4000_I2C_SUCCESS)
  236. {
  237. return E4000_1_FAIL;
  238. }
  239. writearray[0] = 0;
  240. status=I2CWriteByte (pTuner, 200,5,writearray[0]);
  241. if(status != E4000_I2C_SUCCESS)
  242. {
  243. return E4000_1_FAIL;
  244. }
  245. writearray[0] = 7;
  246. status=I2CWriteByte (pTuner, 200,0,writearray[0]);
  247. //printf("\nRegister 0=%d", writearray[0]);
  248. if(status != E4000_I2C_SUCCESS)
  249. {
  250. return E4000_1_FAIL;
  251. }
  252. return E4000_1_SUCCESS;
  253. }
  254. /****************************************************************************\
  255. * Function: Tunerclock
  256. *
  257. * Detailed Description:
  258. * The function configures the E4000 clock. (Register 0x06, 0x7a).
  259. * Function disables the clock - values can be modified to enable if required.
  260. \****************************************************************************/
  261. int Tunerclock(void *pTuner)
  262. {
  263. unsigned char writearray[5];
  264. int status;
  265. writearray[0] = 0;
  266. status=I2CWriteByte(pTuner, 200,6,writearray[0]);
  267. //printf("\nRegister 6=%d", writearray[0]);
  268. if(status != E4000_I2C_SUCCESS)
  269. {
  270. return E4000_1_FAIL;
  271. }
  272. writearray[0] = 150;
  273. status=I2CWriteByte(pTuner, 200,122,writearray[0]);
  274. //printf("\nRegister 7a=%d", writearray[0]);
  275. //**Modify commands above with value required if output clock is required,
  276. if(status != E4000_I2C_SUCCESS)
  277. {
  278. return E4000_1_FAIL;
  279. }
  280. return E4000_1_SUCCESS;
  281. }
  282. /****************************************************************************\
  283. * Function: filtercal
  284. *
  285. * Detailed Description:
  286. * Instructs RC filter calibration. (Register 0x7b).
  287. *
  288. \****************************************************************************/
  289. /*
  290. int filtercal(void *pTuner)
  291. {
  292. //writearray[0] = 1;
  293. //I2CWriteByte (pTuner, 200,123,writearray[0]);
  294. //printf("\nRegister 7b=%d", writearray[0]);
  295. //return;
  296. return E4000_1_SUCCESS;
  297. }
  298. */
  299. /****************************************************************************\
  300. * Function: Qpeak()
  301. *
  302. * Detailed Description:
  303. * The function configures the E4000 gains.
  304. * Also sigma delta controller. (Register 0x82).
  305. *
  306. \****************************************************************************/
  307. int Qpeak(void *pTuner)
  308. {
  309. unsigned char writearray[5];
  310. int status;
  311. writearray[0] = 1;
  312. writearray[1] = 254;
  313. status=I2CWriteArray(pTuner, 200,126,2,writearray);
  314. //printf("\nRegister 7e=%d", writearray[0]);
  315. //printf("\nRegister 7f=%d", writearray[1]);
  316. if(status != E4000_I2C_SUCCESS)
  317. {
  318. return E4000_1_FAIL;
  319. }
  320. status=I2CWriteByte (pTuner, 200,130,0);
  321. //printf("\nRegister 82=0");
  322. if(status != E4000_I2C_SUCCESS)
  323. {
  324. return E4000_1_FAIL;
  325. }
  326. status=I2CWriteByte (pTuner, 200,36,5);
  327. //printf("\nRegister 24=5");
  328. if(status != E4000_I2C_SUCCESS)
  329. {
  330. return E4000_1_FAIL;
  331. }
  332. writearray[0] = 32;
  333. writearray[1] = 1;
  334. status=I2CWriteArray(pTuner, 200,135,2,writearray);
  335. if(status != E4000_I2C_SUCCESS)
  336. {
  337. return E4000_1_FAIL;
  338. }
  339. //printf("\nRegister 87=%d", writearray[0]);
  340. //printf("\nRegister 88=%d", writearray[1]);
  341. return E4000_1_SUCCESS;
  342. }
  343. /****************************************************************************\
  344. * Function: E4000_gain_freq()
  345. *
  346. * Detailed Description:
  347. * The function configures the E4000 gains vs. freq
  348. * 0xa3 to 0xa7. Also 0x24.
  349. *
  350. \****************************************************************************/
  351. int E4000_gain_freq(void *pTuner, int Freq)
  352. {
  353. unsigned char writearray[5];
  354. int status;
  355. if (Freq<=350000)
  356. {
  357. writearray[0] = 0x10;
  358. writearray[1] = 0x42;
  359. writearray[2] = 0x09;
  360. writearray[3] = 0x21;
  361. writearray[4] = 0x94;
  362. }
  363. else if(Freq>=1000000)
  364. {
  365. writearray[0] = 0x10;
  366. writearray[1] = 0x42;
  367. writearray[2] = 0x09;
  368. writearray[3] = 0x21;
  369. writearray[4] = 0x94;
  370. }
  371. else
  372. {
  373. writearray[0] = 0x10;
  374. writearray[1] = 0x42;
  375. writearray[2] = 0x09;
  376. writearray[3] = 0x21;
  377. writearray[4] = 0x94;
  378. }
  379. status=I2CWriteArray(pTuner, 200,163,5,writearray);
  380. if(status != E4000_I2C_SUCCESS)
  381. {
  382. return E4000_1_FAIL;
  383. }
  384. if (Freq<=350000)
  385. {
  386. writearray[0] = 94;
  387. writearray[1] = 6;
  388. status=I2CWriteArray(pTuner, 200,159,2,writearray);
  389. if(status != E4000_I2C_SUCCESS)
  390. {
  391. return E4000_1_FAIL;
  392. }
  393. writearray[0] = 0;
  394. status=I2CWriteArray(pTuner, 200,136,1,writearray);
  395. if(status != E4000_I2C_SUCCESS)
  396. {
  397. return E4000_1_FAIL;
  398. }
  399. }
  400. else
  401. {
  402. writearray[0] = 127;
  403. writearray[1] = 7;
  404. status=I2CWriteArray(pTuner, 200,159,2,writearray);
  405. if(status != E4000_I2C_SUCCESS)
  406. {
  407. return E4000_1_FAIL;
  408. }
  409. writearray[0] = 1;
  410. status=I2CWriteArray(pTuner, 200,136,1,writearray);
  411. if(status != E4000_I2C_SUCCESS)
  412. {
  413. return E4000_1_FAIL;
  414. }
  415. }
  416. //printf("\nRegister 9f=%d", writearray[0]);
  417. //printf("\nRegister a0=%d", writearray[1]);
  418. return E4000_1_SUCCESS;
  419. }
  420. /****************************************************************************\
  421. * Function: DCoffloop
  422. *
  423. * Detailed Description:
  424. * Populates DC offset LUT. (Registers 0x2d, 0x70, 0x71).
  425. * Turns on DC offset LUT and time varying DC offset.
  426. \****************************************************************************/
  427. int DCoffloop(void *pTuner)
  428. {
  429. unsigned char writearray[5];
  430. int status;
  431. //writearray[0]=0;
  432. //I2CWriteByte(pTuner, 200,115,writearray[0]);
  433. //printf("\nRegister 73=%d", writearray[0]);
  434. writearray[0] = 31;
  435. status=I2CWriteByte(pTuner, 200,45,writearray[0]);
  436. //printf("\nRegister 2d=%d", writearray[0]);
  437. if(status != E4000_I2C_SUCCESS)
  438. {
  439. return E4000_1_FAIL;
  440. }
  441. writearray[0] = 1;
  442. writearray[1] = 1;
  443. status=I2CWriteArray(pTuner, 200,112,2,writearray);
  444. //printf("\nRegister 70=%d", writearray[0]);
  445. //printf("\nRegister 71=%d", writearray[0]);
  446. if(status != E4000_I2C_SUCCESS)
  447. {
  448. return E4000_1_FAIL;
  449. }
  450. return E4000_1_SUCCESS;
  451. }
  452. /****************************************************************************\
  453. * Function: commonmode
  454. *
  455. * Detailed Description:
  456. * Configures common mode voltage. (Registers 0x2f).
  457. *
  458. \****************************************************************************/
  459. /*
  460. int commonmode(void *pTuner)
  461. {
  462. //writearray[0] = 0;
  463. //I2CWriteByte(Device_address,47,writearray[0]);
  464. //printf("\nRegister 0x2fh = %d", writearray[0]);
  465. // Sets 550mV. Modify if alternative is desired.
  466. return E4000_1_SUCCESS;
  467. }
  468. */
  469. /****************************************************************************\
  470. * Function: GainControlinit
  471. *
  472. * Detailed Description:
  473. * Configures gain control mode. (Registers 0x1d, 0x1e, 0x1f, 0x20, 0x21,
  474. * 0x1a, 0x74h, 0x75h).
  475. * User may wish to modify values depending on usage scenario.
  476. * Routine configures LNA: autonomous gain control
  477. * IF PWM gain control.
  478. * PWM thresholds = default
  479. * Mixer: switches when LNA gain =7.5dB
  480. * Sensitivity / Linearity mode: manual switch
  481. *
  482. \****************************************************************************/
  483. int GainControlinit(void *pTuner)
  484. {
  485. unsigned char writearray[5];
  486. unsigned char read1[1];
  487. int status;
  488. unsigned char sum=255;
  489. writearray[0] = 23;
  490. status=I2CWriteByte(pTuner, 200,26,writearray[0]);
  491. if(status != E4000_I2C_SUCCESS)
  492. {
  493. return E4000_1_FAIL;
  494. }
  495. //printf("\nRegister 1a=%d", writearray[0]);
  496. status=I2CReadByte(pTuner, 201,27,read1);
  497. if(status != E4000_I2C_SUCCESS)
  498. {
  499. return E4000_1_FAIL;
  500. }
  501. writearray[0] = 16;
  502. writearray[1] = 4;
  503. writearray[2] = 26;
  504. writearray[3] = 15;
  505. writearray[4] = 167;
  506. status=I2CWriteArray(pTuner, 200,29,5,writearray);
  507. //printf("\nRegister 1d=%d", writearray[0]);
  508. if(status != E4000_I2C_SUCCESS)
  509. {
  510. return E4000_1_FAIL;
  511. }
  512. writearray[0] = 81;
  513. status=I2CWriteByte(pTuner, 200,134,writearray[0]);
  514. if(status != E4000_I2C_SUCCESS)
  515. {
  516. return E4000_1_FAIL;
  517. }
  518. //printf("\nRegister 86=%d", writearray[0]);
  519. //For Realtek - gain control logic
  520. status=I2CReadByte(pTuner, 201,27,read1);
  521. if(status != E4000_I2C_SUCCESS)
  522. {
  523. return E4000_1_FAIL;
  524. }
  525. if(read1[0]<=sum)
  526. {
  527. sum=read1[0];
  528. }
  529. status=I2CWriteByte(pTuner, 200,31,writearray[2]);
  530. if(status != E4000_I2C_SUCCESS)
  531. {
  532. return E4000_1_FAIL;
  533. }
  534. status=I2CReadByte(pTuner, 201,27,read1);
  535. if(status != E4000_I2C_SUCCESS)
  536. {
  537. return E4000_1_FAIL;
  538. }
  539. if(read1[0] <= sum)
  540. {
  541. sum=read1[0];
  542. }
  543. status=I2CWriteByte(pTuner, 200,31,writearray[2]);
  544. if(status != E4000_I2C_SUCCESS)
  545. {
  546. return E4000_1_FAIL;
  547. }
  548. status=I2CReadByte(pTuner, 201,27,read1);
  549. if(status != E4000_I2C_SUCCESS)
  550. {
  551. return E4000_1_FAIL;
  552. }
  553. if(read1[0] <= sum)
  554. {
  555. sum=read1[0];
  556. }
  557. status=I2CWriteByte(pTuner, 200,31,writearray[2]);
  558. if(status != E4000_I2C_SUCCESS)
  559. {
  560. return E4000_1_FAIL;
  561. }
  562. status=I2CReadByte(pTuner, 201,27,read1);
  563. if(status != E4000_I2C_SUCCESS)
  564. {
  565. return E4000_1_FAIL;
  566. }
  567. if(read1[0] <= sum)
  568. {
  569. sum=read1[0];
  570. }
  571. status=I2CWriteByte(pTuner, 200,31,writearray[2]);
  572. if(status != E4000_I2C_SUCCESS)
  573. {
  574. return E4000_1_FAIL;
  575. }
  576. status=I2CReadByte(pTuner, 201,27,read1);
  577. if(status != E4000_I2C_SUCCESS)
  578. {
  579. return E4000_1_FAIL;
  580. }
  581. if (read1[0]<=sum)
  582. {
  583. sum=read1[0];
  584. }
  585. writearray[0]=sum;
  586. status=I2CWriteByte(pTuner, 200,27,writearray[0]);
  587. if(status != E4000_I2C_SUCCESS)
  588. {
  589. return E4000_1_FAIL;
  590. }
  591. //printf("\nRegister 1b=%d", writearray[0]);
  592. //printf("\nRegister 1e=%d", writearray[1]);
  593. //printf("\nRegister 1f=%d", writearray[2]);
  594. //printf("\nRegister 20=%d", writearray[3]);
  595. //printf("\nRegister 21=%d", writearray[4]);
  596. //writearray[0] = 3;
  597. //writearray[1] = 252;
  598. //writearray[2] = 3;
  599. //writearray[3] = 252;
  600. //I2CWriteArray(pTuner, 200,116,4,writearray);
  601. //printf("\nRegister 74=%d", writearray[0]);
  602. //printf("\nRegister 75=%d", writearray[1]);
  603. //printf("\nRegister 76=%d", writearray[2]);
  604. //printf("\nRegister 77=%d", writearray[3]);
  605. return E4000_1_SUCCESS;
  606. }
  607. /****************************************************************************\
  608. * Main program
  609. *
  610. *
  611. *
  612. \****************************************************************************/
  613. /*
  614. int main()
  615. {
  616. tunerreset ();
  617. Tunerclock();
  618. //filtercal();
  619. Qpeak();
  620. //PLL(Ref_clk, Freq);
  621. //LNAfilter(Freq);
  622. //IFfilter(bandwidth, Ref_clk);
  623. //freqband(Freq);
  624. //DCoffLUT();
  625. DCoffloop();
  626. //commonmode();
  627. GainControlinit();
  628. // system("PAUSE");
  629. return(0);
  630. }
  631. */
  632. // Elonics source code - frequency_change_rev2.04_realtek.c
  633. //****************************************************************************/
  634. //
  635. // Filename E4000_freqchangerev2.04.c
  636. // Revision 2.04
  637. //
  638. // Description:
  639. // Frequency change script for the Elonics E4000 revB tuner
  640. //
  641. // Copyright (c) Elonics Ltd
  642. //
  643. // Any software supplied free of charge for use with elonics
  644. // evaluation kits is supplied without warranty and for
  645. // evaluation purposes only. Incorporation of any of this
  646. // code into products for open sale is permitted but only at
  647. // the user's own risk. Elonics accepts no liability for the
  648. // integrity of this software whatsoever.
  649. //
  650. //
  651. //****************************************************************************/
  652. //#include <stdio.h>
  653. //#include <stdlib.h>
  654. //
  655. // User defined variable definitions
  656. //
  657. /*
  658. int Ref_clk = 20000; // Reference clock frequency(kHz).
  659. int Freq = 590000; // RF Frequency (kHz)
  660. int bandwidth = 8; //RF channel bandwith (MHz)
  661. */
  662. //
  663. // API defined variable definitions
  664. //int VCO_freq;
  665. //unsigned char writearray[5];
  666. //unsigned char read1[1];
  667. //int E4000_1_SUCCESS;
  668. //int E4000_1_FAIL;
  669. //int E4000_I2C_SUCCESS;
  670. //int status;
  671. //
  672. //
  673. // function definitions
  674. //
  675. /*
  676. int Gainmanual();
  677. int PLL(int Ref_clk, int Freq);
  678. int LNAfilter(int Freq);
  679. int IFfilter(int bandwidth, int Ref_clk);
  680. int freqband(int Freq);
  681. int DCoffLUT();
  682. int GainControlauto();
  683. */
  684. //
  685. //****************************************************************************
  686. // --- Public functions ------------------------------------------------------
  687. /****************************************************************************\
  688. //****************************************************************************\
  689. * Function: Gainmanual
  690. *
  691. * Detailed Description:
  692. * Sets Gain control to serial interface control.
  693. *
  694. \****************************************************************************/
  695. int Gainmanual(void *pTuner)
  696. {
  697. unsigned char writearray[5];
  698. int status;
  699. writearray[0]=0;
  700. status=I2CWriteByte(pTuner, 200,26,writearray[0]);
  701. //printf("\nRegister 1a=%d", writearray[0]);
  702. if(status != E4000_I2C_SUCCESS)
  703. {
  704. return E4000_1_FAIL;
  705. }
  706. writearray[0] = 0;
  707. status=I2CWriteByte (pTuner, 200,9,writearray[0]);
  708. if(status != E4000_I2C_SUCCESS)
  709. {
  710. return E4000_1_FAIL;
  711. }
  712. writearray[0] = 0;
  713. status=I2CWriteByte (pTuner, 200,5,writearray[0]);
  714. if(status != E4000_I2C_SUCCESS)
  715. {
  716. return E4000_1_FAIL;
  717. }
  718. return E4000_1_SUCCESS;
  719. }
  720. /****************************************************************************\
  721. * Function: PLL
  722. *
  723. * Detailed Description:
  724. * Configures E4000 PLL divider & sigma delta. 0x0d,0x09, 0x0a, 0x0b).
  725. *
  726. \****************************************************************************/
  727. int PLL(void *pTuner, int Ref_clk, int Freq)
  728. {
  729. int VCO_freq;
  730. unsigned char writearray[5];
  731. int status;
  732. unsigned char divider;
  733. int intVCOfreq;
  734. int SigDel;
  735. int SigDel2;
  736. int SigDel3;
  737. // int harmonic_freq;
  738. // int offset;
  739. if (Freq<=72400)
  740. {
  741. writearray[4] = 15;
  742. VCO_freq=Freq*48;
  743. }
  744. else if (Freq<=81200)
  745. {
  746. writearray[4] = 14;
  747. VCO_freq=Freq*40;
  748. }
  749. else if (Freq<=108300)
  750. {
  751. writearray[4]=13;
  752. VCO_freq=Freq*32;
  753. }
  754. else if (Freq<=162500)
  755. {
  756. writearray[4]=12;
  757. VCO_freq=Freq*24;
  758. }
  759. else if (Freq<=216600)
  760. {
  761. writearray[4]=11;
  762. VCO_freq=Freq*16;
  763. }
  764. else if (Freq<=325000)
  765. {
  766. writearray[4]=10;
  767. VCO_freq=Freq*12;
  768. }
  769. else if (Freq<=350000)
  770. {
  771. writearray[4]=9;
  772. VCO_freq=Freq*8;
  773. }
  774. else if (Freq<=432000)
  775. {
  776. writearray[4]=3;
  777. VCO_freq=Freq*8;
  778. }
  779. else if (Freq<=667000)
  780. {
  781. writearray[4]=2;
  782. VCO_freq=Freq*6;
  783. }
  784. else if (Freq<=1200000)
  785. {
  786. writearray[4]=1;
  787. VCO_freq=Freq*4;
  788. }
  789. else
  790. {
  791. writearray[4]=0;
  792. VCO_freq=Freq*2;
  793. }
  794. //printf("\nVCOfreq=%d", VCO_freq);
  795. // divider = VCO_freq * 1000 / Ref_clk;
  796. divider = VCO_freq / Ref_clk;
  797. //printf("\ndivider=%d", divider);
  798. writearray[0]= divider;
  799. // intVCOfreq = divider * Ref_clk /1000;
  800. intVCOfreq = divider * Ref_clk;
  801. //printf("\ninteger VCO freq=%d", intVCOfreq);
  802. // SigDel=65536 * 1000 * (VCO_freq - intVCOfreq) / Ref_clk;
  803. SigDel=65536 * (VCO_freq - intVCOfreq) / Ref_clk;
  804. //printf("\nSigma delta=%d", SigDel);
  805. if (SigDel<=1024)
  806. {
  807. SigDel = 1024;
  808. }
  809. else if (SigDel>=64512)
  810. {
  811. SigDel=64512;
  812. }
  813. SigDel2 = SigDel / 256;
  814. //printf("\nSigdel2=%d", SigDel2);
  815. writearray[2] = (unsigned char)SigDel2;
  816. SigDel3 = SigDel - (256 * SigDel2);
  817. //printf("\nSig del3=%d", SigDel3);
  818. writearray[1]= (unsigned char)SigDel3;
  819. writearray[3]=(unsigned char)0;
  820. status=I2CWriteArray(pTuner, 200,9,5,writearray);
  821. //printf("\nRegister 9=%d", writearray[0]);
  822. //printf("\nRegister a=%d", writearray[1]);
  823. //printf("\nRegister b=%d", writearray[2]);
  824. //printf("\nRegister d=%d", writearray[4]);
  825. if(status != E4000_I2C_SUCCESS)
  826. {
  827. return E4000_1_FAIL;
  828. }
  829. if (Freq<=82900)
  830. {
  831. writearray[0]=0;
  832. writearray[2]=1;
  833. }
  834. else if (Freq<=89900)
  835. {
  836. writearray[0]=3;
  837. writearray[2]=9;
  838. }
  839. else if (Freq<=111700)
  840. {
  841. writearray[0]=0;
  842. writearray[2]=1;
  843. }
  844. else if (Freq<=118700)
  845. {
  846. writearray[0]=3;
  847. writearray[2]=1;
  848. }
  849. else if (Freq<=140500)
  850. {
  851. writearray[0]=0;
  852. writearray[2]=3;
  853. }
  854. else if (Freq<=147500)
  855. {
  856. writearray[0]=3;
  857. writearray[2]=11;
  858. }
  859. else if (Freq<=169300)
  860. {
  861. writearray[0]=0;
  862. writearray[2]=3;
  863. }
  864. else if (Freq<=176300)
  865. {
  866. writearray[0]=3;
  867. writearray[2]=11;
  868. }
  869. else if (Freq<=198100)
  870. {
  871. writearray[0]=0;
  872. writearray[2]=3;
  873. }
  874. else if (Freq<=205100)
  875. {
  876. writearray[0]=3;
  877. writearray[2]=19;
  878. }
  879. else if (Freq<=226900)
  880. {
  881. writearray[0]=0;
  882. writearray[2]=3;
  883. }
  884. else if (Freq<=233900)
  885. {
  886. writearray[0]=3;
  887. writearray[2]=3;
  888. }
  889. else if (Freq<=350000)
  890. {
  891. writearray[0]=0;
  892. writearray[2]=3;
  893. }
  894. else if (Freq<=485600)
  895. {
  896. writearray[0]=0;
  897. writearray[2]=5;
  898. }
  899. else if (Freq<=493600)
  900. {
  901. writearray[0]=3;
  902. writearray[2]=5;
  903. }
  904. else if (Freq<=514400)
  905. {
  906. writearray[0]=0;
  907. writearray[2]=5;
  908. }
  909. else if (Freq<=522400)
  910. {
  911. writearray[0]=3;
  912. writearray[2]=5;
  913. }
  914. else if (Freq<=543200)
  915. {
  916. writearray[0]=0;
  917. writearray[2]=5;
  918. }
  919. else if (Freq<=551200)
  920. {
  921. writearray[0]=3;
  922. writearray[2]=13;
  923. }
  924. else if (Freq<=572000)
  925. {
  926. writearray[0]=0;
  927. writearray[2]=5;
  928. }
  929. else if (Freq<=580000)
  930. {
  931. writearray[0]=3;
  932. writearray[2]=13;
  933. }
  934. else if (Freq<=600800)
  935. {
  936. writearray[0]=0;
  937. writearray[2]=5;
  938. }
  939. else if (Freq<=608800)
  940. {
  941. writearray[0]=3;
  942. writearray[2]=13;
  943. }
  944. else if (Freq<=629600)
  945. {
  946. writearray[0]=0;
  947. writearray[2]=5;
  948. }
  949. else if (Freq<=637600)
  950. {
  951. writearray[0]=3;
  952. writearray[2]=13;
  953. }
  954. else if (Freq<=658400)
  955. {
  956. writearray[0]=0;
  957. writearray[2]=5;
  958. }
  959. else if (Freq<=666400)
  960. {
  961. writearray[0]=3;
  962. writearray[2]=13;
  963. }
  964. else if (Freq<=687200)
  965. {
  966. writearray[0]=0;
  967. writearray[2]=5;
  968. }
  969. else if (Freq<=695200)
  970. {
  971. writearray[0]=3;
  972. writearray[2]=13;
  973. }
  974. else if (Freq<=716000)
  975. {
  976. writearray[0]=0;
  977. writearray[2]=5;
  978. }
  979. else if (Freq<=724000)
  980. {
  981. writearray[0]=3;
  982. writearray[2]=13;
  983. }
  984. else if (Freq<=744800)
  985. {
  986. writearray[0]=0;
  987. writearray[2]=5;
  988. }
  989. else if (Freq<=752800)
  990. {
  991. writearray[0]=3;
  992. writearray[2]=21;
  993. }
  994. else if (Freq<=773600)
  995. {
  996. writearray[0]=0;
  997. writearray[2]=5;
  998. }
  999. else if (Freq<=781600)
  1000. {
  1001. writearray[0]=3;
  1002. writearray[2]=21;
  1003. }
  1004. else if (Freq<=802400)
  1005. {
  1006. writearray[0]=0;
  1007. writearray[2]=5;
  1008. }
  1009. else if (Freq<=810400)
  1010. {
  1011. writearray[0]=3;
  1012. writearray[2]=21;
  1013. }
  1014. else if (Freq<=831200)
  1015. {
  1016. writearray[0]=0;
  1017. writearray[2]=5;
  1018. }
  1019. else if (Freq<=839200)
  1020. {
  1021. writearray[0]=3;
  1022. writearray[2]=21;
  1023. }
  1024. else if (Freq<=860000)
  1025. {
  1026. writearray[0]=0;
  1027. writearray[2]=5;
  1028. }
  1029. else if (Freq<=868000)
  1030. {
  1031. writearray[0]=3;
  1032. writearray[2]=21;
  1033. }
  1034. else
  1035. {
  1036. writearray[0]=0;
  1037. writearray[2]=7;
  1038. }
  1039. status=I2CWriteByte (pTuner, 200,7,writearray[2]);
  1040. if(status != E4000_I2C_SUCCESS)
  1041. {
  1042. return E4000_1_FAIL;
  1043. }
  1044. status=I2CWriteByte (pTuner, 200,5,writearray[0]);
  1045. if(status != E4000_I2C_SUCCESS)
  1046. {
  1047. return E4000_1_FAIL;
  1048. }
  1049. return E4000_1_SUCCESS;
  1050. }
  1051. /****************************************************************************\
  1052. * Function: LNAfilter
  1053. *
  1054. * Detailed Description:
  1055. * The function configures the E4000 LNA filter. (Register 0x10).
  1056. *
  1057. \****************************************************************************/
  1058. int LNAfilter(void *pTuner, int Freq)
  1059. {
  1060. unsigned char writearray[5];
  1061. int status;
  1062. if(Freq<=370000)
  1063. {
  1064. writearray[0]=0;
  1065. }
  1066. else if(Freq<=392500)
  1067. {
  1068. writearray[0]=1;
  1069. }
  1070. else if(Freq<=415000)
  1071. {
  1072. writearray[0] =2;
  1073. }
  1074. else if(Freq<=437500)
  1075. {
  1076. writearray[0]=3;
  1077. }
  1078. else if(Freq<=462500)
  1079. {
  1080. writearray[0]=4;
  1081. }
  1082. else if(Freq<=490000)
  1083. {
  1084. writearray[0]=5;
  1085. }
  1086. else if(Freq<=522500)
  1087. {
  1088. writearray[0]=6;
  1089. }
  1090. else if(Freq<=557500)
  1091. {
  1092. writearray[0]=7;
  1093. }
  1094. else if(Freq<=595000)
  1095. {
  1096. writearray[0]=8;
  1097. }
  1098. else if(Freq<=642500)
  1099. {
  1100. writearray[0]=9;
  1101. }
  1102. else if(Freq<=695000)
  1103. {
  1104. writearray[0]=10;
  1105. }
  1106. else if(Freq<=740000)
  1107. {
  1108. writearray[0]=11;
  1109. }
  1110. else if(Freq<=800000)
  1111. {
  1112. writearray[0]=12;
  1113. }
  1114. else if(Freq<=865000)
  1115. {
  1116. writearray[0] =13;
  1117. }
  1118. else if(Freq<=930000)
  1119. {
  1120. writearray[0]=14;
  1121. }
  1122. else if(Freq<=1000000)
  1123. {
  1124. writearray[0]=15;
  1125. }
  1126. else if(Freq<=1310000)
  1127. {
  1128. writearray[0]=0;
  1129. }
  1130. else if(Freq<=1340000)
  1131. {
  1132. writearray[0]=1;
  1133. }
  1134. else if(Freq<=1385000)
  1135. {
  1136. writearray[0]=2;
  1137. }
  1138. else if(Freq<=1427500)
  1139. {
  1140. writearray[0]=3;
  1141. }
  1142. else if(Freq<=1452500)
  1143. {
  1144. writearray[0]=4;
  1145. }
  1146. else if(Freq<=1475000)
  1147. {
  1148. writearray[0]=5;
  1149. }
  1150. else if(Freq<=1510000)
  1151. {
  1152. writearray[0]=6;
  1153. }
  1154. else if(Freq<=1545000)
  1155. {
  1156. writearray[0]=7;
  1157. }
  1158. else if(Freq<=1575000)
  1159. {
  1160. writearray[0] =8;
  1161. }
  1162. else if(Freq<=1615000)
  1163. {
  1164. writearray[0]=9;
  1165. }
  1166. else if(Freq<=1650000)
  1167. {
  1168. writearray[0] =10;
  1169. }
  1170. else if(Freq<=1670000)
  1171. {
  1172. writearray[0]=11;
  1173. }
  1174. else if(Freq<=1690000)
  1175. {
  1176. writearray[0]=12;
  1177. }
  1178. else if(Freq<=1710000)
  1179. {
  1180. writearray[0]=13;
  1181. }
  1182. else if(Freq<=1735000)
  1183. {
  1184. writearray[0]=14;
  1185. }
  1186. else
  1187. {
  1188. writearray[0]=15;
  1189. }
  1190. status=I2CWriteByte (pTuner, 200,16,writearray[0]);
  1191. //printf("\nRegister 10=%d", writearray[0]);
  1192. if(status != E4000_I2C_SUCCESS)
  1193. {
  1194. return E4000_1_FAIL;
  1195. }
  1196. return E4000_1_SUCCESS;
  1197. }
  1198. /****************************************************************************\
  1199. * Function: IFfilter
  1200. *
  1201. * Detailed Description:
  1202. * The function configures the E4000 IF filter. (Register 0x11,0x12).
  1203. *
  1204. \****************************************************************************/
  1205. int IFfilter(void *pTuner, int bandwidth, int Ref_clk)
  1206. {
  1207. unsigned char writearray[5];
  1208. int status;
  1209. int IF_BW;
  1210. IF_BW = bandwidth / 2;
  1211. if(IF_BW<=2150)
  1212. {
  1213. writearray[0]=253;
  1214. writearray[1]=31;
  1215. }
  1216. else if(IF_BW<=2200)
  1217. {
  1218. writearray[0]=253;
  1219. writearray[1]=30;
  1220. }
  1221. else if(IF_BW<=2240)
  1222. {
  1223. writearray[0]=252;
  1224. writearray[1]=29;
  1225. }
  1226. else if(IF_BW<=2280)
  1227. {
  1228. writearray[0]=252;
  1229. writearray[1]=28;
  1230. }
  1231. else if(IF_BW<=2300)
  1232. {
  1233. writearray[0]=252;
  1234. writearray[1]=27;
  1235. }
  1236. else if(IF_BW<=2400)
  1237. {
  1238. writearray[0]=252;
  1239. writearray[1]=26;
  1240. }
  1241. else if(IF_BW<=2450)
  1242. {
  1243. writearray[0]=252;
  1244. writearray[1]=25;
  1245. }
  1246. else if(IF_BW<=2500)
  1247. {
  1248. writearray[0]=252;
  1249. writearray[1]=24;
  1250. }
  1251. else if(IF_BW<=2550)
  1252. {
  1253. writearray[0]=252;
  1254. writearray[1]=23;
  1255. }
  1256. else if(IF_BW<=2600)
  1257. {
  1258. writearray[0]=252;
  1259. writearray[1]=22;
  1260. }
  1261. else if(IF_BW<=2700)
  1262. {
  1263. writearray[0]=252;
  1264. writearray[1]=21;
  1265. }
  1266. else if(IF_BW<=2750)
  1267. {
  1268. writearray[0]=252;
  1269. writearray[1]=20;
  1270. }
  1271. else if(IF_BW<=2800)
  1272. {
  1273. writearray[0]=252;
  1274. writearray[1]=19;
  1275. }
  1276. else if(IF_BW<=2900)
  1277. {
  1278. writearray[0]=251;
  1279. writearray[1]=18;
  1280. }
  1281. else if(IF_BW<=2950)
  1282. {
  1283. writearray[0]=251;
  1284. writearray[1]=17;
  1285. }
  1286. else if(IF_BW<=3000)
  1287. {
  1288. writearray[0]=251;
  1289. writearray[1]=16;
  1290. }
  1291. else if(IF_BW<=3100)
  1292. {
  1293. writearray[0]=251;
  1294. writearray[1]=15;
  1295. }
  1296. else if(IF_BW<=3200)
  1297. {
  1298. writearray[0]=250;
  1299. writearray[1]=14;
  1300. }
  1301. else if(IF_BW<=3300)
  1302. {
  1303. writearray[0]=250;
  1304. writearray[1]=13;
  1305. }
  1306. else if(IF_BW<=3400)
  1307. {
  1308. writearray[0]=249;
  1309. writearray[1]=12;
  1310. }
  1311. else if(IF_BW<=3600)
  1312. {
  1313. writearray[0]=249;
  1314. writearray[1]=11;
  1315. }
  1316. else if(IF_BW<=3700)
  1317. {
  1318. writearray[0]=249;
  1319. writearray[1]=10;
  1320. }
  1321. else if(IF_BW<=3800)
  1322. {
  1323. writearray[0]=248;
  1324. writearray[1]=9;
  1325. }
  1326. else if(IF_BW<=3900)
  1327. {
  1328. writearray[0]=248;
  1329. writearray[1]=8;
  1330. }
  1331. else if(IF_BW<=4100)
  1332. {
  1333. writearray[0]=248;
  1334. writearray[1]=7;
  1335. }
  1336. else if(IF_BW<=4300)
  1337. {
  1338. writearray[0]=247;
  1339. writearray[1]=6;
  1340. }
  1341. else if(IF_BW<=4400)
  1342. {
  1343. writearray[0]=247;
  1344. writearray[1]=5;
  1345. }
  1346. else if(IF_BW<=4600)
  1347. {
  1348. writearray[0]=247;
  1349. writearray[1]=4;
  1350. }
  1351. else if(IF_BW<=4800)
  1352. {
  1353. writearray[0]=246;
  1354. writearray[1]=3;
  1355. }
  1356. else if(IF_BW<=5000)
  1357. {
  1358. writearray[0]=246;
  1359. writearray[1]=2;
  1360. }
  1361. else if(IF_BW<=5300)
  1362. {
  1363. writearray[0]=245;
  1364. writearray[1]=1;
  1365. }
  1366. else if(IF_BW<=5500)
  1367. {
  1368. writearray[0]=245;
  1369. writearray[1]=0;
  1370. }
  1371. else
  1372. {
  1373. writearray[0]=0;
  1374. writearray[1]=32;
  1375. }
  1376. status=I2CWriteArray(pTuner, 200,17,2,writearray);
  1377. //printf("\nRegister 11=%d", writearray[0]);
  1378. //printf("\nRegister 12=%d", writearray[1]);
  1379. if(status != E4000_I2C_SUCCESS)
  1380. {
  1381. return E4000_1_FAIL;
  1382. }
  1383. return E4000_1_SUCCESS;
  1384. }
  1385. /****************************************************************************\
  1386. * Function: freqband
  1387. *
  1388. * Detailed Description:
  1389. * Configures the E4000 frequency band. (Registers 0x07, 0x78).
  1390. *
  1391. \****************************************************************************/
  1392. int freqband(void *pTuner, int Freq)
  1393. {
  1394. unsigned char writearray[5];
  1395. int status;
  1396. if (Freq<=140000)
  1397. {
  1398. writearray[0] = 3;
  1399. status=I2CWriteByte(pTuner, 200,120,writearray[0]);
  1400. if(status != E4000_I2C_SUCCESS)
  1401. {
  1402. return E4000_1_FAIL;
  1403. }
  1404. }
  1405. else if (Freq<=350000)
  1406. {
  1407. writearray[0] = 3;
  1408. status=I2CWriteByte(pTuner, 200,120,writearray[0]);
  1409. if(status != E4000_I2C_SUCCESS)
  1410. {
  1411. return E4000_1_FAIL;
  1412. }
  1413. }
  1414. else if (Freq<=1000000)
  1415. {
  1416. writearray[0] = 3;
  1417. status=I2CWriteByte(pTuner, 200,120,writearray[0]);
  1418. if(status != E4000_I2C_SUCCESS)
  1419. {
  1420. return E4000_1_FAIL;
  1421. }
  1422. }
  1423. else
  1424. {
  1425. writearray[0] = 7;
  1426. status=I2CWriteByte(pTuner, 200,7,writearray[0]);
  1427. if(status != E4000_I2C_SUCCESS)
  1428. {
  1429. return E4000_1_FAIL;
  1430. }
  1431. writearray[0] = 0;
  1432. status=I2CWriteByte(pTuner, 200,120,writearray[0]);
  1433. if(status != E4000_I2C_SUCCESS)
  1434. {
  1435. return E4000_1_FAIL;
  1436. }
  1437. }
  1438. return E4000_1_SUCCESS;
  1439. }
  1440. /****************************************************************************\
  1441. * Function: DCoffLUT
  1442. *
  1443. * Detailed Description:
  1444. * Populates DC offset LUT. (Registers 0x50 - 0x53, 0x60 - 0x63).
  1445. *
  1446. \****************************************************************************/
  1447. int DCoffLUT(void *pTuner)
  1448. {
  1449. unsigned char writearray[5];
  1450. int status;
  1451. unsigned char read1[1];
  1452. unsigned char IOFF;
  1453. unsigned char QOFF;
  1454. unsigned char RANGE1;
  1455. // unsigned char RANGE2;
  1456. unsigned char QRANGE;
  1457. unsigned char IRANGE;
  1458. writearray[0] = 0;
  1459. writearray[1] = 126;
  1460. writearray[2] = 36;
  1461. status=I2CWriteArray(pTuner, 200,21,3,writearray);
  1462. if(status != E4000_I2C_SUCCESS)
  1463. {
  1464. return E4000_1_FAIL;
  1465. }
  1466. // Sets mixer & IF stage 1 gain = 00 and IF stg 2+ to max gain.
  1467. writearray[0] = 1;
  1468. status=I2CWriteByte(pTuner, 200,41,writearray[0]);
  1469. // Instructs a DC offset calibration.
  1470. status=I2CReadByte(pTuner, 201,42,read1);
  1471. if(status != E4000_I2C_SUCCESS)
  1472. {
  1473. return E4000_1_FAIL;
  1474. }
  1475. IOFF=read1[0];
  1476. status=I2CReadByte(pTuner, 201,43,read1);
  1477. if(status != E4000_I2C_SUCCESS)
  1478. {
  1479. return E4000_1_FAIL;
  1480. }
  1481. QOFF=read1[0];
  1482. status=I2CReadByte(pTuner, 201,44,read1);
  1483. if(status != E4000_I2C_SUCCESS)
  1484. {
  1485. return E4000_1_FAIL;
  1486. }
  1487. RANGE1=read1[0];
  1488. //reads DC offset values back
  1489. if(RANGE1>=32)
  1490. {
  1491. RANGE1 = RANGE1 -32;
  1492. }
  1493. if(RANGE1>=16)
  1494. {
  1495. RANGE1 = RANGE1 - 16;
  1496. }
  1497. IRANGE=RANGE1;
  1498. QRANGE = (read1[0] - RANGE1) / 16;
  1499. writearray[0] = (IRANGE * 64) + IOFF;
  1500. status=I2CWriteByte(pTuner, 200,96,writearray[0]);
  1501. if(status != E4000_I2C_SUCCESS)
  1502. {
  1503. return E4000_1_FAIL;
  1504. }
  1505. writearray[0] = (QRANGE * 64) + QOFF;
  1506. status=I2CWriteByte(pTuner, 200,80,writearray[0]);
  1507. if(status != E4000_I2C_SUCCESS)
  1508. {
  1509. return E4000_1_FAIL;
  1510. }
  1511. // Populate DC offset LUT
  1512. writearray[0] = 0;
  1513. writearray[1] = 127;
  1514. status=I2CWriteArray(pTuner, 200,21,2,writearray);
  1515. if(status != E4000_I2C_SUCCESS)
  1516. {
  1517. return E4000_1_FAIL;
  1518. }
  1519. // Sets mixer & IF stage 1 gain = 01 leaving IF stg 2+ at max gain.
  1520. writearray[0]= 1;
  1521. status=I2CWriteByte(pTuner, 200,41,writearray[0]);
  1522. if(status != E4000_I2C_SUCCESS)
  1523. {
  1524. return E4000_1_FAIL;
  1525. }
  1526. // Instructs a DC offset calibration.
  1527. status=I2CReadByte(pTuner, 201,42,read1);
  1528. if(status != E4000_I2C_SUCCESS)
  1529. {
  1530. return E4000_1_FAIL;
  1531. }
  1532. IOFF=read1[0];
  1533. status=I2CReadByte(pTuner, 201,43,read1);
  1534. if(status != E4000_I2C_SUCCESS)
  1535. {
  1536. return E4000_1_FAIL;
  1537. }
  1538. QOFF=read1[0];
  1539. status=I2CReadByte(pTuner, 201,44,read1);
  1540. if(status != E4000_I2C_SUCCESS)
  1541. {
  1542. return E4000_1_FAIL;
  1543. }
  1544. RANGE1=read1[0];
  1545. // Read DC offset values
  1546. if(RANGE1>=32)
  1547. {
  1548. RANGE1 = RANGE1 -32;
  1549. }
  1550. if(RANGE1>=16)
  1551. {
  1552. RANGE1 = RANGE1 - 16;
  1553. }
  1554. IRANGE = RANGE1;
  1555. QRANGE = (read1[0] - RANGE1) / 16;
  1556. writearray[0] = (IRANGE * 64) + IOFF;
  1557. status=I2CWriteByte(pTuner, 200,97,writearray[0]);
  1558. if(status != E4000_I2C_SUCCESS)
  1559. {
  1560. return E4000_1_FAIL;
  1561. }
  1562. writearray[0] = (QRANGE * 64) + QOFF;
  1563. status=I2CWriteByte(pTuner, 200,81,writearray[0]);
  1564. if(status != E4000_I2C_SUCCESS)
  1565. {
  1566. return E4000_1_FAIL;
  1567. }
  1568. // Populate DC offset LUT
  1569. writearray[0] = 1;
  1570. status=I2CWriteByte(pTuner, 200,21,writearray[0]);
  1571. if(status != E4000_I2C_SUCCESS)
  1572. {
  1573. return E4000_1_FAIL;
  1574. }
  1575. // Sets mixer & IF stage 1 gain = 11 leaving IF stg 2+ at max gain.
  1576. writearray[0] = 1;
  1577. status=I2CWriteByte(pTuner, 200,41,writearray[0]);
  1578. if(status != E4000_I2C_SUCCESS)
  1579. {
  1580. return E4000_1_FAIL;
  1581. }
  1582. // Instructs a DC offset calibration.
  1583. status=I2CReadByte(pTuner, 201,42,read1);
  1584. if(status != E4000_I2C_SUCCESS)
  1585. {
  1586. return E4000_1_FAIL;
  1587. }
  1588. IOFF=read1[0];
  1589. status=I2CReadByte(pTuner, 201,43,read1);
  1590. if(status != E4000_I2C_SUCCESS)
  1591. {
  1592. return E4000_1_FAIL;
  1593. }
  1594. QOFF=read1[0];
  1595. status=I2CReadByte(pTuner, 201,44,read1);
  1596. if(status != E4000_I2C_SUCCESS)
  1597. {
  1598. return E4000_1_FAIL;
  1599. }
  1600. RANGE1 = read1[0];
  1601. // Read DC offset values
  1602. if(RANGE1>=32)
  1603. {
  1604. RANGE1 = RANGE1 -32;
  1605. }
  1606. if(RANGE1>=16)
  1607. {
  1608. RANGE1 = RANGE1 - 16;
  1609. }
  1610. IRANGE = RANGE1;
  1611. QRANGE = (read1[0] - RANGE1) / 16;
  1612. writearray[0] = (IRANGE * 64) + IOFF;
  1613. status=I2CWriteByte(pTuner, 200,99,writearray[0]);
  1614. if(status != E4000_I2C_SUCCESS)
  1615. {
  1616. return E4000_1_FAIL;
  1617. }
  1618. writearray[0] = (QRANGE * 64) + QOFF;
  1619. status=I2CWriteByte(pTuner, 200,83,writearray[0]);
  1620. if(status != E4000_I2C_SUCCESS)
  1621. {
  1622. return E4000_1_FAIL;
  1623. }
  1624. // Populate DC offset LUT
  1625. writearray[0] = 126;
  1626. status=I2CWriteByte(pTuner, 200,22,writearray[0]);
  1627. if(status != E4000_I2C_SUCCESS)
  1628. {
  1629. return E4000_1_FAIL;
  1630. }
  1631. // Sets mixer & IF stage 1 gain = 11 leaving IF stg 2+ at max gain.
  1632. writearray[0] = 1;
  1633. status=I2CWriteByte(pTuner, 200,41,writearray[0]);
  1634. if(status != E4000_I2C_SUCCESS)
  1635. {
  1636. return E4000_1_FAIL;
  1637. }
  1638. // Instructs a DC offset calibration.
  1639. status=I2CReadByte(pTuner, 201,42,read1);
  1640. if(status != E4000_I2C_SUCCESS)
  1641. {
  1642. return E4000_1_FAIL;
  1643. }
  1644. IOFF=read1[0];
  1645. status=I2CReadByte(pTuner, 201,43,read1);
  1646. if(status != E4000_I2C_SUCCESS)
  1647. {
  1648. return E4000_1_FAIL;
  1649. }
  1650. QOFF=read1[0];
  1651. status=I2CReadByte(pTuner, 201,44,read1);
  1652. if(status != E4000_I2C_SUCCESS)
  1653. {
  1654. return E4000_1_FAIL;
  1655. }
  1656. RANGE1=read1[0];
  1657. // Read DC offset values
  1658. if(RANGE1>=32)
  1659. {
  1660. RANGE1 = RANGE1 -32;
  1661. }
  1662. if(RANGE1>=16)
  1663. {
  1664. RANGE1 = RANGE1 - 16;
  1665. }
  1666. IRANGE = RANGE1;
  1667. QRANGE = (read1[0] - RANGE1) / 16;
  1668. writearray[0]=(IRANGE * 64) + IOFF;
  1669. status=I2CWriteByte(pTuner, 200,98,writearray[0]);
  1670. if(status != E4000_I2C_SUCCESS)
  1671. {
  1672. return E4000_1_FAIL;
  1673. }
  1674. writearray[0] = (QRANGE * 64) + QOFF;
  1675. status=I2CWriteByte(pTuner, 200,82,writearray[0]);
  1676. // Populate DC offset LUT
  1677. if(status != E4000_I2C_SUCCESS)
  1678. {
  1679. return E4000_1_FAIL;
  1680. }
  1681. return E4000_1_SUCCESS;
  1682. }
  1683. /****************************************************************************\
  1684. * Function: GainControlinit
  1685. *
  1686. * Detailed Description:
  1687. * Configures gain control mode. (Registers 0x1a)
  1688. *
  1689. \****************************************************************************/
  1690. int GainControlauto(void *pTuner)
  1691. {
  1692. unsigned char writearray[5];
  1693. int status;
  1694. writearray[0] = 23;
  1695. status=I2CWriteByte(pTuner, 200,26,writearray[0]);
  1696. if(status != E4000_I2C_SUCCESS)
  1697. {
  1698. return E4000_1_FAIL;
  1699. }
  1700. return E4000_1_SUCCESS;
  1701. }
  1702. /****************************************************************************\
  1703. * Main program
  1704. *
  1705. *
  1706. *
  1707. \****************************************************************************/
  1708. /*
  1709. int main()
  1710. {
  1711. Gainmanual();
  1712. PLL(Ref_clk, Freq);
  1713. LNAfilter(Freq);
  1714. IFfilter(bandwidth, Ref_clk);
  1715. freqband(Freq);
  1716. DCoffLUT();
  1717. GainControlauto();
  1718. return(0);
  1719. }
  1720. */
  1721. // Elonics source code - RT2832_SW_optimisation_rev2.c
  1722. /****************************************************************************\
  1723. * Function: E4000_sensitivity
  1724. *
  1725. * Detailed Description:
  1726. * The function configures the E4000 for sensitivity mode.
  1727. *
  1728. \****************************************************************************/
  1729. int E4000_sensitivity(void *pTuner, int Freq, int bandwidth)
  1730. {
  1731. unsigned char writearray[2];
  1732. int status;
  1733. int IF_BW;
  1734. writearray[1]=0x00;
  1735. if(Freq<=700000)
  1736. {
  1737. writearray[0] = 0x07;
  1738. }
  1739. else
  1740. {
  1741. writearray[0] = 0x05;
  1742. }
  1743. status = I2CWriteArray(pTuner,200,36,1,writearray);
  1744. if(status != E4000_I2C_SUCCESS)
  1745. {
  1746. return E4000_1_FAIL;
  1747. }
  1748. IF_BW = bandwidth / 2;
  1749. if(IF_BW<=2500)
  1750. {
  1751. writearray[0]=0xfc;
  1752. writearray[1]=0x17;
  1753. }
  1754. else if(IF_BW<=3000)
  1755. {
  1756. writearray[0]=0xfb;
  1757. writearray[1]=0x0f;
  1758. }
  1759. else if(IF_BW<=3500)
  1760. {
  1761. writearray[0]=0xf9;
  1762. writearray[1]=0x0b;
  1763. }
  1764. else if(IF_BW<=4000)
  1765. {
  1766. writearray[0]=0xf8;
  1767. writearray[1]=0x07;
  1768. }
  1769. status = I2CWriteArray(pTuner,200,17,2,writearray);
  1770. if(status != E4000_I2C_SUCCESS)
  1771. {
  1772. return E4000_1_FAIL;
  1773. }
  1774. return E4000_1_SUCCESS;
  1775. }
  1776. /****************************************************************************\
  1777. * Function: E4000_linearity
  1778. *
  1779. * Detailed Description:
  1780. * The function configures the E4000 for linearity mode.
  1781. *
  1782. \****************************************************************************/
  1783. int E4000_linearity(void *pTuner, int Freq, int bandwidth)
  1784. {
  1785. unsigned char writearray[2];
  1786. int status;
  1787. int IF_BW;
  1788. writearray[1]=0x00;
  1789. if(Freq<=700000)
  1790. {
  1791. writearray[0] = 0x03;
  1792. }
  1793. else
  1794. {
  1795. writearray[0] = 0x01;
  1796. }
  1797. status = I2CWriteArray(pTuner,200,36,1,writearray);
  1798. if(status != E4000_I2C_SUCCESS)
  1799. {
  1800. return E4000_1_FAIL;
  1801. }
  1802. IF_BW = bandwidth / 2;
  1803. if(IF_BW<=2500)
  1804. {
  1805. writearray[0]=0xfe;
  1806. writearray[1]=0x19;
  1807. }
  1808. else if(IF_BW<=3000)
  1809. {
  1810. writearray[0]=0xfd;
  1811. writearray[1]=0x11;
  1812. }
  1813. else if(IF_BW<=3500)
  1814. {
  1815. writearray[0]=0xfb;
  1816. writearray[1]=0x0d;
  1817. }
  1818. else if(IF_BW<=4000)
  1819. {
  1820. writearray[0]=0xfa;
  1821. writearray[1]=0x0a;
  1822. }
  1823. status = I2CWriteArray(pTuner,200,17,2,writearray);
  1824. if(status != E4000_I2C_SUCCESS)
  1825. {
  1826. return E4000_1_FAIL;
  1827. }
  1828. return E4000_1_SUCCESS;
  1829. }
  1830. /****************************************************************************\
  1831. * Function: E4000_nominal
  1832. *
  1833. * Detailed Description:
  1834. * The function configures the E4000 for nominal
  1835. *
  1836. \****************************************************************************/
  1837. int E4000_nominal(void *pTuner, int Freq, int bandwidth)
  1838. {
  1839. unsigned char writearray[2];
  1840. int status;
  1841. int IF_BW;
  1842. writearray[1]=0x00;
  1843. if(Freq<=700000)
  1844. {
  1845. writearray[0] = 0x03;
  1846. }
  1847. else
  1848. {
  1849. writearray[0] = 0x01;
  1850. }
  1851. status = I2CWriteArray(pTuner,200,36,1,writearray);
  1852. if(status != E4000_I2C_SUCCESS)
  1853. {
  1854. return E4000_1_FAIL;
  1855. }
  1856. IF_BW = bandwidth / 2;
  1857. if(IF_BW<=2500)
  1858. {
  1859. writearray[0]=0xfc;
  1860. writearray[1]=0x17;
  1861. }
  1862. else if(IF_BW<=3000)
  1863. {
  1864. writearray[0]=0xfb;
  1865. writearray[1]=0x0f;
  1866. }
  1867. else if(IF_BW<=3500)
  1868. {
  1869. writearray[0]=0xf9;
  1870. writearray[1]=0x0b;
  1871. }
  1872. else if(IF_BW<=4000)
  1873. {
  1874. writearray[0]=0xf8;
  1875. writearray[1]=0x07;
  1876. }
  1877. status = I2CWriteArray(pTuner,200,17,2,writearray);
  1878. if(status != E4000_I2C_SUCCESS)
  1879. {
  1880. return E4000_1_FAIL;
  1881. }
  1882. return E4000_1_SUCCESS;
  1883. }