Mauro Carvalho Chehab | 0c20e8c | 2017-12-01 08:47:09 -0500 | [diff] [blame] | 1 | /* |
| 2 | * SPDX-License-Identifier: GPL-2.0 |
| 3 | * tuner-xc2028 |
Mauro Carvalho Chehab | 6cb4587 | 2007-10-02 11:57:03 -0300 | [diff] [blame] | 4 | * |
Mauro Carvalho Chehab | 3259081 | 2018-04-25 05:34:48 -0400 | [diff] [blame] | 5 | * Copyright (c) 2007-2008 Mauro Carvalho Chehab <mchehab@kernel.org> |
Mauro Carvalho Chehab | 6cb4587 | 2007-10-02 11:57:03 -0300 | [diff] [blame] | 6 | */ |
| 7 | |
Mauro Carvalho Chehab | 215b95b | 2007-10-23 15:24:06 -0300 | [diff] [blame] | 8 | #ifndef __TUNER_XC2028_H__ |
| 9 | #define __TUNER_XC2028_H__ |
| 10 | |
Mauro Carvalho Chehab | fada193 | 2017-12-28 13:03:51 -0500 | [diff] [blame] | 11 | #include <media/dvb_frontend.h> |
Mauro Carvalho Chehab | 215b95b | 2007-10-23 15:24:06 -0300 | [diff] [blame] | 12 | |
Mauro Carvalho Chehab | de3fe21 | 2007-10-24 09:22:08 -0300 | [diff] [blame] | 13 | #define XC2028_DEFAULT_FIRMWARE "xc3028-v27.fw" |
Devin Heitmueller | 5ea7fe4 | 2008-09-16 02:02:12 -0300 | [diff] [blame] | 14 | #define XC3028L_DEFAULT_FIRMWARE "xc3028L-v36.fw" |
Mauro Carvalho Chehab | de3fe21 | 2007-10-24 09:22:08 -0300 | [diff] [blame] | 15 | |
Mauro Carvalho Chehab | 66c2d53 | 2007-11-25 19:26:36 -0300 | [diff] [blame] | 16 | /* Dmoduler IF (kHz) */ |
Mauro Carvalho Chehab | 33e5316 | 2008-04-21 06:58:48 -0300 | [diff] [blame] | 17 | #define XC3028_FE_DEFAULT 0 /* Don't load SCODE */ |
Mauro Carvalho Chehab | 66c2d53 | 2007-11-25 19:26:36 -0300 | [diff] [blame] | 18 | #define XC3028_FE_LG60 6000 |
| 19 | #define XC3028_FE_ATI638 6380 |
| 20 | #define XC3028_FE_OREN538 5380 |
| 21 | #define XC3028_FE_OREN36 3600 |
| 22 | #define XC3028_FE_TOYOTA388 3880 |
| 23 | #define XC3028_FE_TOYOTA794 7940 |
| 24 | #define XC3028_FE_DIBCOM52 5200 |
| 25 | #define XC3028_FE_ZARLINK456 4560 |
| 26 | #define XC3028_FE_CHINA 5200 |
Mauro Carvalho Chehab | b542dfd | 2007-11-24 11:07:12 -0300 | [diff] [blame] | 27 | |
Mauro Carvalho Chehab | 0975fc6 | 2008-09-28 02:24:44 -0300 | [diff] [blame] | 28 | enum firmware_type { |
| 29 | XC2028_AUTO = 0, /* By default, auto-detects */ |
| 30 | XC2028_D2633, |
| 31 | XC2028_D2620, |
| 32 | }; |
| 33 | |
Mauro Carvalho Chehab | de3fe21 | 2007-10-24 09:22:08 -0300 | [diff] [blame] | 34 | struct xc2028_ctrl { |
Mauro Carvalho Chehab | de3fe21 | 2007-10-24 09:22:08 -0300 | [diff] [blame] | 35 | char *fname; |
Mauro Carvalho Chehab | 352fae1 | 2007-11-01 16:56:26 -0300 | [diff] [blame] | 36 | int max_len; |
Mauro Carvalho Chehab | e5cc2bf | 2008-01-08 11:26:59 -0300 | [diff] [blame] | 37 | int msleep; |
Chris Pascoe | e0f0b37 | 2007-11-19 11:22:03 -0300 | [diff] [blame] | 38 | unsigned int scode_table; |
Mauro Carvalho Chehab | d74cb25 | 2007-11-24 10:20:15 -0300 | [diff] [blame] | 39 | unsigned int mts :1; |
Mauro Carvalho Chehab | d74cb25 | 2007-11-24 10:20:15 -0300 | [diff] [blame] | 40 | unsigned int input1:1; |
Chris Pascoe | 3dfefc5 | 2007-12-02 10:07:06 -0300 | [diff] [blame] | 41 | unsigned int vhfbw7:1; |
| 42 | unsigned int uhfbw8:1; |
Devin Heitmueller | 93b9992 | 2009-08-03 22:52:59 -0300 | [diff] [blame] | 43 | unsigned int disable_power_mgmt:1; |
Mauro Carvalho Chehab | 2d5024a | 2009-09-14 10:23:20 -0300 | [diff] [blame] | 44 | unsigned int read_not_reliable:1; |
Mauro Carvalho Chehab | 66c2d53 | 2007-11-25 19:26:36 -0300 | [diff] [blame] | 45 | unsigned int demod; |
Mauro Carvalho Chehab | 0975fc6 | 2008-09-28 02:24:44 -0300 | [diff] [blame] | 46 | enum firmware_type type:2; |
Mauro Carvalho Chehab | de3fe21 | 2007-10-24 09:22:08 -0300 | [diff] [blame] | 47 | }; |
| 48 | |
Michel Ludwig | a37b4c9 | 2007-11-16 07:46:14 -0300 | [diff] [blame] | 49 | struct xc2028_config { |
| 50 | struct i2c_adapter *i2c_adap; |
Mauro Carvalho Chehab | 6e6a8b5 | 2018-01-04 13:08:56 -0500 | [diff] [blame] | 51 | u8 i2c_addr; |
Mauro Carvalho Chehab | 71a2ee3 | 2007-11-22 12:19:37 -0300 | [diff] [blame] | 52 | struct xc2028_ctrl *ctrl; |
Michel Ludwig | a37b4c9 | 2007-11-16 07:46:14 -0300 | [diff] [blame] | 53 | }; |
| 54 | |
Mauro Carvalho Chehab | 6cb4587 | 2007-10-02 11:57:03 -0300 | [diff] [blame] | 55 | /* xc2028 commands for callback */ |
| 56 | #define XC2028_TUNER_RESET 0 |
| 57 | #define XC2028_RESET_CLK 1 |
Thierry Reding | 4d37ece | 2011-08-04 04:13:59 -0300 | [diff] [blame] | 58 | #define XC2028_I2C_FLUSH 2 |
Michel Ludwig | 701672e | 2007-07-18 10:29:10 -0300 | [diff] [blame] | 59 | |
Arnd Bergmann | 9b17452 | 2015-02-18 14:12:42 -0300 | [diff] [blame] | 60 | #if IS_REACHABLE(CONFIG_MEDIA_TUNER_XC2028) |
Michael Krufky | 7972f98 | 2007-12-21 16:12:09 -0300 | [diff] [blame] | 61 | extern struct dvb_frontend *xc2028_attach(struct dvb_frontend *fe, |
| 62 | struct xc2028_config *cfg); |
Mauro Carvalho Chehab | 215b95b | 2007-10-23 15:24:06 -0300 | [diff] [blame] | 63 | #else |
Michael Krufky | 7972f98 | 2007-12-21 16:12:09 -0300 | [diff] [blame] | 64 | static inline struct dvb_frontend *xc2028_attach(struct dvb_frontend *fe, |
| 65 | struct xc2028_config *cfg) |
Mauro Carvalho Chehab | 215b95b | 2007-10-23 15:24:06 -0300 | [diff] [blame] | 66 | { |
| 67 | printk(KERN_INFO "%s: not probed - driver disabled by Kconfig\n", |
Harvey Harrison | 7e28adb | 2008-04-08 23:20:00 -0300 | [diff] [blame] | 68 | __func__); |
Michael Krufky | 7972f98 | 2007-12-21 16:12:09 -0300 | [diff] [blame] | 69 | return NULL; |
Mauro Carvalho Chehab | 215b95b | 2007-10-23 15:24:06 -0300 | [diff] [blame] | 70 | } |
| 71 | #endif |
| 72 | |
| 73 | #endif /* __TUNER_XC2028_H__ */ |