⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 d0mini360.c

📁 st7710的tuner标准驱动
💻 C
📖 第 1 页 / 共 4 页
字号:
/*R_COR_STAT*/       0xf6,
/*R_COR_INTEN*/      0x00,

/*R_COR_INTSTAT*/    0x3d,
/*R_COR_MODEGUARD*/  0x3,
/*R_AGC_CTL*/        0x18,
/*R_AGC_MANUAL1*/    0x00,
/*R_AGC_MANUAL2*/    0x00,

/*R_AGC_TARGET*/     0x20,
/*R_AGC_GAIN1*/      0x9,
/*R_AGC_GAIN2*/      0x10,
/*R_ITB_CTL*/        0x00,
/*R_ITB_FREQ1*/      0x00,

/*R_ITB_FREQ2*/      0x00,
/*R_CAS_CTL*/        0x85,
/*R_CAS_FREQ*/       0xB3,
/*R_CAS_DAGCGAIN*/   0x10,
/*R_SYR_CTL*/        0x00,

/*R_SYR_STAT*/       0x17,
/*R_SYR_NC01*/       0x00,
/*R_SYR_NC02*/       0x00,
/*R_SYR_OFFSET1*/    0x00,
/*R_SYR_OFFSET2*/    0x00,

/*R_FFT_CTL*/        0x00,
/*R_SCR_CTL*/        0x00,
/*R_PPM_CTL1*/       0x30,
/*R_TRL_CTL*/        0x94,
/*R_TRL_NOMRATE1*/   0xb0,

/*R_TRL_NOMRATE2*/   0x56,
/*R_TRL_TIME1*/      0xee,
/*R_TRL_TIME2*/      0xfd,
/*R_CRL_CTL*/        0x4F,
/*R_CRL_FREQ1*/      0x90,

/*R_CRL_FREQ2*/      0x9b,
/*R_CRL_FREQ3*/      0x0,
/*R_CHC_CTL1*/       0xb1,
/*R_CHC_SNR*/        0xd7,
/*R_BDI_CTL*/        0x00,

/*R_DMP_CTL*/        0x00,
/*R_TPS_RCVD1*/      0x32,
/*R_TPS_RCVD2*/      0x2,
/*R_TPS_RCVD3*/      0x01,
/*R_TPS_RCVD4*/      0x31,

/*R_TPS_CELLID*/     0x00,
/*R_TPS_FREE2*/      0x00,
/*R_TPS_SET1*/       0x01,
/*R_TPS_SET2*/       0x02,
/*R_TPS_SET3*/       0x4,

/*R_TPS_CTL*/        0x00,
/*R_CTL_FFTOSNUM*/   0x2b,
/*R_CAR_DISP_SEL*/   0x0C,
/*R_MSC_REV*/        0x0A,
/*R_PIR_CTL*/        0x00,

/*R_SNR_CARRIER1*/   0xA8,
/*R_SNR_CARRIER2*/   0x86,
/*R_PPM_CPAMP*/      0xcc,
/*R_TSM_AP0*/        0x00,
/*R_TSM_AP1*/        0x00,

/*R_TSM_AP2*/        0x00,
/*R_TSM_AP3*/        0x00,
/*R_TSM_AP4*/        0x00,
/*R_TSM_AP5*/        0x00,
/*R_TSM_AP6*/        0x00,

/*R_TSM_AP7*/        0x00,
/*R_CONSTMODE*/      0x02,
/*R_CONSTCARR1*/     0xD2,
/*R_CONSTCARR2*/     0x04,
/*R_ICONSTEL*/       0xf7,

/*R_QCONSTEL*/       0xf8,
/*R_AGC1RF*/         0xff,
/*R_EN_RF_AGC1*/     0x83,
/*R_FECM*/           0x00,
/*R_VTH0*/           0x1E,

/*R_VTH1*/           0x1e,
/*R_VTH2*/           0x0F,
/*R_VTH3*/           0x09,
/*R_VTH4*/           0x00,
/*R_VTH5*/           0x05,

/*R_FREEVIT*/        0x00,
/*R_VITPROG*/        0x92,
/*R_PR*/             0x2,
/*R_VSEARCH*/        0xb0,
/*R_RS*/             0xbc,

/*R_RSOUT*/          0x15,
/*R_ERRCTRL1*/       0x12,
/*R_ERRCNTM1*/       0x00,
/*R_ERRCNTL1*/       0x00,
/*R_ERRCTRL2*/       0x12,

