Commit | Line | Data |
---|---|---|
aacb9d31 ST |
1 | /* |
2 | * Driver for Xceive XC5000 "QAM/8VSB single chip tuner" | |
3 | * | |
6d897616 | 4 | * Copyright (c) 2007 Steven Toth <stoth@linuxtv.org> |
aacb9d31 ST |
5 | * |
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. | |
10 | * | |
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 | * | |
15 | * GNU General Public License for more details. | |
16 | * | |
17 | * You should have received a copy of the GNU General Public License | |
18 | * along with this program; if not, write to the Free Software | |
19 | * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. | |
20 | */ | |
21 | ||
22 | #ifndef __XC5000_H__ | |
23 | #define __XC5000_H__ | |
24 | ||
9dc353c6 | 25 | #include <linux/kconfig.h> |
aacb9d31 ST |
26 | #include <linux/firmware.h> |
27 | ||
28 | struct dvb_frontend; | |
29 | struct i2c_adapter; | |
30 | ||
6fab81df MK |
31 | #define XC5000A 1 |
32 | #define XC5000C 2 | |
76efb0ba | 33 | |
aacb9d31 | 34 | struct xc5000_config { |
27c685a4 ST |
35 | u8 i2c_address; |
36 | u32 if_khz; | |
496e9057 | 37 | u8 radio_input; |
409328a4 | 38 | u16 xtal_khz; |
52e269b1 | 39 | u16 output_amp; |
76efb0ba | 40 | |
6fab81df | 41 | int chip_id; |
aacb9d31 ST |
42 | }; |
43 | ||
27c685a4 ST |
44 | /* xc5000 callback command */ |
45 | #define XC5000_TUNER_RESET 0 | |
46 | ||
496e9057 DH |
47 | /* Possible Radio inputs */ |
48 | #define XC5000_RADIO_NOT_CONFIGURED 0 | |
49 | #define XC5000_RADIO_FM1 1 | |
50 | #define XC5000_RADIO_FM2 2 | |
724dcbfa | 51 | #define XC5000_RADIO_FM1_MONO 3 |
496e9057 | 52 | |
48723543 MK |
53 | /* For each bridge framework, when it attaches either analog or digital, |
54 | * it has to store a reference back to its _core equivalent structure, | |
55 | * so that it can service the hardware by steering gpio's etc. | |
56 | * Each bridge implementation is different so cast devptr accordingly. | |
57 | * The xc5000 driver cares not for this value, other than ensuring | |
58 | * it's passed back to a bridge during tuner_callback(). | |
59 | */ | |
60 | ||
9b174527 | 61 | #if IS_REACHABLE(CONFIG_MEDIA_TUNER_XC5000) |
8f3cd530 | 62 | extern struct dvb_frontend *xc5000_attach(struct dvb_frontend *fe, |
aacb9d31 | 63 | struct i2c_adapter *i2c, |
2e4e98e7 | 64 | const struct xc5000_config *cfg); |
aacb9d31 | 65 | #else |
8f3cd530 | 66 | static inline struct dvb_frontend *xc5000_attach(struct dvb_frontend *fe, |
aacb9d31 | 67 | struct i2c_adapter *i2c, |
2e4e98e7 | 68 | const struct xc5000_config *cfg) |
aacb9d31 | 69 | { |
271ddbf7 | 70 | printk(KERN_WARNING "%s: driver disabled by Kconfig\n", __func__); |
aacb9d31 ST |
71 | return NULL; |
72 | } | |
8f3cd530 | 73 | #endif |
aacb9d31 | 74 | |
8f3cd530 | 75 | #endif |