blob: bbf1ccee7255bf4a8b2b05473078146444d514a2 [file] [log] [blame]
Thomas Gleixnerc942fdd2019-05-27 08:55:06 +02001/* SPDX-License-Identifier: GPL-2.0-or-later */
Antti Palosaari825b9672008-09-15 15:01:52 -03002/*
Antti Palosaaric89f66f62010-06-17 21:19:13 -03003 * Afatech AF9013 demodulator driver
Antti Palosaari825b9672008-09-15 15:01:52 -03004 *
5 * Copyright (C) 2007 Antti Palosaari <crope@iki.fi>
Antti Palosaarif571e002011-11-28 20:58:11 -03006 * Copyright (C) 2011 Antti Palosaari <crope@iki.fi>
Antti Palosaari825b9672008-09-15 15:01:52 -03007 *
8 * Thanks to Afatech who kindly provided information.
Antti Palosaari825b9672008-09-15 15:01:52 -03009 */
10
Antti Palosaarif571e002011-11-28 20:58:11 -030011#ifndef AF9013_H
12#define AF9013_H
Antti Palosaari825b9672008-09-15 15:01:52 -030013
14#include <linux/dvb/frontend.h>
15
Antti Palosaari82d1ce32017-06-10 20:53:42 -030016/*
17 * I2C address: 0x1c, 0x1d
18 */
Antti Palosaarif571e002011-11-28 20:58:11 -030019
Antti Palosaari82d1ce32017-06-10 20:53:42 -030020/**
21 * struct af9013_platform_data - Platform data for the af9013 driver
22 * @clk: Clock frequency.
23 * @tuner: Used tuner model.
24 * @if_frequency: IF frequency.
25 * @ts_mode: TS mode.
Antti Palosaarieaa455f2017-06-13 20:32:15 -030026 * @ts_output_pin: TS output pin.
Antti Palosaari82d1ce32017-06-10 20:53:42 -030027 * @spec_inv: Input spectrum inverted.
28 * @api_version: Firmware API version.
29 * @gpio: GPIOs.
30 * @get_dvb_frontend: Get DVB frontend callback.
Antti Palosaari83d6b7c2017-06-26 04:57:09 -040031 * @get_i2c_adapter: Get I2C adapter.
32 * @pid_filter_ctrl: Control PID filter.
33 * @pid_filter: Set PID to PID filter.
Antti Palosaari82d1ce32017-06-10 20:53:42 -030034 */
35struct af9013_platform_data {
Antti Palosaarif571e002011-11-28 20:58:11 -030036 /*
Antti Palosaarif571e002011-11-28 20:58:11 -030037 * 20480000, 25000000, 28000000, 28800000
38 */
Antti Palosaari82d1ce32017-06-10 20:53:42 -030039 u32 clk;
Antti Palosaarif571e002011-11-28 20:58:11 -030040#define AF9013_TUNER_MXL5003D 3 /* MaxLinear */
41#define AF9013_TUNER_MXL5005D 13 /* MaxLinear */
42#define AF9013_TUNER_MXL5005R 30 /* MaxLinear */
43#define AF9013_TUNER_ENV77H11D5 129 /* Panasonic */
44#define AF9013_TUNER_MT2060 130 /* Microtune */
45#define AF9013_TUNER_MC44S803 133 /* Freescale */
46#define AF9013_TUNER_QT1010 134 /* Quantek */
47#define AF9013_TUNER_UNKNOWN 140 /* for can tuners ? */
48#define AF9013_TUNER_MT2060_2 147 /* Microtune */
49#define AF9013_TUNER_TDA18271 156 /* NXP */
50#define AF9013_TUNER_QT1010A 162 /* Quantek */
51#define AF9013_TUNER_MXL5007T 177 /* MaxLinear */
52#define AF9013_TUNER_TDA18218 179 /* NXP */
53 u8 tuner;
Antti Palosaarif571e002011-11-28 20:58:11 -030054 u32 if_frequency;
Antti Palosaari82d1ce32017-06-10 20:53:42 -030055#define AF9013_TS_MODE_USB 0
56#define AF9013_TS_MODE_PARALLEL 1
57#define AF9013_TS_MODE_SERIAL 2
58 u8 ts_mode;
Antti Palosaarieaa455f2017-06-13 20:32:15 -030059 u8 ts_output_pin;
Antti Palosaarif571e002011-11-28 20:58:11 -030060 bool spec_inv;
Antti Palosaarif571e002011-11-28 20:58:11 -030061 u8 api_version[4];
Antti Palosaari825b9672008-09-15 15:01:52 -030062#define AF9013_GPIO_ON (1 << 0)
63#define AF9013_GPIO_EN (1 << 1)
64#define AF9013_GPIO_O (1 << 2)
65#define AF9013_GPIO_I (1 << 3)
Antti Palosaari825b9672008-09-15 15:01:52 -030066#define AF9013_GPIO_LO (AF9013_GPIO_ON|AF9013_GPIO_EN)
67#define AF9013_GPIO_HI (AF9013_GPIO_ON|AF9013_GPIO_EN|AF9013_GPIO_O)
Antti Palosaari825b9672008-09-15 15:01:52 -030068#define AF9013_GPIO_TUNER_ON (AF9013_GPIO_ON|AF9013_GPIO_EN)
69#define AF9013_GPIO_TUNER_OFF (AF9013_GPIO_ON|AF9013_GPIO_EN|AF9013_GPIO_O)
Antti Palosaari825b9672008-09-15 15:01:52 -030070 u8 gpio[4];
Antti Palosaari82d1ce32017-06-10 20:53:42 -030071
72 struct dvb_frontend* (*get_dvb_frontend)(struct i2c_client *);
Antti Palosaari22e59e72017-06-22 12:18:21 -040073 struct i2c_adapter* (*get_i2c_adapter)(struct i2c_client *);
Antti Palosaari83d6b7c2017-06-26 04:57:09 -040074 int (*pid_filter_ctrl)(struct dvb_frontend *, int);
75 int (*pid_filter)(struct dvb_frontend *, u8, u16, int);
Antti Palosaari825b9672008-09-15 15:01:52 -030076};
77
Antti Palosaari12c6b222017-06-23 05:31:49 -040078/*
79 * AF9013/5 GPIOs (mostly guessed)
80 * demod#1-gpio#0 - set demod#2 i2c-addr for dual devices
81 * demod#1-gpio#1 - xtal setting (?)
82 * demod#1-gpio#3 - tuner#1
83 * demod#2-gpio#0 - tuner#2
84 * demod#2-gpio#1 - xtal setting (?)
Mauro Carvalho Chehabbe9b53c2017-11-29 14:02:22 -050085 */
Antti Palosaari825b9672008-09-15 15:01:52 -030086
Antti Palosaarif571e002011-11-28 20:58:11 -030087#endif /* AF9013_H */