📄 d0mini360.c
字号:
/*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 + -