dib0070.h 2.1 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17
/*
 * Linux-DVB Driver for DiBcom's DiB0070 base-band RF Tuner.
 *
 * Copyright (C) 2005-7 DiBcom (http://www.dibcom.fr/)
 *
 * This program is free software; you can redistribute it and/or
 *	modify it under the terms of the GNU General Public License as
 *	published by the Free Software Foundation, version 2.
 */
#ifndef DIB0070_H
#define DIB0070_H

struct dvb_frontend;
struct i2c_adapter;

#define DEFAULT_DIB0070_I2C_ADDRESS 0x60

18
struct dib0070_wbd_gain_cfg {
19 20
	u16 freq;
	u16 wbd_gain_val;
21 22
};

23 24 25 26 27 28 29 30 31 32 33
struct dib0070_config {
	u8 i2c_address;

	/* tuner pins controlled externally */
	int (*reset) (struct dvb_frontend *, int);
	int (*sleep) (struct dvb_frontend *, int);

	/*  offset in kHz */
	int freq_offset_khz_uhf;
	int freq_offset_khz_vhf;

34 35 36
	u8 osc_buffer_state;	/* 0= normal, 1= tri-state */
	u32 clock_khz;
	u8 clock_pad_drive;	/* (Drive + 1) * 2mA */
37

38
	u8 invert_iq;		/* invert Q - in case I or Q is inverted on the board */
39

40
	u8 force_crystal_mode;	/* if == 0 -> decision is made in the driver default: <24 -> 2, >=24 -> 1 */
41 42

	u8 flip_chip;
43 44
	u8 enable_third_order_filter;
	u8 charge_pump;
45

46
	const struct dib0070_wbd_gain_cfg *wbd_gain;
47

48
	u8 vga_filter;
49 50
};

51
#if defined(CONFIG_DVB_TUNER_DIB0070) || (defined(CONFIG_DVB_TUNER_DIB0070_MODULE) && defined(MODULE))
52
extern struct dvb_frontend *dib0070_attach(struct dvb_frontend *fe, struct i2c_adapter *i2c, struct dib0070_config *cfg);
53
extern u16 dib0070_wbd_offset(struct dvb_frontend *);
54
extern void dib0070_ctrl_agc_filter(struct dvb_frontend *, u8 open);
55 56
extern u8 dib0070_get_rf_output(struct dvb_frontend *fe);
extern int dib0070_set_rf_output(struct dvb_frontend *fe, u8 no);
57
#else
58
static inline struct dvb_frontend *dib0070_attach(struct dvb_frontend *fe, struct i2c_adapter *i2c, struct dib0070_config *cfg)
59 60 61 62
{
	printk(KERN_WARNING "%s: driver disabled by Kconfig\n", __func__);
	return NULL;
}
63 64 65 66

static inline u16 dib0070_wbd_offset(struct dvb_frontend *fe)
{
	printk(KERN_WARNING "%s: driver disabled by Kconfig\n", __func__);
67
	return 0;
68
}
69 70 71 72 73

static inline void dib0070_ctrl_agc_filter(struct dvb_frontend *fe, u8 open)
{
	printk(KERN_WARNING "%s: driver disabled by Kconfig\n", __func__);
}
74 75
#endif

76
#endif