[media] rc: img-ir: pass toggle bit to the rc driver
[linux-2.6/btrfs-unstable.git] / drivers / media / dvb-frontends / m88ds3103.h
blob9b3b4962da7c1653171c56d8f2f0dd6693a6c59d
1 /*
2 * Montage M88DS3103 demodulator driver
4 * Copyright (C) 2013 Antti Palosaari <crope@iki.fi>
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2 of the License, or
9 * (at your option) any later version.
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
17 #ifndef M88DS3103_H
18 #define M88DS3103_H
20 #include <linux/dvb/frontend.h>
22 struct m88ds3103_config {
24 * I2C address
25 * Default: none, must set
26 * 0x68, ...
28 u8 i2c_addr;
31 * clock
32 * Default: none, must set
33 * 27000000
35 u32 clock;
38 * max bytes I2C provider is asked to write at once
39 * Default: none, must set
40 * 33, 65, ...
42 u16 i2c_wr_max;
45 * TS output mode
46 * Default: M88DS3103_TS_SERIAL
48 #define M88DS3103_TS_SERIAL 0 /* TS output pin D0, normal */
49 #define M88DS3103_TS_SERIAL_D7 1 /* TS output pin D7 */
50 #define M88DS3103_TS_PARALLEL 2 /* TS Parallel mode */
51 #define M88DS3103_TS_CI 3 /* TS CI Mode */
52 u8 ts_mode;
55 * TS clk in KHz
56 * Default: 0.
58 u32 ts_clk;
61 * TS clk polarity.
62 * Default: 0. 1-active at falling edge; 0-active at rising edge.
64 u8 ts_clk_pol:1;
67 * spectrum inversion
68 * Default: 0
70 u8 spec_inv:1;
73 * AGC polarity
74 * Default: 0
76 u8 agc_inv:1;
79 * clock output
80 * Default: M88DS3103_CLOCK_OUT_DISABLED
82 #define M88DS3103_CLOCK_OUT_DISABLED 0
83 #define M88DS3103_CLOCK_OUT_ENABLED 1
84 #define M88DS3103_CLOCK_OUT_ENABLED_DIV2 2
85 u8 clock_out;
88 * DiSEqC envelope mode
89 * Default: 0
91 u8 envelope_mode:1;
94 * AGC configuration
95 * Default: none, must set
97 u8 agc;
100 * LNB H/V pin polarity
101 * Default: 0.
102 * 1: pin high set to VOLTAGE_13, pin low to set VOLTAGE_18.
103 * 0: pin high set to VOLTAGE_18, pin low to set VOLTAGE_13.
105 u8 lnb_hv_pol:1;
108 * LNB enable pin polarity
109 * Default: 0.
110 * 1: pin high to enable, pin low to disable.
111 * 0: pin high to disable, pin low to enable.
113 u8 lnb_en_pol:1;
117 * Driver implements own I2C-adapter for tuner I2C access. That's since chip
118 * has I2C-gate control which closes gate automatically after I2C transfer.
119 * Using own I2C adapter we can workaround that.
122 #if defined(CONFIG_DVB_M88DS3103) || \
123 (defined(CONFIG_DVB_M88DS3103_MODULE) && defined(MODULE))
124 extern struct dvb_frontend *m88ds3103_attach(
125 const struct m88ds3103_config *config,
126 struct i2c_adapter *i2c,
127 struct i2c_adapter **tuner_i2c);
128 #else
129 static inline struct dvb_frontend *m88ds3103_attach(
130 const struct m88ds3103_config *config,
131 struct i2c_adapter *i2c,
132 struct i2c_adapter **tuner_i2c)
134 pr_warn("%s: driver disabled by Kconfig\n", __func__);
135 return NULL;
137 #endif
139 #endif