1fc7669c6SThomas Gleixner /* SPDX-License-Identifier: GPL-2.0-only */
29a0bf528SMauro Carvalho Chehab /*
39a0bf528SMauro Carvalho Chehab  * public header file of the frontend drivers for mobile DVB-T demodulators
49a0bf528SMauro Carvalho Chehab  * DiBcom 3000M-B and DiBcom 3000P/M-C (http://www.dibcom.fr/)
59a0bf528SMauro Carvalho Chehab  *
699e44da7SPatrick Boettcher  * Copyright (C) 2004-5 Patrick Boettcher (patrick.boettcher@posteo.de)
79a0bf528SMauro Carvalho Chehab  *
89a0bf528SMauro Carvalho Chehab  * based on GPL code from DibCom, which has
99a0bf528SMauro Carvalho Chehab  *
1099e44da7SPatrick Boettcher  * Copyright (C) 2004 Amaury Demol for DiBcom
119a0bf528SMauro Carvalho Chehab  *
129a0bf528SMauro Carvalho Chehab  * Acknowledgements
139a0bf528SMauro Carvalho Chehab  *
1499e44da7SPatrick Boettcher  *  Amaury Demol from DiBcom for providing specs and driver
159a0bf528SMauro Carvalho Chehab  *  sources, on which this driver (and the dvb-dibusb) are based.
169a0bf528SMauro Carvalho Chehab  *
17577a7ad3SMauro Carvalho Chehab  * see Documentation/driver-api/media/drivers/dvb-usb.rst for more information
189a0bf528SMauro Carvalho Chehab  */
199a0bf528SMauro Carvalho Chehab 
209a0bf528SMauro Carvalho Chehab #ifndef DIB3000_H
219a0bf528SMauro Carvalho Chehab #define DIB3000_H
229a0bf528SMauro Carvalho Chehab 
239a0bf528SMauro Carvalho Chehab #include <linux/dvb/frontend.h>
249a0bf528SMauro Carvalho Chehab 
259a0bf528SMauro Carvalho Chehab struct dib3000_config
269a0bf528SMauro Carvalho Chehab {
279a0bf528SMauro Carvalho Chehab 	/* the demodulator's i2c address */
289a0bf528SMauro Carvalho Chehab 	u8 demod_address;
299a0bf528SMauro Carvalho Chehab };
309a0bf528SMauro Carvalho Chehab 
319a0bf528SMauro Carvalho Chehab struct dib_fe_xfer_ops
329a0bf528SMauro Carvalho Chehab {
339a0bf528SMauro Carvalho Chehab 	/* pid and transfer handling is done in the demodulator */
349a0bf528SMauro Carvalho Chehab 	int (*pid_parse)(struct dvb_frontend *fe, int onoff);
359a0bf528SMauro Carvalho Chehab 	int (*fifo_ctrl)(struct dvb_frontend *fe, int onoff);
369a0bf528SMauro Carvalho Chehab 	int (*pid_ctrl)(struct dvb_frontend *fe, int index, int pid, int onoff);
379a0bf528SMauro Carvalho Chehab 	int (*tuner_pass_ctrl)(struct dvb_frontend *fe, int onoff, u8 pll_ctrl);
389a0bf528SMauro Carvalho Chehab };
399a0bf528SMauro Carvalho Chehab 
409b174527SArnd Bergmann #if IS_REACHABLE(CONFIG_DVB_DIB3000MB)
419a0bf528SMauro Carvalho Chehab extern struct dvb_frontend* dib3000mb_attach(const struct dib3000_config* config,
429a0bf528SMauro Carvalho Chehab 					     struct i2c_adapter* i2c, struct dib_fe_xfer_ops *xfer_ops);
439a0bf528SMauro Carvalho Chehab #else
dib3000mb_attach(const struct dib3000_config * config,struct i2c_adapter * i2c,struct dib_fe_xfer_ops * xfer_ops)449a0bf528SMauro Carvalho Chehab static inline struct dvb_frontend* dib3000mb_attach(const struct dib3000_config* config,
459a0bf528SMauro Carvalho Chehab 					     struct i2c_adapter* i2c, struct dib_fe_xfer_ops *xfer_ops)
469a0bf528SMauro Carvalho Chehab {
479a0bf528SMauro Carvalho Chehab 	printk(KERN_WARNING "%s: driver disabled by Kconfig\n", __func__);
489a0bf528SMauro Carvalho Chehab 	return NULL;
499a0bf528SMauro Carvalho Chehab }
509a0bf528SMauro Carvalho Chehab #endif // CONFIG_DVB_DIB3000MB
519a0bf528SMauro Carvalho Chehab 
529a0bf528SMauro Carvalho Chehab #endif // DIB3000_H
53