[PATCH] W1: w1_netlink: New init/fini netlink callbacks.
[linux-2.6/verdex.git] / drivers / media / dvb / ttusb-dec / ttusb_dec.c
blob45c9a9a08e4d8ecea7b940d149cef87d609ad310
1 /*
2 * TTUSB DEC Driver
4 * Copyright (C) 2003-2004 Alex Woods <linux-dvb@giblets.org>
5 * IR support by Peter Beutner <p.beutner@gmx.net>
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published by
9 * the Free Software Foundation; either version 2 of the License, or
10 * (at your option) any later version.
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
17 * You should have received a copy of the GNU General Public License
18 * along with this program; if not, write to the Free Software
19 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
23 #include <asm/semaphore.h>
24 #include <linux/list.h>
25 #include <linux/module.h>
26 #include <linux/moduleparam.h>
27 #include <linux/pci.h>
28 #include <linux/slab.h>
29 #include <linux/spinlock.h>
30 #include <linux/usb.h>
31 #include <linux/version.h>
32 #include <linux/interrupt.h>
33 #include <linux/firmware.h>
34 #include <linux/crc32.h>
35 #include <linux/init.h>
36 #include <linux/input.h>
38 #include "dmxdev.h"
39 #include "dvb_demux.h"
40 #include "dvb_filter.h"
41 #include "dvb_frontend.h"
42 #include "dvb_net.h"
43 #include "ttusbdecfe.h"
45 static int debug;
46 static int output_pva;
47 static int enable_rc;
49 module_param(debug, int, 0644);
50 MODULE_PARM_DESC(debug, "Turn on/off debugging (default:off).");
51 module_param(output_pva, int, 0444);
52 MODULE_PARM_DESC(output_pva, "Output PVA from dvr device (default:off)");
53 module_param(enable_rc, int, 0644);
54 MODULE_PARM_DESC(enable_rc, "Turn on/off IR remote control(default: off)");
56 #define dprintk if (debug) printk
58 #define DRIVER_NAME "TechnoTrend/Hauppauge DEC USB"
60 #define COMMAND_PIPE 0x03
61 #define RESULT_PIPE 0x04
62 #define IN_PIPE 0x08
63 #define OUT_PIPE 0x07
64 #define IRQ_PIPE 0x0A
66 #define COMMAND_PACKET_SIZE 0x3c
67 #define ARM_PACKET_SIZE 0x1000
68 #define IRQ_PACKET_SIZE 0x8
70 #define ISO_BUF_COUNT 0x04
71 #define FRAMES_PER_ISO_BUF 0x04
72 #define ISO_FRAME_SIZE 0x0380
74 #define MAX_PVA_LENGTH 6144
76 enum ttusb_dec_model {
77 TTUSB_DEC2000T,
78 TTUSB_DEC2540T,
79 TTUSB_DEC3000S
82 enum ttusb_dec_packet_type {
83 TTUSB_DEC_PACKET_PVA,
84 TTUSB_DEC_PACKET_SECTION,
85 TTUSB_DEC_PACKET_EMPTY
88 enum ttusb_dec_interface {
89 TTUSB_DEC_INTERFACE_INITIAL,
90 TTUSB_DEC_INTERFACE_IN,
91 TTUSB_DEC_INTERFACE_OUT
94 struct ttusb_dec {
95 enum ttusb_dec_model model;
96 char *model_name;
97 char *firmware_name;
98 int can_playback;
100 /* DVB bits */
101 struct dvb_adapter adapter;
102 struct dmxdev dmxdev;
103 struct dvb_demux demux;
104 struct dmx_frontend frontend;
105 struct dvb_net dvb_net;
106 struct dvb_frontend* fe;
108 u16 pid[DMX_PES_OTHER];
110 /* USB bits */
111 struct usb_device *udev;
112 u8 trans_count;
113 unsigned int command_pipe;
114 unsigned int result_pipe;
115 unsigned int in_pipe;
116 unsigned int out_pipe;
117 unsigned int irq_pipe;
118 enum ttusb_dec_interface interface;
119 struct semaphore usb_sem;
121 void *irq_buffer;
122 struct urb *irq_urb;
123 dma_addr_t irq_dma_handle;
124 void *iso_buffer;
125 dma_addr_t iso_dma_handle;
126 struct urb *iso_urb[ISO_BUF_COUNT];
127 int iso_stream_count;
128 struct semaphore iso_sem;
130 u8 packet[MAX_PVA_LENGTH + 4];
131 enum ttusb_dec_packet_type packet_type;
132 int packet_state;
133 int packet_length;
134 int packet_payload_length;
135 u16 next_packet_id;
137 int pva_stream_count;
138 int filter_stream_count;
140 struct dvb_filter_pes2ts a_pes2ts;
141 struct dvb_filter_pes2ts v_pes2ts;
143 u8 v_pes[16 + MAX_PVA_LENGTH];
144 int v_pes_length;
145 int v_pes_postbytes;
147 struct list_head urb_frame_list;
148 struct tasklet_struct urb_tasklet;
149 spinlock_t urb_frame_list_lock;
151 struct dvb_demux_filter *audio_filter;
152 struct dvb_demux_filter *video_filter;
153 struct list_head filter_info_list;
154 spinlock_t filter_info_list_lock;
156 struct input_dev rc_input_dev;
158 int active; /* Loaded successfully */
161 struct urb_frame {
162 u8 data[ISO_FRAME_SIZE];
163 int length;
164 struct list_head urb_frame_list;
167 struct filter_info {
168 u8 stream_id;
169 struct dvb_demux_filter *filter;
170 struct list_head filter_info_list;
173 static u16 rc_keys[] = {
174 KEY_POWER,
175 KEY_MUTE,
176 KEY_1,
177 KEY_2,
178 KEY_3,
179 KEY_4,
180 KEY_5,
181 KEY_6,
182 KEY_7,
183 KEY_8,
184 KEY_9,
185 KEY_0,
186 KEY_CHANNELUP,
187 KEY_VOLUMEDOWN,
188 KEY_OK,
189 KEY_VOLUMEUP,
190 KEY_CHANNELDOWN,
191 KEY_PREVIOUS,
192 KEY_ESC,
193 KEY_RED,
194 KEY_GREEN,
195 KEY_YELLOW,
196 KEY_BLUE,
197 KEY_OPTION,
198 KEY_M,
199 KEY_RADIO
202 static void ttusb_dec_set_model(struct ttusb_dec *dec,
203 enum ttusb_dec_model model);
205 static void ttusb_dec_handle_irq( struct urb *urb, struct pt_regs *regs)
207 struct ttusb_dec * dec = urb->context;
208 char *buffer = dec->irq_buffer;
209 int retval;
211 switch(urb->status) {
212 case 0: /*success*/
213 break;
214 case -ECONNRESET:
215 case -ENOENT:
216 case -ESHUTDOWN:
217 case -ETIMEDOUT:
218 /* this urb is dead, cleanup */
219 dprintk("%s:urb shutting down with status: %d\n",
220 __FUNCTION__, urb->status);
221 return;
222 default:
223 dprintk("%s:nonzero status received: %d\n",
224 __FUNCTION__,urb->status);
225 goto exit;
228 if( (buffer[0] == 0x1) && (buffer[2] == 0x15) ) {
229 /* IR - Event */
230 /* this is an fact a bit too simple implementation;
231 * the box also reports a keyrepeat signal
232 * (with buffer[3] == 0x40) in an intervall of ~100ms.
233 * But to handle this correctly we had to imlemenent some
234 * kind of timer which signals a 'key up' event if no
235 * keyrepeat signal is recieved for lets say 200ms.
236 * this should/could be added later ...
237 * for now lets report each signal as a key down and up*/
238 dprintk("%s:rc signal:%d\n", __FUNCTION__, buffer[4]);
239 input_report_key(&dec->rc_input_dev,rc_keys[buffer[4]-1],1);
240 input_report_key(&dec->rc_input_dev,rc_keys[buffer[4]-1],0);
241 input_sync(&dec->rc_input_dev);
244 exit: retval = usb_submit_urb(urb, GFP_ATOMIC);
245 if(retval)
246 printk("%s - usb_commit_urb failed with result: %d\n",
247 __FUNCTION__, retval);
250 static u16 crc16(u16 crc, const u8 *buf, size_t len)
252 u16 tmp;
254 while (len--) {
255 crc ^= *buf++;
256 crc ^= (u8)crc >> 4;
257 tmp = (u8)crc;
258 crc ^= (tmp ^ (tmp << 1)) << 4;
260 return crc;
263 static int ttusb_dec_send_command(struct ttusb_dec *dec, const u8 command,
264 int param_length, const u8 params[],
265 int *result_length, u8 cmd_result[])
267 int result, actual_len, i;
268 u8 *b;
270 dprintk("%s\n", __FUNCTION__);
272 b = kmalloc(COMMAND_PACKET_SIZE + 4, GFP_KERNEL);
273 if (!b)
274 return -ENOMEM;
276 if ((result = down_interruptible(&dec->usb_sem))) {
277 kfree(b);
278 printk("%s: Failed to down usb semaphore.\n", __FUNCTION__);
279 return result;
282 b[0] = 0xaa;
283 b[1] = ++dec->trans_count;
284 b[2] = command;
285 b[3] = param_length;
287 if (params)
288 memcpy(&b[4], params, param_length);
290 if (debug) {
291 printk("%s: command: ", __FUNCTION__);
292 for (i = 0; i < param_length + 4; i++)
293 printk("0x%02X ", b[i]);
294 printk("\n");
297 result = usb_bulk_msg(dec->udev, dec->command_pipe, b,
298 COMMAND_PACKET_SIZE + 4, &actual_len, 1000);
300 if (result) {
301 printk("%s: command bulk message failed: error %d\n",
302 __FUNCTION__, result);
303 up(&dec->usb_sem);
304 kfree(b);
305 return result;
308 result = usb_bulk_msg(dec->udev, dec->result_pipe, b,
309 COMMAND_PACKET_SIZE + 4, &actual_len, 1000);
311 if (result) {
312 printk("%s: result bulk message failed: error %d\n",
313 __FUNCTION__, result);
314 up(&dec->usb_sem);
315 kfree(b);
316 return result;
317 } else {
318 if (debug) {
319 printk("%s: result: ", __FUNCTION__);
320 for (i = 0; i < actual_len; i++)
321 printk("0x%02X ", b[i]);
322 printk("\n");
325 if (result_length)
326 *result_length = b[3];
327 if (cmd_result && b[3] > 0)
328 memcpy(cmd_result, &b[4], b[3]);
330 up(&dec->usb_sem);
332 kfree(b);
333 return 0;
337 static int ttusb_dec_get_stb_state (struct ttusb_dec *dec, unsigned int *mode,
338 unsigned int *model, unsigned int *version)
340 u8 c[COMMAND_PACKET_SIZE];
341 int c_length;
342 int result;
343 unsigned int tmp;
345 dprintk("%s\n", __FUNCTION__);
347 result = ttusb_dec_send_command(dec, 0x08, 0, NULL, &c_length, c);
348 if (result)
349 return result;
351 if (c_length >= 0x0c) {
352 if (mode != NULL) {
353 memcpy(&tmp, c, 4);
354 *mode = ntohl(tmp);
356 if (model != NULL) {
357 memcpy(&tmp, &c[4], 4);
358 *model = ntohl(tmp);
360 if (version != NULL) {
361 memcpy(&tmp, &c[8], 4);
362 *version = ntohl(tmp);
364 return 0;
365 } else {
366 return -1;
370 static int ttusb_dec_audio_pes2ts_cb(void *priv, unsigned char *data)
372 struct ttusb_dec *dec = (struct ttusb_dec *)priv;
374 dec->audio_filter->feed->cb.ts(data, 188, NULL, 0,
375 &dec->audio_filter->feed->feed.ts,
376 DMX_OK);
378 return 0;
381 static int ttusb_dec_video_pes2ts_cb(void *priv, unsigned char *data)
383 struct ttusb_dec *dec = (struct ttusb_dec *)priv;
385 dec->video_filter->feed->cb.ts(data, 188, NULL, 0,
386 &dec->video_filter->feed->feed.ts,
387 DMX_OK);
389 return 0;
392 static void ttusb_dec_set_pids(struct ttusb_dec *dec)
394 u8 b[] = { 0x00, 0x00, 0x00, 0x00,
395 0x00, 0x00, 0xff, 0xff,
396 0xff, 0xff, 0xff, 0xff };
398 u16 pcr = htons(dec->pid[DMX_PES_PCR]);
399 u16 audio = htons(dec->pid[DMX_PES_AUDIO]);
400 u16 video = htons(dec->pid[DMX_PES_VIDEO]);
402 dprintk("%s\n", __FUNCTION__);
404 memcpy(&b[0], &pcr, 2);
405 memcpy(&b[2], &audio, 2);
406 memcpy(&b[4], &video, 2);
408 ttusb_dec_send_command(dec, 0x50, sizeof(b), b, NULL, NULL);
410 dvb_filter_pes2ts_init(&dec->a_pes2ts, dec->pid[DMX_PES_AUDIO],
411 ttusb_dec_audio_pes2ts_cb, dec);
412 dvb_filter_pes2ts_init(&dec->v_pes2ts, dec->pid[DMX_PES_VIDEO],
413 ttusb_dec_video_pes2ts_cb, dec);
414 dec->v_pes_length = 0;
415 dec->v_pes_postbytes = 0;
418 static void ttusb_dec_process_pva(struct ttusb_dec *dec, u8 *pva, int length)
420 if (length < 8) {
421 printk("%s: packet too short - discarding\n", __FUNCTION__);
422 return;
425 if (length > 8 + MAX_PVA_LENGTH) {
426 printk("%s: packet too long - discarding\n", __FUNCTION__);
427 return;
430 switch (pva[2]) {
432 case 0x01: { /* VideoStream */
433 int prebytes = pva[5] & 0x03;
434 int postbytes = (pva[5] & 0x0c) >> 2;
435 u16 v_pes_payload_length;
437 if (output_pva) {
438 dec->video_filter->feed->cb.ts(pva, length, NULL, 0,
439 &dec->video_filter->feed->feed.ts, DMX_OK);
440 return;
443 if (dec->v_pes_postbytes > 0 &&
444 dec->v_pes_postbytes == prebytes) {
445 memcpy(&dec->v_pes[dec->v_pes_length],
446 &pva[12], prebytes);
448 dvb_filter_pes2ts(&dec->v_pes2ts, dec->v_pes,
449 dec->v_pes_length + prebytes, 1);
452 if (pva[5] & 0x10) {
453 dec->v_pes[7] = 0x80;
454 dec->v_pes[8] = 0x05;
456 dec->v_pes[9] = 0x21 | ((pva[8] & 0xc0) >> 5);
457 dec->v_pes[10] = ((pva[8] & 0x3f) << 2) |
458 ((pva[9] & 0xc0) >> 6);
459 dec->v_pes[11] = 0x01 |
460 ((pva[9] & 0x3f) << 2) |
461 ((pva[10] & 0x80) >> 6);
462 dec->v_pes[12] = ((pva[10] & 0x7f) << 1) |
463 ((pva[11] & 0xc0) >> 7);
464 dec->v_pes[13] = 0x01 | ((pva[11] & 0x7f) << 1);
466 memcpy(&dec->v_pes[14], &pva[12 + prebytes],
467 length - 12 - prebytes);
468 dec->v_pes_length = 14 + length - 12 - prebytes;
469 } else {
470 dec->v_pes[7] = 0x00;
471 dec->v_pes[8] = 0x00;
473 memcpy(&dec->v_pes[9], &pva[8], length - 8);
474 dec->v_pes_length = 9 + length - 8;
477 dec->v_pes_postbytes = postbytes;
479 if (dec->v_pes[9 + dec->v_pes[8]] == 0x00 &&
480 dec->v_pes[10 + dec->v_pes[8]] == 0x00 &&
481 dec->v_pes[11 + dec->v_pes[8]] == 0x01)
482 dec->v_pes[6] = 0x84;
483 else
484 dec->v_pes[6] = 0x80;
486 v_pes_payload_length = htons(dec->v_pes_length - 6 +
487 postbytes);
488 memcpy(&dec->v_pes[4], &v_pes_payload_length, 2);
490 if (postbytes == 0)
491 dvb_filter_pes2ts(&dec->v_pes2ts, dec->v_pes,
492 dec->v_pes_length, 1);
494 break;
497 case 0x02: /* MainAudioStream */
498 if (output_pva) {
499 dec->audio_filter->feed->cb.ts(pva, length, NULL, 0,
500 &dec->audio_filter->feed->feed.ts, DMX_OK);
501 return;
504 dvb_filter_pes2ts(&dec->a_pes2ts, &pva[8], length - 8,
505 pva[5] & 0x10);
506 break;
508 default:
509 printk("%s: unknown PVA type: %02x.\n", __FUNCTION__,
510 pva[2]);
511 break;
515 static void ttusb_dec_process_filter(struct ttusb_dec *dec, u8 *packet,
516 int length)
518 struct list_head *item;
519 struct filter_info *finfo;
520 struct dvb_demux_filter *filter = NULL;
521 unsigned long flags;
522 u8 sid;
524 sid = packet[1];
525 spin_lock_irqsave(&dec->filter_info_list_lock, flags);
526 for (item = dec->filter_info_list.next; item != &dec->filter_info_list;
527 item = item->next) {
528 finfo = list_entry(item, struct filter_info, filter_info_list);
529 if (finfo->stream_id == sid) {
530 filter = finfo->filter;
531 break;
534 spin_unlock_irqrestore(&dec->filter_info_list_lock, flags);
536 if (filter)
537 filter->feed->cb.sec(&packet[2], length - 2, NULL, 0,
538 &filter->filter, DMX_OK);
541 static void ttusb_dec_process_packet(struct ttusb_dec *dec)
543 int i;
544 u16 csum = 0;
545 u16 packet_id;
547 if (dec->packet_length % 2) {
548 printk("%s: odd sized packet - discarding\n", __FUNCTION__);
549 return;
552 for (i = 0; i < dec->packet_length; i += 2)
553 csum ^= ((dec->packet[i] << 8) + dec->packet[i + 1]);
555 if (csum) {
556 printk("%s: checksum failed - discarding\n", __FUNCTION__);
557 return;
560 packet_id = dec->packet[dec->packet_length - 4] << 8;
561 packet_id += dec->packet[dec->packet_length - 3];
563 if ((packet_id != dec->next_packet_id) && dec->next_packet_id) {
564 printk("%s: warning: lost packets between %u and %u\n",
565 __FUNCTION__, dec->next_packet_id - 1, packet_id);
568 if (packet_id == 0xffff)
569 dec->next_packet_id = 0x8000;
570 else
571 dec->next_packet_id = packet_id + 1;
573 switch (dec->packet_type) {
574 case TTUSB_DEC_PACKET_PVA:
575 if (dec->pva_stream_count)
576 ttusb_dec_process_pva(dec, dec->packet,
577 dec->packet_payload_length);
578 break;
580 case TTUSB_DEC_PACKET_SECTION:
581 if (dec->filter_stream_count)
582 ttusb_dec_process_filter(dec, dec->packet,
583 dec->packet_payload_length);
584 break;
586 case TTUSB_DEC_PACKET_EMPTY:
587 break;
591 static void swap_bytes(u8 *b, int length)
593 u8 c;
595 length -= length % 2;
596 for (; length; b += 2, length -= 2) {
597 c = *b;
598 *b = *(b + 1);
599 *(b + 1) = c;
603 static void ttusb_dec_process_urb_frame(struct ttusb_dec *dec, u8 *b,
604 int length)
606 swap_bytes(b, length);
608 while (length) {
609 switch (dec->packet_state) {
611 case 0:
612 case 1:
613 case 2:
614 if (*b++ == 0xaa)
615 dec->packet_state++;
616 else
617 dec->packet_state = 0;
619 length--;
620 break;
622 case 3:
623 if (*b == 0x00) {
624 dec->packet_state++;
625 dec->packet_length = 0;
626 } else if (*b != 0xaa) {
627 dec->packet_state = 0;
630 b++;
631 length--;
632 break;
634 case 4:
635 dec->packet[dec->packet_length++] = *b++;
637 if (dec->packet_length == 2) {
638 if (dec->packet[0] == 'A' &&
639 dec->packet[1] == 'V') {
640 dec->packet_type =
641 TTUSB_DEC_PACKET_PVA;
642 dec->packet_state++;
643 } else if (dec->packet[0] == 'S') {
644 dec->packet_type =
645 TTUSB_DEC_PACKET_SECTION;
646 dec->packet_state++;
647 } else if (dec->packet[0] == 0x00) {
648 dec->packet_type =
649 TTUSB_DEC_PACKET_EMPTY;
650 dec->packet_payload_length = 2;
651 dec->packet_state = 7;
652 } else {
653 printk("%s: unknown packet type: "
654 "%02x%02x\n", __FUNCTION__,
655 dec->packet[0], dec->packet[1]);
656 dec->packet_state = 0;
660 length--;
661 break;
663 case 5:
664 dec->packet[dec->packet_length++] = *b++;
666 if (dec->packet_type == TTUSB_DEC_PACKET_PVA &&
667 dec->packet_length == 8) {
668 dec->packet_state++;
669 dec->packet_payload_length = 8 +
670 (dec->packet[6] << 8) +
671 dec->packet[7];
672 } else if (dec->packet_type ==
673 TTUSB_DEC_PACKET_SECTION &&
674 dec->packet_length == 5) {
675 dec->packet_state++;
676 dec->packet_payload_length = 5 +
677 ((dec->packet[3] & 0x0f) << 8) +
678 dec->packet[4];
681 length--;
682 break;
684 case 6: {
685 int remainder = dec->packet_payload_length -
686 dec->packet_length;
688 if (length >= remainder) {
689 memcpy(dec->packet + dec->packet_length,
690 b, remainder);
691 dec->packet_length += remainder;
692 b += remainder;
693 length -= remainder;
694 dec->packet_state++;
695 } else {
696 memcpy(&dec->packet[dec->packet_length],
697 b, length);
698 dec->packet_length += length;
699 length = 0;
702 break;
705 case 7: {
706 int tail = 4;
708 dec->packet[dec->packet_length++] = *b++;
710 if (dec->packet_type == TTUSB_DEC_PACKET_SECTION &&
711 dec->packet_payload_length % 2)
712 tail++;
714 if (dec->packet_length ==
715 dec->packet_payload_length + tail) {
716 ttusb_dec_process_packet(dec);
717 dec->packet_state = 0;
720 length--;
721 break;
724 default:
725 printk("%s: illegal packet state encountered.\n",
726 __FUNCTION__);
727 dec->packet_state = 0;
732 static void ttusb_dec_process_urb_frame_list(unsigned long data)
734 struct ttusb_dec *dec = (struct ttusb_dec *)data;
735 struct list_head *item;
736 struct urb_frame *frame;
737 unsigned long flags;
739 while (1) {
740 spin_lock_irqsave(&dec->urb_frame_list_lock, flags);
741 if ((item = dec->urb_frame_list.next) != &dec->urb_frame_list) {
742 frame = list_entry(item, struct urb_frame,
743 urb_frame_list);
744 list_del(&frame->urb_frame_list);
745 } else {
746 spin_unlock_irqrestore(&dec->urb_frame_list_lock,
747 flags);
748 return;
750 spin_unlock_irqrestore(&dec->urb_frame_list_lock, flags);
752 ttusb_dec_process_urb_frame(dec, frame->data, frame->length);
753 kfree(frame);
757 static void ttusb_dec_process_urb(struct urb *urb, struct pt_regs *ptregs)
759 struct ttusb_dec *dec = urb->context;
761 if (!urb->status) {
762 int i;
764 for (i = 0; i < FRAMES_PER_ISO_BUF; i++) {
765 struct usb_iso_packet_descriptor *d;
766 u8 *b;
767 int length;
768 struct urb_frame *frame;
770 d = &urb->iso_frame_desc[i];
771 b = urb->transfer_buffer + d->offset;
772 length = d->actual_length;
774 if ((frame = kmalloc(sizeof(struct urb_frame),
775 GFP_ATOMIC))) {
776 unsigned long flags;
778 memcpy(frame->data, b, length);
779 frame->length = length;
781 spin_lock_irqsave(&dec->urb_frame_list_lock,
782 flags);
783 list_add_tail(&frame->urb_frame_list,
784 &dec->urb_frame_list);
785 spin_unlock_irqrestore(&dec->urb_frame_list_lock,
786 flags);
788 tasklet_schedule(&dec->urb_tasklet);
791 } else {
792 /* -ENOENT is expected when unlinking urbs */
793 if (urb->status != -ENOENT)
794 dprintk("%s: urb error: %d\n", __FUNCTION__,
795 urb->status);
798 if (dec->iso_stream_count)
799 usb_submit_urb(urb, GFP_ATOMIC);
802 static void ttusb_dec_setup_urbs(struct ttusb_dec *dec)
804 int i, j, buffer_offset = 0;
806 dprintk("%s\n", __FUNCTION__);
808 for (i = 0; i < ISO_BUF_COUNT; i++) {
809 int frame_offset = 0;
810 struct urb *urb = dec->iso_urb[i];
812 urb->dev = dec->udev;
813 urb->context = dec;
814 urb->complete = ttusb_dec_process_urb;
815 urb->pipe = dec->in_pipe;
816 urb->transfer_flags = URB_ISO_ASAP;
817 urb->interval = 1;
818 urb->number_of_packets = FRAMES_PER_ISO_BUF;
819 urb->transfer_buffer_length = ISO_FRAME_SIZE *
820 FRAMES_PER_ISO_BUF;
821 urb->transfer_buffer = dec->iso_buffer + buffer_offset;
822 buffer_offset += ISO_FRAME_SIZE * FRAMES_PER_ISO_BUF;
824 for (j = 0; j < FRAMES_PER_ISO_BUF; j++) {
825 urb->iso_frame_desc[j].offset = frame_offset;
826 urb->iso_frame_desc[j].length = ISO_FRAME_SIZE;
827 frame_offset += ISO_FRAME_SIZE;
832 static void ttusb_dec_stop_iso_xfer(struct ttusb_dec *dec)
834 int i;
836 dprintk("%s\n", __FUNCTION__);
838 if (down_interruptible(&dec->iso_sem))
839 return;
841 dec->iso_stream_count--;
843 if (!dec->iso_stream_count) {
844 for (i = 0; i < ISO_BUF_COUNT; i++)
845 usb_kill_urb(dec->iso_urb[i]);
848 up(&dec->iso_sem);
851 /* Setting the interface of the DEC tends to take down the USB communications
852 * for a short period, so it's important not to call this function just before
853 * trying to talk to it.
855 static int ttusb_dec_set_interface(struct ttusb_dec *dec,
856 enum ttusb_dec_interface interface)
858 int result = 0;
859 u8 b[] = { 0x05 };
861 if (interface != dec->interface) {
862 switch (interface) {
863 case TTUSB_DEC_INTERFACE_INITIAL:
864 result = usb_set_interface(dec->udev, 0, 0);
865 break;
866 case TTUSB_DEC_INTERFACE_IN:
867 result = ttusb_dec_send_command(dec, 0x80, sizeof(b),
868 b, NULL, NULL);
869 if (result)
870 return result;
871 result = usb_set_interface(dec->udev, 0, 8);
872 break;
873 case TTUSB_DEC_INTERFACE_OUT:
874 result = usb_set_interface(dec->udev, 0, 1);
875 break;
878 if (result)
879 return result;
881 dec->interface = interface;
884 return 0;
887 static int ttusb_dec_start_iso_xfer(struct ttusb_dec *dec)
889 int i, result;
891 dprintk("%s\n", __FUNCTION__);
893 if (down_interruptible(&dec->iso_sem))
894 return -EAGAIN;
896 if (!dec->iso_stream_count) {
897 ttusb_dec_setup_urbs(dec);
899 dec->packet_state = 0;
900 dec->v_pes_postbytes = 0;
901 dec->next_packet_id = 0;
903 for (i = 0; i < ISO_BUF_COUNT; i++) {
904 if ((result = usb_submit_urb(dec->iso_urb[i],
905 GFP_ATOMIC))) {
906 printk("%s: failed urb submission %d: "
907 "error %d\n", __FUNCTION__, i, result);
909 while (i) {
910 usb_kill_urb(dec->iso_urb[i - 1]);
911 i--;
914 up(&dec->iso_sem);
915 return result;
920 dec->iso_stream_count++;
922 up(&dec->iso_sem);
924 return 0;
927 static int ttusb_dec_start_ts_feed(struct dvb_demux_feed *dvbdmxfeed)
929 struct dvb_demux *dvbdmx = dvbdmxfeed->demux;
930 struct ttusb_dec *dec = dvbdmx->priv;
931 u8 b0[] = { 0x05 };
932 int result = 0;
934 dprintk("%s\n", __FUNCTION__);
936 dprintk(" ts_type:");
938 if (dvbdmxfeed->ts_type & TS_DECODER)
939 dprintk(" TS_DECODER");
941 if (dvbdmxfeed->ts_type & TS_PACKET)
942 dprintk(" TS_PACKET");
944 if (dvbdmxfeed->ts_type & TS_PAYLOAD_ONLY)
945 dprintk(" TS_PAYLOAD_ONLY");
947 dprintk("\n");
949 switch (dvbdmxfeed->pes_type) {
951 case DMX_TS_PES_VIDEO:
952 dprintk(" pes_type: DMX_TS_PES_VIDEO\n");
953 dec->pid[DMX_PES_PCR] = dvbdmxfeed->pid;
954 dec->pid[DMX_PES_VIDEO] = dvbdmxfeed->pid;
955 dec->video_filter = dvbdmxfeed->filter;
956 ttusb_dec_set_pids(dec);
957 break;
959 case DMX_TS_PES_AUDIO:
960 dprintk(" pes_type: DMX_TS_PES_AUDIO\n");
961 dec->pid[DMX_PES_AUDIO] = dvbdmxfeed->pid;
962 dec->audio_filter = dvbdmxfeed->filter;
963 ttusb_dec_set_pids(dec);
964 break;
966 case DMX_TS_PES_TELETEXT:
967 dec->pid[DMX_PES_TELETEXT] = dvbdmxfeed->pid;
968 dprintk(" pes_type: DMX_TS_PES_TELETEXT\n");
969 break;
971 case DMX_TS_PES_PCR:
972 dprintk(" pes_type: DMX_TS_PES_PCR\n");
973 dec->pid[DMX_PES_PCR] = dvbdmxfeed->pid;
974 ttusb_dec_set_pids(dec);
975 break;
977 case DMX_TS_PES_OTHER:
978 dprintk(" pes_type: DMX_TS_PES_OTHER\n");
979 break;
981 default:
982 dprintk(" pes_type: unknown (%d)\n", dvbdmxfeed->pes_type);
983 return -EINVAL;
987 result = ttusb_dec_send_command(dec, 0x80, sizeof(b0), b0, NULL, NULL);
988 if (result)
989 return result;
991 dec->pva_stream_count++;
992 return ttusb_dec_start_iso_xfer(dec);
995 static int ttusb_dec_start_sec_feed(struct dvb_demux_feed *dvbdmxfeed)
997 struct ttusb_dec *dec = dvbdmxfeed->demux->priv;
998 u8 b0[] = { 0x00, 0x00, 0x00, 0x01,
999 0x00, 0x00, 0x00, 0x00,
1000 0x00, 0x00, 0x00, 0x00,
1001 0x00, 0x00, 0x00, 0x00,
1002 0x00, 0xff, 0x00, 0x00,
1003 0x00, 0x00, 0x00, 0x00,
1004 0x00, 0x00, 0x00, 0x00,
1005 0x00 };
1006 u16 pid;
1007 u8 c[COMMAND_PACKET_SIZE];
1008 int c_length;
1009 int result;
1010 struct filter_info *finfo;
1011 unsigned long flags;
1012 u8 x = 1;
1014 dprintk("%s\n", __FUNCTION__);
1016 pid = htons(dvbdmxfeed->pid);
1017 memcpy(&b0[0], &pid, 2);
1018 memcpy(&b0[4], &x, 1);
1019 memcpy(&b0[5], &dvbdmxfeed->filter->filter.filter_value[0], 1);
1021 result = ttusb_dec_send_command(dec, 0x60, sizeof(b0), b0,
1022 &c_length, c);
1024 if (!result) {
1025 if (c_length == 2) {
1026 if (!(finfo = kmalloc(sizeof(struct filter_info),
1027 GFP_ATOMIC)))
1028 return -ENOMEM;
1030 finfo->stream_id = c[1];
1031 finfo->filter = dvbdmxfeed->filter;
1033 spin_lock_irqsave(&dec->filter_info_list_lock, flags);
1034 list_add_tail(&finfo->filter_info_list,
1035 &dec->filter_info_list);
1036 spin_unlock_irqrestore(&dec->filter_info_list_lock,
1037 flags);
1039 dvbdmxfeed->priv = finfo;
1041 dec->filter_stream_count++;
1042 return ttusb_dec_start_iso_xfer(dec);
1045 return -EAGAIN;
1046 } else
1047 return result;
1050 static int ttusb_dec_start_feed(struct dvb_demux_feed *dvbdmxfeed)
1052 struct dvb_demux *dvbdmx = dvbdmxfeed->demux;
1054 dprintk("%s\n", __FUNCTION__);
1056 if (!dvbdmx->dmx.frontend)
1057 return -EINVAL;
1059 dprintk(" pid: 0x%04X\n", dvbdmxfeed->pid);
1061 switch (dvbdmxfeed->type) {
1063 case DMX_TYPE_TS:
1064 return ttusb_dec_start_ts_feed(dvbdmxfeed);
1065 break;
1067 case DMX_TYPE_SEC:
1068 return ttusb_dec_start_sec_feed(dvbdmxfeed);
1069 break;
1071 default:
1072 dprintk(" type: unknown (%d)\n", dvbdmxfeed->type);
1073 return -EINVAL;
1078 static int ttusb_dec_stop_ts_feed(struct dvb_demux_feed *dvbdmxfeed)
1080 struct ttusb_dec *dec = dvbdmxfeed->demux->priv;
1081 u8 b0[] = { 0x00 };
1083 ttusb_dec_send_command(dec, 0x81, sizeof(b0), b0, NULL, NULL);
1085 dec->pva_stream_count--;
1087 ttusb_dec_stop_iso_xfer(dec);
1089 return 0;
1092 static int ttusb_dec_stop_sec_feed(struct dvb_demux_feed *dvbdmxfeed)
1094 struct ttusb_dec *dec = dvbdmxfeed->demux->priv;
1095 u8 b0[] = { 0x00, 0x00 };
1096 struct filter_info *finfo = (struct filter_info *)dvbdmxfeed->priv;
1097 unsigned long flags;
1099 b0[1] = finfo->stream_id;
1100 spin_lock_irqsave(&dec->filter_info_list_lock, flags);
1101 list_del(&finfo->filter_info_list);
1102 spin_unlock_irqrestore(&dec->filter_info_list_lock, flags);
1103 kfree(finfo);
1104 ttusb_dec_send_command(dec, 0x62, sizeof(b0), b0, NULL, NULL);
1106 dec->filter_stream_count--;
1108 ttusb_dec_stop_iso_xfer(dec);
1110 return 0;
1113 static int ttusb_dec_stop_feed(struct dvb_demux_feed *dvbdmxfeed)
1115 dprintk("%s\n", __FUNCTION__);
1117 switch (dvbdmxfeed->type) {
1118 case DMX_TYPE_TS:
1119 return ttusb_dec_stop_ts_feed(dvbdmxfeed);
1120 break;
1122 case DMX_TYPE_SEC:
1123 return ttusb_dec_stop_sec_feed(dvbdmxfeed);
1124 break;
1127 return 0;
1130 static void ttusb_dec_free_iso_urbs(struct ttusb_dec *dec)
1132 int i;
1134 dprintk("%s\n", __FUNCTION__);
1136 for (i = 0; i < ISO_BUF_COUNT; i++)
1137 if (dec->iso_urb[i])
1138 usb_free_urb(dec->iso_urb[i]);
1140 pci_free_consistent(NULL,
1141 ISO_FRAME_SIZE * (FRAMES_PER_ISO_BUF *
1142 ISO_BUF_COUNT),
1143 dec->iso_buffer, dec->iso_dma_handle);
1146 static int ttusb_dec_alloc_iso_urbs(struct ttusb_dec *dec)
1148 int i;
1150 dprintk("%s\n", __FUNCTION__);
1152 dec->iso_buffer = pci_alloc_consistent(NULL,
1153 ISO_FRAME_SIZE *
1154 (FRAMES_PER_ISO_BUF *
1155 ISO_BUF_COUNT),
1156 &dec->iso_dma_handle);
1158 memset(dec->iso_buffer, 0,
1159 ISO_FRAME_SIZE * (FRAMES_PER_ISO_BUF * ISO_BUF_COUNT));
1161 for (i = 0; i < ISO_BUF_COUNT; i++) {
1162 struct urb *urb;
1164 if (!(urb = usb_alloc_urb(FRAMES_PER_ISO_BUF, GFP_ATOMIC))) {
1165 ttusb_dec_free_iso_urbs(dec);
1166 return -ENOMEM;
1169 dec->iso_urb[i] = urb;
1172 ttusb_dec_setup_urbs(dec);
1174 return 0;
1177 static void ttusb_dec_init_tasklet(struct ttusb_dec *dec)
1179 spin_lock_init(&dec->urb_frame_list_lock);
1180 INIT_LIST_HEAD(&dec->urb_frame_list);
1181 tasklet_init(&dec->urb_tasklet, ttusb_dec_process_urb_frame_list,
1182 (unsigned long)dec);
1185 static void ttusb_init_rc( struct ttusb_dec *dec)
1187 u8 b[] = { 0x00, 0x01 };
1188 int i;
1190 init_input_dev(&dec->rc_input_dev);
1192 dec->rc_input_dev.name = "ttusb_dec remote control";
1193 dec->rc_input_dev.evbit[0] = BIT(EV_KEY);
1194 dec->rc_input_dev.keycodesize = sizeof(u16);
1195 dec->rc_input_dev.keycodemax = 0x1a;
1196 dec->rc_input_dev.keycode = rc_keys;
1198 for (i = 0; i < sizeof(rc_keys)/sizeof(rc_keys[0]); i++)
1199 set_bit(rc_keys[i], dec->rc_input_dev.keybit);
1201 input_register_device(&dec->rc_input_dev);
1203 if(usb_submit_urb(dec->irq_urb,GFP_KERNEL)) {
1204 printk("%s: usb_submit_urb failed\n",__FUNCTION__);
1206 /* enable irq pipe */
1207 ttusb_dec_send_command(dec,0xb0,sizeof(b),b,NULL,NULL);
1210 static void ttusb_dec_init_v_pes(struct ttusb_dec *dec)
1212 dprintk("%s\n", __FUNCTION__);
1214 dec->v_pes[0] = 0x00;
1215 dec->v_pes[1] = 0x00;
1216 dec->v_pes[2] = 0x01;
1217 dec->v_pes[3] = 0xe0;
1220 static int ttusb_dec_init_usb(struct ttusb_dec *dec)
1222 dprintk("%s\n", __FUNCTION__);
1224 sema_init(&dec->usb_sem, 1);
1225 sema_init(&dec->iso_sem, 1);
1227 dec->command_pipe = usb_sndbulkpipe(dec->udev, COMMAND_PIPE);
1228 dec->result_pipe = usb_rcvbulkpipe(dec->udev, RESULT_PIPE);
1229 dec->in_pipe = usb_rcvisocpipe(dec->udev, IN_PIPE);
1230 dec->out_pipe = usb_sndisocpipe(dec->udev, OUT_PIPE);
1231 dec->irq_pipe = usb_rcvintpipe(dec->udev, IRQ_PIPE);
1233 if(enable_rc) {
1234 dec->irq_urb = usb_alloc_urb(0, GFP_KERNEL);
1235 if(!dec->irq_urb) {
1236 return -ENOMEM;
1238 dec->irq_buffer = usb_buffer_alloc(dec->udev,IRQ_PACKET_SIZE,
1239 SLAB_ATOMIC, &dec->irq_dma_handle);
1240 if(!dec->irq_buffer) {
1241 return -ENOMEM;
1243 usb_fill_int_urb(dec->irq_urb, dec->udev,dec->irq_pipe,
1244 dec->irq_buffer, IRQ_PACKET_SIZE,
1245 ttusb_dec_handle_irq, dec, 1);
1246 dec->irq_urb->transfer_dma = dec->irq_dma_handle;
1247 dec->irq_urb->transfer_flags |= URB_NO_TRANSFER_DMA_MAP;
1250 return ttusb_dec_alloc_iso_urbs(dec);
1253 static int ttusb_dec_boot_dsp(struct ttusb_dec *dec)
1255 int i, j, actual_len, result, size, trans_count;
1256 u8 b0[] = { 0x00, 0x00, 0x00, 0x00,
1257 0x00, 0x00, 0x00, 0x00,
1258 0x61, 0x00 };
1259 u8 b1[] = { 0x61 };
1260 u8 *b;
1261 char idstring[21];
1262 u8 *firmware = NULL;
1263 size_t firmware_size = 0;
1264 u16 firmware_csum = 0;
1265 u16 firmware_csum_ns;
1266 u32 firmware_size_nl;
1267 u32 crc32_csum, crc32_check, tmp;
1268 const struct firmware *fw_entry = NULL;
1270 dprintk("%s\n", __FUNCTION__);
1272 if (request_firmware(&fw_entry, dec->firmware_name, &dec->udev->dev)) {
1273 printk(KERN_ERR "%s: Firmware (%s) unavailable.\n",
1274 __FUNCTION__, dec->firmware_name);
1275 return 1;
1278 firmware = fw_entry->data;
1279 firmware_size = fw_entry->size;
1281 if (firmware_size < 60) {
1282 printk("%s: firmware size too small for DSP code (%zu < 60).\n",
1283 __FUNCTION__, firmware_size);
1284 release_firmware(fw_entry);
1285 return -1;
1288 /* a 32 bit checksum over the first 56 bytes of the DSP Code is stored
1289 at offset 56 of file, so use it to check if the firmware file is
1290 valid. */
1291 crc32_csum = crc32(~0L, firmware, 56) ^ ~0L;
1292 memcpy(&tmp, &firmware[56], 4);
1293 crc32_check = htonl(tmp);
1294 if (crc32_csum != crc32_check) {
1295 printk("%s: crc32 check of DSP code failed (calculated "
1296 "0x%08x != 0x%08x in file), file invalid.\n",
1297 __FUNCTION__, crc32_csum, crc32_check);
1298 release_firmware(fw_entry);
1299 return -1;
1301 memcpy(idstring, &firmware[36], 20);
1302 idstring[20] = '\0';
1303 printk(KERN_INFO "ttusb_dec: found DSP code \"%s\".\n", idstring);
1305 firmware_size_nl = htonl(firmware_size);
1306 memcpy(b0, &firmware_size_nl, 4);
1307 firmware_csum = crc16(~0, firmware, firmware_size) ^ ~0;
1308 firmware_csum_ns = htons(firmware_csum);
1309 memcpy(&b0[6], &firmware_csum_ns, 2);
1311 result = ttusb_dec_send_command(dec, 0x41, sizeof(b0), b0, NULL, NULL);
1313 if (result) {
1314 release_firmware(fw_entry);
1315 return result;
1318 trans_count = 0;
1319 j = 0;
1321 b = kmalloc(ARM_PACKET_SIZE, GFP_KERNEL);
1322 if (b == NULL) {
1323 release_firmware(fw_entry);
1324 return -ENOMEM;
1327 for (i = 0; i < firmware_size; i += COMMAND_PACKET_SIZE) {
1328 size = firmware_size - i;
1329 if (size > COMMAND_PACKET_SIZE)
1330 size = COMMAND_PACKET_SIZE;
1332 b[j + 0] = 0xaa;
1333 b[j + 1] = trans_count++;
1334 b[j + 2] = 0xf0;
1335 b[j + 3] = size;
1336 memcpy(&b[j + 4], &firmware[i], size);
1338 j += COMMAND_PACKET_SIZE + 4;
1340 if (j >= ARM_PACKET_SIZE) {
1341 result = usb_bulk_msg(dec->udev, dec->command_pipe, b,
1342 ARM_PACKET_SIZE, &actual_len,
1343 100);
1344 j = 0;
1345 } else if (size < COMMAND_PACKET_SIZE) {
1346 result = usb_bulk_msg(dec->udev, dec->command_pipe, b,
1347 j - COMMAND_PACKET_SIZE + size,
1348 &actual_len, 100);
1352 result = ttusb_dec_send_command(dec, 0x43, sizeof(b1), b1, NULL, NULL);
1354 release_firmware(fw_entry);
1355 kfree(b);
1357 return result;
1360 static int ttusb_dec_init_stb(struct ttusb_dec *dec)
1362 int result;
1363 unsigned int mode, model, version;
1365 dprintk("%s\n", __FUNCTION__);
1367 result = ttusb_dec_get_stb_state(dec, &mode, &model, &version);
1369 if (!result) {
1370 if (!mode) {
1371 if (version == 0xABCDEFAB)
1372 printk(KERN_INFO "ttusb_dec: no version "
1373 "info in Firmware\n");
1374 else
1375 printk(KERN_INFO "ttusb_dec: Firmware "
1376 "%x.%02x%c%c\n",
1377 version >> 24, (version >> 16) & 0xff,
1378 (version >> 8) & 0xff, version & 0xff);
1380 result = ttusb_dec_boot_dsp(dec);
1381 if (result)
1382 return result;
1383 else
1384 return 1;
1385 } else {
1386 /* We can't trust the USB IDs that some firmwares
1387 give the box */
1388 switch (model) {
1389 case 0x00070008:
1390 case 0x0007000c:
1391 ttusb_dec_set_model(dec, TTUSB_DEC3000S);
1392 break;
1393 case 0x00070009:
1394 case 0x00070013:
1395 ttusb_dec_set_model(dec, TTUSB_DEC2000T);
1396 break;
1397 case 0x00070011:
1398 ttusb_dec_set_model(dec, TTUSB_DEC2540T);
1399 break;
1400 default:
1401 printk(KERN_ERR "%s: unknown model returned "
1402 "by firmware (%08x) - please report\n",
1403 __FUNCTION__, model);
1404 return -1;
1405 break;
1408 if (version >= 0x01770000)
1409 dec->can_playback = 1;
1411 return 0;
1414 else
1415 return result;
1418 static int ttusb_dec_init_dvb(struct ttusb_dec *dec)
1420 int result;
1422 dprintk("%s\n", __FUNCTION__);
1424 if ((result = dvb_register_adapter(&dec->adapter,
1425 dec->model_name, THIS_MODULE)) < 0) {
1426 printk("%s: dvb_register_adapter failed: error %d\n",
1427 __FUNCTION__, result);
1429 return result;
1432 dec->demux.dmx.capabilities = DMX_TS_FILTERING | DMX_SECTION_FILTERING;
1434 dec->demux.priv = (void *)dec;
1435 dec->demux.filternum = 31;
1436 dec->demux.feednum = 31;
1437 dec->demux.start_feed = ttusb_dec_start_feed;
1438 dec->demux.stop_feed = ttusb_dec_stop_feed;
1439 dec->demux.write_to_decoder = NULL;
1441 if ((result = dvb_dmx_init(&dec->demux)) < 0) {
1442 printk("%s: dvb_dmx_init failed: error %d\n", __FUNCTION__,
1443 result);
1445 dvb_unregister_adapter(&dec->adapter);
1447 return result;
1450 dec->dmxdev.filternum = 32;
1451 dec->dmxdev.demux = &dec->demux.dmx;
1452 dec->dmxdev.capabilities = 0;
1454 if ((result = dvb_dmxdev_init(&dec->dmxdev, &dec->adapter)) < 0) {
1455 printk("%s: dvb_dmxdev_init failed: error %d\n",
1456 __FUNCTION__, result);
1458 dvb_dmx_release(&dec->demux);
1459 dvb_unregister_adapter(&dec->adapter);
1461 return result;
1464 dec->frontend.source = DMX_FRONTEND_0;
1466 if ((result = dec->demux.dmx.add_frontend(&dec->demux.dmx,
1467 &dec->frontend)) < 0) {
1468 printk("%s: dvb_dmx_init failed: error %d\n", __FUNCTION__,
1469 result);
1471 dvb_dmxdev_release(&dec->dmxdev);
1472 dvb_dmx_release(&dec->demux);
1473 dvb_unregister_adapter(&dec->adapter);
1475 return result;
1478 if ((result = dec->demux.dmx.connect_frontend(&dec->demux.dmx,
1479 &dec->frontend)) < 0) {
1480 printk("%s: dvb_dmx_init failed: error %d\n", __FUNCTION__,
1481 result);
1483 dec->demux.dmx.remove_frontend(&dec->demux.dmx, &dec->frontend);
1484 dvb_dmxdev_release(&dec->dmxdev);
1485 dvb_dmx_release(&dec->demux);
1486 dvb_unregister_adapter(&dec->adapter);
1488 return result;
1491 dvb_net_init(&dec->adapter, &dec->dvb_net, &dec->demux.dmx);
1493 return 0;
1496 static void ttusb_dec_exit_dvb(struct ttusb_dec *dec)
1498 dprintk("%s\n", __FUNCTION__);
1500 dvb_net_release(&dec->dvb_net);
1501 dec->demux.dmx.close(&dec->demux.dmx);
1502 dec->demux.dmx.remove_frontend(&dec->demux.dmx, &dec->frontend);
1503 dvb_dmxdev_release(&dec->dmxdev);
1504 dvb_dmx_release(&dec->demux);
1505 if (dec->fe) dvb_unregister_frontend(dec->fe);
1506 dvb_unregister_adapter(&dec->adapter);
1509 static void ttusb_dec_exit_rc(struct ttusb_dec *dec)
1512 dprintk("%s\n", __FUNCTION__);
1513 /* we have to check whether the irq URB is already submitted.
1514 * As the irq is submitted after the interface is changed,
1515 * this is the best method i figured out.
1516 * Any others?*/
1517 if(dec->interface == TTUSB_DEC_INTERFACE_IN)
1518 usb_kill_urb(dec->irq_urb);
1520 usb_free_urb(dec->irq_urb);
1522 usb_buffer_free(dec->udev,IRQ_PACKET_SIZE,
1523 dec->irq_buffer, dec->irq_dma_handle);
1525 input_unregister_device(&dec->rc_input_dev);
1529 static void ttusb_dec_exit_usb(struct ttusb_dec *dec)
1531 int i;
1533 dprintk("%s\n", __FUNCTION__);
1535 dec->iso_stream_count = 0;
1537 for (i = 0; i < ISO_BUF_COUNT; i++)
1538 usb_kill_urb(dec->iso_urb[i]);
1540 ttusb_dec_free_iso_urbs(dec);
1543 static void ttusb_dec_exit_tasklet(struct ttusb_dec *dec)
1545 struct list_head *item;
1546 struct urb_frame *frame;
1548 tasklet_kill(&dec->urb_tasklet);
1550 while ((item = dec->urb_frame_list.next) != &dec->urb_frame_list) {
1551 frame = list_entry(item, struct urb_frame, urb_frame_list);
1552 list_del(&frame->urb_frame_list);
1553 kfree(frame);
1557 static void ttusb_dec_init_filters(struct ttusb_dec *dec)
1559 INIT_LIST_HEAD(&dec->filter_info_list);
1560 spin_lock_init(&dec->filter_info_list_lock);
1563 static void ttusb_dec_exit_filters(struct ttusb_dec *dec)
1565 struct list_head *item;
1566 struct filter_info *finfo;
1568 while ((item = dec->filter_info_list.next) != &dec->filter_info_list) {
1569 finfo = list_entry(item, struct filter_info, filter_info_list);
1570 list_del(&finfo->filter_info_list);
1571 kfree(finfo);
1575 static int fe_send_command(struct dvb_frontend* fe, const u8 command,
1576 int param_length, const u8 params[],
1577 int *result_length, u8 cmd_result[])
1579 struct ttusb_dec* dec = (struct ttusb_dec*) fe->dvb->priv;
1580 return ttusb_dec_send_command(dec, command, param_length, params, result_length, cmd_result);
1583 static struct ttusbdecfe_config fe_config = {
1584 .send_command = fe_send_command
1587 static int ttusb_dec_probe(struct usb_interface *intf,
1588 const struct usb_device_id *id)
1590 struct usb_device *udev;
1591 struct ttusb_dec *dec;
1593 dprintk("%s\n", __FUNCTION__);
1595 udev = interface_to_usbdev(intf);
1597 if (!(dec = kmalloc(sizeof(struct ttusb_dec), GFP_KERNEL))) {
1598 printk("%s: couldn't allocate memory.\n", __FUNCTION__);
1599 return -ENOMEM;
1602 usb_set_intfdata(intf, (void *)dec);
1604 memset(dec, 0, sizeof(struct ttusb_dec));
1606 switch (le16_to_cpu(id->idProduct)) {
1607 case 0x1006:
1608 ttusb_dec_set_model(dec, TTUSB_DEC3000S);
1609 break;
1611 case 0x1008:
1612 ttusb_dec_set_model(dec, TTUSB_DEC2000T);
1613 break;
1615 case 0x1009:
1616 ttusb_dec_set_model(dec, TTUSB_DEC2540T);
1617 break;
1620 dec->udev = udev;
1622 if (ttusb_dec_init_usb(dec))
1623 return 0;
1624 if (ttusb_dec_init_stb(dec)) {
1625 ttusb_dec_exit_usb(dec);
1626 return 0;
1628 ttusb_dec_init_dvb(dec);
1630 dec->adapter.priv = dec;
1631 switch (le16_to_cpu(id->idProduct)) {
1632 case 0x1006:
1633 dec->fe = ttusbdecfe_dvbs_attach(&fe_config);
1634 break;
1636 case 0x1008:
1637 case 0x1009:
1638 dec->fe = ttusbdecfe_dvbt_attach(&fe_config);
1639 break;
1642 if (dec->fe == NULL) {
1643 printk("dvb-ttusb-dec: A frontend driver was not found for device %04x/%04x\n",
1644 le16_to_cpu(dec->udev->descriptor.idVendor),
1645 le16_to_cpu(dec->udev->descriptor.idProduct));
1646 } else {
1647 if (dvb_register_frontend(&dec->adapter, dec->fe)) {
1648 printk("budget-ci: Frontend registration failed!\n");
1649 if (dec->fe->ops->release)
1650 dec->fe->ops->release(dec->fe);
1651 dec->fe = NULL;
1655 ttusb_dec_init_v_pes(dec);
1656 ttusb_dec_init_filters(dec);
1657 ttusb_dec_init_tasklet(dec);
1659 dec->active = 1;
1661 ttusb_dec_set_interface(dec, TTUSB_DEC_INTERFACE_IN);
1663 if(enable_rc)
1664 ttusb_init_rc(dec);
1666 return 0;
1669 static void ttusb_dec_disconnect(struct usb_interface *intf)
1671 struct ttusb_dec *dec = usb_get_intfdata(intf);
1673 usb_set_intfdata(intf, NULL);
1675 dprintk("%s\n", __FUNCTION__);
1677 if (dec->active) {
1678 ttusb_dec_exit_tasklet(dec);
1679 ttusb_dec_exit_filters(dec);
1680 if(enable_rc)
1681 ttusb_dec_exit_rc(dec);
1682 ttusb_dec_exit_usb(dec);
1683 ttusb_dec_exit_dvb(dec);
1686 kfree(dec);
1689 static void ttusb_dec_set_model(struct ttusb_dec *dec,
1690 enum ttusb_dec_model model)
1692 dec->model = model;
1694 switch (model) {
1695 case TTUSB_DEC2000T:
1696 dec->model_name = "DEC2000-t";
1697 dec->firmware_name = "dvb-ttusb-dec-2000t.fw";
1698 break;
1700 case TTUSB_DEC2540T:
1701 dec->model_name = "DEC2540-t";
1702 dec->firmware_name = "dvb-ttusb-dec-2540t.fw";
1703 break;
1705 case TTUSB_DEC3000S:
1706 dec->model_name = "DEC3000-s";
1707 dec->firmware_name = "dvb-ttusb-dec-3000s.fw";
1708 break;
1712 static struct usb_device_id ttusb_dec_table[] = {
1713 {USB_DEVICE(0x0b48, 0x1006)}, /* DEC3000-s */
1714 /*{USB_DEVICE(0x0b48, 0x1007)}, Unconfirmed */
1715 {USB_DEVICE(0x0b48, 0x1008)}, /* DEC2000-t */
1716 {USB_DEVICE(0x0b48, 0x1009)}, /* DEC2540-t */
1720 static struct usb_driver ttusb_dec_driver = {
1721 .name = "ttusb-dec",
1722 .probe = ttusb_dec_probe,
1723 .disconnect = ttusb_dec_disconnect,
1724 .id_table = ttusb_dec_table,
1727 static int __init ttusb_dec_init(void)
1729 int result;
1731 if ((result = usb_register(&ttusb_dec_driver)) < 0) {
1732 printk("%s: initialisation failed: error %d.\n", __FUNCTION__,
1733 result);
1734 return result;
1737 return 0;
1740 static void __exit ttusb_dec_exit(void)
1742 usb_deregister(&ttusb_dec_driver);
1745 module_init(ttusb_dec_init);
1746 module_exit(ttusb_dec_exit);
1748 MODULE_AUTHOR("Alex Woods <linux-dvb@giblets.org>");
1749 MODULE_DESCRIPTION(DRIVER_NAME);
1750 MODULE_LICENSE("GPL");
1751 MODULE_DEVICE_TABLE(usb, ttusb_dec_table);