Thomas Gleixner | c942fdd | 2019-05-27 08:55:06 +0200 | [diff] [blame^] | 1 | /* SPDX-License-Identifier: GPL-2.0-or-later */ |
Kozlov Sergey | a6dc60ff | 2015-07-28 11:33:03 -0300 | [diff] [blame] | 2 | /* |
| 3 | * cxd2841er.h |
| 4 | * |
| 5 | * Sony CXD2441ER digital demodulator driver public definitions |
| 6 | * |
| 7 | * Copyright 2012 Sony Corporation |
| 8 | * Copyright (C) 2014 NetUP Inc. |
| 9 | * Copyright (C) 2014 Sergey Kozlov <serjk@netup.ru> |
| 10 | * Copyright (C) 2014 Abylay Ospan <aospan@netup.ru> |
Kozlov Sergey | a6dc60ff | 2015-07-28 11:33:03 -0300 | [diff] [blame] | 11 | */ |
| 12 | |
| 13 | #ifndef CXD2841ER_H |
| 14 | #define CXD2841ER_H |
| 15 | |
Kozlov Sergey | a6dc60ff | 2015-07-28 11:33:03 -0300 | [diff] [blame] | 16 | #include <linux/dvb/frontend.h> |
| 17 | |
Daniel Scheller | 03ab1bd | 2017-04-09 16:38:18 -0300 | [diff] [blame] | 18 | #define CXD2841ER_USE_GATECTRL 1 /* bit 0 */ |
| 19 | #define CXD2841ER_AUTO_IFHZ 2 /* bit 1 */ |
| 20 | #define CXD2841ER_TS_SERIAL 4 /* bit 2 */ |
Daniel Scheller | 7afe510 | 2017-04-09 16:38:19 -0300 | [diff] [blame] | 21 | #define CXD2841ER_ASCOT 8 /* bit 3 */ |
Daniel Scheller | 763f857 | 2017-04-09 16:38:20 -0300 | [diff] [blame] | 22 | #define CXD2841ER_EARLY_TUNE 16 /* bit 4 */ |
Daniel Scheller | e3943aa | 2017-04-09 16:38:21 -0300 | [diff] [blame] | 23 | #define CXD2841ER_NO_WAIT_LOCK 32 /* bit 5 */ |
Daniel Scheller | 14fd862 | 2017-04-09 16:38:22 -0300 | [diff] [blame] | 24 | #define CXD2841ER_NO_AGCNEG 64 /* bit 6 */ |
Daniel Scheller | bf51bbb | 2017-04-09 16:38:23 -0300 | [diff] [blame] | 25 | #define CXD2841ER_TSBITS 128 /* bit 7 */ |
Daniel Scheller | c7518d1 | 2017-04-09 16:38:16 -0300 | [diff] [blame] | 26 | |
Abylay Ospan | 83808c2 | 2016-03-22 19:20:34 -0300 | [diff] [blame] | 27 | enum cxd2841er_xtal { |
| 28 | SONY_XTAL_20500, /* 20.5 MHz */ |
| 29 | SONY_XTAL_24000, /* 24 MHz */ |
| 30 | SONY_XTAL_41000 /* 41 MHz */ |
| 31 | }; |
| 32 | |
Kozlov Sergey | a6dc60ff | 2015-07-28 11:33:03 -0300 | [diff] [blame] | 33 | struct cxd2841er_config { |
| 34 | u8 i2c_addr; |
Abylay Ospan | 83808c2 | 2016-03-22 19:20:34 -0300 | [diff] [blame] | 35 | enum cxd2841er_xtal xtal; |
Daniel Scheller | 050863a | 2017-04-09 16:38:15 -0300 | [diff] [blame] | 36 | u32 flags; |
Kozlov Sergey | a6dc60ff | 2015-07-28 11:33:03 -0300 | [diff] [blame] | 37 | }; |
| 38 | |
| 39 | #if IS_REACHABLE(CONFIG_DVB_CXD2841ER) |
| 40 | extern struct dvb_frontend *cxd2841er_attach_s(struct cxd2841er_config *cfg, |
| 41 | struct i2c_adapter *i2c); |
| 42 | |
Abylay Ospan | 3f3b48a | 2016-05-14 00:08:40 -0300 | [diff] [blame] | 43 | extern struct dvb_frontend *cxd2841er_attach_t_c(struct cxd2841er_config *cfg, |
Kozlov Sergey | a6dc60ff | 2015-07-28 11:33:03 -0300 | [diff] [blame] | 44 | struct i2c_adapter *i2c); |
Kozlov Sergey | a6dc60ff | 2015-07-28 11:33:03 -0300 | [diff] [blame] | 45 | #else |
| 46 | static inline struct dvb_frontend *cxd2841er_attach_s( |
| 47 | struct cxd2841er_config *cfg, |
| 48 | struct i2c_adapter *i2c) |
| 49 | { |
Abylay Ospan | 83808c2 | 2016-03-22 19:20:34 -0300 | [diff] [blame] | 50 | pr_warn("%s: driver disabled by Kconfig\n", __func__); |
Kozlov Sergey | a6dc60ff | 2015-07-28 11:33:03 -0300 | [diff] [blame] | 51 | return NULL; |
| 52 | } |
| 53 | |
Abylay Ospan | 3f3b48a | 2016-05-14 00:08:40 -0300 | [diff] [blame] | 54 | static inline struct dvb_frontend *cxd2841er_attach_t_c( |
Abylay Ospan | 83808c2 | 2016-03-22 19:20:34 -0300 | [diff] [blame] | 55 | struct cxd2841er_config *cfg, struct i2c_adapter *i2c) |
| 56 | { |
| 57 | pr_warn("%s: driver disabled by Kconfig\n", __func__); |
| 58 | return NULL; |
| 59 | } |
| 60 | |
Kozlov Sergey | a6dc60ff | 2015-07-28 11:33:03 -0300 | [diff] [blame] | 61 | #endif |
| 62 | |
| 63 | #endif |