^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1) // SPDX-License-Identifier: GPL-2.0-only
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2) /* DVB USB framework compliant Linux driver for the Hauppauge WinTV-NOVA-T usb2
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 3) * DVB-T receiver.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 4) *
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 5) * Copyright (C) 2004-5 Patrick Boettcher (patrick.boettcher@posteo.de)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 6) *
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 7) * see Documentation/driver-api/media/drivers/dvb-usb.rst for more information
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 8) */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 9) #include "dibusb.h"
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 10)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 11) static int debug;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 12) module_param(debug, int, 0644);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 13) MODULE_PARM_DESC(debug, "set debugging level (1=rc,2=eeprom (|-able))." DVB_USB_DEBUG_STATUS);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 14)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 15) DVB_DEFINE_MOD_OPT_ADAPTER_NR(adapter_nr);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 16)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 17) #define deb_rc(args...) dprintk(debug,0x01,args)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 18) #define deb_ee(args...) dprintk(debug,0x02,args)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 19)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 20) /* Hauppauge NOVA-T USB2 keys */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 21) static struct rc_map_table rc_map_haupp_table[] = {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 22) { 0x1e00, KEY_0 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 23) { 0x1e01, KEY_1 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 24) { 0x1e02, KEY_2 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 25) { 0x1e03, KEY_3 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 26) { 0x1e04, KEY_4 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 27) { 0x1e05, KEY_5 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 28) { 0x1e06, KEY_6 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 29) { 0x1e07, KEY_7 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 30) { 0x1e08, KEY_8 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 31) { 0x1e09, KEY_9 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 32) { 0x1e0a, KEY_KPASTERISK },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 33) { 0x1e0b, KEY_RED },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 34) { 0x1e0c, KEY_RADIO },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 35) { 0x1e0d, KEY_MENU },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 36) { 0x1e0e, KEY_GRAVE }, /* # */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 37) { 0x1e0f, KEY_MUTE },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 38) { 0x1e10, KEY_VOLUMEUP },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 39) { 0x1e11, KEY_VOLUMEDOWN },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 40) { 0x1e12, KEY_CHANNEL },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 41) { 0x1e14, KEY_UP },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 42) { 0x1e15, KEY_DOWN },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 43) { 0x1e16, KEY_LEFT },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 44) { 0x1e17, KEY_RIGHT },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 45) { 0x1e18, KEY_VIDEO },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 46) { 0x1e19, KEY_AUDIO },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 47) { 0x1e1a, KEY_IMAGES },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 48) { 0x1e1b, KEY_EPG },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 49) { 0x1e1c, KEY_TV },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 50) { 0x1e1e, KEY_NEXT },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 51) { 0x1e1f, KEY_BACK },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 52) { 0x1e20, KEY_CHANNELUP },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 53) { 0x1e21, KEY_CHANNELDOWN },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 54) { 0x1e24, KEY_LAST }, /* Skip backwards */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 55) { 0x1e25, KEY_OK },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 56) { 0x1e29, KEY_BLUE},
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 57) { 0x1e2e, KEY_GREEN },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 58) { 0x1e30, KEY_PAUSE },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 59) { 0x1e32, KEY_REWIND },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 60) { 0x1e34, KEY_FASTFORWARD },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 61) { 0x1e35, KEY_PLAY },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 62) { 0x1e36, KEY_STOP },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 63) { 0x1e37, KEY_RECORD },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 64) { 0x1e38, KEY_YELLOW },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 65) { 0x1e3b, KEY_GOTO },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 66) { 0x1e3d, KEY_POWER },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 67) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 68)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 69) /* Firmware bug? sometimes, when a new key is pressed, the previous pressed key
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 70) * is delivered. No workaround yet, maybe a new firmware.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 71) */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 72) static int nova_t_rc_query(struct dvb_usb_device *d, u32 *event, int *state)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 73) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 74) u8 *buf, data, toggle, custom;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 75) u16 raw;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 76) int i, ret;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 77) struct dibusb_device_state *st = d->priv;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 78)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 79) buf = kmalloc(5, GFP_KERNEL);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 80) if (!buf)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 81) return -ENOMEM;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 82)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 83) buf[0] = DIBUSB_REQ_POLL_REMOTE;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 84) buf[1] = 0x35;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 85) ret = dvb_usb_generic_rw(d, buf, 2, buf, 5, 0);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 86) if (ret < 0)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 87) goto ret;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 88)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 89) *state = REMOTE_NO_KEY_PRESSED;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 90) switch (buf[0]) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 91) case DIBUSB_RC_HAUPPAUGE_KEY_PRESSED:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 92) raw = ((buf[1] << 8) | buf[2]) >> 3;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 93) toggle = !!(raw & 0x800);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 94) data = raw & 0x3f;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 95) custom = (raw >> 6) & 0x1f;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 96)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 97) deb_rc("raw key code 0x%02x, 0x%02x, 0x%02x to c: %02x d: %02x toggle: %d\n",
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 98) buf[1], buf[2], buf[3], custom, data, toggle);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 99)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 100) for (i = 0; i < ARRAY_SIZE(rc_map_haupp_table); i++) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 101) if (rc5_data(&rc_map_haupp_table[i]) == data &&
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 102) rc5_custom(&rc_map_haupp_table[i]) == custom) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 103)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 104) deb_rc("c: %x, d: %x\n", rc5_data(&rc_map_haupp_table[i]),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 105) rc5_custom(&rc_map_haupp_table[i]));
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 106)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 107) *event = rc_map_haupp_table[i].keycode;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 108) *state = REMOTE_KEY_PRESSED;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 109) if (st->old_toggle == toggle) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 110) if (st->last_repeat_count++ < 2)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 111) *state = REMOTE_NO_KEY_PRESSED;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 112) } else {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 113) st->last_repeat_count = 0;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 114) st->old_toggle = toggle;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 115) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 116) break;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 117) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 118) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 119)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 120) break;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 121) case DIBUSB_RC_HAUPPAUGE_KEY_EMPTY:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 122) default:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 123) break;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 124) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 125)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 126) ret:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 127) kfree(buf);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 128) return ret;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 129) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 130)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 131) static int nova_t_read_mac_address (struct dvb_usb_device *d, u8 mac[6])
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 132) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 133) int i, ret;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 134) u8 b;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 135)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 136) mac[0] = 0x00;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 137) mac[1] = 0x0d;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 138) mac[2] = 0xfe;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 139)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 140) /* this is a complete guess, but works for my box */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 141) for (i = 136; i < 139; i++) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 142) ret = dibusb_read_eeprom_byte(d, i, &b);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 143) if (ret)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 144) return ret;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 145)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 146) mac[5 - (i - 136)] = b;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 147) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 148)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 149) return 0;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 150) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 151)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 152) /* USB Driver stuff */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 153) static struct dvb_usb_device_properties nova_t_properties;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 154)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 155) static int nova_t_probe(struct usb_interface *intf,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 156) const struct usb_device_id *id)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 157) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 158) return dvb_usb_device_init(intf, &nova_t_properties,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 159) THIS_MODULE, NULL, adapter_nr);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 160) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 161)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 162) /* do not change the order of the ID table */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 163) static struct usb_device_id nova_t_table [] = {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 164) /* 00 */ { USB_DEVICE(USB_VID_HAUPPAUGE, USB_PID_WINTV_NOVA_T_USB2_COLD) },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 165) /* 01 */ { USB_DEVICE(USB_VID_HAUPPAUGE, USB_PID_WINTV_NOVA_T_USB2_WARM) },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 166) { } /* Terminating entry */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 167) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 168) MODULE_DEVICE_TABLE(usb, nova_t_table);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 169)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 170) static struct dvb_usb_device_properties nova_t_properties = {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 171) .caps = DVB_USB_IS_AN_I2C_ADAPTER,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 172)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 173) .usb_ctrl = CYPRESS_FX2,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 174) .firmware = "dvb-usb-nova-t-usb2-02.fw",
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 175)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 176) .num_adapters = 1,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 177) .adapter = {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 178) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 179) .num_frontends = 1,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 180) .fe = {{
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 181) .caps = DVB_USB_ADAP_HAS_PID_FILTER | DVB_USB_ADAP_PID_FILTER_CAN_BE_TURNED_OFF,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 182) .pid_filter_count = 32,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 183)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 184) .streaming_ctrl = dibusb2_0_streaming_ctrl,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 185) .pid_filter = dibusb_pid_filter,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 186) .pid_filter_ctrl = dibusb_pid_filter_ctrl,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 187) .frontend_attach = dibusb_dib3000mc_frontend_attach,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 188) .tuner_attach = dibusb_dib3000mc_tuner_attach,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 189)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 190) /* parameter for the MPEG2-data transfer */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 191) .stream = {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 192) .type = USB_BULK,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 193) .count = 7,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 194) .endpoint = 0x06,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 195) .u = {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 196) .bulk = {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 197) .buffersize = 4096,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 198) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 199) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 200) },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 201) }},
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 202) .size_of_priv = sizeof(struct dibusb_state),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 203) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 204) },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 205) .size_of_priv = sizeof(struct dibusb_device_state),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 206)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 207) .power_ctrl = dibusb2_0_power_ctrl,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 208) .read_mac_address = nova_t_read_mac_address,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 209)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 210) .rc.legacy = {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 211) .rc_interval = 100,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 212) .rc_map_table = rc_map_haupp_table,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 213) .rc_map_size = ARRAY_SIZE(rc_map_haupp_table),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 214) .rc_query = nova_t_rc_query,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 215) },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 216)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 217) .i2c_algo = &dibusb_i2c_algo,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 218)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 219) .generic_bulk_ctrl_endpoint = 0x01,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 220)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 221) .num_device_descs = 1,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 222) .devices = {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 223) { "Hauppauge WinTV-NOVA-T usb2",
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 224) { &nova_t_table[0], NULL },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 225) { &nova_t_table[1], NULL },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 226) },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 227) { NULL },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 228) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 229) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 230)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 231) static struct usb_driver nova_t_driver = {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 232) .name = "dvb_usb_nova_t_usb2",
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 233) .probe = nova_t_probe,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 234) .disconnect = dvb_usb_device_exit,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 235) .id_table = nova_t_table,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 236) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 237)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 238) module_usb_driver(nova_t_driver);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 239)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 240) MODULE_AUTHOR("Patrick Boettcher <patrick.boettcher@posteo.de>");
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 241) MODULE_DESCRIPTION("Hauppauge WinTV-NOVA-T usb2");
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 242) MODULE_VERSION("1.0");
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 243) MODULE_LICENSE("GPL");