1/* 2 * tuner.h - definition for different tuners 3 * 4 * Copyright (C) 1997 Markus Schroeder (schroedm@uni-duesseldorf.de) 5 * minor modifications by Ralph Metzler (rjkm@thp.uni-koeln.de) 6 * 7 * This program is free software; you can redistribute it and/or modify 8 * it under the terms of the GNU General Public License as published by 9 * the Free Software Foundation; either version 2 of the License, or 10 * (at your option) any later version. 11 * 12 * This program is distributed in the hope that it will be useful, 13 * but WITHOUT ANY WARRANTY; without even the implied warranty of 14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 15 * GNU General Public License for more details. 16 */ 17 18#ifndef _TUNER_H 19#define _TUNER_H 20#ifdef __KERNEL__ 21 22#include <linux/videodev2.h> 23 24#define ADDR_UNSET (255) 25 26#define TUNER_TEMIC_PAL 0 /* 4002 FH5 (3X 7756, 9483) */ 27#define TUNER_PHILIPS_PAL_I 1 28#define TUNER_PHILIPS_NTSC 2 29#define TUNER_PHILIPS_SECAM 3 /* you must actively select B/G, L, L` */ 30 31#define TUNER_ABSENT 4 32#define TUNER_PHILIPS_PAL 5 33#define TUNER_TEMIC_NTSC 6 /* 4032 FY5 (3X 7004, 9498, 9789) */ 34#define TUNER_TEMIC_PAL_I 7 /* 4062 FY5 (3X 8501, 9957) */ 35 36#define TUNER_TEMIC_4036FY5_NTSC 8 /* 4036 FY5 (3X 1223, 1981, 7686) */ 37#define TUNER_ALPS_TSBH1_NTSC 9 38#define TUNER_ALPS_TSBE1_PAL 10 39#define TUNER_ALPS_TSBB5_PAL_I 11 40 41#define TUNER_ALPS_TSBE5_PAL 12 42#define TUNER_ALPS_TSBC5_PAL 13 43#define TUNER_TEMIC_4006FH5_PAL 14 /* 4006 FH5 (3X 9500, 9501, 7291) */ 44#define TUNER_ALPS_TSHC6_NTSC 15 45 46#define TUNER_TEMIC_PAL_DK 16 /* 4016 FY5 (3X 1392, 1393) */ 47#define TUNER_PHILIPS_NTSC_M 17 48#define TUNER_TEMIC_4066FY5_PAL_I 18 /* 4066 FY5 (3X 7032, 7035) */ 49#define TUNER_TEMIC_4006FN5_MULTI_PAL 19 /* B/G, I and D/K autodetected (3X 7595, 7606, 7657) */ 50 51#define TUNER_TEMIC_4009FR5_PAL 20 /* incl. FM radio (3X 7607, 7488, 7711) */ 52#define TUNER_TEMIC_4039FR5_NTSC 21 /* incl. FM radio (3X 7246, 7578, 7732) */ 53#define TUNER_TEMIC_4046FM5 22 /* you must actively select B/G, D/K, I, L, L` ! (3X 7804, 7806, 8103, 8104) */ 54#define TUNER_PHILIPS_PAL_DK 23 55 56#define TUNER_PHILIPS_FQ1216ME 24 /* you must actively select B/G/D/K, I, L, L` */ 57#define TUNER_LG_PAL_I_FM 25 58#define TUNER_LG_PAL_I 26 59#define TUNER_LG_NTSC_FM 27 60 61#define TUNER_LG_PAL_FM 28 62#define TUNER_LG_PAL 29 63#define TUNER_TEMIC_4009FN5_MULTI_PAL_FM 30 /* B/G, I and D/K autodetected (3X 8155, 8160, 8163) */ 64#define TUNER_SHARP_2U5JF5540_NTSC 31 65 66#define TUNER_Samsung_PAL_TCPM9091PD27 32 67#define TUNER_MT2032 33 68#define TUNER_TEMIC_4106FH5 34 /* 4106 FH5 (3X 7808, 7865) */ 69#define TUNER_TEMIC_4012FY5 35 /* 4012 FY5 (3X 0971, 1099) */ 70 71#define TUNER_TEMIC_4136FY5 36 /* 4136 FY5 (3X 7708, 7746) */ 72#define TUNER_LG_PAL_NEW_TAPC 37 73#define TUNER_PHILIPS_FM1216ME_MK3 38 74#define TUNER_LG_NTSC_NEW_TAPC 39 75 76#define TUNER_HITACHI_NTSC 40 77#define TUNER_PHILIPS_PAL_MK 41 78#define TUNER_PHILIPS_FCV1236D 42 79#define TUNER_PHILIPS_FM1236_MK3 43 80 81#define TUNER_PHILIPS_4IN1 44 /* ATI TV Wonder Pro - Conexant */ 82 /* 83 * Microtune merged with Temic 12/31/1999 partially financed by Alps. 84 * these may be similar to Temic 85 */ 86#define TUNER_MICROTUNE_4049FM5 45 87#define TUNER_PANASONIC_VP27 46 88#define TUNER_LG_NTSC_TAPE 47 89 90#define TUNER_TNF_8831BGFF 48 91#define TUNER_MICROTUNE_4042FI5 49 /* DViCO FusionHDTV 3 Gold-Q - 4042 FI5 (3X 8147) */ 92#define TUNER_TCL_2002N 50 93#define TUNER_PHILIPS_FM1256_IH3 51 94 95#define TUNER_THOMSON_DTT7610 52 96#define TUNER_PHILIPS_FQ1286 53 97#define TUNER_PHILIPS_TDA8290 54 98#define TUNER_TCL_2002MB 55 /* Hauppauge PVR-150 PAL */ 99 100#define TUNER_PHILIPS_FQ1216AME_MK4 56 /* Hauppauge PVR-150 PAL */ 101#define TUNER_PHILIPS_FQ1236A_MK4 57 /* Hauppauge PVR-500MCE NTSC */ 102#define TUNER_YMEC_TVF_8531MF 58 103#define TUNER_YMEC_TVF_5533MF 59 /* Pixelview Pro Ultra NTSC */ 104 105#define TUNER_THOMSON_DTT761X 60 /* DTT 7611 7611A 7612 7613 7613A 7614 7615 7615A */ 106#define TUNER_TENA_9533_DI 61 107#define TUNER_TEA5767 62 /* Only FM Radio Tuner */ 108#define TUNER_PHILIPS_FMD1216ME_MK3 63 109 110#define TUNER_LG_TDVS_H06XF 64 /* TDVS H061F, H062F, H064F */ 111#define TUNER_YMEC_TVF66T5_B_DFF 65 /* Acorp Y878F */ 112#define TUNER_LG_TALN 66 113#define TUNER_PHILIPS_TD1316 67 114 115#define TUNER_PHILIPS_TUV1236D 68 /* ATI HDTV Wonder */ 116#define TUNER_TNF_5335MF 69 /* Sabrent Bt848 */ 117#define TUNER_SAMSUNG_TCPN_2121P30A 70 /* Hauppauge PVR-500MCE NTSC */ 118#define TUNER_XC2028 71 119 120#define TUNER_THOMSON_FE6600 72 /* DViCO FusionHDTV DVB-T Hybrid */ 121#define TUNER_SAMSUNG_TCPG_6121P30A 73 /* Hauppauge PVR-500 PAL */ 122#define TUNER_TDA9887 74 /* This tuner should be used only internally */ 123#define TUNER_TEA5761 75 /* Only FM Radio Tuner */ 124#define TUNER_XC5000 76 /* Xceive Silicon Tuner */ 125#define TUNER_TCL_MF02GIP_5N 77 /* TCL MF02GIP_5N */ 126#define TUNER_PHILIPS_FMD1216MEX_MK3 78 127#define TUNER_PHILIPS_FM1216MK5 79 128#define TUNER_PHILIPS_FQ1216LME_MK3 80 /* Active loopthrough, no FM */ 129 130#define TUNER_PARTSNIC_PTI_5NF05 81 131#define TUNER_PHILIPS_CU1216L 82 132#define TUNER_NXP_TDA18271 83 133#define TUNER_SONY_BTF_PXN01Z 84 134#define TUNER_PHILIPS_FQ1236_MK5 85 /* NTSC, TDA9885, no FM radio */ 135#define TUNER_TENA_TNF_5337 86 136 137#define TUNER_XC4000 87 /* Xceive Silicon Tuner */ 138#define TUNER_XC5000C 88 /* Xceive Silicon Tuner */ 139 140#define TUNER_SONY_BTF_PG472Z 89 /* PAL+SECAM */ 141#define TUNER_SONY_BTF_PK467Z 90 /* NTSC_JP */ 142#define TUNER_SONY_BTF_PB463Z 91 /* NTSC */ 143 144/* tv card specific */ 145#define TDA9887_PRESENT (1<<0) 146#define TDA9887_PORT1_INACTIVE (1<<1) 147#define TDA9887_PORT2_INACTIVE (1<<2) 148#define TDA9887_QSS (1<<3) 149#define TDA9887_INTERCARRIER (1<<4) 150#define TDA9887_PORT1_ACTIVE (1<<5) 151#define TDA9887_PORT2_ACTIVE (1<<6) 152#define TDA9887_INTERCARRIER_NTSC (1<<7) 153/* Tuner takeover point adjustment, in dB, -16 <= top <= 15 */ 154#define TDA9887_TOP_MASK (0x3f << 8) 155#define TDA9887_TOP_SET (1 << 13) 156#define TDA9887_TOP(top) (TDA9887_TOP_SET | \ 157 (((16 + (top)) & 0x1f) << 8)) 158 159/* config options */ 160#define TDA9887_DEEMPHASIS_MASK (3<<16) 161#define TDA9887_DEEMPHASIS_NONE (1<<16) 162#define TDA9887_DEEMPHASIS_50 (2<<16) 163#define TDA9887_DEEMPHASIS_75 (3<<16) 164#define TDA9887_AUTOMUTE (1<<18) 165#define TDA9887_GATING_18 (1<<19) 166#define TDA9887_GAIN_NORMAL (1<<20) 167#define TDA9887_RIF_41_3 (1<<21) /* radio IF1 41.3 vs 33.3 */ 168 169/** 170 * enum tuner_mode - Mode of the tuner 171 * 172 * @T_RADIO: Tuner core will work in radio mode 173 * @T_ANALOG_TV: Tuner core will work in analog TV mode 174 * 175 * Older boards only had a single tuner device, but some devices have a 176 * separate tuner for radio. In any case, the tuner-core needs to know if 177 * the tuner chip(s) will be used in radio mode or analog TV mode, as, on 178 * radio mode, frequencies are specified on a different range than on TV 179 * mode. This enum is used by the tuner core in order to work with the 180 * proper tuner range and eventually use a different tuner chip while in 181 * radio mode. 182 */ 183enum tuner_mode { 184 T_RADIO = 1 << V4L2_TUNER_RADIO, 185 T_ANALOG_TV = 1 << V4L2_TUNER_ANALOG_TV, 186 /* Don't map V4L2_TUNER_DIGITAL_TV, as tuner-core won't use it */ 187}; 188 189/** 190 * struct tuner_setup - setup the tuner chipsets 191 * 192 * @addr: I2C address used to control the tuner device/chipset 193 * @type: Type of the tuner, as defined at the TUNER_* macros. 194 * Each different tuner model should have an unique 195 * identifier. 196 * @mode_mask: Mask with the allowed tuner modes: V4L2_TUNER_RADIO, 197 * V4L2_TUNER_ANALOG_TV and/or V4L2_TUNER_DIGITAL_TV, 198 * describing if the tuner should be used to support 199 * Radio, analog TV and/or digital TV. 200 * @config: Used to send tuner-specific configuration for complex 201 * tuners that require extra parameters to be set. 202 * Only a very few tuners require it and its usage on 203 * newer tuners should be avoided. 204 * @tuner_callback: Some tuners require to call back the bridge driver, 205 * in order to do some tasks like rising a GPIO at the 206 * bridge chipset, in order to do things like resetting 207 * the device. 208 * 209 * Older boards only had a single tuner device. Nowadays multiple tuner 210 * devices may be present on a single board. Using TUNER_SET_TYPE_ADDR 211 * to pass the tuner_setup structure it is possible to setup each tuner 212 * device in turn. 213 * 214 * Since multiple devices may be present it is no longer sufficient to 215 * send a command to a single i2c device. Instead you should broadcast 216 * the command to all i2c devices. 217 * 218 * By setting the mode_mask correctly you can select which commands are 219 * accepted by a specific tuner device. For example, set mode_mask to 220 * T_RADIO if the device is a radio-only tuner. That specific tuner will 221 * only accept commands when the tuner is in radio mode and ignore them 222 * when the tuner is set to TV mode. 223 */ 224 225struct tuner_setup { 226 unsigned short addr; 227 unsigned int type; 228 unsigned int mode_mask; 229 void *config; 230 int (*tuner_callback)(void *dev, int component, int cmd, int arg); 231}; 232 233#endif /* __KERNEL__ */ 234 235#endif /* _TUNER_H */ 236