blob: 8659c52647adf839139a7e1ae38e95071ff800a5 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001 /*
2 Driver for Philips tda1004xh OFDM Frontend
3
4 (c) 2004 Andrew de Quincey
5
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
15 GNU General Public License for more details.
16
17 You should have received a copy of the GNU General Public License
18 along with this program; if not, write to the Free Software
19 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
20
21 */
22
23#ifndef TDA1004X_H
24#define TDA1004X_H
25
26#include <linux/dvb/frontend.h>
27#include <linux/firmware.h>
28
Hartmut Hackmannecb60de2005-07-07 17:57:40 -070029enum tda10046_xtal {
30 TDA10046_XTAL_4M,
31 TDA10046_XTAL_16M,
32};
33
34enum tda10046_agc {
35 TDA10046_AGC_DEFAULT, /* original configuration */
36 TDA10046_AGC_IFO_AUTO_NEG, /* IF AGC only, automatic, negtive */
Hartmut Hackmannf03cbea2005-07-07 17:57:43 -070037 TDA10046_AGC_IFO_AUTO_POS, /* IF AGC only, automatic, positive */
38 TDA10046_AGC_TDA827X, /* IF AGC only, special setup for tda827x */
Hartmut Hackmannecb60de2005-07-07 17:57:40 -070039};
40
41enum tda10046_if {
42 TDA10046_FREQ_3617, /* original config, 36,166 MHZ */
43 TDA10046_FREQ_3613, /* 36,13 MHZ */
Hartmut Hackmannf03cbea2005-07-07 17:57:43 -070044 TDA10046_FREQ_045, /* low IF, 4.0, 4.5, or 5.0 MHZ */
45 TDA10046_FREQ_052, /* low IF, 5.1667 MHZ for tda9889 */
Hartmut Hackmannecb60de2005-07-07 17:57:40 -070046};
47
Linus Torvalds1da177e2005-04-16 15:20:36 -070048struct tda1004x_config
49{
50 /* the demodulator's i2c address */
51 u8 demod_address;
52
53 /* does the "inversion" need inverted? */
Johannes Stezenbachdd102c72005-05-16 21:54:35 -070054 u8 invert;
Linus Torvalds1da177e2005-04-16 15:20:36 -070055
56 /* Does the OCLK signal need inverted? */
Johannes Stezenbachdd102c72005-05-16 21:54:35 -070057 u8 invert_oclk;
Linus Torvalds1da177e2005-04-16 15:20:36 -070058
Hartmut Hackmannecb60de2005-07-07 17:57:40 -070059 /* Xtal frequency, 4 or 16MHz*/
60 enum tda10046_xtal xtal_freq;
61
62 /* IF frequency */
63 enum tda10046_if if_freq;
64
65 /* AGC configuration */
66 enum tda10046_agc agc_config;
Johannes Stezenbach1dfb8002005-05-16 21:54:35 -070067
Linus Torvalds1da177e2005-04-16 15:20:36 -070068 /* PLL maintenance */
69 int (*pll_init)(struct dvb_frontend* fe);
Hartmut Hackmannecb60de2005-07-07 17:57:40 -070070 void (*pll_sleep)(struct dvb_frontend* fe);
Linus Torvalds1da177e2005-04-16 15:20:36 -070071 int (*pll_set)(struct dvb_frontend* fe, struct dvb_frontend_parameters* params);
72
73 /* request firmware for device */
Hartmut Hackmannecb60de2005-07-07 17:57:40 -070074 /* set this to NULL if the card has a firmware EEPROM */
Linus Torvalds1da177e2005-04-16 15:20:36 -070075 int (*request_firmware)(struct dvb_frontend* fe, const struct firmware **fw, char* name);
76};
77
78extern struct dvb_frontend* tda10045_attach(const struct tda1004x_config* config,
79 struct i2c_adapter* i2c);
80
81extern struct dvb_frontend* tda10046_attach(const struct tda1004x_config* config,
82 struct i2c_adapter* i2c);
83
84extern int tda1004x_write_byte(struct dvb_frontend* fe, int reg, int data);
85
86#endif // TDA1004X_H