2019-06-04 08:10:54 +00:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0-only */
|
2011-03-13 04:44:33 +00:00
|
|
|
/*
|
|
|
|
* drxd.h: DRXD DVB-T demodulator driver
|
|
|
|
*
|
|
|
|
* Copyright (C) 2005-2007 Micronas
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _DRXD_H_
|
|
|
|
#define _DRXD_H_
|
|
|
|
|
|
|
|
#include <linux/types.h>
|
|
|
|
#include <linux/i2c.h>
|
|
|
|
|
2011-03-24 16:44:01 +00:00
|
|
|
struct drxd_config {
|
2011-03-13 04:44:33 +00:00
|
|
|
u8 index;
|
|
|
|
|
|
|
|
u8 pll_address;
|
|
|
|
u8 pll_type;
|
|
|
|
#define DRXD_PLL_NONE 0
|
|
|
|
#define DRXD_PLL_DTT7520X 1
|
|
|
|
#define DRXD_PLL_MT3X0823 2
|
|
|
|
|
|
|
|
u32 clock;
|
2011-03-13 04:54:02 +00:00
|
|
|
u8 insert_rs_byte;
|
2011-03-13 04:44:33 +00:00
|
|
|
|
|
|
|
u8 demod_address;
|
|
|
|
u8 demoda_address;
|
|
|
|
u8 demod_revision;
|
|
|
|
|
2011-03-13 05:02:01 +00:00
|
|
|
/* If the tuner is not behind an i2c gate, be sure to flip this bit
|
|
|
|
or else the i2c bus could get wedged */
|
|
|
|
u8 disable_i2c_gate_ctrl;
|
|
|
|
|
2011-03-13 04:44:33 +00:00
|
|
|
u32 IF;
|
2011-03-24 16:44:01 +00:00
|
|
|
s16(*osc_deviation) (void *priv, s16 dev, int flag);
|
2011-03-13 04:44:33 +00:00
|
|
|
};
|
|
|
|
|
2015-02-18 17:12:42 +00:00
|
|
|
#if IS_REACHABLE(CONFIG_DVB_DRXD)
|
2011-03-13 04:44:33 +00:00
|
|
|
extern
|
|
|
|
struct dvb_frontend *drxd_attach(const struct drxd_config *config,
|
|
|
|
void *priv, struct i2c_adapter *i2c,
|
|
|
|
struct device *dev);
|
2012-05-03 21:22:26 +00:00
|
|
|
#else
|
|
|
|
static inline
|
|
|
|
struct dvb_frontend *drxd_attach(const struct drxd_config *config,
|
|
|
|
void *priv, struct i2c_adapter *i2c,
|
|
|
|
struct device *dev)
|
|
|
|
{
|
|
|
|
printk(KERN_INFO "%s: not probed - driver disabled by Kconfig\n",
|
|
|
|
__func__);
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2011-03-13 04:44:33 +00:00
|
|
|
#endif
|