2  * DVB USB Linux driver for Afatech AF9015 DVB-T USB2.0 receiver
 
   4  * Copyright (C) 2007 Antti Palosaari <crope@iki.fi>
 
   6  * Thanks to Afatech who kindly provided information.
 
   8  *    This program is free software; you can redistribute it and/or modify
 
   9  *    it under the terms of the GNU General Public License as published by
 
  10  *    the Free Software Foundation; either version 2 of the License, or
 
  11  *    (at your option) any later version.
 
  13  *    This program is distributed in the hope that it will be useful,
 
  14  *    but WITHOUT ANY WARRANTY; without even the implied warranty of
 
  15  *    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
  16  *    GNU General Public License for more details.
 
  18  *    You should have received a copy of the GNU General Public License
 
  19  *    along with this program; if not, write to the Free Software
 
  20  *    Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
 
  32 static int dvb_usb_af9015_debug;
 
  33 module_param_named(debug, dvb_usb_af9015_debug, int, 0644);
 
  34 MODULE_PARM_DESC(debug, "set debugging level" DVB_USB_DEBUG_STATUS);
 
  35 static int dvb_usb_af9015_remote;
 
  36 module_param_named(remote, dvb_usb_af9015_remote, int, 0644);
 
  37 MODULE_PARM_DESC(remote, "select remote");
 
  38 DVB_DEFINE_MOD_OPT_ADAPTER_NR(adapter_nr);
 
  40 static DEFINE_MUTEX(af9015_usb_mutex);
 
  42 static struct af9015_config af9015_config;
 
  43 static struct dvb_usb_device_properties af9015_properties[2];
 
  44 static int af9015_properties_count = ARRAY_SIZE(af9015_properties);
 
  46 static struct af9013_config af9015_af9013_config[] = {
 
  48                 .demod_address = AF9015_I2C_DEMOD,
 
  49                 .output_mode = AF9013_OUTPUT_MODE_USB,
 
  50                 .api_version = { 0, 1, 9, 0 },
 
  51                 .gpio[0] = AF9013_GPIO_HI,
 
  52                 .gpio[3] = AF9013_GPIO_TUNER_ON,
 
  55                 .output_mode = AF9013_OUTPUT_MODE_SERIAL,
 
  56                 .api_version = { 0, 1, 9, 0 },
 
  57                 .gpio[0] = AF9013_GPIO_TUNER_ON,
 
  58                 .gpio[1] = AF9013_GPIO_LO,
 
  62 static int af9015_rw_udev(struct usb_device *udev, struct req_t *req)
 
  68         static u8 seq; /* packet sequence number */
 
  70         if (mutex_lock_interruptible(&af9015_usb_mutex) < 0)
 
  75         buf[2] = req->i2c_addr;
 
  76         buf[3] = req->addr >> 8;
 
  77         buf[4] = req->addr & 0xff;
 
  79         buf[6] = req->addr_len;
 
  80         buf[7] = req->data_len;
 
  92                 buf[2] |= 0x01; /* set I2C direction */
 
  94                 buf[0] = READ_WRITE_I2C;
 
  97                 if (((req->addr & 0xff00) == 0xff00) ||
 
  98                     ((req->addr & 0xae00) == 0xae00))
 
  99                         buf[0] = WRITE_VIRTUAL_MEMORY;
 
 100         case WRITE_VIRTUAL_MEMORY:
 
 102         case DOWNLOAD_FIRMWARE:
 
 105                 err("unknown command:%d", req->cmd);
 
 110         /* write requested */
 
 112                 memcpy(&buf[8], req->data, req->data_len);
 
 113                 msg_len += req->data_len;
 
 116         debug_dump(buf, msg_len, deb_xfer);
 
 119         ret = usb_bulk_msg(udev, usb_sndbulkpipe(udev, 0x02), buf, msg_len,
 
 120         &act_len, AF9015_USB_TIMEOUT);
 
 122                 err("bulk message failed:%d (%d/%d)", ret, msg_len, act_len);
 
 124                 if (act_len != msg_len)
 
 125                         ret = -1; /* all data is not send */
 
 129         /* no ack for those packets */
 
 130         if (req->cmd == DOWNLOAD_FIRMWARE || req->cmd == RECONNECT_USB)
 
 133         /* receive ack and data if read req */
 
 134         msg_len = 1 + 1 + req->data_len;  /* seq + status + data len */
 
 135         ret = usb_bulk_msg(udev, usb_rcvbulkpipe(udev, 0x81), buf, msg_len,
 
 136                            &act_len, AF9015_USB_TIMEOUT);
 
 138                 err("recv bulk message failed:%d", ret);
 
 144         debug_dump(buf, act_len, deb_xfer);
 
 146         /* remote controller query status is 1 if remote code is not received */
 
 147         if (req->cmd == GET_IR_CODE && buf[1] == 1) {
 
 148                 buf[1] = 0; /* clear command "error" status */
 
 149                 memset(&buf[2], 0, req->data_len);
 
 150                 buf[3] = 1; /* no remote code received mark */
 
 155                 err("command failed:%d", buf[1]);
 
 160         /* read request, copy returned data to return buf */
 
 162                 memcpy(req->data, &buf[2], req->data_len);
 
 166         mutex_unlock(&af9015_usb_mutex);
 
 171 static int af9015_ctrl_msg(struct dvb_usb_device *d, struct req_t *req)
 
 173         return af9015_rw_udev(d->udev, req);
 
 176 static int af9015_write_regs(struct dvb_usb_device *d, u16 addr, u8 *val,
 
 179         struct req_t req = {WRITE_MEMORY, AF9015_I2C_DEMOD, addr, 0, 0, len,
 
 181         return af9015_ctrl_msg(d, &req);
 
 184 static int af9015_write_reg(struct dvb_usb_device *d, u16 addr, u8 val)
 
 186         return af9015_write_regs(d, addr, &val, 1);
 
 189 static int af9015_read_reg(struct dvb_usb_device *d, u16 addr, u8 *val)
 
 191         struct req_t req = {READ_MEMORY, AF9015_I2C_DEMOD, addr, 0, 0, 1, val};
 
 192         return af9015_ctrl_msg(d, &req);
 
 195 static int af9015_write_reg_i2c(struct dvb_usb_device *d, u8 addr, u16 reg,
 
 198         struct req_t req = {WRITE_I2C, addr, reg, 1, 1, 1, &val};
 
 200         if (addr == af9015_af9013_config[0].demod_address ||
 
 201             addr == af9015_af9013_config[1].demod_address)
 
 204         return af9015_ctrl_msg(d, &req);
 
 207 static int af9015_read_reg_i2c(struct dvb_usb_device *d, u8 addr, u16 reg,
 
 210         struct req_t req = {READ_I2C, addr, reg, 0, 1, 1, val};
 
 212         if (addr == af9015_af9013_config[0].demod_address ||
 
 213             addr == af9015_af9013_config[1].demod_address)
 
 216         return af9015_ctrl_msg(d, &req);
 
 219 static int af9015_i2c_xfer(struct i2c_adapter *adap, struct i2c_msg msg[],
 
 222         struct dvb_usb_device *d = i2c_get_adapdata(adap);
 
 228 /* TODO: implement bus lock
 
 230 The bus lock is needed because there is two tuners both using same I2C-address.
 
 231 Due to that the only way to select correct tuner is use demodulator I2C-gate.
 
 233 ................................................
 
 234 . AF9015 includes integrated AF9013 demodulator.
 
 235 . ____________                   ____________  .                ____________
 
 236 .|     uC     |                 |   demod    | .               |    tuner   |
 
 237 .|------------|                 |------------| .               |------------|
 
 238 .|   AF9015   |                 |  AF9013/5  | .               |   MXL5003  |
 
 239 .|            |--+----I2C-------|-----/ -----|-.-----I2C-------|            |
 
 240 .|            |  |              | addr 0x38  | .               |  addr 0xc6 |
 
 241 .|____________|  |              |____________| .               |____________|
 
 242 .................|..............................
 
 243                  |               ____________                   ____________
 
 244                  |              |   demod    |                 |    tuner   |
 
 245                  |              |------------|                 |------------|
 
 246                  |              |   AF9013   |                 |   MXL5003  |
 
 247                  +----I2C-------|-----/ -----|-------I2C-------|            |
 
 248                                 | addr 0x3a  |                 |  addr 0xc6 |
 
 249                                 |____________|                 |____________|
 
 251         if (mutex_lock_interruptible(&d->i2c_mutex) < 0)
 
 255                 if (msg[i].addr == af9015_af9013_config[0].demod_address ||
 
 256                     msg[i].addr == af9015_af9013_config[1].demod_address) {
 
 257                         addr = msg[i].buf[0] << 8;
 
 258                         addr += msg[i].buf[1];
 
 259                         mbox = msg[i].buf[2];
 
 262                         addr = msg[i].buf[0];
 
 267                 if (num > i + 1 && (msg[i+1].flags & I2C_M_RD)) {
 
 269                                 af9015_af9013_config[0].demod_address)
 
 270                                 req.cmd = READ_MEMORY;
 
 273                         req.i2c_addr = msg[i].addr;
 
 276                         req.addr_len = addr_len;
 
 277                         req.data_len = msg[i+1].len;
 
 278                         req.data = &msg[i+1].buf[0];
 
 279                         ret = af9015_ctrl_msg(d, &req);
 
 281                 } else if (msg[i].flags & I2C_M_RD) {
 
 284                                 af9015_af9013_config[0].demod_address)
 
 288                         req.i2c_addr = msg[i].addr;
 
 291                         req.addr_len = addr_len;
 
 292                         req.data_len = msg[i].len;
 
 293                         req.data = &msg[i].buf[0];
 
 294                         ret = af9015_ctrl_msg(d, &req);
 
 298                                 af9015_af9013_config[0].demod_address)
 
 299                                 req.cmd = WRITE_MEMORY;
 
 302                         req.i2c_addr = msg[i].addr;
 
 305                         req.addr_len = addr_len;
 
 306                         req.data_len = msg[i].len-addr_len;
 
 307                         req.data = &msg[i].buf[addr_len];
 
 308                         ret = af9015_ctrl_msg(d, &req);
 
 318         mutex_unlock(&d->i2c_mutex);
 
 323 static u32 af9015_i2c_func(struct i2c_adapter *adapter)
 
 328 static struct i2c_algorithm af9015_i2c_algo = {
 
 329         .master_xfer = af9015_i2c_xfer,
 
 330         .functionality = af9015_i2c_func,
 
 333 static int af9015_do_reg_bit(struct dvb_usb_device *d, u16 addr, u8 bit, u8 op)
 
 338         ret = af9015_read_reg(d, addr, &val);
 
 352         return af9015_write_reg(d, addr, val);
 
 355 static int af9015_set_reg_bit(struct dvb_usb_device *d, u16 addr, u8 bit)
 
 357         return af9015_do_reg_bit(d, addr, bit, 1);
 
 360 static int af9015_clear_reg_bit(struct dvb_usb_device *d, u16 addr, u8 bit)
 
 362         return af9015_do_reg_bit(d, addr, bit, 0);
 
 365 static int af9015_init_endpoint(struct dvb_usb_device *d)
 
 370         deb_info("%s: USB speed:%d\n", __func__, d->udev->speed);
 
 372 #define TS_PACKET_SIZE            188
 
 374 #define TS_USB20_PACKET_COUNT     348
 
 375 #define TS_USB20_FRAME_SIZE       (TS_PACKET_SIZE*TS_USB20_PACKET_COUNT)
 
 377 #define TS_USB11_PACKET_COUNT      21
 
 378 #define TS_USB11_FRAME_SIZE       (TS_PACKET_SIZE*TS_USB11_PACKET_COUNT)
 
 380 #define TS_USB20_MAX_PACKET_SIZE  512
 
 381 #define TS_USB11_MAX_PACKET_SIZE   64
 
 383         if (d->udev->speed == USB_SPEED_FULL) {
 
 384                 frame_size = TS_USB11_FRAME_SIZE/4;
 
 385                 packet_size = TS_USB11_MAX_PACKET_SIZE/4;
 
 387                 frame_size = TS_USB20_FRAME_SIZE/4;
 
 388                 packet_size = TS_USB20_MAX_PACKET_SIZE/4;
 
 391         ret = af9015_set_reg_bit(d, 0xd507, 2); /* assert EP4 reset */
 
 394         ret = af9015_set_reg_bit(d, 0xd50b, 1); /* assert EP5 reset */
 
 397         ret = af9015_clear_reg_bit(d, 0xdd11, 5); /* disable EP4 */
 
 400         ret = af9015_clear_reg_bit(d, 0xdd11, 6); /* disable EP5 */
 
 403         ret = af9015_set_reg_bit(d, 0xdd11, 5); /* enable EP4 */
 
 406         if (af9015_config.dual_mode) {
 
 407                 ret = af9015_set_reg_bit(d, 0xdd11, 6); /* enable EP5 */
 
 411         ret = af9015_clear_reg_bit(d, 0xdd13, 5); /* disable EP4 NAK */
 
 414         if (af9015_config.dual_mode) {
 
 415                 ret = af9015_clear_reg_bit(d, 0xdd13, 6); /* disable EP5 NAK */
 
 419         /* EP4 xfer length */
 
 420         ret = af9015_write_reg(d, 0xdd88, frame_size & 0xff);
 
 423         ret = af9015_write_reg(d, 0xdd89, frame_size >> 8);
 
 426         /* EP5 xfer length */
 
 427         ret = af9015_write_reg(d, 0xdd8a, frame_size & 0xff);
 
 430         ret = af9015_write_reg(d, 0xdd8b, frame_size >> 8);
 
 433         ret = af9015_write_reg(d, 0xdd0c, packet_size); /* EP4 packet size */
 
 436         ret = af9015_write_reg(d, 0xdd0d, packet_size); /* EP5 packet size */
 
 439         ret = af9015_clear_reg_bit(d, 0xd507, 2); /* negate EP4 reset */
 
 442         if (af9015_config.dual_mode) {
 
 443                 ret = af9015_clear_reg_bit(d, 0xd50b, 1); /* negate EP5 reset */
 
 448         /* enable / disable mp2if2 */
 
 449         if (af9015_config.dual_mode)
 
 450                 ret = af9015_set_reg_bit(d, 0xd50b, 0);
 
 452                 ret = af9015_clear_reg_bit(d, 0xd50b, 0);
 
 455                 err("endpoint init failed:%d", ret);
 
 459 static int af9015_copy_firmware(struct dvb_usb_device *d)
 
 464         struct req_t req = {COPY_FIRMWARE, 0, 0x5100, 0, 0, sizeof(fw_params),
 
 466         deb_info("%s:\n", __func__);
 
 468         fw_params[0] = af9015_config.firmware_size >> 8;
 
 469         fw_params[1] = af9015_config.firmware_size & 0xff;
 
 470         fw_params[2] = af9015_config.firmware_checksum >> 8;
 
 471         fw_params[3] = af9015_config.firmware_checksum & 0xff;
 
 473         /* wait 2nd demodulator ready */
 
 476         ret = af9015_read_reg_i2c(d, 0x3a, 0x98be, &val);
 
 480                 deb_info("%s: firmware status:%02x\n", __func__, val);
 
 482         if (val == 0x0c) /* fw is running, no need for download */
 
 485         /* set I2C master clock to fast (to speed up firmware copy) */
 
 486         ret = af9015_write_reg(d, 0xd416, 0x04); /* 0x04 * 400ns */
 
 493         ret = af9015_ctrl_msg(d, &req);
 
 495                 err("firmware copy cmd failed:%d", ret);
 
 496         deb_info("%s: firmware copy done\n", __func__);
 
 498         /* set I2C master clock back to normal */
 
 499         ret = af9015_write_reg(d, 0xd416, 0x14); /* 0x14 * 400ns */
 
 503         /* request boot firmware */
 
 504         ret = af9015_write_reg_i2c(d, af9015_af9013_config[1].demod_address,
 
 506         deb_info("%s: firmware boot cmd status:%d\n", __func__, ret);
 
 510         for (i = 0; i < 15; i++) {
 
 513                 /* check firmware status */
 
 514                 ret = af9015_read_reg_i2c(d,
 
 515                         af9015_af9013_config[1].demod_address, 0x98be, &val);
 
 516                 deb_info("%s: firmware status cmd status:%d fw status:%02x\n",
 
 521                 if (val == 0x0c || val == 0x04) /* success or fail */
 
 526                 err("firmware did not run");
 
 528         } else if (val != 0x0c) {
 
 529                 err("firmware boot timeout");
 
 539 static int af9015_eeprom_dump(struct dvb_usb_device *d)
 
 541         char buf[52], buf2[4];
 
 544         for (reg = 0; ; reg++) {
 
 547                                 deb_info("%s\n", buf);
 
 548                         sprintf(buf, "%02x: ", reg);
 
 550                 if (af9015_read_reg_i2c(d, AF9015_I2C_EEPROM, reg, &val) == 0)
 
 551                         sprintf(buf2, "%02x ", val);
 
 558         deb_info("%s\n", buf);
 
 562 static int af9015_download_ir_table(struct dvb_usb_device *d)
 
 564         int i, packets = 0, ret;
 
 565         u16 addr = 0x9a56; /* ir-table start address */
 
 566         struct req_t req = {WRITE_MEMORY, 0, 0, 0, 0, 1, NULL};
 
 568         deb_info("%s:\n", __func__);
 
 570         data = af9015_config.ir_table;
 
 571         packets = af9015_config.ir_table_size;
 
 577         /* load remote ir-table */
 
 578         for (i = 0; i < packets; i++) {
 
 581                 ret = af9015_ctrl_msg(d, &req);
 
 583                         err("ir-table download failed at packet %d with " \
 
 593 static int af9015_init(struct dvb_usb_device *d)
 
 596         deb_info("%s:\n", __func__);
 
 598         ret = af9015_init_endpoint(d);
 
 602         ret = af9015_download_ir_table(d);
 
 610 static int af9015_pid_filter_ctrl(struct dvb_usb_adapter *adap, int onoff)
 
 613         deb_info("%s: onoff:%d\n", __func__, onoff);
 
 616                 ret = af9015_set_reg_bit(adap->dev, 0xd503, 0);
 
 618                 ret = af9015_clear_reg_bit(adap->dev, 0xd503, 0);
 
 623 static int af9015_pid_filter(struct dvb_usb_adapter *adap, int index, u16 pid,
 
 629         deb_info("%s: set pid filter, index %d, pid %x, onoff %d\n",
 
 630                 __func__, index, pid, onoff);
 
 632         ret = af9015_write_reg(adap->dev, 0xd505, (pid & 0xff));
 
 636         ret = af9015_write_reg(adap->dev, 0xd506, (pid >> 8));
 
 640         idx = ((index & 0x1f) | (1 << 5));
 
 641         ret = af9015_write_reg(adap->dev, 0xd504, idx);
 
 647 static int af9015_download_firmware(struct usb_device *udev,
 
 648         const struct firmware *fw)
 
 650         int i, len, packets, remainder, ret;
 
 651         struct req_t req = {DOWNLOAD_FIRMWARE, 0, 0, 0, 0, 0, NULL};
 
 652         u16 addr = 0x5100; /* firmware start address */
 
 655         deb_info("%s:\n", __func__);
 
 658         for (i = 0; i < fw->size; i++)
 
 659                 checksum += fw->data[i];
 
 661         af9015_config.firmware_size = fw->size;
 
 662         af9015_config.firmware_checksum = checksum;
 
 664         #define FW_PACKET_MAX_DATA  55
 
 666         packets = fw->size / FW_PACKET_MAX_DATA;
 
 667         remainder = fw->size % FW_PACKET_MAX_DATA;
 
 668         len = FW_PACKET_MAX_DATA;
 
 669         for (i = 0; i <= packets; i++) {
 
 670                 if (i == packets)  /* set size of the last packet */
 
 674                 req.data = (u8 *)(fw->data + i * FW_PACKET_MAX_DATA);
 
 676                 addr += FW_PACKET_MAX_DATA;
 
 678                 ret = af9015_rw_udev(udev, &req);
 
 680                         err("firmware download failed at packet %d with " \
 
 686         /* firmware loaded, request boot */
 
 688         ret = af9015_rw_udev(udev, &req);
 
 690                 err("firmware boot failed:%d", ret);
 
 698 static int af9015_read_config(struct usb_device *udev)
 
 701         u8 val, i, offset = 0;
 
 702         struct req_t req = {READ_I2C, AF9015_I2C_EEPROM, 0, 0, 1, 1, &val};
 
 703         char manufacturer[10];
 
 705         /* IR remote controller */
 
 706         req.addr = AF9015_EEPROM_IR_MODE;
 
 707         /* first message will timeout often due to possible hw bug */
 
 708         for (i = 0; i < 4; i++) {
 
 709                 ret = af9015_rw_udev(udev, &req);
 
 715         deb_info("%s: IR mode:%d\n", __func__, val);
 
 716         for (i = 0; i < af9015_properties_count; i++) {
 
 717                 if (val == AF9015_IR_MODE_DISABLED || val == 0x04) {
 
 718                         af9015_properties[i].rc_key_map = NULL;
 
 719                         af9015_properties[i].rc_key_map_size  = 0;
 
 720                 } else if (dvb_usb_af9015_remote) {
 
 721                         /* load remote defined as module param */
 
 722                         switch (dvb_usb_af9015_remote) {
 
 723                         case AF9015_REMOTE_A_LINK_DTU_M:
 
 724                                 af9015_properties[i].rc_key_map =
 
 725                                   af9015_rc_keys_a_link;
 
 726                                 af9015_properties[i].rc_key_map_size =
 
 727                                   ARRAY_SIZE(af9015_rc_keys_a_link);
 
 728                                 af9015_config.ir_table = af9015_ir_table_a_link;
 
 729                                 af9015_config.ir_table_size =
 
 730                                   ARRAY_SIZE(af9015_ir_table_a_link);
 
 732                         case AF9015_REMOTE_MSI_DIGIVOX_MINI_II_V3:
 
 733                                 af9015_properties[i].rc_key_map =
 
 735                                 af9015_properties[i].rc_key_map_size =
 
 736                                   ARRAY_SIZE(af9015_rc_keys_msi);
 
 737                                 af9015_config.ir_table = af9015_ir_table_msi;
 
 738                                 af9015_config.ir_table_size =
 
 739                                   ARRAY_SIZE(af9015_ir_table_msi);
 
 741                         case AF9015_REMOTE_MYGICTV_U718:
 
 742                                 af9015_properties[i].rc_key_map =
 
 743                                   af9015_rc_keys_mygictv;
 
 744                                 af9015_properties[i].rc_key_map_size =
 
 745                                   ARRAY_SIZE(af9015_rc_keys_mygictv);
 
 746                                 af9015_config.ir_table =
 
 747                                   af9015_ir_table_mygictv;
 
 748                                 af9015_config.ir_table_size =
 
 749                                   ARRAY_SIZE(af9015_ir_table_mygictv);
 
 751                         case AF9015_REMOTE_DIGITTRADE_DVB_T:
 
 752                                 af9015_properties[i].rc_key_map =
 
 753                                   af9015_rc_keys_digittrade;
 
 754                                 af9015_properties[i].rc_key_map_size =
 
 755                                   ARRAY_SIZE(af9015_rc_keys_digittrade);
 
 756                                 af9015_config.ir_table =
 
 757                                   af9015_ir_table_digittrade;
 
 758                                 af9015_config.ir_table_size =
 
 759                                   ARRAY_SIZE(af9015_ir_table_digittrade);
 
 761                         case AF9015_REMOTE_AVERMEDIA_KS:
 
 762                                 af9015_properties[i].rc_key_map =
 
 763                                   af9015_rc_keys_avermedia;
 
 764                                 af9015_properties[i].rc_key_map_size =
 
 765                                   ARRAY_SIZE(af9015_rc_keys_avermedia);
 
 766                                 af9015_config.ir_table =
 
 767                                   af9015_ir_table_avermedia_ks;
 
 768                                 af9015_config.ir_table_size =
 
 769                                   ARRAY_SIZE(af9015_ir_table_avermedia_ks);
 
 773                         switch (le16_to_cpu(udev->descriptor.idVendor)) {
 
 774                         case USB_VID_LEADTEK:
 
 775                                 af9015_properties[i].rc_key_map =
 
 776                                   af9015_rc_keys_leadtek;
 
 777                                 af9015_properties[i].rc_key_map_size =
 
 778                                   ARRAY_SIZE(af9015_rc_keys_leadtek);
 
 779                                 af9015_config.ir_table =
 
 780                                   af9015_ir_table_leadtek;
 
 781                                 af9015_config.ir_table_size =
 
 782                                   ARRAY_SIZE(af9015_ir_table_leadtek);
 
 784                         case USB_VID_VISIONPLUS:
 
 785                                 af9015_properties[i].rc_key_map =
 
 786                                   af9015_rc_keys_twinhan;
 
 787                                 af9015_properties[i].rc_key_map_size =
 
 788                                   ARRAY_SIZE(af9015_rc_keys_twinhan);
 
 789                                 af9015_config.ir_table =
 
 790                                   af9015_ir_table_twinhan;
 
 791                                 af9015_config.ir_table_size =
 
 792                                   ARRAY_SIZE(af9015_ir_table_twinhan);
 
 794                         case USB_VID_KWORLD_2:
 
 795                                 /* TODO: use correct rc keys */
 
 796                                 af9015_properties[i].rc_key_map =
 
 797                                   af9015_rc_keys_twinhan;
 
 798                                 af9015_properties[i].rc_key_map_size =
 
 799                                   ARRAY_SIZE(af9015_rc_keys_twinhan);
 
 800                                 af9015_config.ir_table = af9015_ir_table_kworld;
 
 801                                 af9015_config.ir_table_size =
 
 802                                   ARRAY_SIZE(af9015_ir_table_kworld);
 
 804                         /* Check USB manufacturer and product strings and try
 
 805                            to determine correct remote in case of chip vendor
 
 806                            reference IDs are used. */
 
 807                         case USB_VID_AFATECH:
 
 808                                 memset(manufacturer, 0, sizeof(manufacturer));
 
 809                                 usb_string(udev, udev->descriptor.iManufacturer,
 
 810                                         manufacturer, sizeof(manufacturer));
 
 811                                 if (!strcmp("Geniatech", manufacturer)) {
 
 812                                         /* iManufacturer 1 Geniatech
 
 814                                         af9015_properties[i].rc_key_map =
 
 815                                           af9015_rc_keys_mygictv;
 
 816                                         af9015_properties[i].rc_key_map_size =
 
 817                                           ARRAY_SIZE(af9015_rc_keys_mygictv);
 
 818                                         af9015_config.ir_table =
 
 819                                           af9015_ir_table_mygictv;
 
 820                                         af9015_config.ir_table_size =
 
 821                                           ARRAY_SIZE(af9015_ir_table_mygictv);
 
 822                                 } else if (!strcmp("MSI", manufacturer)) {
 
 823                                         /* iManufacturer 1 MSI
 
 824                                            iProduct      2 MSI K-VOX */
 
 825                                         af9015_properties[i].rc_key_map =
 
 827                                         af9015_properties[i].rc_key_map_size =
 
 828                                           ARRAY_SIZE(af9015_rc_keys_msi);
 
 829                                         af9015_config.ir_table =
 
 831                                         af9015_config.ir_table_size =
 
 832                                           ARRAY_SIZE(af9015_ir_table_msi);
 
 833                                 } else if (udev->descriptor.idProduct ==
 
 834                                         cpu_to_le16(USB_PID_TREKSTOR_DVBT)) {
 
 835                                         af9015_properties[i].rc_key_map =
 
 836                                           af9015_rc_keys_trekstor;
 
 837                                         af9015_properties[i].rc_key_map_size =
 
 838                                           ARRAY_SIZE(af9015_rc_keys_trekstor);
 
 839                                         af9015_config.ir_table =
 
 840                                           af9015_ir_table_trekstor;
 
 841                                         af9015_config.ir_table_size =
 
 842                                           ARRAY_SIZE(af9015_ir_table_trekstor);
 
 845                         case USB_VID_AVERMEDIA:
 
 846                                 af9015_properties[i].rc_key_map =
 
 847                                   af9015_rc_keys_avermedia;
 
 848                                 af9015_properties[i].rc_key_map_size =
 
 849                                   ARRAY_SIZE(af9015_rc_keys_avermedia);
 
 850                                 af9015_config.ir_table =
 
 851                                   af9015_ir_table_avermedia;
 
 852                                 af9015_config.ir_table_size =
 
 853                                   ARRAY_SIZE(af9015_ir_table_avermedia);
 
 859         /* TS mode - one or two receivers */
 
 860         req.addr = AF9015_EEPROM_TS_MODE;
 
 861         ret = af9015_rw_udev(udev, &req);
 
 864         af9015_config.dual_mode = val;
 
 865         deb_info("%s: TS mode:%d\n", __func__, af9015_config.dual_mode);
 
 867         /* Set adapter0 buffer size according to USB port speed, adapter1 buffer
 
 868            size can be static because it is enabled only USB2.0 */
 
 869         for (i = 0; i < af9015_properties_count; i++) {
 
 870                 /* USB1.1 set smaller buffersize and disable 2nd adapter */
 
 871                 if (udev->speed == USB_SPEED_FULL) {
 
 872                         af9015_properties[i].adapter[0].stream.u.bulk.buffersize
 
 873                                 = TS_USB11_MAX_PACKET_SIZE;
 
 874                         /* disable 2nd adapter because we don't have
 
 876                         af9015_config.dual_mode = 0;
 
 878                         af9015_properties[i].adapter[0].stream.u.bulk.buffersize
 
 879                                 = TS_USB20_MAX_PACKET_SIZE;
 
 883         if (af9015_config.dual_mode) {
 
 884                 /* read 2nd demodulator I2C address */
 
 885                 req.addr = AF9015_EEPROM_DEMOD2_I2C;
 
 886                 ret = af9015_rw_udev(udev, &req);
 
 889                 af9015_af9013_config[1].demod_address = val;
 
 891                 /* enable 2nd adapter */
 
 892                 for (i = 0; i < af9015_properties_count; i++)
 
 893                         af9015_properties[i].num_adapters = 2;
 
 896                  /* disable 2nd adapter */
 
 897                 for (i = 0; i < af9015_properties_count; i++)
 
 898                         af9015_properties[i].num_adapters = 1;
 
 901         for (i = 0; i < af9015_properties[0].num_adapters; i++) {
 
 903                         offset = AF9015_EEPROM_OFFSET;
 
 905                 req.addr = AF9015_EEPROM_XTAL_TYPE1 + offset;
 
 906                 ret = af9015_rw_udev(udev, &req);
 
 911                         af9015_af9013_config[i].adc_clock = 28800;
 
 914                         af9015_af9013_config[i].adc_clock = 20480;
 
 917                         af9015_af9013_config[i].adc_clock = 28000;
 
 920                         af9015_af9013_config[i].adc_clock = 25000;
 
 923                 deb_info("%s: [%d] xtal:%d set adc_clock:%d\n", __func__, i,
 
 924                         val, af9015_af9013_config[i].adc_clock);
 
 927                 req.addr = AF9015_EEPROM_IF1H + offset;
 
 928                 ret = af9015_rw_udev(udev, &req);
 
 931                 af9015_af9013_config[i].tuner_if = val << 8;
 
 932                 req.addr = AF9015_EEPROM_IF1L + offset;
 
 933                 ret = af9015_rw_udev(udev, &req);
 
 936                 af9015_af9013_config[i].tuner_if += val;
 
 937                 deb_info("%s: [%d] IF1:%d\n", __func__, i,
 
 938                         af9015_af9013_config[0].tuner_if);
 
 941                 req.addr = AF9015_EEPROM_MT2060_IF1H  + offset;
 
 942                 ret = af9015_rw_udev(udev, &req);
 
 945                 af9015_config.mt2060_if1[i] = val << 8;
 
 946                 req.addr = AF9015_EEPROM_MT2060_IF1L + offset;
 
 947                 ret = af9015_rw_udev(udev, &req);
 
 950                 af9015_config.mt2060_if1[i] += val;
 
 951                 deb_info("%s: [%d] MT2060 IF1:%d\n", __func__, i,
 
 952                         af9015_config.mt2060_if1[i]);
 
 955                 req.addr =  AF9015_EEPROM_TUNER_ID1 + offset;
 
 956                 ret = af9015_rw_udev(udev, &req);
 
 960                 case AF9013_TUNER_ENV77H11D5:
 
 961                 case AF9013_TUNER_MT2060:
 
 962                 case AF9013_TUNER_QT1010:
 
 963                 case AF9013_TUNER_UNKNOWN:
 
 964                 case AF9013_TUNER_MT2060_2:
 
 965                 case AF9013_TUNER_TDA18271:
 
 966                 case AF9013_TUNER_QT1010A:
 
 967                         af9015_af9013_config[i].rf_spec_inv = 1;
 
 969                 case AF9013_TUNER_MXL5003D:
 
 970                 case AF9013_TUNER_MXL5005D:
 
 971                 case AF9013_TUNER_MXL5005R:
 
 972                         af9015_af9013_config[i].rf_spec_inv = 0;
 
 974                 case AF9013_TUNER_MC44S803:
 
 975                         af9015_af9013_config[i].gpio[1] = AF9013_GPIO_LO;
 
 976                         af9015_af9013_config[i].rf_spec_inv = 1;
 
 979                         warn("tuner id:%d not supported, please report!", val);
 
 983                 af9015_af9013_config[i].tuner = val;
 
 984                 deb_info("%s: [%d] tuner id:%d\n", __func__, i, val);
 
 989                 err("eeprom read failed:%d", ret);
 
 991         /* AverMedia AVerTV Volar Black HD (A850) device have bad EEPROM
 
 992            content :-( Override some wrong values here. */
 
 993         if (le16_to_cpu(udev->descriptor.idVendor) == USB_VID_AVERMEDIA &&
 
 994             le16_to_cpu(udev->descriptor.idProduct) == USB_PID_AVERMEDIA_A850) {
 
 995                 deb_info("%s: AverMedia A850: overriding config\n", __func__);
 
 996                 /* disable dual mode */
 
 997                 af9015_config.dual_mode = 0;
 
 998                  /* disable 2nd adapter */
 
 999                 for (i = 0; i < af9015_properties_count; i++)
 
1000                         af9015_properties[i].num_adapters = 1;
 
1002                 /* set correct IF */
 
1003                 af9015_af9013_config[0].tuner_if = 4570;
 
1009 static int af9015_identify_state(struct usb_device *udev,
 
1010                                  struct dvb_usb_device_properties *props,
 
1011                                  struct dvb_usb_device_description **desc,
 
1016         struct req_t req = {GET_CONFIG, 0, 0, 0, 0, 1, &reply};
 
1018         ret = af9015_rw_udev(udev, &req);
 
1022         deb_info("%s: reply:%02x\n", __func__, reply);
 
1031 static int af9015_rc_query(struct dvb_usb_device *d, u32 *event, int *state)
 
1034         struct req_t req = {GET_IR_CODE, 0, 0, 0, 0, sizeof(buf), buf};
 
1035         struct dvb_usb_rc_key *keymap = d->props.rc_key_map;
 
1038         memset(buf, 0, sizeof(buf));
 
1040         ret = af9015_ctrl_msg(d, &req);
 
1045         *state = REMOTE_NO_KEY_PRESSED;
 
1047         for (i = 0; i < d->props.rc_key_map_size; i++) {
 
1048                 if (!buf[1] && keymap[i].custom == buf[0] &&
 
1049                     keymap[i].data == buf[2]) {
 
1050                         *event = keymap[i].event;
 
1051                         *state = REMOTE_KEY_PRESSED;
 
1056                 deb_rc("%s: %02x %02x %02x %02x %02x %02x %02x %02x\n",
 
1057                         __func__, buf[0], buf[1], buf[2], buf[3], buf[4],
 
1058                         buf[5], buf[6], buf[7]);
 
1063 /* init 2nd I2C adapter */
 
1064 static int af9015_i2c_init(struct dvb_usb_device *d)
 
1067         struct af9015_state *state = d->priv;
 
1068         deb_info("%s:\n", __func__);
 
1070         strncpy(state->i2c_adap.name, d->desc->name,
 
1071                 sizeof(state->i2c_adap.name));
 
1072 #ifdef I2C_ADAP_CLASS_TV_DIGITAL
 
1073         state->i2c_adap.class = I2C_ADAP_CLASS_TV_DIGITAL,
 
1075         state->i2c_adap.class = I2C_CLASS_TV_DIGITAL,
 
1077         state->i2c_adap.algo      = d->props.i2c_algo;
 
1078         state->i2c_adap.algo_data = NULL;
 
1079         state->i2c_adap.dev.parent = &d->udev->dev;
 
1081         i2c_set_adapdata(&state->i2c_adap, d);
 
1083         ret = i2c_add_adapter(&state->i2c_adap);
 
1085                 err("could not add i2c adapter");
 
1090 static int af9015_af9013_frontend_attach(struct dvb_usb_adapter *adap)
 
1093         struct af9015_state *state = adap->dev->priv;
 
1094         struct i2c_adapter *i2c_adap;
 
1096         if (adap->id == 0) {
 
1097                 /* select I2C adapter */
 
1098                 i2c_adap = &adap->dev->i2c_adap;
 
1100                 deb_info("%s: init I2C\n", __func__);
 
1101                 ret = af9015_i2c_init(adap->dev);
 
1103                 /* dump eeprom (debug) */
 
1104                 ret = af9015_eeprom_dump(adap->dev);
 
1108                 /* select I2C adapter */
 
1109                 i2c_adap = &state->i2c_adap;
 
1111                 /* copy firmware to 2nd demodulator */
 
1112                 if (af9015_config.dual_mode) {
 
1113                         ret = af9015_copy_firmware(adap->dev);
 
1115                                 err("firmware copy to 2nd frontend " \
 
1116                                         "failed, will disable it");
 
1117                                 af9015_config.dual_mode = 0;
 
1125         /* attach demodulator */
 
1126         adap->fe = dvb_attach(af9013_attach, &af9015_af9013_config[adap->id],
 
1129         return adap->fe == NULL ? -ENODEV : 0;
 
1132 static struct mt2060_config af9015_mt2060_config = {
 
1133         .i2c_address = 0xc0,
 
1137 static struct qt1010_config af9015_qt1010_config = {
 
1138         .i2c_address = 0xc4,
 
1141 static struct tda18271_config af9015_tda18271_config = {
 
1142         .gate = TDA18271_GATE_DIGITAL,
 
1146 static struct mxl5005s_config af9015_mxl5003_config = {
 
1147         .i2c_address     = 0xc6,
 
1148         .if_freq         = IF_FREQ_4570000HZ,
 
1149         .xtal_freq       = CRYSTAL_FREQ_16000000HZ,
 
1150         .agc_mode        = MXL_SINGLE_AGC,
 
1151         .tracking_filter = MXL_TF_DEFAULT,
 
1152         .rssi_enable     = MXL_RSSI_ENABLE,
 
1153         .cap_select      = MXL_CAP_SEL_ENABLE,
 
1154         .div_out         = MXL_DIV_OUT_4,
 
1155         .clock_out       = MXL_CLOCK_OUT_DISABLE,
 
1156         .output_load     = MXL5005S_IF_OUTPUT_LOAD_200_OHM,
 
1157         .top             = MXL5005S_TOP_25P2,
 
1158         .mod_mode        = MXL_DIGITAL_MODE,
 
1159         .if_mode         = MXL_ZERO_IF,
 
1160         .AgcMasterByte   = 0x00,
 
1163 static struct mxl5005s_config af9015_mxl5005_config = {
 
1164         .i2c_address     = 0xc6,
 
1165         .if_freq         = IF_FREQ_4570000HZ,
 
1166         .xtal_freq       = CRYSTAL_FREQ_16000000HZ,
 
1167         .agc_mode        = MXL_SINGLE_AGC,
 
1168         .tracking_filter = MXL_TF_OFF,
 
1169         .rssi_enable     = MXL_RSSI_ENABLE,
 
1170         .cap_select      = MXL_CAP_SEL_ENABLE,
 
1171         .div_out         = MXL_DIV_OUT_4,
 
1172         .clock_out       = MXL_CLOCK_OUT_DISABLE,
 
1173         .output_load     = MXL5005S_IF_OUTPUT_LOAD_200_OHM,
 
1174         .top             = MXL5005S_TOP_25P2,
 
1175         .mod_mode        = MXL_DIGITAL_MODE,
 
1176         .if_mode         = MXL_ZERO_IF,
 
1177         .AgcMasterByte   = 0x00,
 
1180 static struct mc44s803_config af9015_mc44s803_config = {
 
1181         .i2c_address = 0xc0,
 
1185 static int af9015_tuner_attach(struct dvb_usb_adapter *adap)
 
1187         struct af9015_state *state = adap->dev->priv;
 
1188         struct i2c_adapter *i2c_adap;
 
1190         deb_info("%s: \n", __func__);
 
1192         /* select I2C adapter */
 
1194                 i2c_adap = &adap->dev->i2c_adap;
 
1196                 i2c_adap = &state->i2c_adap;
 
1198         switch (af9015_af9013_config[adap->id].tuner) {
 
1199         case AF9013_TUNER_MT2060:
 
1200         case AF9013_TUNER_MT2060_2:
 
1201                 ret = dvb_attach(mt2060_attach, adap->fe, i2c_adap,
 
1202                         &af9015_mt2060_config,
 
1203                         af9015_config.mt2060_if1[adap->id])
 
1204                         == NULL ? -ENODEV : 0;
 
1206         case AF9013_TUNER_QT1010:
 
1207         case AF9013_TUNER_QT1010A:
 
1208                 ret = dvb_attach(qt1010_attach, adap->fe, i2c_adap,
 
1209                         &af9015_qt1010_config) == NULL ? -ENODEV : 0;
 
1211         case AF9013_TUNER_TDA18271:
 
1212                 ret = dvb_attach(tda18271_attach, adap->fe, 0xc0, i2c_adap,
 
1213                         &af9015_tda18271_config) == NULL ? -ENODEV : 0;
 
1215         case AF9013_TUNER_MXL5003D:
 
1216                 ret = dvb_attach(mxl5005s_attach, adap->fe, i2c_adap,
 
1217                         &af9015_mxl5003_config) == NULL ? -ENODEV : 0;
 
1219         case AF9013_TUNER_MXL5005D:
 
1220         case AF9013_TUNER_MXL5005R:
 
1221                 ret = dvb_attach(mxl5005s_attach, adap->fe, i2c_adap,
 
1222                         &af9015_mxl5005_config) == NULL ? -ENODEV : 0;
 
1224         case AF9013_TUNER_ENV77H11D5:
 
1225                 ret = dvb_attach(dvb_pll_attach, adap->fe, 0xc0, i2c_adap,
 
1226                         DVB_PLL_TDA665X) == NULL ? -ENODEV : 0;
 
1228         case AF9013_TUNER_MC44S803:
 
1229                 ret = dvb_attach(mc44s803_attach, adap->fe, i2c_adap,
 
1230                         &af9015_mc44s803_config) == NULL ? -ENODEV : 0;
 
1232         case AF9013_TUNER_UNKNOWN:
 
1235                 err("Unknown tuner id:%d",
 
1236                         af9015_af9013_config[adap->id].tuner);
 
1241 static struct usb_device_id af9015_usb_table[] = {
 
1242 /*  0 */{USB_DEVICE(USB_VID_AFATECH,   USB_PID_AFATECH_AF9015_9015)},
 
1243         {USB_DEVICE(USB_VID_AFATECH,   USB_PID_AFATECH_AF9015_9016)},
 
1244         {USB_DEVICE(USB_VID_LEADTEK,   USB_PID_WINFAST_DTV_DONGLE_GOLD)},
 
1245         {USB_DEVICE(USB_VID_PINNACLE,  USB_PID_PINNACLE_PCTV71E)},
 
1246         {USB_DEVICE(USB_VID_KWORLD_2,  USB_PID_KWORLD_399U)},
 
1247 /*  5 */{USB_DEVICE(USB_VID_VISIONPLUS,
 
1249         {USB_DEVICE(USB_VID_VISIONPLUS,
 
1250                 USB_PID_AZUREWAVE_AD_TU700)},
 
1251         {USB_DEVICE(USB_VID_TERRATEC,  USB_PID_TERRATEC_CINERGY_T_USB_XE_REV2)},
 
1252         {USB_DEVICE(USB_VID_KWORLD_2,  USB_PID_KWORLD_PC160_2T)},
 
1253         {USB_DEVICE(USB_VID_AVERMEDIA, USB_PID_AVERMEDIA_VOLAR_X)},
 
1254 /* 10 */{USB_DEVICE(USB_VID_XTENSIONS, USB_PID_XTENSIONS_XD_380)},
 
1255         {USB_DEVICE(USB_VID_MSI_2,     USB_PID_MSI_DIGIVOX_DUO)},
 
1256         {USB_DEVICE(USB_VID_AVERMEDIA, USB_PID_AVERMEDIA_VOLAR_X_2)},
 
1257         {USB_DEVICE(USB_VID_TELESTAR,  USB_PID_TELESTAR_STARSTICK_2)},
 
1258         {USB_DEVICE(USB_VID_AVERMEDIA, USB_PID_AVERMEDIA_A309)},
 
1259 /* 15 */{USB_DEVICE(USB_VID_MSI_2,     USB_PID_MSI_DIGI_VOX_MINI_III)},
 
1260         {USB_DEVICE(USB_VID_KWORLD_2,  USB_PID_KWORLD_395U)},
 
1261         {USB_DEVICE(USB_VID_KWORLD_2,  USB_PID_KWORLD_395U_2)},
 
1262         {USB_DEVICE(USB_VID_KWORLD_2,  USB_PID_KWORLD_395U_3)},
 
1263         {USB_DEVICE(USB_VID_AFATECH,   USB_PID_TREKSTOR_DVBT)},
 
1264         {USB_DEVICE(USB_VID_AVERMEDIA, USB_PID_AVERMEDIA_A850)},
 
1267 MODULE_DEVICE_TABLE(usb, af9015_usb_table);
 
1269 static struct dvb_usb_device_properties af9015_properties[] = {
 
1271                 .caps = DVB_USB_IS_AN_I2C_ADAPTER,
 
1273                 .usb_ctrl = DEVICE_SPECIFIC,
 
1274                 .download_firmware = af9015_download_firmware,
 
1275                 .firmware = "dvb-usb-af9015.fw",
 
1278                 .size_of_priv = sizeof(struct af9015_state), \
 
1283                                 .caps = DVB_USB_ADAP_HAS_PID_FILTER |
 
1284                                 DVB_USB_ADAP_PID_FILTER_CAN_BE_TURNED_OFF,
 
1286                                 .pid_filter_count = 32,
 
1287                                 .pid_filter       = af9015_pid_filter,
 
1288                                 .pid_filter_ctrl  = af9015_pid_filter_ctrl,
 
1291                                         af9015_af9013_frontend_attach,
 
1292                                 .tuner_attach    = af9015_tuner_attach,
 
1301                                         af9015_af9013_frontend_attach,
 
1302                                 .tuner_attach    = af9015_tuner_attach,
 
1310                                                 TS_USB20_MAX_PACKET_SIZE,
 
1317                 .identify_state = af9015_identify_state,
 
1319                 .rc_query         = af9015_rc_query,
 
1322                 .i2c_algo = &af9015_i2c_algo,
 
1324                 .num_device_descs = 9,
 
1327                                 .name = "Afatech AF9015 DVB-T USB2.0 stick",
 
1328                                 .cold_ids = {&af9015_usb_table[0],
 
1329                                              &af9015_usb_table[1], NULL},
 
1333                                 .name = "Leadtek WinFast DTV Dongle Gold",
 
1334                                 .cold_ids = {&af9015_usb_table[2], NULL},
 
1338                                 .name = "Pinnacle PCTV 71e",
 
1339                                 .cold_ids = {&af9015_usb_table[3], NULL},
 
1343                                 .name = "KWorld PlusTV Dual DVB-T Stick " \
 
1345                                 .cold_ids = {&af9015_usb_table[4], NULL},
 
1349                                 .name = "DigitalNow TinyTwin DVB-T Receiver",
 
1350                                 .cold_ids = {&af9015_usb_table[5], NULL},
 
1354                                 .name = "TwinHan AzureWave AD-TU700(704J)",
 
1355                                 .cold_ids = {&af9015_usb_table[6], NULL},
 
1359                                 .name = "TerraTec Cinergy T USB XE",
 
1360                                 .cold_ids = {&af9015_usb_table[7], NULL},
 
1364                                 .name = "KWorld PlusTV Dual DVB-T PCI " \
 
1366                                 .cold_ids = {&af9015_usb_table[8], NULL},
 
1370                                 .name = "AVerMedia AVerTV DVB-T Volar X",
 
1371                                 .cold_ids = {&af9015_usb_table[9], NULL},
 
1376                 .caps = DVB_USB_IS_AN_I2C_ADAPTER,
 
1378                 .usb_ctrl = DEVICE_SPECIFIC,
 
1379                 .download_firmware = af9015_download_firmware,
 
1380                 .firmware = "dvb-usb-af9015.fw",
 
1383                 .size_of_priv = sizeof(struct af9015_state), \
 
1388                                 .caps = DVB_USB_ADAP_HAS_PID_FILTER |
 
1389                                 DVB_USB_ADAP_PID_FILTER_CAN_BE_TURNED_OFF,
 
1391                                 .pid_filter_count = 32,
 
1392                                 .pid_filter       = af9015_pid_filter,
 
1393                                 .pid_filter_ctrl  = af9015_pid_filter_ctrl,
 
1396                                         af9015_af9013_frontend_attach,
 
1397                                 .tuner_attach    = af9015_tuner_attach,
 
1406                                         af9015_af9013_frontend_attach,
 
1407                                 .tuner_attach    = af9015_tuner_attach,
 
1415                                                 TS_USB20_MAX_PACKET_SIZE,
 
1422                 .identify_state = af9015_identify_state,
 
1424                 .rc_query         = af9015_rc_query,
 
1427                 .i2c_algo = &af9015_i2c_algo,
 
1429                 .num_device_descs = 9,
 
1432                                 .name = "Xtensions XD-380",
 
1433                                 .cold_ids = {&af9015_usb_table[10], NULL},
 
1437                                 .name = "MSI DIGIVOX Duo",
 
1438                                 .cold_ids = {&af9015_usb_table[11], NULL},
 
1442                                 .name = "Fujitsu-Siemens Slim Mobile USB DVB-T",
 
1443                                 .cold_ids = {&af9015_usb_table[12], NULL},
 
1447                                 .name = "Telestar Starstick 2",
 
1448                                 .cold_ids = {&af9015_usb_table[13], NULL},
 
1452                                 .name = "AVerMedia A309",
 
1453                                 .cold_ids = {&af9015_usb_table[14], NULL},
 
1457                                 .name = "MSI Digi VOX mini III",
 
1458                                 .cold_ids = {&af9015_usb_table[15], NULL},
 
1462                                 .name = "KWorld USB DVB-T TV Stick II " \
 
1464                                 .cold_ids = {&af9015_usb_table[16],
 
1465                                              &af9015_usb_table[17],
 
1466                                              &af9015_usb_table[18], NULL},
 
1470                                 .name = "TrekStor DVB-T USB Stick",
 
1471                                 .cold_ids = {&af9015_usb_table[19], NULL},
 
1475                                 .name = "AverMedia AVerTV Volar Black HD " \
 
1477                                 .cold_ids = {&af9015_usb_table[20], NULL},
 
1484 static int af9015_usb_probe(struct usb_interface *intf,
 
1485                             const struct usb_device_id *id)
 
1488         struct dvb_usb_device *d = NULL;
 
1489         struct usb_device *udev = interface_to_usbdev(intf);
 
1492         deb_info("%s: interface:%d\n", __func__,
 
1493                 intf->cur_altsetting->desc.bInterfaceNumber);
 
1495         /* interface 0 is used by DVB-T receiver and
 
1496            interface 1 is for remote controller (HID) */
 
1497         if (intf->cur_altsetting->desc.bInterfaceNumber == 0) {
 
1498                 ret = af9015_read_config(udev);
 
1502                 for (i = 0; i < af9015_properties_count; i++) {
 
1503                         ret = dvb_usb_device_init(intf, &af9015_properties[i],
 
1504                                 THIS_MODULE, &d, adapter_nr);
 
1514                         ret = af9015_init(d);
 
1520 static void af9015_i2c_exit(struct dvb_usb_device *d)
 
1522         struct af9015_state *state = d->priv;
 
1523         deb_info("%s: \n", __func__);
 
1525         /* remove 2nd I2C adapter */
 
1526         if (d->state & DVB_USB_STATE_I2C)
 
1527                 i2c_del_adapter(&state->i2c_adap);
 
1530 static void af9015_usb_device_exit(struct usb_interface *intf)
 
1532         struct dvb_usb_device *d = usb_get_intfdata(intf);
 
1533         deb_info("%s: \n", __func__);
 
1535         /* remove 2nd I2C adapter */
 
1536         if (d != NULL && d->desc != NULL)
 
1539         dvb_usb_device_exit(intf);
 
1542 /* usb specific object needed to register this driver with the usb subsystem */
 
1543 static struct usb_driver af9015_usb_driver = {
 
1544         .name = "dvb_usb_af9015",
 
1545         .probe = af9015_usb_probe,
 
1546         .disconnect = af9015_usb_device_exit,
 
1547         .id_table = af9015_usb_table,
 
1551 static int __init af9015_usb_module_init(void)
 
1554         ret = usb_register(&af9015_usb_driver);
 
1556                 err("module init failed:%d", ret);
 
1561 static void __exit af9015_usb_module_exit(void)
 
1563         /* deregister this driver from the USB subsystem */
 
1564         usb_deregister(&af9015_usb_driver);
 
1567 module_init(af9015_usb_module_init);
 
1568 module_exit(af9015_usb_module_exit);
 
1570 MODULE_AUTHOR("Antti Palosaari <crope@iki.fi>");
 
1571 MODULE_DESCRIPTION("Driver for Afatech AF9015 DVB-T");
 
1572 MODULE_LICENSE("GPL");