/*R_ERRCNTM2*/       0x00,
/*R_ERRCNTL2*/       0x00,
/*R_ERRCTRL3*/       0x12,
/*R_ERRCNTM3*/       0x00,
/*R_ERRCNTL3*/       0x00,

/*R_DILSTK1*/        0x00,
/*R_DILSTK0*/        0x03,
/*R_DILBWSTK1*/      0x00,
/*R_DILBWST0*/       0x03,
/*R_LNBRX*/          0x80,

/*R_RSTC*/           0xB0,
/*R_VIT_BIST*/       0x07,
/*R_FREEDRS*/        0x00,
/*R_VERROR*/         0x00,
/*R_TSTRES*/         0x00,

/*R_ANACTRL*/        0x00,
/*R_TSTBUS*/         0x00,
/*R_TSTCK*/          0x00,
/*R_TSTI2C*/         0x00,
/*R_TSTRAM1*/        0x00,

/*R_TSTRATE*/        0x00,
/*R_SELOUT*/         0x00,
/*R_FORCEIN*/        0x00,
/*R_TSTFIFO*/        0x00,
/*R_TSTRS*/          0x00,

/*R_TSTBISTRES0*/    0x00,
/*R_TSTBISTRES1*/    0x00,
/*R_TSTBISTRES2*/    0x00,
/*R_TSTBISTRES3*/    0x00

	        };/** end of array TMM8MHZ**/
