blob: 205fbbff632bcbfe6d7e2851dc957fd901c18adb [file] [log] [blame]
Patrick Boettchera75763f2006-10-18 08:34:16 -03001#ifndef DIB7000P_H
2#define DIB7000P_H
3
4#include "dibx000_common.h"
5
6struct dib7000p_config {
7 u8 output_mpeg2_in_188_bytes;
8 u8 hostbus_diversity;
9 u8 tuner_is_baseband;
10 int (*update_lna) (struct dvb_frontend *, u16 agc_global);
11
Patrick Boettcherb6884a12007-07-27 10:08:51 -030012 u8 agc_config_count;
Patrick Boettchera75763f2006-10-18 08:34:16 -030013 struct dibx000_agc_config *agc;
14 struct dibx000_bandwidth_config *bw;
15
16#define DIB7000P_GPIO_DEFAULT_DIRECTIONS 0xffff
17 u16 gpio_dir;
18#define DIB7000P_GPIO_DEFAULT_VALUES 0x0000
19 u16 gpio_val;
20#define DIB7000P_GPIO_PWM_POS0(v) ((v & 0xf) << 12)
21#define DIB7000P_GPIO_PWM_POS1(v) ((v & 0xf) << 8 )
22#define DIB7000P_GPIO_PWM_POS2(v) ((v & 0xf) << 4 )
23#define DIB7000P_GPIO_PWM_POS3(v) (v & 0xf)
24#define DIB7000P_GPIO_DEFAULT_PWM_POS 0xffff
25 u16 gpio_pwm_pos;
26
27 u16 pwm_freq_div;
28
29 u8 quartz_direct;
30
Patrick Boettcherb6884a12007-07-27 10:08:51 -030031 u8 spur_protect;
32
Patrick Boettchera75763f2006-10-18 08:34:16 -030033 int (*agc_control) (struct dvb_frontend *, u8 before);
Steven Totha38d6e32008-04-22 15:37:01 -030034
35 u8 output_mode;
Olivier Grenie713d54a2011-01-04 04:54:31 -030036 u8 disable_sample_and_hold:1;
Olivier Grenie90e12ce2010-09-07 12:50:45 -030037
Olivier Grenie713d54a2011-01-04 04:54:31 -030038 u8 enable_current_mirror:1;
39 u16 diversity_delay;
Olivier Grenie90e12ce2010-09-07 12:50:45 -030040
Olivier Grenie713d54a2011-01-04 04:54:31 -030041 u8 default_i2c_addr;
Olivier Grenieb4d6046e2011-01-04 13:08:14 -030042 u8 enMpegOutput:1;
Patrick Boettchera75763f2006-10-18 08:34:16 -030043};
44
45#define DEFAULT_DIB7000P_I2C_ADDRESS 18
46
Mauro Carvalho Chehab8abe4a02014-05-29 09:20:15 -030047struct dib7000p_ops {
48 int (*set_wbd_ref)(struct dvb_frontend *demod, u16 value);
49 int (*get_agc_values)(struct dvb_frontend *fe,
Olivier Grenie6724a2f2011-08-05 13:49:33 -030050 u16 *agc_global, u16 *agc1, u16 *agc2, u16 *wbd);
Mauro Carvalho Chehab8abe4a02014-05-29 09:20:15 -030051 int (*set_agc1_min)(struct dvb_frontend *fe, u16 v);
52 int (*update_pll)(struct dvb_frontend *fe, struct dibx000_bandwidth_config *bw);
53 int (*set_gpio)(struct dvb_frontend *demod, u8 num, u8 dir, u8 val);
54 u32 (*ctrl_timf)(struct dvb_frontend *fe, u8 op, u32 timf);
55 int (*dib7000pc_detection)(struct i2c_adapter *i2c_adap);
56 struct i2c_adapter *(*get_i2c_master)(struct dvb_frontend *demod, enum dibx000_i2c_interface intf, int gating);
57 int (*pid_filter_ctrl)(struct dvb_frontend *fe, u8 onoff);
58 int (*pid_filter)(struct dvb_frontend *fe, u8 id, u16 pid, u8 onoff);
59 int (*i2c_enumeration)(struct i2c_adapter *i2c, int no_of_demods, u8 default_addr, struct dib7000p_config cfg[]);
60 struct i2c_adapter *(*get_i2c_tuner)(struct dvb_frontend *fe);
61 int (*tuner_sleep)(struct dvb_frontend *fe, int onoff);
62 int (*get_adc_power)(struct dvb_frontend *fe);
63 int (*slave_reset)(struct dvb_frontend *fe);
64 struct dvb_frontend *(*init)(struct i2c_adapter *i2c_adap, u8 i2c_addr, struct dib7000p_config *cfg);
65};
66
Arnd Bergmann9b174522015-02-18 14:12:42 -030067#if IS_REACHABLE(CONFIG_DVB_DIB7000P)
Mauro Carvalho Chehab8abe4a02014-05-29 09:20:15 -030068void *dib7000p_attach(struct dib7000p_ops *ops);
Michael Krufky2f1a1c72008-05-25 13:09:51 -030069#else
Mauro Carvalho Chehab8abe4a02014-05-29 09:20:15 -030070static inline void *dib7000p_attach(struct dib7000p_ops *ops)
Michael Krufky2f1a1c72008-05-25 13:09:51 -030071{
72 printk(KERN_WARNING "%s: driver disabled by Kconfig\n", __func__);
73 return NULL;
74}
Michael Krufky5aed9752009-03-09 00:04:17 -030075#endif
Patrick Boettchera75763f2006-10-18 08:34:16 -030076
77#endif