blob: f03d26954517e7563fd78d5c9b21bc5ab8c85110 [file] [log] [blame]
Patrick Boettcherfb41f5a2005-07-07 17:58:23 -07001/* DVB USB library compliant Linux driver for the WideView/ Yakumo/ Hama/
Rasmus Rohded3c35ac2007-07-21 15:37:35 -03002 * Typhoon/ Yuan/ Miglia DVB-T USB2.0 receiver.
Johannes Stezenbach776338e2005-06-23 22:02:35 -07003 *
Patrick Boettcher99e44da2016-01-24 12:56:58 -02004 * Copyright (C) 2004-5 Patrick Boettcher (patrick.boettcher@posteo.de)
Johannes Stezenbach776338e2005-06-23 22:02:35 -07005 *
Patrick Boettcherd590f9c2005-07-07 17:58:33 -07006 * Thanks to Steve Chang from WideView for providing support for the WT-220U.
7 *
Johannes Stezenbach776338e2005-06-23 22:02:35 -07008 * This program is free software; you can redistribute it and/or modify it
9 * under the terms of the GNU General Public License as published by the Free
10 * Software Foundation, version 2.
11 *
Mauro Carvalho Chehab670d7adb2018-05-08 18:29:30 -030012 * see Documentation/media/dvb-drivers/dvb-usb.rst for more information
Johannes Stezenbach776338e2005-06-23 22:02:35 -070013 */
14#include "dtt200u.h"
15
16/* debug */
17int dvb_usb_dtt200u_debug;
18module_param_named(debug,dvb_usb_dtt200u_debug, int, 0644);
19MODULE_PARM_DESC(debug, "set debugging level (1=info,xfer=2 (or-able))." DVB_USB_DEBUG_STATUS);
20
Janne Grunau78e92002008-04-09 19:13:13 -030021DVB_DEFINE_MOD_OPT_ADAPTER_NR(adapter_nr);
22
Mauro Carvalho Chehabab883e22016-10-07 08:40:43 -030023struct dtt200u_state {
24 unsigned char data[80];
Mauro Carvalho Chehabab883e22016-10-07 08:40:43 -030025};
26
Patrick Boettcherd590f9c2005-07-07 17:58:33 -070027static int dtt200u_power_ctrl(struct dvb_usb_device *d, int onoff)
28{
Mauro Carvalho Chehabab883e22016-10-07 08:40:43 -030029 struct dtt200u_state *st = d->priv;
Mauro Carvalho Chehaba3f9f072016-10-07 13:37:50 -030030 int ret = 0;
Mauro Carvalho Chehabab883e22016-10-07 08:40:43 -030031
Mauro Carvalho Chehab77243252016-11-12 12:46:26 -020032 mutex_lock(&d->data_mutex);
Mauro Carvalho Chehabab883e22016-10-07 08:40:43 -030033
34 st->data[0] = SET_INIT;
Patrick Boettcherd590f9c2005-07-07 17:58:33 -070035
36 if (onoff)
Mauro Carvalho Chehaba3f9f072016-10-07 13:37:50 -030037 ret = dvb_usb_generic_write(d, st->data, 2);
Patrick Boettcherd590f9c2005-07-07 17:58:33 -070038
Mauro Carvalho Chehab77243252016-11-12 12:46:26 -020039 mutex_unlock(&d->data_mutex);
Mauro Carvalho Chehaba3f9f072016-10-07 13:37:50 -030040 return ret;
Patrick Boettcherd590f9c2005-07-07 17:58:33 -070041}
42
Patrick Boettcher4d43e132006-09-30 06:53:48 -030043static int dtt200u_streaming_ctrl(struct dvb_usb_adapter *adap, int onoff)
Johannes Stezenbach776338e2005-06-23 22:02:35 -070044{
Mauro Carvalho Chehab77243252016-11-12 12:46:26 -020045 struct dvb_usb_device *d = adap->dev;
46 struct dtt200u_state *st = d->priv;
Mauro Carvalho Chehaba3f9f072016-10-07 13:37:50 -030047 int ret;
Johannes Stezenbach776338e2005-06-23 22:02:35 -070048
Mauro Carvalho Chehab77243252016-11-12 12:46:26 -020049 mutex_lock(&d->data_mutex);
Mauro Carvalho Chehabab883e22016-10-07 08:40:43 -030050 st->data[0] = SET_STREAMING;
51 st->data[1] = onoff;
Johannes Stezenbach776338e2005-06-23 22:02:35 -070052
Mauro Carvalho Chehaba3f9f072016-10-07 13:37:50 -030053 ret = dvb_usb_generic_write(adap->dev, st->data, 2);
54 if (ret < 0)
55 goto ret;
Mauro Carvalho Chehabab883e22016-10-07 08:40:43 -030056
57 if (onoff)
Mauro Carvalho Chehaba3f9f072016-10-07 13:37:50 -030058 goto ret;
Mauro Carvalho Chehabab883e22016-10-07 08:40:43 -030059
60 st->data[0] = RESET_PID_FILTER;
Mauro Carvalho Chehaba3f9f072016-10-07 13:37:50 -030061 ret = dvb_usb_generic_write(adap->dev, st->data, 1);
Mauro Carvalho Chehabab883e22016-10-07 08:40:43 -030062
Mauro Carvalho Chehaba3f9f072016-10-07 13:37:50 -030063ret:
Mauro Carvalho Chehab77243252016-11-12 12:46:26 -020064 mutex_unlock(&d->data_mutex);
Mauro Carvalho Chehabab883e22016-10-07 08:40:43 -030065
Mauro Carvalho Chehaba3f9f072016-10-07 13:37:50 -030066 return ret;
Johannes Stezenbach776338e2005-06-23 22:02:35 -070067}
68
Patrick Boettcher4d43e132006-09-30 06:53:48 -030069static int dtt200u_pid_filter(struct dvb_usb_adapter *adap, int index, u16 pid, int onoff)
Johannes Stezenbach776338e2005-06-23 22:02:35 -070070{
Mauro Carvalho Chehab77243252016-11-12 12:46:26 -020071 struct dvb_usb_device *d = adap->dev;
72 struct dtt200u_state *st = d->priv;
Mauro Carvalho Chehabab883e22016-10-07 08:40:43 -030073 int ret;
74
Johannes Stezenbach776338e2005-06-23 22:02:35 -070075 pid = onoff ? pid : 0;
76
Mauro Carvalho Chehab77243252016-11-12 12:46:26 -020077 mutex_lock(&d->data_mutex);
Mauro Carvalho Chehabab883e22016-10-07 08:40:43 -030078 st->data[0] = SET_PID_FILTER;
79 st->data[1] = index;
80 st->data[2] = pid & 0xff;
81 st->data[3] = (pid >> 8) & 0x1f;
Johannes Stezenbach776338e2005-06-23 22:02:35 -070082
Mauro Carvalho Chehabab883e22016-10-07 08:40:43 -030083 ret = dvb_usb_generic_write(adap->dev, st->data, 4);
Mauro Carvalho Chehab77243252016-11-12 12:46:26 -020084 mutex_unlock(&d->data_mutex);
Mauro Carvalho Chehabab883e22016-10-07 08:40:43 -030085
86 return ret;
Johannes Stezenbach776338e2005-06-23 22:02:35 -070087}
88
Jonathan McDowella4d020e2016-05-20 12:08:35 -030089static int dtt200u_rc_query(struct dvb_usb_device *d)
Johannes Stezenbach776338e2005-06-23 22:02:35 -070090{
Mauro Carvalho Chehabab883e22016-10-07 08:40:43 -030091 struct dtt200u_state *st = d->priv;
Jonathan McDowella4d020e2016-05-20 12:08:35 -030092 u32 scancode;
Mauro Carvalho Chehaba3f9f072016-10-07 13:37:50 -030093 int ret;
Jonathan McDowella4d020e2016-05-20 12:08:35 -030094
Mauro Carvalho Chehab77243252016-11-12 12:46:26 -020095 mutex_lock(&d->data_mutex);
Mauro Carvalho Chehabab883e22016-10-07 08:40:43 -030096 st->data[0] = GET_RC_CODE;
97
Mauro Carvalho Chehaba3f9f072016-10-07 13:37:50 -030098 ret = dvb_usb_generic_rw(d, st->data, 1, st->data, 5, 0);
99 if (ret < 0)
100 goto ret;
101
Mauro Carvalho Chehabab883e22016-10-07 08:40:43 -0300102 if (st->data[0] == 1) {
Sean Young6d741bf2017-08-07 16:20:58 -0400103 enum rc_proto proto = RC_PROTO_NEC;
Sean Young2ceeca02016-09-21 06:54:19 -0300104
Mauro Carvalho Chehabab883e22016-10-07 08:40:43 -0300105 scancode = st->data[1];
106 if ((u8) ~st->data[1] != st->data[2]) {
Jonathan McDowella4d020e2016-05-20 12:08:35 -0300107 /* Extended NEC */
108 scancode = scancode << 8;
Mauro Carvalho Chehabab883e22016-10-07 08:40:43 -0300109 scancode |= st->data[2];
Sean Young6d741bf2017-08-07 16:20:58 -0400110 proto = RC_PROTO_NECX;
Jonathan McDowella4d020e2016-05-20 12:08:35 -0300111 }
112 scancode = scancode << 8;
Mauro Carvalho Chehabab883e22016-10-07 08:40:43 -0300113 scancode |= st->data[3];
Jonathan McDowella4d020e2016-05-20 12:08:35 -0300114
115 /* Check command checksum is ok */
Mauro Carvalho Chehabab883e22016-10-07 08:40:43 -0300116 if ((u8) ~st->data[3] == st->data[4])
Sean Young2ceeca02016-09-21 06:54:19 -0300117 rc_keydown(d->rc_dev, proto, scancode, 0);
Jonathan McDowella4d020e2016-05-20 12:08:35 -0300118 else
119 rc_keyup(d->rc_dev);
Mauro Carvalho Chehabab883e22016-10-07 08:40:43 -0300120 } else if (st->data[0] == 2) {
Jonathan McDowella4d020e2016-05-20 12:08:35 -0300121 rc_repeat(d->rc_dev);
122 } else {
123 rc_keyup(d->rc_dev);
124 }
125
Mauro Carvalho Chehabab883e22016-10-07 08:40:43 -0300126 if (st->data[0] != 0)
127 deb_info("st->data: %*ph\n", 5, st->data);
Jonathan McDowella4d020e2016-05-20 12:08:35 -0300128
Mauro Carvalho Chehaba3f9f072016-10-07 13:37:50 -0300129ret:
Mauro Carvalho Chehab77243252016-11-12 12:46:26 -0200130 mutex_unlock(&d->data_mutex);
Mauro Carvalho Chehaba3f9f072016-10-07 13:37:50 -0300131 return ret;
Johannes Stezenbach776338e2005-06-23 22:02:35 -0700132}
133
Patrick Boettcher4d43e132006-09-30 06:53:48 -0300134static int dtt200u_frontend_attach(struct dvb_usb_adapter *adap)
Johannes Stezenbach776338e2005-06-23 22:02:35 -0700135{
Michael Krufky77eed212011-09-06 09:31:57 -0300136 adap->fe_adap[0].fe = dtt200u_fe_attach(adap->dev);
Johannes Stezenbach776338e2005-06-23 22:02:35 -0700137 return 0;
138}
139
Patrick Boettcher4d43e132006-09-30 06:53:48 -0300140static struct dvb_usb_device_properties dtt200u_properties;
141static struct dvb_usb_device_properties wt220u_fc_properties;
142static struct dvb_usb_device_properties wt220u_properties;
143static struct dvb_usb_device_properties wt220u_zl0353_properties;
Rasmus Rohded3c35ac2007-07-21 15:37:35 -0300144static struct dvb_usb_device_properties wt220u_miglia_properties;
Johannes Stezenbach776338e2005-06-23 22:02:35 -0700145
146static int dtt200u_usb_probe(struct usb_interface *intf,
147 const struct usb_device_id *id)
148{
Janne Grunau78e92002008-04-09 19:13:13 -0300149 if (0 == dvb_usb_device_init(intf, &dtt200u_properties,
Mauro Carvalho Chehab77243252016-11-12 12:46:26 -0200150 THIS_MODULE, NULL, adapter_nr) ||
Janne Grunau78e92002008-04-09 19:13:13 -0300151 0 == dvb_usb_device_init(intf, &wt220u_properties,
Mauro Carvalho Chehab77243252016-11-12 12:46:26 -0200152 THIS_MODULE, NULL, adapter_nr) ||
Janne Grunau78e92002008-04-09 19:13:13 -0300153 0 == dvb_usb_device_init(intf, &wt220u_fc_properties,
Mauro Carvalho Chehab77243252016-11-12 12:46:26 -0200154 THIS_MODULE, NULL, adapter_nr) ||
Janne Grunau78e92002008-04-09 19:13:13 -0300155 0 == dvb_usb_device_init(intf, &wt220u_zl0353_properties,
Mauro Carvalho Chehab77243252016-11-12 12:46:26 -0200156 THIS_MODULE, NULL, adapter_nr) ||
Janne Grunau78e92002008-04-09 19:13:13 -0300157 0 == dvb_usb_device_init(intf, &wt220u_miglia_properties,
Mauro Carvalho Chehab77243252016-11-12 12:46:26 -0200158 THIS_MODULE, NULL, adapter_nr))
Patrick Boettcherd590f9c2005-07-07 17:58:33 -0700159 return 0;
160
161 return -ENODEV;
Johannes Stezenbach776338e2005-06-23 22:02:35 -0700162}
163
164static struct usb_device_id dtt200u_usb_table [] = {
Patrick Boettcher62703b92005-09-09 13:02:46 -0700165 { USB_DEVICE(USB_VID_WIDEVIEW, USB_PID_DTT200U_COLD) },
166 { USB_DEVICE(USB_VID_WIDEVIEW, USB_PID_DTT200U_WARM) },
167 { USB_DEVICE(USB_VID_WIDEVIEW, USB_PID_WT220U_COLD) },
168 { USB_DEVICE(USB_VID_WIDEVIEW, USB_PID_WT220U_WARM) },
Patrick Boettcherd46e6452006-03-28 16:15:05 -0300169 { USB_DEVICE(USB_VID_WIDEVIEW, USB_PID_WT220U_ZL0353_COLD) },
170 { USB_DEVICE(USB_VID_WIDEVIEW, USB_PID_WT220U_ZL0353_WARM) },
Alexander Tuschen19e22572006-07-16 15:03:17 -0300171 { USB_DEVICE(USB_VID_WIDEVIEW, USB_PID_WT220U_FC_COLD) },
172 { USB_DEVICE(USB_VID_WIDEVIEW, USB_PID_WT220U_FC_WARM) },
Jochen Issingded38d22006-08-19 16:03:21 -0300173 { USB_DEVICE(USB_VID_WIDEVIEW, USB_PID_WT220U_ZAP250_COLD) },
Rasmus Rohded3c35ac2007-07-21 15:37:35 -0300174 { USB_DEVICE(USB_VID_MIGLIA, USB_PID_WT220U_ZAP250_COLD) },
Patrick Boettcher62703b92005-09-09 13:02:46 -0700175 { 0 },
Johannes Stezenbach776338e2005-06-23 22:02:35 -0700176};
177MODULE_DEVICE_TABLE(usb, dtt200u_usb_table);
178
Patrick Boettcher4d43e132006-09-30 06:53:48 -0300179static struct dvb_usb_device_properties dtt200u_properties = {
Johannes Stezenbach776338e2005-06-23 22:02:35 -0700180 .usb_ctrl = CYPRESS_FX2,
181 .firmware = "dvb-usb-dtt200u-01.fw",
182
Mauro Carvalho Chehabab883e22016-10-07 08:40:43 -0300183 .size_of_priv = sizeof(struct dtt200u_state),
184
Patrick Boettcher4d43e132006-09-30 06:53:48 -0300185 .num_adapters = 1,
186 .adapter = {
187 {
Michael Krufky77eed212011-09-06 09:31:57 -0300188 .num_frontends = 1,
189 .fe = {{
Patrick Boettcher4d43e132006-09-30 06:53:48 -0300190 .caps = DVB_USB_ADAP_HAS_PID_FILTER | DVB_USB_ADAP_NEED_PID_FILTERING,
191 .pid_filter_count = 15,
192
Johannes Stezenbach776338e2005-06-23 22:02:35 -0700193 .streaming_ctrl = dtt200u_streaming_ctrl,
194 .pid_filter = dtt200u_pid_filter,
195 .frontend_attach = dtt200u_frontend_attach,
Johannes Stezenbach776338e2005-06-23 22:02:35 -0700196 /* parameter for the MPEG2-data transfer */
Patrick Boettcher4d43e132006-09-30 06:53:48 -0300197 .stream = {
198 .type = USB_BULK,
Johannes Stezenbach776338e2005-06-23 22:02:35 -0700199 .count = 7,
200 .endpoint = 0x02,
201 .u = {
202 .bulk = {
203 .buffersize = 4096,
204 }
205 }
206 },
Michael Krufky77eed212011-09-06 09:31:57 -0300207 }},
Patrick Boettcher4d43e132006-09-30 06:53:48 -0300208 }
209 },
210 .power_ctrl = dtt200u_power_ctrl,
211
Jonathan McDowella4d020e2016-05-20 12:08:35 -0300212 .rc.core = {
Mauro Carvalho Chehabf72a27b2010-07-31 18:04:09 -0300213 .rc_interval = 300,
Jonathan McDowella4d020e2016-05-20 12:08:35 -0300214 .rc_codes = RC_MAP_DTT200U,
Mauro Carvalho Chehabf72a27b2010-07-31 18:04:09 -0300215 .rc_query = dtt200u_rc_query,
Sean Young6d741bf2017-08-07 16:20:58 -0400216 .allowed_protos = RC_PROTO_BIT_NEC,
Mauro Carvalho Chehabf72a27b2010-07-31 18:04:09 -0300217 },
Patrick Boettcher4d43e132006-09-30 06:53:48 -0300218
219 .generic_bulk_ctrl_endpoint = 0x01,
Johannes Stezenbach776338e2005-06-23 22:02:35 -0700220
221 .num_device_descs = 1,
222 .devices = {
Patrick Boettcherd590f9c2005-07-07 17:58:33 -0700223 { .name = "WideView/Yuan/Yakumo/Hama/Typhoon DVB-T USB2.0 (WT-200U)",
Patrick Boettcherfb41f5a2005-07-07 17:58:23 -0700224 .cold_ids = { &dtt200u_usb_table[0], NULL },
Johannes Stezenbach776338e2005-06-23 22:02:35 -0700225 .warm_ids = { &dtt200u_usb_table[1], NULL },
226 },
Al Virodad08df2006-02-01 06:02:50 -0500227 { NULL },
Johannes Stezenbach776338e2005-06-23 22:02:35 -0700228 }
229};
230
Patrick Boettcher4d43e132006-09-30 06:53:48 -0300231static struct dvb_usb_device_properties wt220u_properties = {
Patrick Boettcherd590f9c2005-07-07 17:58:33 -0700232 .usb_ctrl = CYPRESS_FX2,
Patrick Boettcher6ce17c52006-01-09 15:25:45 -0200233 .firmware = "dvb-usb-wt220u-02.fw",
Patrick Boettcherd590f9c2005-07-07 17:58:33 -0700234
Mauro Carvalho Chehabab883e22016-10-07 08:40:43 -0300235 .size_of_priv = sizeof(struct dtt200u_state),
236
Patrick Boettcher4d43e132006-09-30 06:53:48 -0300237 .num_adapters = 1,
238 .adapter = {
239 {
Michael Krufky77eed212011-09-06 09:31:57 -0300240 .num_frontends = 1,
241 .fe = {{
Patrick Boettcher4d43e132006-09-30 06:53:48 -0300242 .caps = DVB_USB_ADAP_HAS_PID_FILTER | DVB_USB_ADAP_NEED_PID_FILTERING,
243 .pid_filter_count = 15,
244
Patrick Boettcherd590f9c2005-07-07 17:58:33 -0700245 .streaming_ctrl = dtt200u_streaming_ctrl,
246 .pid_filter = dtt200u_pid_filter,
247 .frontend_attach = dtt200u_frontend_attach,
Patrick Boettcherd590f9c2005-07-07 17:58:33 -0700248 /* parameter for the MPEG2-data transfer */
Patrick Boettcher4d43e132006-09-30 06:53:48 -0300249 .stream = {
250 .type = USB_BULK,
Patrick Boettcherd590f9c2005-07-07 17:58:33 -0700251 .count = 7,
252 .endpoint = 0x02,
253 .u = {
254 .bulk = {
255 .buffersize = 4096,
256 }
257 }
258 },
Michael Krufky77eed212011-09-06 09:31:57 -0300259 }},
Patrick Boettcher4d43e132006-09-30 06:53:48 -0300260 }
261 },
262 .power_ctrl = dtt200u_power_ctrl,
263
Jonathan McDowella4d020e2016-05-20 12:08:35 -0300264 .rc.core = {
Mauro Carvalho Chehabf72a27b2010-07-31 18:04:09 -0300265 .rc_interval = 300,
Jonathan McDowella4d020e2016-05-20 12:08:35 -0300266 .rc_codes = RC_MAP_DTT200U,
Mauro Carvalho Chehabf72a27b2010-07-31 18:04:09 -0300267 .rc_query = dtt200u_rc_query,
Sean Young6d741bf2017-08-07 16:20:58 -0400268 .allowed_protos = RC_PROTO_BIT_NEC,
Mauro Carvalho Chehabf72a27b2010-07-31 18:04:09 -0300269 },
Patrick Boettcher4d43e132006-09-30 06:53:48 -0300270
271 .generic_bulk_ctrl_endpoint = 0x01,
Patrick Boettcherd590f9c2005-07-07 17:58:33 -0700272
273 .num_device_descs = 1,
274 .devices = {
Patrick Boettcher62703b92005-09-09 13:02:46 -0700275 { .name = "WideView WT-220U PenType Receiver (Typhoon/Freecom)",
Jochen Issingded38d22006-08-19 16:03:21 -0300276 .cold_ids = { &dtt200u_usb_table[2], &dtt200u_usb_table[8], NULL },
Patrick Boettcherd590f9c2005-07-07 17:58:33 -0700277 .warm_ids = { &dtt200u_usb_table[3], NULL },
278 },
Al Virodad08df2006-02-01 06:02:50 -0500279 { NULL },
Patrick Boettcherd590f9c2005-07-07 17:58:33 -0700280 }
281};
282
Patrick Boettcher4d43e132006-09-30 06:53:48 -0300283static struct dvb_usb_device_properties wt220u_fc_properties = {
Alexander Tuschen19e22572006-07-16 15:03:17 -0300284 .usb_ctrl = CYPRESS_FX2,
285 .firmware = "dvb-usb-wt220u-fc03.fw",
286
Mauro Carvalho Chehabab883e22016-10-07 08:40:43 -0300287 .size_of_priv = sizeof(struct dtt200u_state),
288
Patrick Boettcher4d43e132006-09-30 06:53:48 -0300289 .num_adapters = 1,
290 .adapter = {
291 {
Michael Krufky77eed212011-09-06 09:31:57 -0300292 .num_frontends = 1,
293 .fe = {{
Patrick Boettcher4d43e132006-09-30 06:53:48 -0300294 .caps = DVB_USB_ADAP_HAS_PID_FILTER | DVB_USB_ADAP_NEED_PID_FILTERING,
295 .pid_filter_count = 15,
296
Alexander Tuschen19e22572006-07-16 15:03:17 -0300297 .streaming_ctrl = dtt200u_streaming_ctrl,
298 .pid_filter = dtt200u_pid_filter,
299 .frontend_attach = dtt200u_frontend_attach,
Patrick Boettcher4d43e132006-09-30 06:53:48 -0300300 /* parameter for the MPEG2-data transfer */
301 .stream = {
302 .type = USB_BULK,
303 .count = 7,
304 .endpoint = 0x06,
305 .u = {
306 .bulk = {
307 .buffersize = 4096,
308 }
309 }
310 },
Michael Krufky77eed212011-09-06 09:31:57 -0300311 }},
Patrick Boettcher4d43e132006-09-30 06:53:48 -0300312 }
313 },
314 .power_ctrl = dtt200u_power_ctrl,
Alexander Tuschen19e22572006-07-16 15:03:17 -0300315
Jonathan McDowella4d020e2016-05-20 12:08:35 -0300316 .rc.core = {
Mauro Carvalho Chehabf72a27b2010-07-31 18:04:09 -0300317 .rc_interval = 300,
Jonathan McDowella4d020e2016-05-20 12:08:35 -0300318 .rc_codes = RC_MAP_DTT200U,
Mauro Carvalho Chehabf72a27b2010-07-31 18:04:09 -0300319 .rc_query = dtt200u_rc_query,
Sean Young6d741bf2017-08-07 16:20:58 -0400320 .allowed_protos = RC_PROTO_BIT_NEC,
Mauro Carvalho Chehabf72a27b2010-07-31 18:04:09 -0300321 },
Alexander Tuschen19e22572006-07-16 15:03:17 -0300322
323 .generic_bulk_ctrl_endpoint = 0x01,
324
Alexander Tuschen19e22572006-07-16 15:03:17 -0300325 .num_device_descs = 1,
326 .devices = {
327 { .name = "WideView WT-220U PenType Receiver (Typhoon/Freecom)",
328 .cold_ids = { &dtt200u_usb_table[6], NULL },
329 .warm_ids = { &dtt200u_usb_table[7], NULL },
330 },
331 { NULL },
332 }
333};
334
Patrick Boettcher4d43e132006-09-30 06:53:48 -0300335static struct dvb_usb_device_properties wt220u_zl0353_properties = {
Patrick Boettcherd46e6452006-03-28 16:15:05 -0300336 .usb_ctrl = CYPRESS_FX2,
337 .firmware = "dvb-usb-wt220u-zl0353-01.fw",
338
Mauro Carvalho Chehabab883e22016-10-07 08:40:43 -0300339 .size_of_priv = sizeof(struct dtt200u_state),
340
Patrick Boettcher4d43e132006-09-30 06:53:48 -0300341 .num_adapters = 1,
342 .adapter = {
343 {
Michael Krufky77eed212011-09-06 09:31:57 -0300344 .num_frontends = 1,
345 .fe = {{
Patrick Boettcher4d43e132006-09-30 06:53:48 -0300346 .caps = DVB_USB_ADAP_HAS_PID_FILTER | DVB_USB_ADAP_NEED_PID_FILTERING,
347 .pid_filter_count = 15,
348
Patrick Boettcher01451e72006-10-13 11:34:46 -0300349 .streaming_ctrl = dtt200u_streaming_ctrl,
350 .pid_filter = dtt200u_pid_filter,
351 .frontend_attach = dtt200u_frontend_attach,
352 /* parameter for the MPEG2-data transfer */
Patrick Boettcher4d43e132006-09-30 06:53:48 -0300353 .stream = {
354 .type = USB_BULK,
Patrick Boettcher01451e72006-10-13 11:34:46 -0300355 .count = 7,
356 .endpoint = 0x02,
357 .u = {
358 .bulk = {
359 .buffersize = 4096,
360 }
361 }
362 },
Michael Krufky77eed212011-09-06 09:31:57 -0300363 }},
Patrick Boettcher4d43e132006-09-30 06:53:48 -0300364 }
365 },
366 .power_ctrl = dtt200u_power_ctrl,
367
Jonathan McDowella4d020e2016-05-20 12:08:35 -0300368 .rc.core = {
Mauro Carvalho Chehabf72a27b2010-07-31 18:04:09 -0300369 .rc_interval = 300,
Jonathan McDowella4d020e2016-05-20 12:08:35 -0300370 .rc_codes = RC_MAP_DTT200U,
Mauro Carvalho Chehabf72a27b2010-07-31 18:04:09 -0300371 .rc_query = dtt200u_rc_query,
Sean Young6d741bf2017-08-07 16:20:58 -0400372 .allowed_protos = RC_PROTO_BIT_NEC,
Mauro Carvalho Chehabf72a27b2010-07-31 18:04:09 -0300373 },
Patrick Boettcher4d43e132006-09-30 06:53:48 -0300374
375 .generic_bulk_ctrl_endpoint = 0x01,
Patrick Boettcherd46e6452006-03-28 16:15:05 -0300376
377 .num_device_descs = 1,
378 .devices = {
379 { .name = "WideView WT-220U PenType Receiver (based on ZL353)",
380 .cold_ids = { &dtt200u_usb_table[4], NULL },
381 .warm_ids = { &dtt200u_usb_table[5], NULL },
382 },
383 { NULL },
384 }
385};
386
Rasmus Rohded3c35ac2007-07-21 15:37:35 -0300387static struct dvb_usb_device_properties wt220u_miglia_properties = {
388 .usb_ctrl = CYPRESS_FX2,
389 .firmware = "dvb-usb-wt220u-miglia-01.fw",
390
Mauro Carvalho Chehabab883e22016-10-07 08:40:43 -0300391 .size_of_priv = sizeof(struct dtt200u_state),
392
Rasmus Rohded3c35ac2007-07-21 15:37:35 -0300393 .num_adapters = 1,
394 .generic_bulk_ctrl_endpoint = 0x01,
395
396 .num_device_descs = 1,
397 .devices = {
398 { .name = "WideView WT-220U PenType Receiver (Miglia)",
399 .cold_ids = { &dtt200u_usb_table[9], NULL },
400 /* This device turns into WT220U_ZL0353_WARM when fw
401 has been uploaded */
402 .warm_ids = { NULL },
403 },
404 { NULL },
405 }
406};
407
Johannes Stezenbach776338e2005-06-23 22:02:35 -0700408/* usb specific object needed to register this driver with the usb subsystem */
409static struct usb_driver dtt200u_usb_driver = {
Patrick Boettcherd590f9c2005-07-07 17:58:33 -0700410 .name = "dvb_usb_dtt200u",
Patrick Boettcher62703b92005-09-09 13:02:46 -0700411 .probe = dtt200u_usb_probe,
Johannes Stezenbach776338e2005-06-23 22:02:35 -0700412 .disconnect = dvb_usb_device_exit,
Patrick Boettcher62703b92005-09-09 13:02:46 -0700413 .id_table = dtt200u_usb_table,
Johannes Stezenbach776338e2005-06-23 22:02:35 -0700414};
415
Greg Kroah-Hartmanecb3b2b2011-11-18 09:46:12 -0800416module_usb_driver(dtt200u_usb_driver);
Johannes Stezenbach776338e2005-06-23 22:02:35 -0700417
Patrick Boettcher99e44da2016-01-24 12:56:58 -0200418MODULE_AUTHOR("Patrick Boettcher <patrick.boettcher@posteo.de>");
Rasmus Rohded3c35ac2007-07-21 15:37:35 -0300419MODULE_DESCRIPTION("Driver for the WideView/Yakumo/Hama/Typhoon/Club3D/Miglia DVB-T USB2.0 devices");
Johannes Stezenbach776338e2005-06-23 22:02:35 -0700420MODULE_VERSION("1.0");
421MODULE_LICENSE("GPL");