#else
const U8 Def360Val[STV360_NBREGS]={
/*R_ID*/             0x21, 
/*R_I2CRPT*/         0x27, 
/*R_TOPCTRL*/        0x2 ,
/*R_IOCFG0*/         0x40, 
/*R_DAC0R*/          0x00, 

/*R_IOCFG1*/         0x00, 
/*R_DAC1R*/          0x00, 
/*R_IOCFG2*/         0x80, 
/*R_PWMFR*/          0x00,
/*R_STATUS*/         0xf9,

/*R_AUX_CLK*/        0x1c,
/*R_FREESYS1*/       0x00,
/*R_FREESYS2*/       0x00,
/*R_FREESYS3*/       0x00,
/*R_AGC2MAX*/        0xFF, 

/*R_AGC2MIN*/        0x28, 
/*R_AGC1MAX*/        0xff, 
/*R_AGC1MIN*/        0x6b, 
/*R_AGCR*/           0xbc, 
/*R_AGC2TH*/         0x0c, 

/*R_AGC12C3*/        0x00,
/*R_AGCCTRL1*/       0x85, 
/*R_AGCCTRL2*/       0x1f,
/*R_AGC1VAL1*/       0xff,
/*R_AGC1VAL2*/       0xf,

/*R_AGC2VAL1*/       0xff, 
/*R_AGC2VAL2*/       0x0f, 
/*R_AGC2PGA*/        0x00, 
/*R_OVF_RATE1*/      0x00, 
/*R_OVF_RATE2*/      0x00, 

/*R_GAIN_SRC1*/      0xca, 
/*R_GAIN_SRC2*/      0x41,
/*R_INC_DEROT1*/     0x55,
/*R_INC_DEROT2*/     0x53,
/*R_FREESTFE_1*/     0x03,

/*R_SYR_THR*/        0x1c,
/*R_INR*/            0xff, 
/*R_EN_PROCESS*/     0x1, 
/*R_SDI_SMOOTHER*/   0xff, 
/*R_FE_LOOP_OPEN*/   0x00, 

/*R_EPQ*/            0x00, 
/*R_EPQ2*/           0x15,
/*R_COR_CTL*/        0x20,
/*R_COR_STAT*/       0xf6,
/*R_COR_INTEN*/      0x00,

/*R_COR_INTSTAT*/    0x3F,
/*R_COR_MODEGUARD*/  0x3,
/*R_AGC_CTL*/        0x18,
/*R_AGC_MANUAL1*/    0x00,
/*R_AGC_MANUAL2*/    0x00,

/*R_AGC_TARGET*/     0x28,
/*R_AGC_GAIN1*/      0xFF,
/*R_AGC_GAIN2*/      0x17,
/*R_ITB_CTL*/        0x00,
/*R_ITB_FREQ1*/      0x00,

/*R_ITB_FREQ2*/      0x00,
/*R_CAS_CTL*/        0x40,
/*R_CAS_FREQ*/       0xB3,
/*R_CAS_DAGCGAIN*/   0x10,
/*R_SYR_CTL*/        0x00,

/*R_SYR_STAT*/       0x13,
/*R_SYR_NC01*/       0x00,
/*R_SYR_NC02*/       0x00,
/*R_SYR_OFFSET1*/    0x00,
/*R_SYR_OFFSET2*/    0x00,

/*R_FFT_CTL*/        0x00,
/*R_SCR_CTL*/        0x00,
/*R_PPM_CTL1*/       0x30,
/*R_TRL_CTL*/        0x94,
/*R_TRL_NOMRATE1*/   0x4d,

/*R_TRL_NOMRATE2*/   0x55,
/*R_TRL_TIME1*/      0xc1,
/*R_TRL_TIME2*/      0xF8,
/*R_CRL_CTL*/        0x4F,
/*R_CRL_FREQ1*/      0xdc,

/*R_CRL_FREQ2*/      0xf1,
/*R_CRL_FREQ3*/      0xff,
/*R_CHC_CTL1*/       0x01,
/*R_CHC_SNR*/        0xE8,
/*R_BDI_CTL*/        0x60,

/*R_DMP_CTL*/        0x00,
/*R_TPS_RCVD1*/      0x32,
/*R_TPS_RCVD2*/      0x2,
/*R_TPS_RCVD3*/      0x01,
/*R_TPS_RCVD4*/      0x30,

/*R_TPS_CELLID*/     0x00,
/*R_TPS_FREE2*/      0x00,
/*R_TPS_SET1*/       0x01,
/*R_TPS_SET2*/       0x02,
/*R_TPS_SET3*/       0x01,

/*R_TPS_CTL*/        0x00,
/*R_CTL_FFTOSNUM*/   0x27,
/*R_CAR_DISP_SEL*/   0x0C,
/*R_MSC_REV*/        0x0A,
/*R_PIR_CTL*/        0x00,

/*R_SNR_CARRIER1*/   0xA8,
/*R_SNR_CARRIER2*/   0x86,
/*R_PPM_CPAMP*/      0x2C,
/*R_TSM_AP0*/        0x00,
/*R_TSM_AP1*/        0x00,

/*R_TSM_AP2*/        0x00,
/*R_TSM_AP3*/        0x00,
/*R_TSM_AP4*/        0x00,
/*R_TSM_AP5*/        0x00,
/*R_TSM_AP6*/        0x00,

/*R_TSM_AP7*/        0x00,
/*R_CONSTMODE*/      0x02,
/*R_CONSTCARR1*/     0xD2,
/*R_CONSTCARR2*/     0x04,
/*R_ICONSTEL*/       0xDC,

/*R_QCONSTEL*/       0xDB,
/*R_AGC1RF*/         0xAB,
/*R_EN_RF_AGC1*/     0x03,
/*R_FECM*/           0x00,
/*R_VTH0*/           0x1E,

/*R_VTH1*/           0x14,
/*R_VTH2*/           0x0F,
/*R_VTH3*/           0x09,
/*R_VTH4*/           0x00,
/*R_VTH5*/           0x05,

/*R_FREEVIT*/        0x00,
/*R_VITPROG*/        0x92,
/*R_PR*/             0xAF,
/*R_VSEARCH*/        0x30,
/*R_RS*/             0xFE,

/*R_RSOUT*/          0x15,
/*R_ERRCTRL1*/       0x12,
/*R_ERRCNTM1*/       0x00,
/*R_ERRCNTL1*/       0x00,
/*R_ERRCTRL2*/       0x12,

/*R_ERRCNTM2*/       0x00,
/*R_ERRCNTL2*/       0x00,
/*R_ERRCTRL3*/       0x12,
/*R_ERRCNTM3*/       0x00,
/*R_ERRCNTL3*/       0x00,

/*R_DILSTK1*/        0x00,
/*R_DILSTK0*/        0x0C,
/*R_DILBWSTK1*/      0x00,
/*R_DILBWST0*/       0x03,
/*R_LNBRX*/          0x80,

/*R_RSTC*/           0xB0,
/*R_VIT_BIST*/       0x07,
/*R_FREEDRS*/        0x00,
/*R_VERROR*/         0x00,
/*R_TSTRES*/         0x00,

/*R_ANACTRL*/        0x00,
/*R_TSTBUS*/         0x00,
/*R_TSTCK*/          0x00,
/*R_TSTI2C*/         0x00,
/*R_TSTRAM1*/        0x00,

/*R_TSTRATE*/        0x00,
/*R_SELOUT*/         0x00,
/*R_FORCEIN*/        0x00,
/*R_TSTFIFO*/        0x00,
/*R_TSTRS*/          0x00,

/*R_TSTBISTRES0*/    0x00,
/*R_TSTBISTRES1*/    0x00,
/*R_TSTBISTRES2*/    0x00,
/*R_TSTBISTRES3*/    0x00

	        };/** end of array**/
