blob: 165ae29ccac44b570b34b6302e21dbc579d4e47b [file] [log] [blame]
Antti Palosaari825b9672008-09-15 15:01:52 -03001/*
Antti Palosaaric89f66f62010-06-17 21:19:13 -03002 * Afatech AF9013 demodulator driver
Antti Palosaari825b9672008-09-15 15:01:52 -03003 *
4 * Copyright (C) 2007 Antti Palosaari <crope@iki.fi>
Antti Palosaarif571e002011-11-28 20:58:11 -03005 * Copyright (C) 2011 Antti Palosaari <crope@iki.fi>
Antti Palosaari825b9672008-09-15 15:01:52 -03006 *
7 * Thanks to Afatech who kindly provided information.
8 *
9 * This program is free software; you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License as published by
11 * the Free Software Foundation; either version 2 of the License, or
12 * (at your option) any later version.
13 *
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU General Public License for more details.
18 *
Antti Palosaari825b9672008-09-15 15:01:52 -030019 */
20
Antti Palosaarif571e002011-11-28 20:58:11 -030021#ifndef AF9013_H
22#define AF9013_H
Antti Palosaari825b9672008-09-15 15:01:52 -030023
24#include <linux/dvb/frontend.h>
25
Antti Palosaari82d1ce32017-06-10 20:53:42 -030026/*
27 * I2C address: 0x1c, 0x1d
28 */
Antti Palosaarif571e002011-11-28 20:58:11 -030029
Antti Palosaari82d1ce32017-06-10 20:53:42 -030030/**
31 * struct af9013_platform_data - Platform data for the af9013 driver
32 * @clk: Clock frequency.
33 * @tuner: Used tuner model.
34 * @if_frequency: IF frequency.
35 * @ts_mode: TS mode.
Antti Palosaarieaa455f2017-06-13 20:32:15 -030036 * @ts_output_pin: TS output pin.
Antti Palosaari82d1ce32017-06-10 20:53:42 -030037 * @spec_inv: Input spectrum inverted.
38 * @api_version: Firmware API version.
39 * @gpio: GPIOs.
40 * @get_dvb_frontend: Get DVB frontend callback.
Antti Palosaari83d6b7c2017-06-26 04:57:09 -040041 * @get_i2c_adapter: Get I2C adapter.
42 * @pid_filter_ctrl: Control PID filter.
43 * @pid_filter: Set PID to PID filter.
Antti Palosaari82d1ce32017-06-10 20:53:42 -030044 */
45struct af9013_platform_data {
Antti Palosaarif571e002011-11-28 20:58:11 -030046 /*
Antti Palosaarif571e002011-11-28 20:58:11 -030047 * 20480000, 25000000, 28000000, 28800000
48 */
Antti Palosaari82d1ce32017-06-10 20:53:42 -030049 u32 clk;
Antti Palosaarif571e002011-11-28 20:58:11 -030050#define AF9013_TUNER_MXL5003D 3 /* MaxLinear */
51#define AF9013_TUNER_MXL5005D 13 /* MaxLinear */
52#define AF9013_TUNER_MXL5005R 30 /* MaxLinear */
53#define AF9013_TUNER_ENV77H11D5 129 /* Panasonic */
54#define AF9013_TUNER_MT2060 130 /* Microtune */
55#define AF9013_TUNER_MC44S803 133 /* Freescale */
56#define AF9013_TUNER_QT1010 134 /* Quantek */
57#define AF9013_TUNER_UNKNOWN 140 /* for can tuners ? */
58#define AF9013_TUNER_MT2060_2 147 /* Microtune */
59#define AF9013_TUNER_TDA18271 156 /* NXP */
60#define AF9013_TUNER_QT1010A 162 /* Quantek */
61#define AF9013_TUNER_MXL5007T 177 /* MaxLinear */
62#define AF9013_TUNER_TDA18218 179 /* NXP */
63 u8 tuner;
Antti Palosaarif571e002011-11-28 20:58:11 -030064 u32 if_frequency;
Antti Palosaari82d1ce32017-06-10 20:53:42 -030065#define AF9013_TS_MODE_USB 0
66#define AF9013_TS_MODE_PARALLEL 1
67#define AF9013_TS_MODE_SERIAL 2
68 u8 ts_mode;
Antti Palosaarieaa455f2017-06-13 20:32:15 -030069 u8 ts_output_pin;
Antti Palosaarif571e002011-11-28 20:58:11 -030070 bool spec_inv;
Antti Palosaarif571e002011-11-28 20:58:11 -030071 u8 api_version[4];
Antti Palosaari825b9672008-09-15 15:01:52 -030072#define AF9013_GPIO_ON (1 << 0)
73#define AF9013_GPIO_EN (1 << 1)
74#define AF9013_GPIO_O (1 << 2)
75#define AF9013_GPIO_I (1 << 3)
Antti Palosaari825b9672008-09-15 15:01:52 -030076#define AF9013_GPIO_LO (AF9013_GPIO_ON|AF9013_GPIO_EN)
77#define AF9013_GPIO_HI (AF9013_GPIO_ON|AF9013_GPIO_EN|AF9013_GPIO_O)
Antti Palosaari825b9672008-09-15 15:01:52 -030078#define AF9013_GPIO_TUNER_ON (AF9013_GPIO_ON|AF9013_GPIO_EN)
79#define AF9013_GPIO_TUNER_OFF (AF9013_GPIO_ON|AF9013_GPIO_EN|AF9013_GPIO_O)
Antti Palosaari825b9672008-09-15 15:01:52 -030080 u8 gpio[4];
Antti Palosaari82d1ce32017-06-10 20:53:42 -030081
82 struct dvb_frontend* (*get_dvb_frontend)(struct i2c_client *);
Antti Palosaari22e59e72017-06-22 12:18:21 -040083 struct i2c_adapter* (*get_i2c_adapter)(struct i2c_client *);
Antti Palosaari83d6b7c2017-06-26 04:57:09 -040084 int (*pid_filter_ctrl)(struct dvb_frontend *, int);
85 int (*pid_filter)(struct dvb_frontend *, u8, u16, int);
Antti Palosaari825b9672008-09-15 15:01:52 -030086};
87
Antti Palosaari12c6b222017-06-23 05:31:49 -040088/*
89 * AF9013/5 GPIOs (mostly guessed)
90 * demod#1-gpio#0 - set demod#2 i2c-addr for dual devices
91 * demod#1-gpio#1 - xtal setting (?)
92 * demod#1-gpio#3 - tuner#1
93 * demod#2-gpio#0 - tuner#2
94 * demod#2-gpio#1 - xtal setting (?)
Mauro Carvalho Chehabbe9b53c2017-11-29 14:02:22 -050095 */
Antti Palosaari825b9672008-09-15 15:01:52 -030096
Antti Palosaarif571e002011-11-28 20:58:11 -030097#endif /* AF9013_H */