📄 d0361.c
字号:
/* ----------------------------------------------------------------------------
File Name: d0361.c
Description:
stv0361 demod driver.
Copyright (C) 1999-2001 STMicroelectronics
History:
date: 12-Sept-2001
version: 3.1.0
author: GB from work by GJP
comment: rewrite for terrestrial.
Reference:
ST API Definition "TUNER Driver API" DVD-API-06
---------------------------------------------------------------------------- */
/* Includes ---------------------------------------------------------------- */
/* C libs */
#ifdef ST_OSLINUX
#include "stos.h"
#else
#include <string.h>
#include "stlite.h" /* Standard includes */
/* STAPI */
#include "sttbx.h"
#endif
#include "stevt.h"
#include "sttuner.h"
/* local to sttuner */
#include "util.h" /* generic utility functions for sttuner */
#include "dbtypes.h" /* data types for databases */
#include "sysdbase.h" /* functions to accesss system data */
#include "ioarch.h" /* I/O for this driver */
#include "ioreg.h" /* I/O for this driver */
/*#include "chip.h"*/
/* LLA */
#include "361_echo.h"
#include "361_drv.h" /* misc driver functions */
#include "d0361.h" /* header for this file */
#include "361_map.h"
#include "tioctl.h" /* data structure typedefs for all the ter ioctl functions */
#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
U16 STV0361_address[STV361_NBREGS]=
{
0x0000,
0x0001,
0x0002,
0x0003,
0x0004,
0x0005,
0x0006,
0x0007,
0x0008,
0x0009,
0x000a,
0x000b,
0x000c,
0x000d,
0x0010,
0x0011,
0x0012,
0x0013,
0x0014,
0x0015,
0x0016,
0x0017,
0x0018,
0x0019,
0x001a,
0x001b,
0x001c,
0x001d,
0x001e,
0x001f,
0x0020,
0x0021,
0x0022,
0x0023,
0x0024,
0x0025,
0x0026,
0x0027,
0x0028,
0x0029,
0x002a,
0x002b,
0x002c,
0x002d,
0x002e,
0x002f,
0x0030,
0x0031,
0x0032,
0x0033,
0x0034,
0x0035,
0x0036,
0x0080,
0x0081,
0x0082,
0x0083,
0x0084,
0x0085,
0x0086,
0x0087,
0x0088,
0x0089,
0x008a,
0x008b,
0x008c,
0x008d,
0x008e,
0x008f,
0x0090,
0x0091,
0x0092,
0x0093,
0x0094,
0x0095,
0x0096,
0x0097,
0x0098,
0x0099,
0x009a,
0x009b,
0x009c,
0x009d,
0x009e,
0x009f,
0x00a0,
0x00a1,
0x00a2,
0x00a3,
0x00a4,
0x00a5,
0x00a6,
0x00a7,
0x00a8,
0x00a9,
0x00aa,
0x00ab,
0x00ac,
0x00ad,
0x00ae,
0x00af,
0x00b0,
0x00b1,
0x00b2,
0x00b3,
0x00b4,
0x00b5,
0x00b6,
0x00b7,
0x00b8,
0x00b9,
0x00ba,
0x00bb,
0x00bc,
0x00bd,
0x00be,
0x00bf,
0x0040,
0x0041,
0x0042,
0x0043,
0x0044,
0x0045,
0x0046,
0x0047,
0x0049,
0x004a,
0x004b,
0x004c,
0x004d,
0x004e,
0x004f,
0x0050,
0x0051,
0x0052,
0x0053,
0x0054,
0x0055,
0x0056,
0x0057,
0x0058,
0x0059,
0x005a,
0x005b,
0x005c,
0x005d,
0x005e,
0x005f,
0x00c0,
0x00c1,
0x00c2,
0x00c3,
0x00c4,
0x00c5,
0x00c6,
0x00c7,
0x00c8,
0x00c9,
0x00ca,
0x00cb,
0x00cc,
0x00cd,
0x00ce,
0x00cf,
0x00d0,
0x00d1,
0x00d2,
0x00d3,
0x00d4,
0x00d5,
0x00d6,
0x00db,
0x00d8,
0x00d9,
0x00da,
0x00d7,
0x00dc
};
/*******Never change the order of this array elements as it is accordance with******
******361_init.c settings of register.*********************/
/****** Register settings for DemodSTV0361*************/
#ifdef STTUNER_TERR_TMM_6MHZ
U8 Def361Val[STV361_NBREGS]={
/*R_ID*/ 0x30,
/*R_I2CRPT*/ 0x22,
/*R_TOPCTRL*/ 0x02,
/*R_IOCFG0*/ 0x40,
/*R_DAC0R*/ 0x00,
/*R_IOCFG1*/ 0x40,
/*R_DAC1R*/ 0x00,
/*R_IOCFG2*/ 0x80,
/*R_SDFR*/ 0x00,
/*R_STATUS*/ 0xF9,
/*R_AUX_CLK*/ 0x1C,
/*R_RESERVED_1*/ 0x00,
/*R_RESERVED_2*/ 0x00,
/*R_RESERVED_3*/ 0x00,
/*R_AGC2MAX*/ 0x8C,
/*R_AGC2MIN*/ 0x14,
/*R_AGC1MAX*/ 0xFF,
/*R_AGC1MIN*/ 0x6B,
/*R_AGCR*/ 0xBC,
/*R_AGC2TH*/ 0x50,
/*R_AGC12C*/ 0x40,
/*R_AGCCTRL1*/ 0x85,
/*R_AGCCTRL2*/ 0x18,
/*R_AGC1VAL1*/ 0xFF,
/*R_AGC1VAL2*/ 0x0F,
/*R_AGC2VAL1*/ 0xFA,
/*R_AGC2VAL2*/ 0x01,
/*R_AGC2PGA*/ 0x00,
/*R_OVF_RATE1*/ 0x00,
/*R_OVF_RATE2*/ 0x00,
/*R_GAIN_SRC1*/ 0xFD,
/*R_GAIN_SRC2*/ 0xAC,
/*R_INC_DEROT1*/ 0x55,
/*R_INC_DEROT2*/ 0x4B,
/*R_PPM_CPAMP_DIR*/ 0x2C, /*0x5D*/
/*R_PPM_CPAMP_INV*/ 0x00,
/*R_FREESTFE_1*/ 0x03,
/*R_FREESTFE_2*/ 0x1C,
/*R_DCOFFSET*/ 0x06,
/*R_EN_PROCESS*/ 0x01,
/*R_RESERVED_4*/ 0xFF,
/*R_RESERVED_5*/ 0x00,
/*R_RESERVED_6*/ 0x80,
/*R_RESERVED_7*/ 0x1D,
/*R_RESERVED_8*/ 0x29,
/*R_RESERVED_9*/ 0x14,
/*R_RESERVED_10*/ 0xFE,
/*R_EPQ*/ 0x02,
/*R_EPQAUTO*/ 0x01,
/*R_CHP_TAPS*/ 0x03,/* 0x01 for 2k mode and 0x03 for 8K mode*/
/*R_CHP_DYN_COEFF*/ 0x00,
/*R_PPM_STATE_MAC*/ 0x23,
/*R_INR_THRESHOLD*/ 0x09,
/*R_COR_CTL*/ 0x20,
/*R_COR_STAT*/ 0xF6,
/*R_COR_INTEN*/ 0x00,
/*R_COR_INTSTAT*/ 0x3D,
/*R_COR_MODEGUARD*/ 0x00,
/*R_AGC_CTL*/ 0x18,
/*R_RESERVED_11*/ 0x00,
/*R_RESERVED_12*/ 0x00,
/*R_AGC_TARGET*/ 0x1E,
/*R_AGC_GAIN1*/ 0xFB,
/*R_AGC_GAIN2*/ 0x1A,
/*R_RESERVED_13*/ 0x00,
/*R_RESERVED_14*/ 0x00,
/*R_RESERVED_15*/ 0x00,
/*R_CAS_CTL*/ 0x40,
/*R_CAS_FREQ*/ 0xB3,
/*R_CAS_DAGCGAIN*/ 0x10,
/*R_SYR_CTL*/ 0x04,
/*R_SYR_STAT*/ 0x13,
/*R_RESERVED_16*/ 0x00,
/*R_RESERVED_17*/ 0x00,
/*R_SYR_OFFSET1*/ 0x00,
/*R_SYR_OFFSET2*/ 0x00,
/*R_RESERVED_18*/ 0x00,
/*R_SCR_CTL*/ 0x00,
/*R_PPM_CTL1*/ 0x38,
/*R_TRL_CTL*/ 0x94,/* 0x14 */
/*R_TRL_NOMRATE1*/ 0xAB, /*0xAC*/
/*R_TRL_NOMRATE2*/ 0x56,
/*R_TRL_TIME1*/ 0x3C,
/*R_TRL_TIME2*/ 0x01,
/*R_CRL_CTL*/ 0x4F,
/*R_CRL_FREQ1*/ 0x30,
/*R_CRL_FREQ2*/ 0xBE,
/*R_CRL_FREQ3*/ 0xFE,
/*R_CHC_CTL1*/ 0x11,
/*R_CHC_SNR*/ 0xC3,
/*R_BDI_CTL*/ 0x00,
/*R_DMP_CTL*/ 0x00,
/*R_TPS_RCVD1*/ 0x31,
/*R_TPS_RCVD2*/ 0x02,
/*R_TPS_RCVD3*/ 0x01,
/*R_TPS_RCVD4*/ 0x30,
/*R_TPS_ID_CELL1*/ 0x00,
/*R_TPS_ID_CELL2*/ 0x00,
/*R_RESERVED_19*/ 0x01,
/*R_RESERVED_20*/ 0x02,
/*R_RESERVED_21*/ 0x02,
/*R_TPS_CTL*/ 0x00,
/*R_CTL_FFTOSNUM*/ 0x10,
/*R_TESTSELECT*/ 0x0C,
/*R_MSC_REV*/ 0x0A,
/*R_PIR_CTL*/ 0x00,
/*R_SNR_CARRIER1*/ 0xA9,
/*R_SNR_CARRIER2*/ 0x86,
/*R_RESERVED_22*/ 0x30,
/*R_RESERVED_23*/ 0x00,
/*R_RESERVED_24*/ 0x00,
/*R_RESERVED_25*/ 0x00,
/*R_RESERVED_26*/ 0x00,
/*R_RESERVED_27*/ 0x00,
/*R_RESERVED_28*/ 0x00,
/*R_RESERVED_29*/ 0x00,
/*R_RESERVED_30*/ 0x00,
/*R_RESERVED_31*/ 0x00,
/*R_VTH0*/ 0x1E,
/*R_VTH1*/ 0x14,
/*R_VTH2*/ 0x0F,
/*R_VTH3*/ 0x09,
/*R_RESERVED_32*/ 0x00,
/*R_VTH5*/ 0x05,
/*R_RESERVED_33*/ 0x00,
/*R_VITPROG*/ 0x92,
/*R_PR*/ 0xAF,
/*R_VSEARCH*/ 0x30,
/*R_RS*/ 0xBC,
/*R_RSOUT*/ 0x05,
/*R_ERRCTRL1*/ 0x12,
/*R_ERRCNTM1*/ 0x00,
/*R_ERRCNTL1*/ 0x00,
/*R_ERRCTRL2*/ 0xB3,
/*R_ERRCNTM2*/ 0x00,
/*R_ERRCNTL2*/ 0x00,
/*R_RESERVED_34*/ 0x00,
/*R_VERROR*/ 0x00,
/*R_ERRCTRL3*/ 0x12,
/*R_ERRCNTM3*/ 0x00,
/*R_ERRCNTL3*/ 0x00,
/*R_RESERVED_35*/ 0x00,
/*R_RESERVED_36*/ 0x03,
/*R_RESERVED_37*/ 0x00,
/*R_RESERVED_38*/ 0x03,
/*R_LNBRX*/ 0x80, /*0xC0*/
/*R_RESERVED_39*/ 0xB0,
/*R_RESERVED_40*/ 0x07,
/*R_RESERVED_41*/ 0x00,
/*R_ANACTRL*/ 0x00,
/*R_RESERVED_42*/ 0x00,
/*R_RESERVED_43*/ 0x00,
/*R_RESERVED_44*/ 0x00,
/*R_RESERVED_45*/ 0x00,
/*R_RESERVED_46*/ 0x00,
/*R_RESERVED_47*/ 0x00,
/*R_RESERVED_48*/ 0x00,
/*R_RESERVED_49*/ 0x00,
/*R_RESERVED_50*/ 0x00,
/*R_CONSTMODE*/ 0x02,
/*R_CONSTCARR1*/ 0xD2,
/*R_CONSTCARR2*/ 0x04,
/*R_ICONSTEL*/ 0xDB,
/*R_QCONSTEL*/ 0x8,
/*R_RESERVED_51*/ 0x00,
/*R_RESERVED_52*/ 0x00,
/*R_RESERVED_53*/ 0x00,
/*R_RESERVED_54*/ 0x00,
/*R_RF_AGC1*/ 0x81,
/*R_RF_AGC2*/ 0x80,
/*R_RESERVED_55*/ 0x08,
/*R_ANACTRL2*/ 0x00,
/*R_PLLMDIV*/ 0x00,
/*R_PLLNDIV*/ 0x03,
/*R_PLLSETUP*/ 0x17,
/*R_ANADIGCTRL*/ 0x00,
/*R_TSTBIST*/ 0x00
};/** end of array TMM6MHZ**/
#elif defined (STTUNER_TERR_TMM_7MHZ)
U8 Def361Val[STV361_NBREGS]={
/*R_ID*/ 0x30,
/*R_I2CRPT*/ 0x22,
/*R_TOPCTRL*/ 0x02,
/*R_IOCFG0*/ 0x40,
/*R_DAC0R*/ 0x00,
/*R_IOCFG1*/ 0x40,
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -