blob: 2a6529cccf1afe59a1c5204b76c30dab1dc676e3 [file] [log] [blame]
Mac Michaelsd8667cb2005-07-07 17:58:29 -07001/*
Michael Krufky1963c902005-08-08 09:22:43 -07002 * Support for LGDT3302 and LGDT3303 - VSB/QAM
Mac Michaelsd8667cb2005-07-07 17:58:29 -07003 *
4 * Copyright (C) 2005 Wilson Michaels <wilsonmichaels@earthlink.net>
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 * 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
Michael Krufky6ddcc912005-07-27 11:46:00 -070022#ifndef LGDT330X_H
23#define LGDT330X_H
Mac Michaelsd8667cb2005-07-07 17:58:29 -070024
25#include <linux/dvb/frontend.h>
26
Michael Krufky1963c902005-08-08 09:22:43 -070027typedef enum lg_chip_t {
28 UNDEFINED,
29 LGDT3302,
30 LGDT3303
31}lg_chip_type;
32
Michael Krufky6ddcc912005-07-27 11:46:00 -070033struct lgdt330x_config
Mac Michaelsd8667cb2005-07-07 17:58:29 -070034{
35 /* The demodulator's i2c address */
36 u8 demod_address;
Michael Krufkyb6aef072005-07-27 11:45:54 -070037
Michael Krufky1963c902005-08-08 09:22:43 -070038 /* LG demodulator chip LGDT3302 or LGDT3303 */
39 lg_chip_type demod_chip;
40
41 /* MPEG hardware interface - 0:parallel 1:serial */
42 int serial_mpeg;
43
Michael Krufkyb6aef072005-07-27 11:45:54 -070044 /* PLL interface */
Michael Krufky0ccef6d2005-07-27 11:45:55 -070045 int (*pll_rf_set) (struct dvb_frontend* fe, int index);
Michael Krufky1963c902005-08-08 09:22:43 -070046 int (*pll_set)(struct dvb_frontend* fe, struct dvb_frontend_parameters* params);
Mac Michaelsd8667cb2005-07-07 17:58:29 -070047
48 /* Need to set device param for start_dma */
49 int (*set_ts_params)(struct dvb_frontend* fe, int is_punctured);
Michael Krufkyc0b11b92005-11-08 21:35:32 -080050
51 /* Flip the polarity of the mpeg data transfer clock using alternate init data
52 * This option applies ONLY to LGDT3303 - 0:disabled (default) 1:enabled */
53 int clock_polarity_flip;
Mac Michaelsd8667cb2005-07-07 17:58:29 -070054};
55
Michael Krufky6ddcc912005-07-27 11:46:00 -070056extern struct dvb_frontend* lgdt330x_attach(const struct lgdt330x_config* config,
Mac Michaelsd8667cb2005-07-07 17:58:29 -070057 struct i2c_adapter* i2c);
58
Michael Krufky6ddcc912005-07-27 11:46:00 -070059#endif /* LGDT330X_H */
Mac Michaelsd8667cb2005-07-07 17:58:29 -070060
61/*
62 * Local variables:
63 * c-basic-offset: 8
64 * End:
65 */