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