1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-2.0-or-later */ 2*4882a593Smuzhiyun /* 3*4882a593Smuzhiyun * Driver for Zarlink DVB-T MT352 demodulator 4*4882a593Smuzhiyun * 5*4882a593Smuzhiyun * Written by Holger Waechtler <holger@qanu.de> 6*4882a593Smuzhiyun * and Daniel Mack <daniel@qanu.de> 7*4882a593Smuzhiyun * 8*4882a593Smuzhiyun * AVerMedia AVerTV DVB-T 771 support by 9*4882a593Smuzhiyun * Wolfram Joost <dbox2@frokaschwei.de> 10*4882a593Smuzhiyun * 11*4882a593Smuzhiyun * Support for Samsung TDTC9251DH01C(M) tuner 12*4882a593Smuzhiyun * Copyright (C) 2004 Antonio Mancuso <antonio.mancuso@digitaltelevision.it> 13*4882a593Smuzhiyun * Amauri Celani <acelani@essegi.net> 14*4882a593Smuzhiyun * 15*4882a593Smuzhiyun * DVICO FusionHDTV DVB-T1 and DVICO FusionHDTV DVB-T Lite support by 16*4882a593Smuzhiyun * Christopher Pascoe <c.pascoe@itee.uq.edu.au> 17*4882a593Smuzhiyun */ 18*4882a593Smuzhiyun 19*4882a593Smuzhiyun #ifndef _MT352_PRIV_ 20*4882a593Smuzhiyun #define _MT352_PRIV_ 21*4882a593Smuzhiyun 22*4882a593Smuzhiyun #define ID_MT352 0x13 23*4882a593Smuzhiyun 24*4882a593Smuzhiyun #define msb(x) (((x) >> 8) & 0xff) 25*4882a593Smuzhiyun #define lsb(x) ((x) & 0xff) 26*4882a593Smuzhiyun 27*4882a593Smuzhiyun enum mt352_reg_addr { 28*4882a593Smuzhiyun STATUS_0 = 0x00, 29*4882a593Smuzhiyun STATUS_1 = 0x01, 30*4882a593Smuzhiyun STATUS_2 = 0x02, 31*4882a593Smuzhiyun STATUS_3 = 0x03, 32*4882a593Smuzhiyun STATUS_4 = 0x04, 33*4882a593Smuzhiyun INTERRUPT_0 = 0x05, 34*4882a593Smuzhiyun INTERRUPT_1 = 0x06, 35*4882a593Smuzhiyun INTERRUPT_2 = 0x07, 36*4882a593Smuzhiyun INTERRUPT_3 = 0x08, 37*4882a593Smuzhiyun SNR = 0x09, 38*4882a593Smuzhiyun VIT_ERR_CNT_2 = 0x0A, 39*4882a593Smuzhiyun VIT_ERR_CNT_1 = 0x0B, 40*4882a593Smuzhiyun VIT_ERR_CNT_0 = 0x0C, 41*4882a593Smuzhiyun RS_ERR_CNT_2 = 0x0D, 42*4882a593Smuzhiyun RS_ERR_CNT_1 = 0x0E, 43*4882a593Smuzhiyun RS_ERR_CNT_0 = 0x0F, 44*4882a593Smuzhiyun RS_UBC_1 = 0x10, 45*4882a593Smuzhiyun RS_UBC_0 = 0x11, 46*4882a593Smuzhiyun AGC_GAIN_3 = 0x12, 47*4882a593Smuzhiyun AGC_GAIN_2 = 0x13, 48*4882a593Smuzhiyun AGC_GAIN_1 = 0x14, 49*4882a593Smuzhiyun AGC_GAIN_0 = 0x15, 50*4882a593Smuzhiyun FREQ_OFFSET_2 = 0x17, 51*4882a593Smuzhiyun FREQ_OFFSET_1 = 0x18, 52*4882a593Smuzhiyun FREQ_OFFSET_0 = 0x19, 53*4882a593Smuzhiyun TIMING_OFFSET_1 = 0x1A, 54*4882a593Smuzhiyun TIMING_OFFSET_0 = 0x1B, 55*4882a593Smuzhiyun CHAN_FREQ_1 = 0x1C, 56*4882a593Smuzhiyun CHAN_FREQ_0 = 0x1D, 57*4882a593Smuzhiyun TPS_RECEIVED_1 = 0x1E, 58*4882a593Smuzhiyun TPS_RECEIVED_0 = 0x1F, 59*4882a593Smuzhiyun TPS_CURRENT_1 = 0x20, 60*4882a593Smuzhiyun TPS_CURRENT_0 = 0x21, 61*4882a593Smuzhiyun TPS_CELL_ID_1 = 0x22, 62*4882a593Smuzhiyun TPS_CELL_ID_0 = 0x23, 63*4882a593Smuzhiyun TPS_MISC_DATA_2 = 0x24, 64*4882a593Smuzhiyun TPS_MISC_DATA_1 = 0x25, 65*4882a593Smuzhiyun TPS_MISC_DATA_0 = 0x26, 66*4882a593Smuzhiyun RESET = 0x50, 67*4882a593Smuzhiyun TPS_GIVEN_1 = 0x51, 68*4882a593Smuzhiyun TPS_GIVEN_0 = 0x52, 69*4882a593Smuzhiyun ACQ_CTL = 0x53, 70*4882a593Smuzhiyun TRL_NOMINAL_RATE_1 = 0x54, 71*4882a593Smuzhiyun TRL_NOMINAL_RATE_0 = 0x55, 72*4882a593Smuzhiyun INPUT_FREQ_1 = 0x56, 73*4882a593Smuzhiyun INPUT_FREQ_0 = 0x57, 74*4882a593Smuzhiyun TUNER_ADDR = 0x58, 75*4882a593Smuzhiyun CHAN_START_1 = 0x59, 76*4882a593Smuzhiyun CHAN_START_0 = 0x5A, 77*4882a593Smuzhiyun CONT_1 = 0x5B, 78*4882a593Smuzhiyun CONT_0 = 0x5C, 79*4882a593Smuzhiyun TUNER_GO = 0x5D, 80*4882a593Smuzhiyun STATUS_EN_0 = 0x5F, 81*4882a593Smuzhiyun STATUS_EN_1 = 0x60, 82*4882a593Smuzhiyun INTERRUPT_EN_0 = 0x61, 83*4882a593Smuzhiyun INTERRUPT_EN_1 = 0x62, 84*4882a593Smuzhiyun INTERRUPT_EN_2 = 0x63, 85*4882a593Smuzhiyun INTERRUPT_EN_3 = 0x64, 86*4882a593Smuzhiyun AGC_TARGET = 0x67, 87*4882a593Smuzhiyun AGC_CTL = 0x68, 88*4882a593Smuzhiyun CAPT_RANGE = 0x75, 89*4882a593Smuzhiyun SNR_SELECT_1 = 0x79, 90*4882a593Smuzhiyun SNR_SELECT_0 = 0x7A, 91*4882a593Smuzhiyun RS_ERR_PER_1 = 0x7C, 92*4882a593Smuzhiyun RS_ERR_PER_0 = 0x7D, 93*4882a593Smuzhiyun CHIP_ID = 0x7F, 94*4882a593Smuzhiyun CHAN_STOP_1 = 0x80, 95*4882a593Smuzhiyun CHAN_STOP_0 = 0x81, 96*4882a593Smuzhiyun CHAN_STEP_1 = 0x82, 97*4882a593Smuzhiyun CHAN_STEP_0 = 0x83, 98*4882a593Smuzhiyun FEC_LOCK_TIME = 0x85, 99*4882a593Smuzhiyun OFDM_LOCK_TIME = 0x86, 100*4882a593Smuzhiyun ACQ_DELAY = 0x87, 101*4882a593Smuzhiyun SCAN_CTL = 0x88, 102*4882a593Smuzhiyun CLOCK_CTL = 0x89, 103*4882a593Smuzhiyun CONFIG = 0x8A, 104*4882a593Smuzhiyun MCLK_RATIO = 0x8B, 105*4882a593Smuzhiyun GPP_CTL = 0x8C, 106*4882a593Smuzhiyun ADC_CTL_1 = 0x8E, 107*4882a593Smuzhiyun ADC_CTL_0 = 0x8F 108*4882a593Smuzhiyun }; 109*4882a593Smuzhiyun 110*4882a593Smuzhiyun /* here we assume 1/6MHz == 166.66kHz stepsize */ 111*4882a593Smuzhiyun #define IF_FREQUENCYx6 217 /* 6 * 36.16666666667MHz */ 112*4882a593Smuzhiyun 113*4882a593Smuzhiyun #endif /* _MT352_PRIV_ */ 114