blob: 50cfa8cebb9309043e63059c350d7091e877e24c [file] [log] [blame]
Michael Krufky5bea1cd2007-10-22 09:56:38 -03001/*
2 tda18271.h - header for the Philips / NXP TDA18271 silicon tuner
3
Michael Krufky59067f72008-01-02 01:58:26 -03004 Copyright (C) 2007, 2008 Michael Krufky <mkrufky@linuxtv.org>
Michael Krufky5bea1cd2007-10-22 09:56:38 -03005
6 This program is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation; either version 2 of the License, or
9 (at your option) any later version.
10
11 This program is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
15
16 You should have received a copy of the GNU General Public License
17 along with this program; if not, write to the Free Software
18 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
19*/
20
21#ifndef __TDA18271_H__
22#define __TDA18271_H__
23
24#include <linux/i2c.h>
25#include "dvb_frontend.h"
26
Michael Krufkyf21e0d72008-01-02 03:01:54 -030027struct tda18271_std_map_item {
Michael Krufky2ba65d52008-01-03 01:17:45 -030028 u16 if_freq;
Michael Krufky7f7203d2008-04-22 14:46:06 -030029
30 /* EP3[4:3] */
31 unsigned int agc_mode:2;
32 /* EP3[2:0] */
33 unsigned int std:3;
34 /* EP4[7] */
Michael Krufkyc293d0a2008-04-22 14:46:06 -030035 unsigned int fm_rfn:1;
Michael Krufky14c74b22008-04-22 14:46:21 -030036 /* EP4[4:2] */
37 unsigned int if_lvl:3;
Michael Krufkyc0dc0c12008-04-22 14:46:22 -030038 /* EB22[6:0] */
39 unsigned int rfagc_top:7;
Michael Krufkyf21e0d72008-01-02 03:01:54 -030040};
41
42struct tda18271_std_map {
Michael Krufkyc353f422008-01-08 10:38:10 -030043 struct tda18271_std_map_item fm_radio;
Michael Krufkyf21e0d72008-01-02 03:01:54 -030044 struct tda18271_std_map_item atv_b;
45 struct tda18271_std_map_item atv_dk;
46 struct tda18271_std_map_item atv_gh;
47 struct tda18271_std_map_item atv_i;
48 struct tda18271_std_map_item atv_l;
49 struct tda18271_std_map_item atv_lc;
50 struct tda18271_std_map_item atv_mn;
51 struct tda18271_std_map_item atsc_6;
52 struct tda18271_std_map_item dvbt_6;
53 struct tda18271_std_map_item dvbt_7;
54 struct tda18271_std_map_item dvbt_8;
55 struct tda18271_std_map_item qam_6;
56 struct tda18271_std_map_item qam_8;
57};
58
Michael Krufky868f5cc2008-04-22 14:46:23 -030059enum tda18271_role {
60 TDA18271_MASTER = 0,
61 TDA18271_SLAVE,
62};
63
Michael Krufkye435f952007-12-09 22:23:30 -030064enum tda18271_i2c_gate {
65 TDA18271_GATE_AUTO = 0,
66 TDA18271_GATE_ANALOG,
67 TDA18271_GATE_DIGITAL,
68};
69
Michael Krufky4240b462009-08-29 16:25:37 -030070enum tda18271_output_options {
71 /* slave tuner output & loop thru & xtal oscillator always on */
72 TDA18271_OUTPUT_LT_XT_ON = 0,
Michael Krufky81259f22008-05-11 12:46:52 -030073
Michael Krufky4240b462009-08-29 16:25:37 -030074 /* slave tuner output loop thru off */
75 TDA18271_OUTPUT_LT_OFF = 1,
Michael Krufky81259f22008-05-11 12:46:52 -030076
Michael Krufky4240b462009-08-29 16:25:37 -030077 /* xtal oscillator off */
78 TDA18271_OUTPUT_XT_OFF = 2,
Michael Krufky81259f22008-05-11 12:46:52 -030079};
80
Michael Krufky1724c8f2009-10-23 02:47:49 -030081enum tda18271_small_i2c {
82 TDA18271_39_BYTE_CHUNK_INIT = 0,
Mauro Carvalho Chehabe350d442010-09-26 22:58:28 -030083 TDA18271_16_BYTE_CHUNK_INIT = 16,
84 TDA18271_08_BYTE_CHUNK_INIT = 8,
85 TDA18271_03_BYTE_CHUNK_INIT = 3,
Michael Krufky1724c8f2009-10-23 02:47:49 -030086};
87
Michael Krufkyf21e0d72008-01-02 03:01:54 -030088struct tda18271_config {
Michael Krufky0e1fab92008-01-03 01:40:47 -030089 /* override default if freq / std settings (optional) */
Michael Krufkyf21e0d72008-01-02 03:01:54 -030090 struct tda18271_std_map *std_map;
Michael Krufky0e1fab92008-01-03 01:40:47 -030091
Michael Krufky868f5cc2008-04-22 14:46:23 -030092 /* master / slave tuner: master uses main pll, slave uses cal pll */
93 enum tda18271_role role;
94
Michael Krufky0e1fab92008-01-03 01:40:47 -030095 /* use i2c gate provided by analog or digital demod */
Michael Krufkyf21e0d72008-01-02 03:01:54 -030096 enum tda18271_i2c_gate gate;
Michael Krufky55553092008-04-22 14:46:06 -030097
Michael Krufky4240b462009-08-29 16:25:37 -030098 /* output options that can be disabled */
99 enum tda18271_output_options output_opt;
Michael Krufky81259f22008-05-11 12:46:52 -0300100
Lucas De Marchi25985ed2011-03-30 22:57:33 -0300101 /* some i2c providers can't write all 39 registers at once */
Michael Krufky1724c8f2009-10-23 02:47:49 -0300102 enum tda18271_small_i2c small_i2c;
103
Michael Krufky81016b42009-08-27 16:58:06 -0300104 /* force rf tracking filter calibration on startup */
105 unsigned int rf_cal_on_startup:1;
106
Michael Krufkyadcc4b32009-03-04 19:42:06 -0300107 /* interface to saa713x / tda829x */
108 unsigned int config;
109};
110
111#define TDA18271_CALLBACK_CMD_AGC_ENABLE 0
112
113enum tda18271_mode {
114 TDA18271_ANALOG = 0,
115 TDA18271_DIGITAL,
Michael Krufkyf21e0d72008-01-02 03:01:54 -0300116};
117
Mauro Carvalho Chehab149ef722008-04-29 21:38:46 -0300118#if defined(CONFIG_MEDIA_TUNER_TDA18271) || (defined(CONFIG_MEDIA_TUNER_TDA18271_MODULE) && defined(MODULE))
Michael Krufky5bea1cd2007-10-22 09:56:38 -0300119extern struct dvb_frontend *tda18271_attach(struct dvb_frontend *fe, u8 addr,
Michael Krufkye435f952007-12-09 22:23:30 -0300120 struct i2c_adapter *i2c,
Michael Krufkyf21e0d72008-01-02 03:01:54 -0300121 struct tda18271_config *cfg);
Michael Krufky5bea1cd2007-10-22 09:56:38 -0300122#else
123static inline struct dvb_frontend *tda18271_attach(struct dvb_frontend *fe,
124 u8 addr,
Michael Krufkye435f952007-12-09 22:23:30 -0300125 struct i2c_adapter *i2c,
Michael Krufkyf21e0d72008-01-02 03:01:54 -0300126 struct tda18271_config *cfg)
Michael Krufky5bea1cd2007-10-22 09:56:38 -0300127{
Harvey Harrison271ddbf2008-04-08 23:20:00 -0300128 printk(KERN_WARNING "%s: driver disabled by Kconfig\n", __func__);
Michael Krufky5bea1cd2007-10-22 09:56:38 -0300129 return NULL;
130}
131#endif
132
133#endif /* __TDA18271_H__ */