x86, cpufeature: If we disable CLFLUSH, we should disable CLFLUSHOPT
[linux/fpc-iii.git] / drivers / media / dvb-frontends / m88ds3103.h
blobbbb7e3aa56755f886db48ffb6e4c34897b31cb2e
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 /* 24 MHz, normal */
51 #define M88DS3103_TS_PARALLEL_12 3 /* 12 MHz */
52 #define M88DS3103_TS_PARALLEL_16 4 /* 16 MHz */
53 #define M88DS3103_TS_PARALLEL_19_2 5 /* 19.2 MHz */
54 #define M88DS3103_TS_CI 6 /* 6 MHz */
55 u8 ts_mode;
58 * spectrum inversion
59 * Default: 0
61 u8 spec_inv:1;
64 * AGC polarity
65 * Default: 0
67 u8 agc_inv:1;
70 * clock output
71 * Default: M88DS3103_CLOCK_OUT_DISABLED
73 #define M88DS3103_CLOCK_OUT_DISABLED 0
74 #define M88DS3103_CLOCK_OUT_ENABLED 1
75 #define M88DS3103_CLOCK_OUT_ENABLED_DIV2 2
76 u8 clock_out;
79 * DiSEqC envelope mode
80 * Default: 0
82 u8 envelope_mode:1;
85 * AGC configuration
86 * Default: none, must set
88 u8 agc;
92 * Driver implements own I2C-adapter for tuner I2C access. That's since chip
93 * has I2C-gate control which closes gate automatically after I2C transfer.
94 * Using own I2C adapter we can workaround that.
97 #if defined(CONFIG_DVB_M88DS3103) || \
98 (defined(CONFIG_DVB_M88DS3103_MODULE) && defined(MODULE))
99 extern struct dvb_frontend *m88ds3103_attach(
100 const struct m88ds3103_config *config,
101 struct i2c_adapter *i2c,
102 struct i2c_adapter **tuner_i2c);
103 #else
104 static inline struct dvb_frontend *m88ds3103_attach(
105 const struct m88ds3103_config *config,
106 struct i2c_adapter *i2c,
107 struct i2c_adapter **tuner_i2c)
109 pr_warn("%s: driver disabled by Kconfig\n", __func__);
110 return NULL;
112 #endif
114 #endif