blob: 323f2912128daa0dc991871f8a04501e464a73a4 [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 Krufkyf21e0d72008-01-02 03:01:54 -030081struct tda18271_config {
Michael Krufky0e1fab92008-01-03 01:40:47 -030082 /* override default if freq / std settings (optional) */
Michael Krufkyf21e0d72008-01-02 03:01:54 -030083 struct tda18271_std_map *std_map;
Michael Krufky0e1fab92008-01-03 01:40:47 -030084
Michael Krufky868f5cc2008-04-22 14:46:23 -030085 /* master / slave tuner: master uses main pll, slave uses cal pll */
86 enum tda18271_role role;
87
Michael Krufky0e1fab92008-01-03 01:40:47 -030088 /* use i2c gate provided by analog or digital demod */
Michael Krufkyf21e0d72008-01-02 03:01:54 -030089 enum tda18271_i2c_gate gate;
Michael Krufky55553092008-04-22 14:46:06 -030090
Michael Krufky4240b462009-08-29 16:25:37 -030091 /* output options that can be disabled */
92 enum tda18271_output_options output_opt;
Michael Krufky81259f22008-05-11 12:46:52 -030093
Michael Krufky81016b42009-08-27 16:58:06 -030094 /* force rf tracking filter calibration on startup */
95 unsigned int rf_cal_on_startup:1;
96
Michael Krufky55553092008-04-22 14:46:06 -030097 /* some i2c providers cant write all 39 registers at once */
98 unsigned int small_i2c:1;
Michael Krufkyadcc4b32009-03-04 19:42:06 -030099
100 /* interface to saa713x / tda829x */
101 unsigned int config;
102};
103
104#define TDA18271_CALLBACK_CMD_AGC_ENABLE 0
105
106enum tda18271_mode {
107 TDA18271_ANALOG = 0,
108 TDA18271_DIGITAL,
Michael Krufkyf21e0d72008-01-02 03:01:54 -0300109};
110
Mauro Carvalho Chehab149ef722008-04-29 21:38:46 -0300111#if defined(CONFIG_MEDIA_TUNER_TDA18271) || (defined(CONFIG_MEDIA_TUNER_TDA18271_MODULE) && defined(MODULE))
Michael Krufky5bea1cd2007-10-22 09:56:38 -0300112extern struct dvb_frontend *tda18271_attach(struct dvb_frontend *fe, u8 addr,
Michael Krufkye435f952007-12-09 22:23:30 -0300113 struct i2c_adapter *i2c,
Michael Krufkyf21e0d72008-01-02 03:01:54 -0300114 struct tda18271_config *cfg);
Michael Krufky5bea1cd2007-10-22 09:56:38 -0300115#else
116static inline struct dvb_frontend *tda18271_attach(struct dvb_frontend *fe,
117 u8 addr,
Michael Krufkye435f952007-12-09 22:23:30 -0300118 struct i2c_adapter *i2c,
Michael Krufkyf21e0d72008-01-02 03:01:54 -0300119 struct tda18271_config *cfg)
Michael Krufky5bea1cd2007-10-22 09:56:38 -0300120{
Harvey Harrison271ddbf2008-04-08 23:20:00 -0300121 printk(KERN_WARNING "%s: driver disabled by Kconfig\n", __func__);
Michael Krufky5bea1cd2007-10-22 09:56:38 -0300122 return NULL;
123}
124#endif
125
126#endif /* __TDA18271_H__ */