#endif	        

#ifdef STTUNER_MINIDRIVER
const U8 SubAddrIndex[13]={
0x00,0x10,0x26,0x31,0x80,0xCB,0xD4,0x40,0x49,0x56,0x54,0xC0,0xD0 };

const U8 SizeIndex[13]={
14,20,6,2,64,5,2,8,11,10,2,11,4 }; 
#endif        
/* Private types/constants ------------------------------------------------ */

#define ANALOG_CARRIER_DETECT_SYMBOL_RATE   5000000
#define ANALOG_CARRIER_DETECT_AGC2_VALUE    25

/* Device capabilities */
#define MAX_AGC                         4095 /*fix for DDTS 33979 "AGC calculations for STV0360"*/
#define MAX_SIGNAL_QUALITY              100
#define MAX_BER                         200000
#define STCHIP_HANDLE(x) ((STCHIP_InstanceData_t *)x)

#ifdef ST_OS21
#define WAIT_N_MS(X)     task_delay( (signed int)(X * (ST_GetClocksPerSecond() / 1000)) )   /*task_delay(X)*/
#else
#define WAIT_N_MS(X)     task_delay( (unsigned int)(X * (ST_GetClocksPerSecond() / 1000)) )   /*task_delay(X)*/
#endif

/* private variables ------------------------------------------------------- */
#ifdef ST_OS21
static semaphore_t *Lock_InitTermOpenClose; /* guard calls to the functions */
#else
static semaphore_t Lock_InitTermOpenClose; /* guard calls to the functions */
#endif
/*ifndef STTUNER_MINIDRIVER
static BOOL        Installed = FALSE;	*/



/* instance chain, the default boot value is invalid, to catch errors */
/* static D0360_InstanceData_t *InstanceChainTop = (D0360_InstanceData_t *)0x7fffffff;
endif	  */

D0360_InstanceData_t *DEMODInstance;

/* functions --------------------------------------------------------------- */

int FE_360_PowOf2(int number);

/* API */
/*ST_ErrorCode_t demod_d0360_Init(ST_DeviceName_t *DeviceName, DEMOD_InitParams_t *InitParams);
ST_ErrorCode_t demod_d0360_Term(ST_DeviceName_t *DeviceName, DEMOD_TermParams_t *TermParams);

ST_ErrorCode_t demod_d0360_Open (ST_DeviceName_t *DeviceName, DEMOD_OpenParams_t  *OpenParams, DEMOD_Capability_t *Capability, DEMOD_Handle_t *Handle);
ST_ErrorCode_t demod_d0360_Close(DEMOD_Handle_t  Handle, DEMOD_CloseParams_t *CloseParams);

ST_ErrorCode_t demod_d0360_GetTunerInfo    (DEMOD_Handle_t Handle, STTUNER_TunerInfo_t *TunerInfo_p);
ST_ErrorCode_t demod_d0360_GetSignalQuality(DEMOD_Handle_t Handle, U32  *SignalQuality_p, U32 *Ber);
ST_ErrorCode_t demod_d0360_GetModulation   (DEMOD_Handle_t Handle, STTUNER_Modulation_t *Modulation);
ST_ErrorCode_t demod_d0360_GetAGC          (DEMOD_Handle_t Handle, S16                  *Agc);
ST_ErrorCode_t demod_d0360_GetMode         (DEMOD_Handle_t Handle, STTUNER_Mode_t       *Mode);
ST_ErrorCode_t demod_d0360_GetGuard        (DEMOD_Handle_t Handle, STTUNER_Guard_t      *Guard);
ST_ErrorCode_t demod_d0360_GetFECRates     (DEMOD_Handle_t Handle, STTUNER_FECRate_t    *FECRates);
ST_ErrorCode_t demod_d0360_IsLocked        (DEMOD_Handle_t Handle, BOOL                 *IsLocked);
ST_ErrorCode_t demod_d0360_Tracking        (DEMOD_Handle_t Handle, BOOL ForceTracking,   U32 *NewFrequency, BOOL *SignalFound);
ST_ErrorCode_t demod_d0360_ScanFrequency   (DEMOD_Handle_t  Handle,
                                            U32  InitialFrequency,
                                            U32  SymbolRate,
                                            U32  MaxOffset,
                                            U32  TunerStep,
                                            U8   DerotatorStep,
                                            BOOL *ScanSuccess,
                                            U32  *NewFrequency,
                                            U32  Mode,
                                            U32  Guard,
                                            U32  Force,
                                            U32  Hierarchy,
                                            U32  Spectrum,
                                            U32  FreqOff,
                                            U32  ChannelBW,
                                            S32  EchoPos);*/
