123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070 |
- /*
- * Elonics E4000 tuner driver, taken from the kernel driver that can be found
- * on http://linux.terratec.de/tv_en.html
- *
- * This driver is a mess, and should be replaced by the osmo-sdr E4000 driver
- *
- */
- #include <stdint.h>
- #include "i2c.h"
- #include "tuner_e4000.h"
- #define FUNCTION_ERROR 1
- #define FUNCTION_SUCCESS 0
- #define NO_USE 0
- #define LEN_2_BYTE 2
- #define I2C_BUFFER_LEN 128
- #define YES 1
- #define NO 0
- #define CRYSTAL_FREQ 28800000
- /* glue functions to rtl-sdr code */
- int
- I2CReadByte(
- void *pTuner,
- unsigned char NoUse,
- unsigned char RegAddr,
- unsigned char *pReadingByte
- )
- {
- uint8_t data = RegAddr;
- if (rtlsdr_i2c_write((rtlsdr_dev_t *)pTuner, E4K_I2C_ADDR, &data, 1) < 0)
- return E4000_I2C_FAIL;
- if (rtlsdr_i2c_read((rtlsdr_dev_t *)pTuner, E4K_I2C_ADDR, &data, 1) < 0)
- return E4000_I2C_FAIL;
- *pReadingByte = data;
- return E4000_I2C_SUCCESS;
- }
- int
- I2CWriteByte(void *pTuner,
- unsigned char NoUse,
- unsigned char RegAddr,
- unsigned char WritingByte
- )
- {
- uint8_t data[2];
- data[0] = RegAddr;
- data[1] = WritingByte;
- if (rtlsdr_i2c_write((rtlsdr_dev_t *)pTuner, E4K_I2C_ADDR, data, 2) < 0)
- return E4000_I2C_FAIL;
- return E4000_I2C_SUCCESS;
- }
- int
- I2CWriteArray(
- void *pTuner,
- unsigned char NoUse,
- unsigned char RegStartAddr,
- unsigned char ByteNum,
- unsigned char *pWritingBytes
- )
- {
- unsigned int i;
- uint8_t WritingBuffer[I2C_BUFFER_LEN];
- WritingBuffer[0] = RegStartAddr;
- for(i = 0; i < ByteNum; i++)
- WritingBuffer[1 + i] = pWritingBytes[i];
- if (rtlsdr_i2c_write((rtlsdr_dev_t *)pTuner, E4K_I2C_ADDR, WritingBuffer, ByteNum + 1) < 0)
- return E4000_I2C_FAIL;
- return E4000_I2C_SUCCESS;
- }
- /**
- @see TUNER_FP_INITIALIZE
- */
- int
- e4000_Initialize(void *pTuner
- )
- {
- // Initialize tuner.
- // Note: Call E4000 source code functions.
- if(tunerreset(pTuner) != E4000_1_SUCCESS)
- goto error_status_execute_function;
- if(Tunerclock(pTuner) != E4000_1_SUCCESS)
- goto error_status_execute_function;
- if(Qpeak(pTuner) != E4000_1_SUCCESS)
- goto error_status_execute_function;
- if(DCoffloop(pTuner) != E4000_1_SUCCESS)
- goto error_status_execute_function;
- if(GainControlinit(pTuner) != E4000_1_SUCCESS)
- goto error_status_execute_function;
- return FUNCTION_SUCCESS;
- error_status_execute_function:
- return FUNCTION_ERROR;
- }
- /**
- @see TUNER_FP_SET_RF_FREQ_HZ
- */
- int
- e4000_SetRfFreqHz(
- void *pTuner,
- unsigned long RfFreqHz
- )
- {
- // E4000_EXTRA_MODULE *pExtra;
- int RfFreqKhz;
- int CrystalFreqKhz;
- int CrystalFreqHz = CRYSTAL_FREQ;
- // Set tuner RF frequency in KHz.
- // Note: 1. RfFreqKhz = round(RfFreqHz / 1000)
- // CrystalFreqKhz = round(CrystalFreqHz / 1000)
- // 2. Call E4000 source code functions.
- RfFreqKhz = (int)((RfFreqHz + 500) / 1000);
- CrystalFreqKhz = (int)((CrystalFreqHz + 500) / 1000);
- if(Gainmanual(pTuner) != E4000_1_SUCCESS)
- goto error_status_execute_function;
- if(E4000_gain_freq(pTuner, RfFreqKhz) != E4000_1_SUCCESS)
- goto error_status_execute_function;
- if(PLL(pTuner, CrystalFreqKhz, RfFreqKhz) != E4000_1_SUCCESS)
- goto error_status_execute_function;
- if(LNAfilter(pTuner, RfFreqKhz) != E4000_1_SUCCESS)
- goto error_status_execute_function;
- if(freqband(pTuner, RfFreqKhz) != E4000_1_SUCCESS)
- goto error_status_execute_function;
- if(DCoffLUT(pTuner) != E4000_1_SUCCESS)
- goto error_status_execute_function;
- if(GainControlauto(pTuner) != E4000_1_SUCCESS)
- goto error_status_execute_function;
- return FUNCTION_SUCCESS;
- error_status_execute_function:
- return FUNCTION_ERROR;
- }
- /**
- @brief Set E4000 tuner bandwidth.
- */
- int
- e4000_SetBandwidthHz(
- void *pTuner,
- unsigned long BandwidthHz
- )
- {
- // E4000_EXTRA_MODULE *pExtra;
- int BandwidthKhz;
- int CrystalFreqKhz;
- int CrystalFreqHz = CRYSTAL_FREQ;
- // Get tuner extra module.
- // pExtra = &(pTuner->Extra.E4000);
- // Set tuner bandwidth Hz.
- // Note: 1. BandwidthKhz = round(BandwidthHz / 1000)
- // CrystalFreqKhz = round(CrystalFreqHz / 1000)
- // 2. Call E4000 source code functions.
- BandwidthKhz = (int)((BandwidthHz + 500) / 1000);
- CrystalFreqKhz = (int)((CrystalFreqHz + 500) / 1000);
- if(IFfilter(pTuner, BandwidthKhz, CrystalFreqKhz) != E4000_1_SUCCESS)
- goto error_status_execute_function;
- return FUNCTION_SUCCESS;
- error_status_execute_function:
- return FUNCTION_ERROR;
- }
- // The following context is source code provided by Elonics.
- // Elonics source code - E4000_API_rev2_04_realtek.cpp
- //****************************************************************************/
- //
- // Filename E4000_initialisation.c
- // Revision 2.04
- //
- // Description:
- // Initialisation script for the Elonics E4000 revC tuner
- //
- // Copyright (c) Elonics Ltd
- //
- // Any software supplied free of charge for use with elonics
- // evaluation kits is supplied without warranty and for
- // evaluation purposes only. Incorporation of any of this
- // code into products for open sale is permitted but only at
- // the user's own risk. Elonics accepts no liability for the
- // integrity of this software whatsoever.
- //
- //
- //****************************************************************************/
- //#include <stdio.h>
- //#include <stdlib.h>
- //
- // User defined variable definitions
- //
- /*
- int Ref_clk = 26000; // Reference clock frequency(kHz).
- int Freq = 590000; // RF Frequency (kHz)
- int bandwidth = 8000; //RF channel bandwith (kHz)
- */
- //
- // API defined variable definitions
- //int VCO_freq;
- //unsigned char writearray[5];
- //unsigned char read1[1];
- //int status;
- //
- //
- // function definitions
- //
- /*
- int tunerreset ();
- int Tunerclock();
- int filtercal();
- int Qpeak();
- int PLL(int Ref_clk, int Freq);
- int LNAfilter(int Freq);
- int IFfilter(int bandwidth, int Ref_clk);
- int freqband(int Freq);
- int DCoffLUT();
- int DCoffloop();
- int commonmode();
- int GainControlinit();
- */
- //
- //****************************************************************************
- // --- Public functions ------------------------------------------------------
- /****************************************************************************\
- * Function: tunerreset
- *
- * Detailed Description:
- * The function resets the E4000 tuner. (Register 0x00).
- *
- \****************************************************************************/
- int tunerreset(void *pTuner)
- {
- unsigned char writearray[5];
- int status;
- writearray[0] = 64;
- // For dummy I2C command, don't check executing status.
- status=I2CWriteByte (pTuner, 200,2,writearray[0]);
- status=I2CWriteByte (pTuner, 200,2,writearray[0]);
- //printf("\nRegister 0=%d", writearray[0]);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- writearray[0] = 0;
- status=I2CWriteByte (pTuner, 200,9,writearray[0]);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- writearray[0] = 0;
- status=I2CWriteByte (pTuner, 200,5,writearray[0]);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- writearray[0] = 7;
- status=I2CWriteByte (pTuner, 200,0,writearray[0]);
- //printf("\nRegister 0=%d", writearray[0]);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- return E4000_1_SUCCESS;
- }
- /****************************************************************************\
- * Function: Tunerclock
- *
- * Detailed Description:
- * The function configures the E4000 clock. (Register 0x06, 0x7a).
- * Function disables the clock - values can be modified to enable if required.
- \****************************************************************************/
- int Tunerclock(void *pTuner)
- {
- unsigned char writearray[5];
- int status;
- writearray[0] = 0;
- status=I2CWriteByte(pTuner, 200,6,writearray[0]);
- //printf("\nRegister 6=%d", writearray[0]);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- writearray[0] = 150;
- status=I2CWriteByte(pTuner, 200,122,writearray[0]);
- //printf("\nRegister 7a=%d", writearray[0]);
- //**Modify commands above with value required if output clock is required,
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- return E4000_1_SUCCESS;
- }
- /****************************************************************************\
- * Function: filtercal
- *
- * Detailed Description:
- * Instructs RC filter calibration. (Register 0x7b).
- *
- \****************************************************************************/
- /*
- int filtercal(void *pTuner)
- {
- //writearray[0] = 1;
- //I2CWriteByte (pTuner, 200,123,writearray[0]);
- //printf("\nRegister 7b=%d", writearray[0]);
- //return;
- return E4000_1_SUCCESS;
- }
- */
- /****************************************************************************\
- * Function: Qpeak()
- *
- * Detailed Description:
- * The function configures the E4000 gains.
- * Also sigma delta controller. (Register 0x82).
- *
- \****************************************************************************/
- int Qpeak(void *pTuner)
- {
- unsigned char writearray[5];
- int status;
- writearray[0] = 1;
- writearray[1] = 254;
- status=I2CWriteArray(pTuner, 200,126,2,writearray);
- //printf("\nRegister 7e=%d", writearray[0]);
- //printf("\nRegister 7f=%d", writearray[1]);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- status=I2CWriteByte (pTuner, 200,130,0);
- //printf("\nRegister 82=0");
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- status=I2CWriteByte (pTuner, 200,36,5);
- //printf("\nRegister 24=5");
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- writearray[0] = 32;
- writearray[1] = 1;
- status=I2CWriteArray(pTuner, 200,135,2,writearray);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- //printf("\nRegister 87=%d", writearray[0]);
- //printf("\nRegister 88=%d", writearray[1]);
- return E4000_1_SUCCESS;
- }
- /****************************************************************************\
- * Function: E4000_gain_freq()
- *
- * Detailed Description:
- * The function configures the E4000 gains vs. freq
- * 0xa3 to 0xa7. Also 0x24.
- *
- \****************************************************************************/
- int E4000_gain_freq(void *pTuner, int Freq)
- {
- unsigned char writearray[5];
- int status;
- if (Freq<=350000)
- {
- writearray[0] = 0x10;
- writearray[1] = 0x42;
- writearray[2] = 0x09;
- writearray[3] = 0x21;
- writearray[4] = 0x94;
- }
- else if(Freq>=1000000)
- {
- writearray[0] = 0x10;
- writearray[1] = 0x42;
- writearray[2] = 0x09;
- writearray[3] = 0x21;
- writearray[4] = 0x94;
- }
- else
- {
- writearray[0] = 0x10;
- writearray[1] = 0x42;
- writearray[2] = 0x09;
- writearray[3] = 0x21;
- writearray[4] = 0x94;
- }
- status=I2CWriteArray(pTuner, 200,163,5,writearray);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- if (Freq<=350000)
- {
- writearray[0] = 94;
- writearray[1] = 6;
- status=I2CWriteArray(pTuner, 200,159,2,writearray);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- writearray[0] = 0;
- status=I2CWriteArray(pTuner, 200,136,1,writearray);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- }
- else
- {
- writearray[0] = 127;
- writearray[1] = 7;
- status=I2CWriteArray(pTuner, 200,159,2,writearray);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- writearray[0] = 1;
- status=I2CWriteArray(pTuner, 200,136,1,writearray);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- }
- //printf("\nRegister 9f=%d", writearray[0]);
- //printf("\nRegister a0=%d", writearray[1]);
- return E4000_1_SUCCESS;
- }
- /****************************************************************************\
- * Function: DCoffloop
- *
- * Detailed Description:
- * Populates DC offset LUT. (Registers 0x2d, 0x70, 0x71).
- * Turns on DC offset LUT and time varying DC offset.
- \****************************************************************************/
- int DCoffloop(void *pTuner)
- {
- unsigned char writearray[5];
- int status;
- //writearray[0]=0;
- //I2CWriteByte(pTuner, 200,115,writearray[0]);
- //printf("\nRegister 73=%d", writearray[0]);
- writearray[0] = 31;
- status=I2CWriteByte(pTuner, 200,45,writearray[0]);
- //printf("\nRegister 2d=%d", writearray[0]);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- writearray[0] = 1;
- writearray[1] = 1;
- status=I2CWriteArray(pTuner, 200,112,2,writearray);
- //printf("\nRegister 70=%d", writearray[0]);
- //printf("\nRegister 71=%d", writearray[0]);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- return E4000_1_SUCCESS;
- }
- /****************************************************************************\
- * Function: commonmode
- *
- * Detailed Description:
- * Configures common mode voltage. (Registers 0x2f).
- *
- \****************************************************************************/
- /*
- int commonmode(void *pTuner)
- {
- //writearray[0] = 0;
- //I2CWriteByte(Device_address,47,writearray[0]);
- //printf("\nRegister 0x2fh = %d", writearray[0]);
- // Sets 550mV. Modify if alternative is desired.
- return E4000_1_SUCCESS;
- }
- */
- /****************************************************************************\
- * Function: GainControlinit
- *
- * Detailed Description:
- * Configures gain control mode. (Registers 0x1d, 0x1e, 0x1f, 0x20, 0x21,
- * 0x1a, 0x74h, 0x75h).
- * User may wish to modify values depending on usage scenario.
- * Routine configures LNA: autonomous gain control
- * IF PWM gain control.
- * PWM thresholds = default
- * Mixer: switches when LNA gain =7.5dB
- * Sensitivity / Linearity mode: manual switch
- *
- \****************************************************************************/
- int GainControlinit(void *pTuner)
- {
- unsigned char writearray[5];
- unsigned char read1[1];
- int status;
- unsigned char sum=255;
- writearray[0] = 23;
- status=I2CWriteByte(pTuner, 200,26,writearray[0]);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- //printf("\nRegister 1a=%d", writearray[0]);
- status=I2CReadByte(pTuner, 201,27,read1);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- writearray[0] = 16;
- writearray[1] = 4;
- writearray[2] = 26;
- writearray[3] = 15;
- writearray[4] = 167;
- status=I2CWriteArray(pTuner, 200,29,5,writearray);
- //printf("\nRegister 1d=%d", writearray[0]);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- writearray[0] = 81;
- status=I2CWriteByte(pTuner, 200,134,writearray[0]);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- //printf("\nRegister 86=%d", writearray[0]);
- //For Realtek - gain control logic
- status=I2CReadByte(pTuner, 201,27,read1);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- if(read1[0]<=sum)
- {
- sum=read1[0];
- }
- status=I2CWriteByte(pTuner, 200,31,writearray[2]);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- status=I2CReadByte(pTuner, 201,27,read1);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- if(read1[0] <= sum)
- {
- sum=read1[0];
- }
- status=I2CWriteByte(pTuner, 200,31,writearray[2]);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- status=I2CReadByte(pTuner, 201,27,read1);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- if(read1[0] <= sum)
- {
- sum=read1[0];
- }
- status=I2CWriteByte(pTuner, 200,31,writearray[2]);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- status=I2CReadByte(pTuner, 201,27,read1);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- if(read1[0] <= sum)
- {
- sum=read1[0];
- }
- status=I2CWriteByte(pTuner, 200,31,writearray[2]);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- status=I2CReadByte(pTuner, 201,27,read1);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- if (read1[0]<=sum)
- {
- sum=read1[0];
- }
- writearray[0]=sum;
- status=I2CWriteByte(pTuner, 200,27,writearray[0]);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- //printf("\nRegister 1b=%d", writearray[0]);
- //printf("\nRegister 1e=%d", writearray[1]);
- //printf("\nRegister 1f=%d", writearray[2]);
- //printf("\nRegister 20=%d", writearray[3]);
- //printf("\nRegister 21=%d", writearray[4]);
- //writearray[0] = 3;
- //writearray[1] = 252;
- //writearray[2] = 3;
- //writearray[3] = 252;
- //I2CWriteArray(pTuner, 200,116,4,writearray);
- //printf("\nRegister 74=%d", writearray[0]);
- //printf("\nRegister 75=%d", writearray[1]);
- //printf("\nRegister 76=%d", writearray[2]);
- //printf("\nRegister 77=%d", writearray[3]);
- return E4000_1_SUCCESS;
- }
- /****************************************************************************\
- * Main program
- *
- *
- *
- \****************************************************************************/
- /*
- int main()
- {
- tunerreset ();
- Tunerclock();
- //filtercal();
- Qpeak();
- //PLL(Ref_clk, Freq);
- //LNAfilter(Freq);
- //IFfilter(bandwidth, Ref_clk);
- //freqband(Freq);
- //DCoffLUT();
- DCoffloop();
- //commonmode();
- GainControlinit();
- // system("PAUSE");
- return(0);
- }
- */
- // Elonics source code - frequency_change_rev2.04_realtek.c
- //****************************************************************************/
- //
- // Filename E4000_freqchangerev2.04.c
- // Revision 2.04
- //
- // Description:
- // Frequency change script for the Elonics E4000 revB tuner
- //
- // Copyright (c) Elonics Ltd
- //
- // Any software supplied free of charge for use with elonics
- // evaluation kits is supplied without warranty and for
- // evaluation purposes only. Incorporation of any of this
- // code into products for open sale is permitted but only at
- // the user's own risk. Elonics accepts no liability for the
- // integrity of this software whatsoever.
- //
- //
- //****************************************************************************/
- //#include <stdio.h>
- //#include <stdlib.h>
- //
- // User defined variable definitions
- //
- /*
- int Ref_clk = 20000; // Reference clock frequency(kHz).
- int Freq = 590000; // RF Frequency (kHz)
- int bandwidth = 8; //RF channel bandwith (MHz)
- */
- //
- // API defined variable definitions
- //int VCO_freq;
- //unsigned char writearray[5];
- //unsigned char read1[1];
- //int E4000_1_SUCCESS;
- //int E4000_1_FAIL;
- //int E4000_I2C_SUCCESS;
- //int status;
- //
- //
- // function definitions
- //
- /*
- int Gainmanual();
- int PLL(int Ref_clk, int Freq);
- int LNAfilter(int Freq);
- int IFfilter(int bandwidth, int Ref_clk);
- int freqband(int Freq);
- int DCoffLUT();
- int GainControlauto();
- */
- //
- //****************************************************************************
- // --- Public functions ------------------------------------------------------
- /****************************************************************************\
- //****************************************************************************\
- * Function: Gainmanual
- *
- * Detailed Description:
- * Sets Gain control to serial interface control.
- *
- \****************************************************************************/
- int Gainmanual(void *pTuner)
- {
- unsigned char writearray[5];
- int status;
- writearray[0]=0;
- status=I2CWriteByte(pTuner, 200,26,writearray[0]);
- //printf("\nRegister 1a=%d", writearray[0]);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- writearray[0] = 0;
- status=I2CWriteByte (pTuner, 200,9,writearray[0]);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- writearray[0] = 0;
- status=I2CWriteByte (pTuner, 200,5,writearray[0]);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- return E4000_1_SUCCESS;
- }
- /****************************************************************************\
- * Function: PLL
- *
- * Detailed Description:
- * Configures E4000 PLL divider & sigma delta. 0x0d,0x09, 0x0a, 0x0b).
- *
- \****************************************************************************/
- int PLL(void *pTuner, int Ref_clk, int Freq)
- {
- int VCO_freq;
- unsigned char writearray[5];
- int status;
- unsigned char divider;
- int intVCOfreq;
- int SigDel;
- int SigDel2;
- int SigDel3;
- // int harmonic_freq;
- // int offset;
- if (Freq<=72400)
- {
- writearray[4] = 15;
- VCO_freq=Freq*48;
- }
- else if (Freq<=81200)
- {
- writearray[4] = 14;
- VCO_freq=Freq*40;
- }
- else if (Freq<=108300)
- {
- writearray[4]=13;
- VCO_freq=Freq*32;
- }
- else if (Freq<=162500)
- {
- writearray[4]=12;
- VCO_freq=Freq*24;
- }
- else if (Freq<=216600)
- {
- writearray[4]=11;
- VCO_freq=Freq*16;
- }
- else if (Freq<=325000)
- {
- writearray[4]=10;
- VCO_freq=Freq*12;
- }
- else if (Freq<=350000)
- {
- writearray[4]=9;
- VCO_freq=Freq*8;
- }
- else if (Freq<=432000)
- {
- writearray[4]=3;
- VCO_freq=Freq*8;
- }
- else if (Freq<=667000)
- {
- writearray[4]=2;
- VCO_freq=Freq*6;
- }
- else if (Freq<=1200000)
- {
- writearray[4]=1;
- VCO_freq=Freq*4;
- }
- else
- {
- writearray[4]=0;
- VCO_freq=Freq*2;
- }
- //printf("\nVCOfreq=%d", VCO_freq);
- // divider = VCO_freq * 1000 / Ref_clk;
- divider = VCO_freq / Ref_clk;
- //printf("\ndivider=%d", divider);
- writearray[0]= divider;
- // intVCOfreq = divider * Ref_clk /1000;
- intVCOfreq = divider * Ref_clk;
- //printf("\ninteger VCO freq=%d", intVCOfreq);
- // SigDel=65536 * 1000 * (VCO_freq - intVCOfreq) / Ref_clk;
- SigDel=65536 * (VCO_freq - intVCOfreq) / Ref_clk;
- //printf("\nSigma delta=%d", SigDel);
- if (SigDel<=1024)
- {
- SigDel = 1024;
- }
- else if (SigDel>=64512)
- {
- SigDel=64512;
- }
- SigDel2 = SigDel / 256;
- //printf("\nSigdel2=%d", SigDel2);
- writearray[2] = (unsigned char)SigDel2;
- SigDel3 = SigDel - (256 * SigDel2);
- //printf("\nSig del3=%d", SigDel3);
- writearray[1]= (unsigned char)SigDel3;
- writearray[3]=(unsigned char)0;
- status=I2CWriteArray(pTuner, 200,9,5,writearray);
- //printf("\nRegister 9=%d", writearray[0]);
- //printf("\nRegister a=%d", writearray[1]);
- //printf("\nRegister b=%d", writearray[2]);
- //printf("\nRegister d=%d", writearray[4]);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- if (Freq<=82900)
- {
- writearray[0]=0;
- writearray[2]=1;
- }
- else if (Freq<=89900)
- {
- writearray[0]=3;
- writearray[2]=9;
- }
- else if (Freq<=111700)
- {
- writearray[0]=0;
- writearray[2]=1;
- }
- else if (Freq<=118700)
- {
- writearray[0]=3;
- writearray[2]=1;
- }
- else if (Freq<=140500)
- {
- writearray[0]=0;
- writearray[2]=3;
- }
- else if (Freq<=147500)
- {
- writearray[0]=3;
- writearray[2]=11;
- }
- else if (Freq<=169300)
- {
- writearray[0]=0;
- writearray[2]=3;
- }
- else if (Freq<=176300)
- {
- writearray[0]=3;
- writearray[2]=11;
- }
- else if (Freq<=198100)
- {
- writearray[0]=0;
- writearray[2]=3;
- }
- else if (Freq<=205100)
- {
- writearray[0]=3;
- writearray[2]=19;
- }
- else if (Freq<=226900)
- {
- writearray[0]=0;
- writearray[2]=3;
- }
- else if (Freq<=233900)
- {
- writearray[0]=3;
- writearray[2]=3;
- }
- else if (Freq<=350000)
- {
- writearray[0]=0;
- writearray[2]=3;
- }
- else if (Freq<=485600)
- {
- writearray[0]=0;
- writearray[2]=5;
- }
- else if (Freq<=493600)
- {
- writearray[0]=3;
- writearray[2]=5;
- }
- else if (Freq<=514400)
- {
- writearray[0]=0;
- writearray[2]=5;
- }
- else if (Freq<=522400)
- {
- writearray[0]=3;
- writearray[2]=5;
- }
- else if (Freq<=543200)
- {
- writearray[0]=0;
- writearray[2]=5;
- }
- else if (Freq<=551200)
- {
- writearray[0]=3;
- writearray[2]=13;
- }
- else if (Freq<=572000)
- {
- writearray[0]=0;
- writearray[2]=5;
- }
- else if (Freq<=580000)
- {
- writearray[0]=3;
- writearray[2]=13;
- }
- else if (Freq<=600800)
- {
- writearray[0]=0;
- writearray[2]=5;
- }
- else if (Freq<=608800)
- {
- writearray[0]=3;
- writearray[2]=13;
- }
- else if (Freq<=629600)
- {
- writearray[0]=0;
- writearray[2]=5;
- }
- else if (Freq<=637600)
- {
- writearray[0]=3;
- writearray[2]=13;
- }
- else if (Freq<=658400)
- {
- writearray[0]=0;
- writearray[2]=5;
- }
- else if (Freq<=666400)
- {
- writearray[0]=3;
- writearray[2]=13;
- }
- else if (Freq<=687200)
- {
- writearray[0]=0;
- writearray[2]=5;
- }
- else if (Freq<=695200)
- {
- writearray[0]=3;
- writearray[2]=13;
- }
- else if (Freq<=716000)
- {
- writearray[0]=0;
- writearray[2]=5;
- }
- else if (Freq<=724000)
- {
- writearray[0]=3;
- writearray[2]=13;
- }
- else if (Freq<=744800)
- {
- writearray[0]=0;
- writearray[2]=5;
- }
- else if (Freq<=752800)
- {
- writearray[0]=3;
- writearray[2]=21;
- }
- else if (Freq<=773600)
- {
- writearray[0]=0;
- writearray[2]=5;
- }
- else if (Freq<=781600)
- {
- writearray[0]=3;
- writearray[2]=21;
- }
- else if (Freq<=802400)
- {
- writearray[0]=0;
- writearray[2]=5;
- }
- else if (Freq<=810400)
- {
- writearray[0]=3;
- writearray[2]=21;
- }
- else if (Freq<=831200)
- {
- writearray[0]=0;
- writearray[2]=5;
- }
- else if (Freq<=839200)
- {
- writearray[0]=3;
- writearray[2]=21;
- }
- else if (Freq<=860000)
- {
- writearray[0]=0;
- writearray[2]=5;
- }
- else if (Freq<=868000)
- {
- writearray[0]=3;
- writearray[2]=21;
- }
- else
- {
- writearray[0]=0;
- writearray[2]=7;
- }
- status=I2CWriteByte (pTuner, 200,7,writearray[2]);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- status=I2CWriteByte (pTuner, 200,5,writearray[0]);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- return E4000_1_SUCCESS;
- }
- /****************************************************************************\
- * Function: LNAfilter
- *
- * Detailed Description:
- * The function configures the E4000 LNA filter. (Register 0x10).
- *
- \****************************************************************************/
- int LNAfilter(void *pTuner, int Freq)
- {
- unsigned char writearray[5];
- int status;
- if(Freq<=370000)
- {
- writearray[0]=0;
- }
- else if(Freq<=392500)
- {
- writearray[0]=1;
- }
- else if(Freq<=415000)
- {
- writearray[0] =2;
- }
- else if(Freq<=437500)
- {
- writearray[0]=3;
- }
- else if(Freq<=462500)
- {
- writearray[0]=4;
- }
- else if(Freq<=490000)
- {
- writearray[0]=5;
- }
- else if(Freq<=522500)
- {
- writearray[0]=6;
- }
- else if(Freq<=557500)
- {
- writearray[0]=7;
- }
- else if(Freq<=595000)
- {
- writearray[0]=8;
- }
- else if(Freq<=642500)
- {
- writearray[0]=9;
- }
- else if(Freq<=695000)
- {
- writearray[0]=10;
- }
- else if(Freq<=740000)
- {
- writearray[0]=11;
- }
- else if(Freq<=800000)
- {
- writearray[0]=12;
- }
- else if(Freq<=865000)
- {
- writearray[0] =13;
- }
- else if(Freq<=930000)
- {
- writearray[0]=14;
- }
- else if(Freq<=1000000)
- {
- writearray[0]=15;
- }
- else if(Freq<=1310000)
- {
- writearray[0]=0;
- }
- else if(Freq<=1340000)
- {
- writearray[0]=1;
- }
- else if(Freq<=1385000)
- {
- writearray[0]=2;
- }
- else if(Freq<=1427500)
- {
- writearray[0]=3;
- }
- else if(Freq<=1452500)
- {
- writearray[0]=4;
- }
- else if(Freq<=1475000)
- {
- writearray[0]=5;
- }
- else if(Freq<=1510000)
- {
- writearray[0]=6;
- }
- else if(Freq<=1545000)
- {
- writearray[0]=7;
- }
- else if(Freq<=1575000)
- {
- writearray[0] =8;
- }
- else if(Freq<=1615000)
- {
- writearray[0]=9;
- }
- else if(Freq<=1650000)
- {
- writearray[0] =10;
- }
- else if(Freq<=1670000)
- {
- writearray[0]=11;
- }
- else if(Freq<=1690000)
- {
- writearray[0]=12;
- }
- else if(Freq<=1710000)
- {
- writearray[0]=13;
- }
- else if(Freq<=1735000)
- {
- writearray[0]=14;
- }
- else
- {
- writearray[0]=15;
- }
- status=I2CWriteByte (pTuner, 200,16,writearray[0]);
- //printf("\nRegister 10=%d", writearray[0]);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- return E4000_1_SUCCESS;
- }
- /****************************************************************************\
- * Function: IFfilter
- *
- * Detailed Description:
- * The function configures the E4000 IF filter. (Register 0x11,0x12).
- *
- \****************************************************************************/
- int IFfilter(void *pTuner, int bandwidth, int Ref_clk)
- {
- unsigned char writearray[5];
- int status;
- int IF_BW;
- IF_BW = bandwidth / 2;
- if(IF_BW<=2150)
- {
- writearray[0]=253;
- writearray[1]=31;
- }
- else if(IF_BW<=2200)
- {
- writearray[0]=253;
- writearray[1]=30;
- }
- else if(IF_BW<=2240)
- {
- writearray[0]=252;
- writearray[1]=29;
- }
- else if(IF_BW<=2280)
- {
- writearray[0]=252;
- writearray[1]=28;
- }
- else if(IF_BW<=2300)
- {
- writearray[0]=252;
- writearray[1]=27;
- }
- else if(IF_BW<=2400)
- {
- writearray[0]=252;
- writearray[1]=26;
- }
- else if(IF_BW<=2450)
- {
- writearray[0]=252;
- writearray[1]=25;
- }
- else if(IF_BW<=2500)
- {
- writearray[0]=252;
- writearray[1]=24;
- }
- else if(IF_BW<=2550)
- {
- writearray[0]=252;
- writearray[1]=23;
- }
- else if(IF_BW<=2600)
- {
- writearray[0]=252;
- writearray[1]=22;
- }
- else if(IF_BW<=2700)
- {
- writearray[0]=252;
- writearray[1]=21;
- }
- else if(IF_BW<=2750)
- {
- writearray[0]=252;
- writearray[1]=20;
- }
- else if(IF_BW<=2800)
- {
- writearray[0]=252;
- writearray[1]=19;
- }
- else if(IF_BW<=2900)
- {
- writearray[0]=251;
- writearray[1]=18;
- }
- else if(IF_BW<=2950)
- {
- writearray[0]=251;
- writearray[1]=17;
- }
- else if(IF_BW<=3000)
- {
- writearray[0]=251;
- writearray[1]=16;
- }
- else if(IF_BW<=3100)
- {
- writearray[0]=251;
- writearray[1]=15;
- }
- else if(IF_BW<=3200)
- {
- writearray[0]=250;
- writearray[1]=14;
- }
- else if(IF_BW<=3300)
- {
- writearray[0]=250;
- writearray[1]=13;
- }
- else if(IF_BW<=3400)
- {
- writearray[0]=249;
- writearray[1]=12;
- }
- else if(IF_BW<=3600)
- {
- writearray[0]=249;
- writearray[1]=11;
- }
- else if(IF_BW<=3700)
- {
- writearray[0]=249;
- writearray[1]=10;
- }
- else if(IF_BW<=3800)
- {
- writearray[0]=248;
- writearray[1]=9;
- }
- else if(IF_BW<=3900)
- {
- writearray[0]=248;
- writearray[1]=8;
- }
- else if(IF_BW<=4100)
- {
- writearray[0]=248;
- writearray[1]=7;
- }
- else if(IF_BW<=4300)
- {
- writearray[0]=247;
- writearray[1]=6;
- }
- else if(IF_BW<=4400)
- {
- writearray[0]=247;
- writearray[1]=5;
- }
- else if(IF_BW<=4600)
- {
- writearray[0]=247;
- writearray[1]=4;
- }
- else if(IF_BW<=4800)
- {
- writearray[0]=246;
- writearray[1]=3;
- }
- else if(IF_BW<=5000)
- {
- writearray[0]=246;
- writearray[1]=2;
- }
- else if(IF_BW<=5300)
- {
- writearray[0]=245;
- writearray[1]=1;
- }
- else if(IF_BW<=5500)
- {
- writearray[0]=245;
- writearray[1]=0;
- }
- else
- {
- writearray[0]=0;
- writearray[1]=32;
- }
- status=I2CWriteArray(pTuner, 200,17,2,writearray);
- //printf("\nRegister 11=%d", writearray[0]);
- //printf("\nRegister 12=%d", writearray[1]);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- return E4000_1_SUCCESS;
- }
- /****************************************************************************\
- * Function: freqband
- *
- * Detailed Description:
- * Configures the E4000 frequency band. (Registers 0x07, 0x78).
- *
- \****************************************************************************/
- int freqband(void *pTuner, int Freq)
- {
- unsigned char writearray[5];
- int status;
- if (Freq<=140000)
- {
- writearray[0] = 3;
- status=I2CWriteByte(pTuner, 200,120,writearray[0]);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- }
- else if (Freq<=350000)
- {
- writearray[0] = 3;
- status=I2CWriteByte(pTuner, 200,120,writearray[0]);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- }
- else if (Freq<=1000000)
- {
- writearray[0] = 3;
- status=I2CWriteByte(pTuner, 200,120,writearray[0]);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- }
- else
- {
- writearray[0] = 7;
- status=I2CWriteByte(pTuner, 200,7,writearray[0]);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- writearray[0] = 0;
- status=I2CWriteByte(pTuner, 200,120,writearray[0]);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- }
- return E4000_1_SUCCESS;
- }
- /****************************************************************************\
- * Function: DCoffLUT
- *
- * Detailed Description:
- * Populates DC offset LUT. (Registers 0x50 - 0x53, 0x60 - 0x63).
- *
- \****************************************************************************/
- int DCoffLUT(void *pTuner)
- {
- unsigned char writearray[5];
- int status;
- unsigned char read1[1];
- unsigned char IOFF;
- unsigned char QOFF;
- unsigned char RANGE1;
- // unsigned char RANGE2;
- unsigned char QRANGE;
- unsigned char IRANGE;
- writearray[0] = 0;
- writearray[1] = 126;
- writearray[2] = 36;
- status=I2CWriteArray(pTuner, 200,21,3,writearray);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- // Sets mixer & IF stage 1 gain = 00 and IF stg 2+ to max gain.
- writearray[0] = 1;
- status=I2CWriteByte(pTuner, 200,41,writearray[0]);
- // Instructs a DC offset calibration.
- status=I2CReadByte(pTuner, 201,42,read1);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- IOFF=read1[0];
- status=I2CReadByte(pTuner, 201,43,read1);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- QOFF=read1[0];
- status=I2CReadByte(pTuner, 201,44,read1);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- RANGE1=read1[0];
- //reads DC offset values back
- if(RANGE1>=32)
- {
- RANGE1 = RANGE1 -32;
- }
- if(RANGE1>=16)
- {
- RANGE1 = RANGE1 - 16;
- }
- IRANGE=RANGE1;
- QRANGE = (read1[0] - RANGE1) / 16;
- writearray[0] = (IRANGE * 64) + IOFF;
- status=I2CWriteByte(pTuner, 200,96,writearray[0]);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- writearray[0] = (QRANGE * 64) + QOFF;
- status=I2CWriteByte(pTuner, 200,80,writearray[0]);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- // Populate DC offset LUT
- writearray[0] = 0;
- writearray[1] = 127;
- status=I2CWriteArray(pTuner, 200,21,2,writearray);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- // Sets mixer & IF stage 1 gain = 01 leaving IF stg 2+ at max gain.
- writearray[0]= 1;
- status=I2CWriteByte(pTuner, 200,41,writearray[0]);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- // Instructs a DC offset calibration.
- status=I2CReadByte(pTuner, 201,42,read1);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- IOFF=read1[0];
- status=I2CReadByte(pTuner, 201,43,read1);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- QOFF=read1[0];
- status=I2CReadByte(pTuner, 201,44,read1);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- RANGE1=read1[0];
- // Read DC offset values
- if(RANGE1>=32)
- {
- RANGE1 = RANGE1 -32;
- }
- if(RANGE1>=16)
- {
- RANGE1 = RANGE1 - 16;
- }
- IRANGE = RANGE1;
- QRANGE = (read1[0] - RANGE1) / 16;
- writearray[0] = (IRANGE * 64) + IOFF;
- status=I2CWriteByte(pTuner, 200,97,writearray[0]);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- writearray[0] = (QRANGE * 64) + QOFF;
- status=I2CWriteByte(pTuner, 200,81,writearray[0]);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- // Populate DC offset LUT
- writearray[0] = 1;
- status=I2CWriteByte(pTuner, 200,21,writearray[0]);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- // Sets mixer & IF stage 1 gain = 11 leaving IF stg 2+ at max gain.
- writearray[0] = 1;
- status=I2CWriteByte(pTuner, 200,41,writearray[0]);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- // Instructs a DC offset calibration.
- status=I2CReadByte(pTuner, 201,42,read1);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- IOFF=read1[0];
- status=I2CReadByte(pTuner, 201,43,read1);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- QOFF=read1[0];
- status=I2CReadByte(pTuner, 201,44,read1);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- RANGE1 = read1[0];
- // Read DC offset values
- if(RANGE1>=32)
- {
- RANGE1 = RANGE1 -32;
- }
- if(RANGE1>=16)
- {
- RANGE1 = RANGE1 - 16;
- }
- IRANGE = RANGE1;
- QRANGE = (read1[0] - RANGE1) / 16;
- writearray[0] = (IRANGE * 64) + IOFF;
- status=I2CWriteByte(pTuner, 200,99,writearray[0]);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- writearray[0] = (QRANGE * 64) + QOFF;
- status=I2CWriteByte(pTuner, 200,83,writearray[0]);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- // Populate DC offset LUT
- writearray[0] = 126;
- status=I2CWriteByte(pTuner, 200,22,writearray[0]);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- // Sets mixer & IF stage 1 gain = 11 leaving IF stg 2+ at max gain.
- writearray[0] = 1;
- status=I2CWriteByte(pTuner, 200,41,writearray[0]);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- // Instructs a DC offset calibration.
- status=I2CReadByte(pTuner, 201,42,read1);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- IOFF=read1[0];
- status=I2CReadByte(pTuner, 201,43,read1);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- QOFF=read1[0];
- status=I2CReadByte(pTuner, 201,44,read1);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- RANGE1=read1[0];
- // Read DC offset values
- if(RANGE1>=32)
- {
- RANGE1 = RANGE1 -32;
- }
- if(RANGE1>=16)
- {
- RANGE1 = RANGE1 - 16;
- }
- IRANGE = RANGE1;
- QRANGE = (read1[0] - RANGE1) / 16;
- writearray[0]=(IRANGE * 64) + IOFF;
- status=I2CWriteByte(pTuner, 200,98,writearray[0]);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- writearray[0] = (QRANGE * 64) + QOFF;
- status=I2CWriteByte(pTuner, 200,82,writearray[0]);
- // Populate DC offset LUT
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- return E4000_1_SUCCESS;
- }
- /****************************************************************************\
- * Function: GainControlinit
- *
- * Detailed Description:
- * Configures gain control mode. (Registers 0x1a)
- *
- \****************************************************************************/
- int GainControlauto(void *pTuner)
- {
- unsigned char writearray[5];
- int status;
- writearray[0] = 23;
- status=I2CWriteByte(pTuner, 200,26,writearray[0]);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- return E4000_1_SUCCESS;
- }
- /****************************************************************************\
- * Main program
- *
- *
- *
- \****************************************************************************/
- /*
- int main()
- {
- Gainmanual();
- PLL(Ref_clk, Freq);
- LNAfilter(Freq);
- IFfilter(bandwidth, Ref_clk);
- freqband(Freq);
- DCoffLUT();
- GainControlauto();
- return(0);
- }
- */
- // Elonics source code - RT2832_SW_optimisation_rev2.c
- /****************************************************************************\
- * Function: E4000_sensitivity
- *
- * Detailed Description:
- * The function configures the E4000 for sensitivity mode.
- *
- \****************************************************************************/
- int E4000_sensitivity(void *pTuner, int Freq, int bandwidth)
- {
- unsigned char writearray[2];
- int status;
- int IF_BW;
- writearray[1]=0x00;
- if(Freq<=700000)
- {
- writearray[0] = 0x07;
- }
- else
- {
- writearray[0] = 0x05;
- }
- status = I2CWriteArray(pTuner,200,36,1,writearray);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- IF_BW = bandwidth / 2;
- if(IF_BW<=2500)
- {
- writearray[0]=0xfc;
- writearray[1]=0x17;
- }
- else if(IF_BW<=3000)
- {
- writearray[0]=0xfb;
- writearray[1]=0x0f;
- }
- else if(IF_BW<=3500)
- {
- writearray[0]=0xf9;
- writearray[1]=0x0b;
- }
- else if(IF_BW<=4000)
- {
- writearray[0]=0xf8;
- writearray[1]=0x07;
- }
- status = I2CWriteArray(pTuner,200,17,2,writearray);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- return E4000_1_SUCCESS;
- }
- /****************************************************************************\
- * Function: E4000_linearity
- *
- * Detailed Description:
- * The function configures the E4000 for linearity mode.
- *
- \****************************************************************************/
- int E4000_linearity(void *pTuner, int Freq, int bandwidth)
- {
- unsigned char writearray[2];
- int status;
- int IF_BW;
- writearray[1]=0x00;
- if(Freq<=700000)
- {
- writearray[0] = 0x03;
- }
- else
- {
- writearray[0] = 0x01;
- }
- status = I2CWriteArray(pTuner,200,36,1,writearray);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- IF_BW = bandwidth / 2;
- if(IF_BW<=2500)
- {
- writearray[0]=0xfe;
- writearray[1]=0x19;
- }
- else if(IF_BW<=3000)
- {
- writearray[0]=0xfd;
- writearray[1]=0x11;
- }
- else if(IF_BW<=3500)
- {
- writearray[0]=0xfb;
- writearray[1]=0x0d;
- }
- else if(IF_BW<=4000)
- {
- writearray[0]=0xfa;
- writearray[1]=0x0a;
- }
- status = I2CWriteArray(pTuner,200,17,2,writearray);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- return E4000_1_SUCCESS;
- }
- /****************************************************************************\
- * Function: E4000_nominal
- *
- * Detailed Description:
- * The function configures the E4000 for nominal
- *
- \****************************************************************************/
- int E4000_nominal(void *pTuner, int Freq, int bandwidth)
- {
- unsigned char writearray[2];
- int status;
- int IF_BW;
- writearray[1]=0x00;
- if(Freq<=700000)
- {
- writearray[0] = 0x03;
- }
- else
- {
- writearray[0] = 0x01;
- }
- status = I2CWriteArray(pTuner,200,36,1,writearray);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- IF_BW = bandwidth / 2;
- if(IF_BW<=2500)
- {
- writearray[0]=0xfc;
- writearray[1]=0x17;
- }
- else if(IF_BW<=3000)
- {
- writearray[0]=0xfb;
- writearray[1]=0x0f;
- }
- else if(IF_BW<=3500)
- {
- writearray[0]=0xf9;
- writearray[1]=0x0b;
- }
- else if(IF_BW<=4000)
- {
- writearray[0]=0xf8;
- writearray[1]=0x07;
- }
- status = I2CWriteArray(pTuner,200,17,2,writearray);
- if(status != E4000_I2C_SUCCESS)
- {
- return E4000_1_FAIL;
- }
- return E4000_1_SUCCESS;
- }
|