2019-05-20 15:19:02 +08:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0-or-later */
|
2005-04-17 06:20:36 +08:00
|
|
|
/*
|
2007-04-22 06:37:17 +08:00
|
|
|
TDA10021/TDA10023 - Single Chip Cable Channel Receiver driver module
|
|
|
|
used on the the Siemens DVB-C cards
|
2005-04-17 06:20:36 +08:00
|
|
|
|
|
|
|
Copyright (C) 1999 Convergence Integrated Media GmbH <ralph@convergence.de>
|
|
|
|
Copyright (C) 2004 Markus Schulz <msc@antzsystem.de>
|
2005-12-12 16:37:24 +08:00
|
|
|
Support for TDA10021
|
2005-04-17 06:20:36 +08:00
|
|
|
|
|
|
|
*/
|
|
|
|
|
2007-04-22 06:37:17 +08:00
|
|
|
#ifndef TDA1002x_H
|
|
|
|
#define TDA1002x_H
|
2005-04-17 06:20:36 +08:00
|
|
|
|
|
|
|
#include <linux/dvb/frontend.h>
|
|
|
|
|
2008-05-18 09:58:04 +08:00
|
|
|
struct tda1002x_config {
|
|
|
|
/* the demodulator's i2c address */
|
|
|
|
u8 demod_address;
|
|
|
|
u8 invert;
|
|
|
|
};
|
|
|
|
|
2008-06-10 09:53:04 +08:00
|
|
|
enum tda10023_output_mode {
|
|
|
|
TDA10023_OUTPUT_MODE_PARALLEL_A = 0xe0,
|
|
|
|
TDA10023_OUTPUT_MODE_PARALLEL_B = 0xa1,
|
|
|
|
TDA10023_OUTPUT_MODE_PARALLEL_C = 0xa0,
|
|
|
|
TDA10023_OUTPUT_MODE_SERIAL, /* TODO: not implemented */
|
|
|
|
};
|
|
|
|
|
2008-05-18 09:58:04 +08:00
|
|
|
struct tda10023_config {
|
2005-04-17 06:20:36 +08:00
|
|
|
/* the demodulator's i2c address */
|
|
|
|
u8 demod_address;
|
2007-04-22 06:44:10 +08:00
|
|
|
u8 invert;
|
2008-05-18 09:58:04 +08:00
|
|
|
|
|
|
|
/* clock settings */
|
|
|
|
u32 xtal; /* defaults: 28920000 */
|
|
|
|
u8 pll_m; /* defaults: 8 */
|
|
|
|
u8 pll_p; /* defaults: 4 */
|
|
|
|
u8 pll_n; /* defaults: 1 */
|
|
|
|
|
2008-06-10 09:53:04 +08:00
|
|
|
/* MPEG2 TS output mode */
|
|
|
|
u8 output_mode;
|
|
|
|
|
2008-05-18 09:58:04 +08:00
|
|
|
/* input freq offset + baseband conversion type */
|
|
|
|
u16 deltaf;
|
2005-04-17 06:20:36 +08:00
|
|
|
};
|
|
|
|
|
2015-02-19 01:12:42 +08:00
|
|
|
#if IS_REACHABLE(CONFIG_DVB_TDA10021)
|
2007-04-22 06:37:17 +08:00
|
|
|
extern struct dvb_frontend* tda10021_attach(const struct tda1002x_config* config,
|
2005-04-17 06:20:36 +08:00
|
|
|
struct i2c_adapter* i2c, u8 pwm);
|
2006-08-08 20:10:08 +08:00
|
|
|
#else
|
2007-04-22 06:37:17 +08:00
|
|
|
static inline struct dvb_frontend* tda10021_attach(const struct tda1002x_config* config,
|
2006-08-08 20:10:08 +08:00
|
|
|
struct i2c_adapter* i2c, u8 pwm)
|
|
|
|
{
|
2008-04-09 10:20:00 +08:00
|
|
|
printk(KERN_WARNING "%s: driver disabled by Kconfig\n", __func__);
|
2006-08-08 20:10:08 +08:00
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
#endif // CONFIG_DVB_TDA10021
|
2005-04-17 06:20:36 +08:00
|
|
|
|
2015-02-19 01:12:42 +08:00
|
|
|
#if IS_REACHABLE(CONFIG_DVB_TDA10023)
|
2008-05-18 09:58:04 +08:00
|
|
|
extern struct dvb_frontend *tda10023_attach(
|
|
|
|
const struct tda10023_config *config,
|
|
|
|
struct i2c_adapter *i2c, u8 pwm);
|
2007-04-22 06:37:17 +08:00
|
|
|
#else
|
2008-05-18 09:58:04 +08:00
|
|
|
static inline struct dvb_frontend *tda10023_attach(
|
2008-07-16 06:36:46 +08:00
|
|
|
const struct tda10023_config *config,
|
2008-05-18 09:58:04 +08:00
|
|
|
struct i2c_adapter *i2c, u8 pwm)
|
2007-04-22 06:37:17 +08:00
|
|
|
{
|
2008-04-09 10:20:00 +08:00
|
|
|
printk(KERN_WARNING "%s: driver disabled by Kconfig\n", __func__);
|
2007-04-22 06:37:17 +08:00
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
#endif // CONFIG_DVB_TDA10023
|
|
|
|
|
|
|
|
#endif // TDA1002x_H
|