ST_ErrorCode_t demod_d0360_ioctl           (DEMOD_Handle_t Handle, U32 Function, void *InParams, void *OutParams,
                                             STTUNER_Da_Status_t *Status);
ST_ErrorCode_t demod_d0360_GetRFLevel(DEMOD_Handle_t Handle, S32  *Rflevel);

ST_ErrorCode_t demod_d0360_GetTPSCellId(DEMOD_Handle_t Handle, U16  *TPSCellId);

/* For STANDBY API mode */ 
ST_ErrorCode_t demod_d0360_StandByMode(DEMOD_Handle_t Handle, STTUNER_StandByMode_t PowerMode);

/* I/O API */
ST_ErrorCode_t demod_d0360_ioaccess(DEMOD_Handle_t Handle, IOARCH_Handle_t IOHandle,
                  STTUNER_IOARCH_Operation_t Operation, U16 SubAddr, U8 *Data, U32 TransferSize, U32 Timeout);

/* local functions --------------------------------------------------------- */

D0360_InstanceData_t *D0360_GetInstFromHandle(DEMOD_Handle_t Handle);


/* ------------------------------------------------------------------------- */
/* /\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\ API /\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\ */
/* ------------------------------------------------------------------------- */



/* ----------------------------------------------------------------------------
Name: demod_d0360_Init()

Description:

Parameters:

Return Value:
---------------------------------------------------------------------------- */
ST_ErrorCode_t demod_d0360_Init(ST_DeviceName_t *DeviceName, DEMOD_InitParams_t *InitParams)
{
#ifdef STTUNER_DEBUG_MODULE_TERDRV_D0360
    const char *identity = "STTUNER d0360.c demod_d0360_Init()";
#endif
    ST_ErrorCode_t Error = ST_NO_ERROR;
    #ifdef ST_OS21    
	    Lock_InitTermOpenClose = semaphore_create_fifo(1);
	#else
	    semaphore_init_fifo(&Lock_InitTermOpenClose, 1);
	#endif   
/* now safe to lock semaphore */
    SEM_LOCK(Lock_InitTermOpenClose);
    DEMODInstance = memory_allocate_clear(InitParams->MemoryPartition, 1, sizeof( D0360_InstanceData_t ));
    if (DEMODInstance == NULL)
    {
#ifdef STTUNER_DEBUG_MODULE_TERDRV_D0360
        STTBX_Print(("%s fail memory allocation InstanceNew\n", identity));
#endif    
        SEM_UNLOCK(Lock_InitTermOpenClose);
        return(ST_ERROR_NO_MEMORY);           
    }

    /*DEMODInstance->DeviceName          = DeviceName;*/
    DEMODInstance->TopLevelHandle      = STTUNER_MAX_HANDLES;
    DEMODInstance->IOHandle            = InitParams->IOHandle;
    DEMODInstance->MemoryPartition     = InitParams->MemoryPartition;
    /*DEMODInstance->InstanceChainNext   = NULL; Checknab*/ /* always last in the chain */

    DEMODInstance->ExternalClock       = InitParams->ExternalClock;
    DEMODInstance->TSOutputMode        = InitParams->TSOutputMode;
    DEMODInstance->SerialDataMode      = InitParams->SerialDataMode;
    DEMODInstance->SerialClockSource   = InitParams->SerialClockSource;
    DEMODInstance->FECMode             = InitParams->FECMode;
    DEMODInstance->ClockPolarity       = InitParams->ClockPolarity;


    
    switch(DEMODInstance->TSOutputMode)
    {
        case STTUNER_TS_MODE_DEFAULT:
        case STTUNER_TS_MODE_PARALLEL:
            DEMODInstance->FE_360_InitParams.Clock = FE_PARALLEL_CLOCK;
            break;

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -