xref: /linux/drivers/media/dvb-frontends/dib7000m.h (revision 498495dba268b20e8eadd7fe93c140c68b6cc9d2)
1*b2441318SGreg Kroah-Hartman /* SPDX-License-Identifier: GPL-2.0 */
29a0bf528SMauro Carvalho Chehab #ifndef DIB7000M_H
39a0bf528SMauro Carvalho Chehab #define DIB7000M_H
49a0bf528SMauro Carvalho Chehab 
59a0bf528SMauro Carvalho Chehab #include "dibx000_common.h"
69a0bf528SMauro Carvalho Chehab 
79a0bf528SMauro Carvalho Chehab struct dib7000m_config {
89a0bf528SMauro Carvalho Chehab 	u8 dvbt_mode;
99a0bf528SMauro Carvalho Chehab 	u8 output_mpeg2_in_188_bytes;
109a0bf528SMauro Carvalho Chehab 	u8 hostbus_diversity;
119a0bf528SMauro Carvalho Chehab 	u8 tuner_is_baseband;
129a0bf528SMauro Carvalho Chehab 	u8 mobile_mode;
139a0bf528SMauro Carvalho Chehab 	int (*update_lna) (struct dvb_frontend *, u16 agc_global);
149a0bf528SMauro Carvalho Chehab 
159a0bf528SMauro Carvalho Chehab 	u8 agc_config_count;
169a0bf528SMauro Carvalho Chehab 	struct dibx000_agc_config *agc;
179a0bf528SMauro Carvalho Chehab 
189a0bf528SMauro Carvalho Chehab 	struct dibx000_bandwidth_config *bw;
199a0bf528SMauro Carvalho Chehab 
209a0bf528SMauro Carvalho Chehab #define DIB7000M_GPIO_DEFAULT_DIRECTIONS 0xffff
219a0bf528SMauro Carvalho Chehab 	u16 gpio_dir;
229a0bf528SMauro Carvalho Chehab #define DIB7000M_GPIO_DEFAULT_VALUES     0x0000
239a0bf528SMauro Carvalho Chehab 	u16 gpio_val;
249a0bf528SMauro Carvalho Chehab #define DIB7000M_GPIO_PWM_POS0(v)        ((v & 0xf) << 12)
259a0bf528SMauro Carvalho Chehab #define DIB7000M_GPIO_PWM_POS1(v)        ((v & 0xf) << 8 )
269a0bf528SMauro Carvalho Chehab #define DIB7000M_GPIO_PWM_POS2(v)        ((v & 0xf) << 4 )
279a0bf528SMauro Carvalho Chehab #define DIB7000M_GPIO_PWM_POS3(v)         (v & 0xf)
289a0bf528SMauro Carvalho Chehab #define DIB7000M_GPIO_DEFAULT_PWM_POS    0xffff
299a0bf528SMauro Carvalho Chehab 	u16 gpio_pwm_pos;
309a0bf528SMauro Carvalho Chehab 
319a0bf528SMauro Carvalho Chehab 	u16 pwm_freq_div;
329a0bf528SMauro Carvalho Chehab 
339a0bf528SMauro Carvalho Chehab 	u8 quartz_direct;
349a0bf528SMauro Carvalho Chehab 
359a0bf528SMauro Carvalho Chehab 	u8 input_clk_is_div_2;
369a0bf528SMauro Carvalho Chehab 
379a0bf528SMauro Carvalho Chehab 	int (*agc_control) (struct dvb_frontend *, u8 before);
389a0bf528SMauro Carvalho Chehab };
399a0bf528SMauro Carvalho Chehab 
409a0bf528SMauro Carvalho Chehab #define DEFAULT_DIB7000M_I2C_ADDRESS 18
419a0bf528SMauro Carvalho Chehab 
429b174527SArnd Bergmann #if IS_REACHABLE(CONFIG_DVB_DIB7000M)
439a0bf528SMauro Carvalho Chehab extern struct dvb_frontend *dib7000m_attach(struct i2c_adapter *i2c_adap,
449a0bf528SMauro Carvalho Chehab 					    u8 i2c_addr,
459a0bf528SMauro Carvalho Chehab 					    struct dib7000m_config *cfg);
469a0bf528SMauro Carvalho Chehab extern struct i2c_adapter *dib7000m_get_i2c_master(struct dvb_frontend *,
479a0bf528SMauro Carvalho Chehab 						   enum dibx000_i2c_interface,
489a0bf528SMauro Carvalho Chehab 						   int);
499a0bf528SMauro Carvalho Chehab extern int dib7000m_pid_filter(struct dvb_frontend *, u8 id, u16 pid, u8 onoff);
509a0bf528SMauro Carvalho Chehab extern int dib7000m_pid_filter_ctrl(struct dvb_frontend *fe, u8 onoff);
519a0bf528SMauro Carvalho Chehab #else
529a0bf528SMauro Carvalho Chehab static inline
dib7000m_attach(struct i2c_adapter * i2c_adap,u8 i2c_addr,struct dib7000m_config * cfg)539a0bf528SMauro Carvalho Chehab struct dvb_frontend *dib7000m_attach(struct i2c_adapter *i2c_adap,
549a0bf528SMauro Carvalho Chehab 				     u8 i2c_addr, struct dib7000m_config *cfg)
559a0bf528SMauro Carvalho Chehab {
569a0bf528SMauro Carvalho Chehab 	printk(KERN_WARNING "%s: driver disabled by Kconfig\n", __func__);
579a0bf528SMauro Carvalho Chehab 	return NULL;
589a0bf528SMauro Carvalho Chehab }
599a0bf528SMauro Carvalho Chehab 
609a0bf528SMauro Carvalho Chehab static inline
dib7000m_get_i2c_master(struct dvb_frontend * demod,enum dibx000_i2c_interface intf,int gating)619a0bf528SMauro Carvalho Chehab struct i2c_adapter *dib7000m_get_i2c_master(struct dvb_frontend *demod,
629a0bf528SMauro Carvalho Chehab 					    enum dibx000_i2c_interface intf,
639a0bf528SMauro Carvalho Chehab 					    int gating)
649a0bf528SMauro Carvalho Chehab {
659a0bf528SMauro Carvalho Chehab 	printk(KERN_WARNING "%s: driver disabled by Kconfig\n", __func__);
669a0bf528SMauro Carvalho Chehab 	return NULL;
679a0bf528SMauro Carvalho Chehab }
dib7000m_pid_filter(struct dvb_frontend * fe,u8 id,u16 pid,u8 onoff)689a0bf528SMauro Carvalho Chehab static inline int dib7000m_pid_filter(struct dvb_frontend *fe, u8 id,
699a0bf528SMauro Carvalho Chehab 						u16 pid, u8 onoff)
709a0bf528SMauro Carvalho Chehab {
719a0bf528SMauro Carvalho Chehab 	printk(KERN_WARNING "%s: driver disabled by Kconfig\n", __func__);
729a0bf528SMauro Carvalho Chehab 	return -ENODEV;
739a0bf528SMauro Carvalho Chehab }
749a0bf528SMauro Carvalho Chehab 
dib7000m_pid_filter_ctrl(struct dvb_frontend * fe,uint8_t onoff)759a0bf528SMauro Carvalho Chehab static inline int dib7000m_pid_filter_ctrl(struct dvb_frontend *fe,
769a0bf528SMauro Carvalho Chehab 						uint8_t onoff)
779a0bf528SMauro Carvalho Chehab {
789a0bf528SMauro Carvalho Chehab 	printk(KERN_WARNING "%s: driver disabled by Kconfig\n", __func__);
799a0bf528SMauro Carvalho Chehab 	return -ENODEV;
809a0bf528SMauro Carvalho Chehab }
819a0bf528SMauro Carvalho Chehab #endif
829a0bf528SMauro Carvalho Chehab 
839a0bf528SMauro Carvalho Chehab /* TODO
849a0bf528SMauro Carvalho Chehab extern INT dib7000m_set_gpio(struct dibDemod *demod, UCHAR num, UCHAR dir, UCHAR val);
859a0bf528SMauro Carvalho Chehab extern INT dib7000m_enable_vbg_voltage(struct dibDemod *demod);
869a0bf528SMauro Carvalho Chehab extern void dib7000m_set_hostbus_diversity(struct dibDemod *demod, UCHAR onoff);
879a0bf528SMauro Carvalho Chehab extern USHORT dib7000m_get_current_agc_global(struct dibDemod *demod);
889a0bf528SMauro Carvalho Chehab */
899a0bf528SMauro Carvalho Chehab 
909a0bf528SMauro Carvalho Chehab #endif
91