2019-05-27 14:55:06 +08:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0-or-later */
|
2009-10-26 18:08:17 +08:00
|
|
|
/*
|
|
|
|
* Support for AltoBeam GB20600 (a.k.a DMB-TH) demodulator
|
|
|
|
* ATBM8830, ATBM8831
|
|
|
|
*
|
|
|
|
* Copyright (C) 2009 David T.L. Wong <davidtlwong@gmail.com>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __ATBM8830_H__
|
|
|
|
#define __ATBM8830_H__
|
|
|
|
|
|
|
|
#include <linux/dvb/frontend.h>
|
|
|
|
#include <linux/i2c.h>
|
|
|
|
|
|
|
|
#define ATBM8830_PROD_8830 0
|
|
|
|
#define ATBM8830_PROD_8831 1
|
|
|
|
|
|
|
|
struct atbm8830_config {
|
|
|
|
|
|
|
|
/* product type */
|
|
|
|
u8 prod;
|
|
|
|
|
|
|
|
/* the demodulator's i2c address */
|
|
|
|
u8 demod_address;
|
|
|
|
|
|
|
|
/* parallel or serial transport stream */
|
|
|
|
u8 serial_ts;
|
|
|
|
|
2011-03-31 09:57:33 +08:00
|
|
|
/* transport stream clock output only when receiving valid stream */
|
2009-10-26 18:08:17 +08:00
|
|
|
u8 ts_clk_gated;
|
|
|
|
|
|
|
|
/* Decoder sample TS data at rising edge of clock */
|
|
|
|
u8 ts_sampling_edge;
|
|
|
|
|
|
|
|
/* Oscillator clock frequency */
|
|
|
|
u32 osc_clk_freq; /* in kHz */
|
|
|
|
|
|
|
|
/* IF frequency */
|
|
|
|
u32 if_freq; /* in kHz */
|
|
|
|
|
|
|
|
/* Swap I/Q for zero IF */
|
|
|
|
u8 zif_swap_iq;
|
|
|
|
|
|
|
|
/* Tuner AGC settings */
|
|
|
|
u8 agc_min;
|
|
|
|
u8 agc_max;
|
|
|
|
u8 agc_hold_loop;
|
|
|
|
};
|
|
|
|
|
2015-02-19 01:12:42 +08:00
|
|
|
#if IS_REACHABLE(CONFIG_DVB_ATBM8830)
|
2009-10-26 18:08:17 +08:00
|
|
|
extern struct dvb_frontend *atbm8830_attach(const struct atbm8830_config *config,
|
|
|
|
struct i2c_adapter *i2c);
|
|
|
|
#else
|
|
|
|
static inline
|
|
|
|
struct dvb_frontend *atbm8830_attach(const struct atbm8830_config *config,
|
|
|
|
struct i2c_adapter *i2c) {
|
|
|
|
printk(KERN_WARNING "%s: driver disabled by Kconfig\n", __func__);
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
#endif /* CONFIG_DVB_ATBM8830 */
|
|
|
|
|
|
|
|
#endif /* __ATBM8830_H__ */
|