xref: /openbmc/linux/drivers/media/usb/ttusb-dec/ttusb_dec.c (revision 791d3ef2e11100449837dc0b6fe884e60ca3a484)
1 /*
2  * TTUSB DEC Driver
3  *
4  * Copyright (C) 2003-2004 Alex Woods <linux-dvb@giblets.org>
5  * IR support by Peter Beutner <p.beutner@gmx.net>
6  *
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.
11  *
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.
16  *
17  */
18 
19 #include <linux/list.h>
20 #include <linux/module.h>
21 #include <linux/pci.h>
22 #include <linux/slab.h>
23 #include <linux/spinlock.h>
24 #include <linux/usb.h>
25 #include <linux/interrupt.h>
26 #include <linux/firmware.h>
27 #include <linux/crc32.h>
28 #include <linux/init.h>
29 #include <linux/input.h>
30 
31 #include <linux/mutex.h>
32 
33 #include <media/dmxdev.h>
34 #include <media/dvb_demux.h>
35 #include <media/dvb_frontend.h>
36 #include <media/dvb_net.h>
37 #include "ttusbdecfe.h"
38 
39 static int debug;
40 static int output_pva;
41 static int enable_rc;
42 
43 module_param(debug, int, 0644);
44 MODULE_PARM_DESC(debug, "Turn on/off debugging (default:off).");
45 module_param(output_pva, int, 0444);
46 MODULE_PARM_DESC(output_pva, "Output PVA from dvr device (default:off)");
47 module_param(enable_rc, int, 0644);
48 MODULE_PARM_DESC(enable_rc, "Turn on/off IR remote control(default: off)");
49 
50 DVB_DEFINE_MOD_OPT_ADAPTER_NR(adapter_nr);
51 
52 #define dprintk	if (debug) printk
53 
54 #define DRIVER_NAME		"TechnoTrend/Hauppauge DEC USB"
55 
56 #define COMMAND_PIPE		0x03
57 #define RESULT_PIPE		0x04
58 #define IN_PIPE			0x08
59 #define OUT_PIPE		0x07
60 #define IRQ_PIPE		0x0A
61 
62 #define COMMAND_PACKET_SIZE	0x3c
63 #define ARM_PACKET_SIZE		0x1000
64 #define IRQ_PACKET_SIZE		0x8
65 
66 #define ISO_BUF_COUNT		0x04
67 #define FRAMES_PER_ISO_BUF	0x04
68 #define ISO_FRAME_SIZE		0x0380
69 
70 #define	MAX_PVA_LENGTH		6144
71 
72 enum ttusb_dec_model {
73 	TTUSB_DEC2000T,
74 	TTUSB_DEC2540T,
75 	TTUSB_DEC3000S
76 };
77 
78 enum ttusb_dec_packet_type {
79 	TTUSB_DEC_PACKET_PVA,
80 	TTUSB_DEC_PACKET_SECTION,
81 	TTUSB_DEC_PACKET_EMPTY
82 };
83 
84 enum ttusb_dec_interface {
85 	TTUSB_DEC_INTERFACE_INITIAL,
86 	TTUSB_DEC_INTERFACE_IN,
87 	TTUSB_DEC_INTERFACE_OUT
88 };
89 
90 typedef int (dvb_filter_pes2ts_cb_t) (void *, unsigned char *);
91 
92 struct dvb_filter_pes2ts {
93 	unsigned char buf[188];
94 	unsigned char cc;
95 	dvb_filter_pes2ts_cb_t *cb;
96 	void *priv;
97 };
98 
99 struct ttusb_dec {
100 	enum ttusb_dec_model		model;
101 	char				*model_name;
102 	char				*firmware_name;
103 	int				can_playback;
104 
105 	/* DVB bits */
106 	struct dvb_adapter		adapter;
107 	struct dmxdev			dmxdev;
108 	struct dvb_demux		demux;
109 	struct dmx_frontend		frontend;
110 	struct dvb_net			dvb_net;
111 	struct dvb_frontend*		fe;
112 
113 	u16			pid[DMX_PES_OTHER];
114 
115 	/* USB bits */
116 	struct usb_device		*udev;
117 	u8				trans_count;
118 	unsigned int			command_pipe;
119 	unsigned int			result_pipe;
120 	unsigned int			in_pipe;
121 	unsigned int			out_pipe;
122 	unsigned int			irq_pipe;
123 	enum ttusb_dec_interface	interface;
124 	struct mutex			usb_mutex;
125 
126 	void			*irq_buffer;
127 	struct urb		*irq_urb;
128 	dma_addr_t		irq_dma_handle;
129 	void			*iso_buffer;
130 	struct urb		*iso_urb[ISO_BUF_COUNT];
131 	int			iso_stream_count;
132 	struct mutex		iso_mutex;
133 
134 	u8				packet[MAX_PVA_LENGTH + 4];
135 	enum ttusb_dec_packet_type	packet_type;
136 	int				packet_state;
137 	int				packet_length;
138 	int				packet_payload_length;
139 	u16				next_packet_id;
140 
141 	int				pva_stream_count;
142 	int				filter_stream_count;
143 
144 	struct dvb_filter_pes2ts	a_pes2ts;
145 	struct dvb_filter_pes2ts	v_pes2ts;
146 
147 	u8			v_pes[16 + MAX_PVA_LENGTH];
148 	int			v_pes_length;
149 	int			v_pes_postbytes;
150 
151 	struct list_head	urb_frame_list;
152 	struct tasklet_struct	urb_tasklet;
153 	spinlock_t		urb_frame_list_lock;
154 
155 	struct dvb_demux_filter	*audio_filter;
156 	struct dvb_demux_filter	*video_filter;
157 	struct list_head	filter_info_list;
158 	spinlock_t		filter_info_list_lock;
159 
160 	struct input_dev	*rc_input_dev;
161 	char			rc_phys[64];
162 
163 	int			active; /* Loaded successfully */
164 };
165 
166 struct urb_frame {
167 	u8			data[ISO_FRAME_SIZE];
168 	int			length;
169 	struct list_head	urb_frame_list;
170 };
171 
172 struct filter_info {
173 	u8			stream_id;
174 	struct dvb_demux_filter	*filter;
175 	struct list_head	filter_info_list;
176 };
177 
178 static u16 rc_keys[] = {
179 	KEY_POWER,
180 	KEY_MUTE,
181 	KEY_1,
182 	KEY_2,
183 	KEY_3,
184 	KEY_4,
185 	KEY_5,
186 	KEY_6,
187 	KEY_7,
188 	KEY_8,
189 	KEY_9,
190 	KEY_0,
191 	KEY_CHANNELUP,
192 	KEY_VOLUMEDOWN,
193 	KEY_OK,
194 	KEY_VOLUMEUP,
195 	KEY_CHANNELDOWN,
196 	KEY_PREVIOUS,
197 	KEY_ESC,
198 	KEY_RED,
199 	KEY_GREEN,
200 	KEY_YELLOW,
201 	KEY_BLUE,
202 	KEY_OPTION,
203 	KEY_M,
204 	KEY_RADIO
205 };
206 
207 static void dvb_filter_pes2ts_init(struct dvb_filter_pes2ts *p2ts,
208 				   unsigned short pid,
209 				   dvb_filter_pes2ts_cb_t *cb, void *priv)
210 {
211 	unsigned char *buf=p2ts->buf;
212 
213 	buf[0]=0x47;
214 	buf[1]=(pid>>8);
215 	buf[2]=pid&0xff;
216 	p2ts->cc=0;
217 	p2ts->cb=cb;
218 	p2ts->priv=priv;
219 }
220 
221 static int dvb_filter_pes2ts(struct dvb_filter_pes2ts *p2ts,
222 			     unsigned char *pes, int len, int payload_start)
223 {
224 	unsigned char *buf=p2ts->buf;
225 	int ret=0, rest;
226 
227 	//len=6+((pes[4]<<8)|pes[5]);
228 
229 	if (payload_start)
230 		buf[1]|=0x40;
231 	else
232 		buf[1]&=~0x40;
233 	while (len>=184) {
234 		buf[3]=0x10|((p2ts->cc++)&0x0f);
235 		memcpy(buf+4, pes, 184);
236 		if ((ret=p2ts->cb(p2ts->priv, buf)))
237 			return ret;
238 		len-=184; pes+=184;
239 		buf[1]&=~0x40;
240 	}
241 	if (!len)
242 		return 0;
243 	buf[3]=0x30|((p2ts->cc++)&0x0f);
244 	rest=183-len;
245 	if (rest) {
246 		buf[5]=0x00;
247 		if (rest-1)
248 			memset(buf+6, 0xff, rest-1);
249 	}
250 	buf[4]=rest;
251 	memcpy(buf+5+rest, pes, len);
252 	return p2ts->cb(p2ts->priv, buf);
253 }
254 
255 static void ttusb_dec_set_model(struct ttusb_dec *dec,
256 				enum ttusb_dec_model model);
257 
258 static void ttusb_dec_handle_irq( struct urb *urb)
259 {
260 	struct ttusb_dec *dec = urb->context;
261 	char *buffer = dec->irq_buffer;
262 	int retval;
263 
264 	switch(urb->status) {
265 		case 0: /*success*/
266 			break;
267 		case -ECONNRESET:
268 		case -ENOENT:
269 		case -ESHUTDOWN:
270 		case -ETIME:
271 			/* this urb is dead, cleanup */
272 			dprintk("%s:urb shutting down with status: %d\n",
273 					__func__, urb->status);
274 			return;
275 		default:
276 			dprintk("%s:nonzero status received: %d\n",
277 					__func__,urb->status);
278 			goto exit;
279 	}
280 
281 	if ((buffer[0] == 0x1) && (buffer[2] == 0x15))  {
282 		/*
283 		 * IR - Event
284 		 *
285 		 * this is an fact a bit too simple implementation;
286 		 * the box also reports a keyrepeat signal
287 		 * (with buffer[3] == 0x40) in an intervall of ~100ms.
288 		 * But to handle this correctly we had to imlemenent some
289 		 * kind of timer which signals a 'key up' event if no
290 		 * keyrepeat signal is received for lets say 200ms.
291 		 * this should/could be added later ...
292 		 * for now lets report each signal as a key down and up
293 		 */
294 		if (buffer[4] - 1 < ARRAY_SIZE(rc_keys)) {
295 			dprintk("%s:rc signal:%d\n", __func__, buffer[4]);
296 			input_report_key(dec->rc_input_dev, rc_keys[buffer[4] - 1], 1);
297 			input_sync(dec->rc_input_dev);
298 			input_report_key(dec->rc_input_dev, rc_keys[buffer[4] - 1], 0);
299 			input_sync(dec->rc_input_dev);
300 		}
301 	}
302 
303 exit:
304 	retval = usb_submit_urb(urb, GFP_ATOMIC);
305 	if (retval)
306 		printk("%s - usb_commit_urb failed with result: %d\n",
307 			__func__, retval);
308 }
309 
310 static u16 crc16(u16 crc, const u8 *buf, size_t len)
311 {
312 	u16 tmp;
313 
314 	while (len--) {
315 		crc ^= *buf++;
316 		crc ^= (u8)crc >> 4;
317 		tmp = (u8)crc;
318 		crc ^= (tmp ^ (tmp << 1)) << 4;
319 	}
320 	return crc;
321 }
322 
323 static int ttusb_dec_send_command(struct ttusb_dec *dec, const u8 command,
324 				  int param_length, const u8 params[],
325 				  int *result_length, u8 cmd_result[])
326 {
327 	int result, actual_len;
328 	u8 *b;
329 
330 	dprintk("%s\n", __func__);
331 
332 	b = kmalloc(COMMAND_PACKET_SIZE + 4, GFP_KERNEL);
333 	if (!b)
334 		return -ENOMEM;
335 
336 	if ((result = mutex_lock_interruptible(&dec->usb_mutex))) {
337 		kfree(b);
338 		printk("%s: Failed to lock usb mutex.\n", __func__);
339 		return result;
340 	}
341 
342 	b[0] = 0xaa;
343 	b[1] = ++dec->trans_count;
344 	b[2] = command;
345 	b[3] = param_length;
346 
347 	if (params)
348 		memcpy(&b[4], params, param_length);
349 
350 	if (debug) {
351 		printk(KERN_DEBUG "%s: command: %*ph\n",
352 		       __func__, param_length, b);
353 	}
354 
355 	result = usb_bulk_msg(dec->udev, dec->command_pipe, b,
356 			      COMMAND_PACKET_SIZE + 4, &actual_len, 1000);
357 
358 	if (result) {
359 		printk("%s: command bulk message failed: error %d\n",
360 		       __func__, result);
361 		mutex_unlock(&dec->usb_mutex);
362 		kfree(b);
363 		return result;
364 	}
365 
366 	result = usb_bulk_msg(dec->udev, dec->result_pipe, b,
367 			      COMMAND_PACKET_SIZE + 4, &actual_len, 1000);
368 
369 	if (result) {
370 		printk("%s: result bulk message failed: error %d\n",
371 		       __func__, result);
372 		mutex_unlock(&dec->usb_mutex);
373 		kfree(b);
374 		return result;
375 	} else {
376 		if (debug) {
377 			printk(KERN_DEBUG "%s: result: %*ph\n",
378 			       __func__, actual_len, b);
379 		}
380 
381 		if (result_length)
382 			*result_length = b[3];
383 		if (cmd_result && b[3] > 0)
384 			memcpy(cmd_result, &b[4], b[3]);
385 
386 		mutex_unlock(&dec->usb_mutex);
387 
388 		kfree(b);
389 		return 0;
390 	}
391 }
392 
393 static int ttusb_dec_get_stb_state (struct ttusb_dec *dec, unsigned int *mode,
394 				    unsigned int *model, unsigned int *version)
395 {
396 	u8 c[COMMAND_PACKET_SIZE];
397 	int c_length;
398 	int result;
399 	__be32 tmp;
400 
401 	dprintk("%s\n", __func__);
402 
403 	result = ttusb_dec_send_command(dec, 0x08, 0, NULL, &c_length, c);
404 	if (result)
405 		return result;
406 
407 	if (c_length >= 0x0c) {
408 		if (mode != NULL) {
409 			memcpy(&tmp, c, 4);
410 			*mode = ntohl(tmp);
411 		}
412 		if (model != NULL) {
413 			memcpy(&tmp, &c[4], 4);
414 			*model = ntohl(tmp);
415 		}
416 		if (version != NULL) {
417 			memcpy(&tmp, &c[8], 4);
418 			*version = ntohl(tmp);
419 		}
420 		return 0;
421 	} else {
422 		return -ENOENT;
423 	}
424 }
425 
426 static int ttusb_dec_audio_pes2ts_cb(void *priv, unsigned char *data)
427 {
428 	struct ttusb_dec *dec = priv;
429 
430 	dec->audio_filter->feed->cb.ts(data, 188, NULL, 0,
431 				       &dec->audio_filter->feed->feed.ts, NULL);
432 
433 	return 0;
434 }
435 
436 static int ttusb_dec_video_pes2ts_cb(void *priv, unsigned char *data)
437 {
438 	struct ttusb_dec *dec = priv;
439 
440 	dec->video_filter->feed->cb.ts(data, 188, NULL, 0,
441 				       &dec->video_filter->feed->feed.ts, NULL);
442 
443 	return 0;
444 }
445 
446 static void ttusb_dec_set_pids(struct ttusb_dec *dec)
447 {
448 	u8 b[] = { 0x00, 0x00, 0x00, 0x00,
449 		   0x00, 0x00, 0xff, 0xff,
450 		   0xff, 0xff, 0xff, 0xff };
451 
452 	__be16 pcr = htons(dec->pid[DMX_PES_PCR]);
453 	__be16 audio = htons(dec->pid[DMX_PES_AUDIO]);
454 	__be16 video = htons(dec->pid[DMX_PES_VIDEO]);
455 
456 	dprintk("%s\n", __func__);
457 
458 	memcpy(&b[0], &pcr, 2);
459 	memcpy(&b[2], &audio, 2);
460 	memcpy(&b[4], &video, 2);
461 
462 	ttusb_dec_send_command(dec, 0x50, sizeof(b), b, NULL, NULL);
463 
464 	dvb_filter_pes2ts_init(&dec->a_pes2ts, dec->pid[DMX_PES_AUDIO],
465 			       ttusb_dec_audio_pes2ts_cb, dec);
466 	dvb_filter_pes2ts_init(&dec->v_pes2ts, dec->pid[DMX_PES_VIDEO],
467 			       ttusb_dec_video_pes2ts_cb, dec);
468 	dec->v_pes_length = 0;
469 	dec->v_pes_postbytes = 0;
470 }
471 
472 static void ttusb_dec_process_pva(struct ttusb_dec *dec, u8 *pva, int length)
473 {
474 	if (length < 8) {
475 		printk("%s: packet too short - discarding\n", __func__);
476 		return;
477 	}
478 
479 	if (length > 8 + MAX_PVA_LENGTH) {
480 		printk("%s: packet too long - discarding\n", __func__);
481 		return;
482 	}
483 
484 	switch (pva[2]) {
485 
486 	case 0x01: {		/* VideoStream */
487 		int prebytes = pva[5] & 0x03;
488 		int postbytes = (pva[5] & 0x0c) >> 2;
489 		__be16 v_pes_payload_length;
490 
491 		if (output_pva) {
492 			dec->video_filter->feed->cb.ts(pva, length, NULL, 0,
493 				&dec->video_filter->feed->feed.ts, NULL);
494 			return;
495 		}
496 
497 		if (dec->v_pes_postbytes > 0 &&
498 		    dec->v_pes_postbytes == prebytes) {
499 			memcpy(&dec->v_pes[dec->v_pes_length],
500 			       &pva[12], prebytes);
501 
502 			dvb_filter_pes2ts(&dec->v_pes2ts, dec->v_pes,
503 					  dec->v_pes_length + prebytes, 1);
504 		}
505 
506 		if (pva[5] & 0x10) {
507 			dec->v_pes[7] = 0x80;
508 			dec->v_pes[8] = 0x05;
509 
510 			dec->v_pes[9] = 0x21 | ((pva[8] & 0xc0) >> 5);
511 			dec->v_pes[10] = ((pva[8] & 0x3f) << 2) |
512 					 ((pva[9] & 0xc0) >> 6);
513 			dec->v_pes[11] = 0x01 |
514 					 ((pva[9] & 0x3f) << 2) |
515 					 ((pva[10] & 0x80) >> 6);
516 			dec->v_pes[12] = ((pva[10] & 0x7f) << 1) |
517 					 ((pva[11] & 0xc0) >> 7);
518 			dec->v_pes[13] = 0x01 | ((pva[11] & 0x7f) << 1);
519 
520 			memcpy(&dec->v_pes[14], &pva[12 + prebytes],
521 			       length - 12 - prebytes);
522 			dec->v_pes_length = 14 + length - 12 - prebytes;
523 		} else {
524 			dec->v_pes[7] = 0x00;
525 			dec->v_pes[8] = 0x00;
526 
527 			memcpy(&dec->v_pes[9], &pva[8], length - 8);
528 			dec->v_pes_length = 9 + length - 8;
529 		}
530 
531 		dec->v_pes_postbytes = postbytes;
532 
533 		if (dec->v_pes[9 + dec->v_pes[8]] == 0x00 &&
534 		    dec->v_pes[10 + dec->v_pes[8]] == 0x00 &&
535 		    dec->v_pes[11 + dec->v_pes[8]] == 0x01)
536 			dec->v_pes[6] = 0x84;
537 		else
538 			dec->v_pes[6] = 0x80;
539 
540 		v_pes_payload_length = htons(dec->v_pes_length - 6 +
541 					     postbytes);
542 		memcpy(&dec->v_pes[4], &v_pes_payload_length, 2);
543 
544 		if (postbytes == 0)
545 			dvb_filter_pes2ts(&dec->v_pes2ts, dec->v_pes,
546 					  dec->v_pes_length, 1);
547 
548 		break;
549 	}
550 
551 	case 0x02:		/* MainAudioStream */
552 		if (output_pva) {
553 			dec->audio_filter->feed->cb.ts(pva, length, NULL, 0,
554 				&dec->audio_filter->feed->feed.ts, NULL);
555 			return;
556 		}
557 
558 		dvb_filter_pes2ts(&dec->a_pes2ts, &pva[8], length - 8,
559 				  pva[5] & 0x10);
560 		break;
561 
562 	default:
563 		printk("%s: unknown PVA type: %02x.\n", __func__,
564 		       pva[2]);
565 		break;
566 	}
567 }
568 
569 static void ttusb_dec_process_filter(struct ttusb_dec *dec, u8 *packet,
570 				     int length)
571 {
572 	struct list_head *item;
573 	struct filter_info *finfo;
574 	struct dvb_demux_filter *filter = NULL;
575 	unsigned long flags;
576 	u8 sid;
577 
578 	sid = packet[1];
579 	spin_lock_irqsave(&dec->filter_info_list_lock, flags);
580 	for (item = dec->filter_info_list.next; item != &dec->filter_info_list;
581 	     item = item->next) {
582 		finfo = list_entry(item, struct filter_info, filter_info_list);
583 		if (finfo->stream_id == sid) {
584 			filter = finfo->filter;
585 			break;
586 		}
587 	}
588 	spin_unlock_irqrestore(&dec->filter_info_list_lock, flags);
589 
590 	if (filter)
591 		filter->feed->cb.sec(&packet[2], length - 2, NULL, 0,
592 				     &filter->filter, NULL);
593 }
594 
595 static void ttusb_dec_process_packet(struct ttusb_dec *dec)
596 {
597 	int i;
598 	u16 csum = 0;
599 	u16 packet_id;
600 
601 	if (dec->packet_length % 2) {
602 		printk("%s: odd sized packet - discarding\n", __func__);
603 		return;
604 	}
605 
606 	for (i = 0; i < dec->packet_length; i += 2)
607 		csum ^= ((dec->packet[i] << 8) + dec->packet[i + 1]);
608 
609 	if (csum) {
610 		printk("%s: checksum failed - discarding\n", __func__);
611 		return;
612 	}
613 
614 	packet_id = dec->packet[dec->packet_length - 4] << 8;
615 	packet_id += dec->packet[dec->packet_length - 3];
616 
617 	if ((packet_id != dec->next_packet_id) && dec->next_packet_id) {
618 		printk("%s: warning: lost packets between %u and %u\n",
619 		       __func__, dec->next_packet_id - 1, packet_id);
620 	}
621 
622 	if (packet_id == 0xffff)
623 		dec->next_packet_id = 0x8000;
624 	else
625 		dec->next_packet_id = packet_id + 1;
626 
627 	switch (dec->packet_type) {
628 	case TTUSB_DEC_PACKET_PVA:
629 		if (dec->pva_stream_count)
630 			ttusb_dec_process_pva(dec, dec->packet,
631 					      dec->packet_payload_length);
632 		break;
633 
634 	case TTUSB_DEC_PACKET_SECTION:
635 		if (dec->filter_stream_count)
636 			ttusb_dec_process_filter(dec, dec->packet,
637 						 dec->packet_payload_length);
638 		break;
639 
640 	case TTUSB_DEC_PACKET_EMPTY:
641 		break;
642 	}
643 }
644 
645 static void swap_bytes(u8 *b, int length)
646 {
647 	length -= length % 2;
648 	for (; length; b += 2, length -= 2)
649 		swap(*b, *(b + 1));
650 }
651 
652 static void ttusb_dec_process_urb_frame(struct ttusb_dec *dec, u8 *b,
653 					int length)
654 {
655 	swap_bytes(b, length);
656 
657 	while (length) {
658 		switch (dec->packet_state) {
659 
660 		case 0:
661 		case 1:
662 		case 2:
663 			if (*b++ == 0xaa)
664 				dec->packet_state++;
665 			else
666 				dec->packet_state = 0;
667 
668 			length--;
669 			break;
670 
671 		case 3:
672 			if (*b == 0x00) {
673 				dec->packet_state++;
674 				dec->packet_length = 0;
675 			} else if (*b != 0xaa) {
676 				dec->packet_state = 0;
677 			}
678 
679 			b++;
680 			length--;
681 			break;
682 
683 		case 4:
684 			dec->packet[dec->packet_length++] = *b++;
685 
686 			if (dec->packet_length == 2) {
687 				if (dec->packet[0] == 'A' &&
688 				    dec->packet[1] == 'V') {
689 					dec->packet_type =
690 						TTUSB_DEC_PACKET_PVA;
691 					dec->packet_state++;
692 				} else if (dec->packet[0] == 'S') {
693 					dec->packet_type =
694 						TTUSB_DEC_PACKET_SECTION;
695 					dec->packet_state++;
696 				} else if (dec->packet[0] == 0x00) {
697 					dec->packet_type =
698 						TTUSB_DEC_PACKET_EMPTY;
699 					dec->packet_payload_length = 2;
700 					dec->packet_state = 7;
701 				} else {
702 					printk("%s: unknown packet type: %02x%02x\n",
703 					       __func__,
704 					       dec->packet[0], dec->packet[1]);
705 					dec->packet_state = 0;
706 				}
707 			}
708 
709 			length--;
710 			break;
711 
712 		case 5:
713 			dec->packet[dec->packet_length++] = *b++;
714 
715 			if (dec->packet_type == TTUSB_DEC_PACKET_PVA &&
716 			    dec->packet_length == 8) {
717 				dec->packet_state++;
718 				dec->packet_payload_length = 8 +
719 					(dec->packet[6] << 8) +
720 					dec->packet[7];
721 			} else if (dec->packet_type ==
722 					TTUSB_DEC_PACKET_SECTION &&
723 				   dec->packet_length == 5) {
724 				dec->packet_state++;
725 				dec->packet_payload_length = 5 +
726 					((dec->packet[3] & 0x0f) << 8) +
727 					dec->packet[4];
728 			}
729 
730 			length--;
731 			break;
732 
733 		case 6: {
734 			int remainder = dec->packet_payload_length -
735 					dec->packet_length;
736 
737 			if (length >= remainder) {
738 				memcpy(dec->packet + dec->packet_length,
739 				       b, remainder);
740 				dec->packet_length += remainder;
741 				b += remainder;
742 				length -= remainder;
743 				dec->packet_state++;
744 			} else {
745 				memcpy(&dec->packet[dec->packet_length],
746 				       b, length);
747 				dec->packet_length += length;
748 				length = 0;
749 			}
750 
751 			break;
752 		}
753 
754 		case 7: {
755 			int tail = 4;
756 
757 			dec->packet[dec->packet_length++] = *b++;
758 
759 			if (dec->packet_type == TTUSB_DEC_PACKET_SECTION &&
760 			    dec->packet_payload_length % 2)
761 				tail++;
762 
763 			if (dec->packet_length ==
764 			    dec->packet_payload_length + tail) {
765 				ttusb_dec_process_packet(dec);
766 				dec->packet_state = 0;
767 			}
768 
769 			length--;
770 			break;
771 		}
772 
773 		default:
774 			printk("%s: illegal packet state encountered.\n",
775 			       __func__);
776 			dec->packet_state = 0;
777 		}
778 	}
779 }
780 
781 static void ttusb_dec_process_urb_frame_list(unsigned long data)
782 {
783 	struct ttusb_dec *dec = (struct ttusb_dec *)data;
784 	struct list_head *item;
785 	struct urb_frame *frame;
786 	unsigned long flags;
787 
788 	while (1) {
789 		spin_lock_irqsave(&dec->urb_frame_list_lock, flags);
790 		if ((item = dec->urb_frame_list.next) != &dec->urb_frame_list) {
791 			frame = list_entry(item, struct urb_frame,
792 					   urb_frame_list);
793 			list_del(&frame->urb_frame_list);
794 		} else {
795 			spin_unlock_irqrestore(&dec->urb_frame_list_lock,
796 					       flags);
797 			return;
798 		}
799 		spin_unlock_irqrestore(&dec->urb_frame_list_lock, flags);
800 
801 		ttusb_dec_process_urb_frame(dec, frame->data, frame->length);
802 		kfree(frame);
803 	}
804 }
805 
806 static void ttusb_dec_process_urb(struct urb *urb)
807 {
808 	struct ttusb_dec *dec = urb->context;
809 
810 	if (!urb->status) {
811 		int i;
812 
813 		for (i = 0; i < FRAMES_PER_ISO_BUF; i++) {
814 			struct usb_iso_packet_descriptor *d;
815 			u8 *b;
816 			int length;
817 			struct urb_frame *frame;
818 
819 			d = &urb->iso_frame_desc[i];
820 			b = urb->transfer_buffer + d->offset;
821 			length = d->actual_length;
822 
823 			if ((frame = kmalloc(sizeof(struct urb_frame),
824 					     GFP_ATOMIC))) {
825 				unsigned long flags;
826 
827 				memcpy(frame->data, b, length);
828 				frame->length = length;
829 
830 				spin_lock_irqsave(&dec->urb_frame_list_lock,
831 						     flags);
832 				list_add_tail(&frame->urb_frame_list,
833 					      &dec->urb_frame_list);
834 				spin_unlock_irqrestore(&dec->urb_frame_list_lock,
835 						       flags);
836 
837 				tasklet_schedule(&dec->urb_tasklet);
838 			}
839 		}
840 	} else {
841 		 /* -ENOENT is expected when unlinking urbs */
842 		if (urb->status != -ENOENT)
843 			dprintk("%s: urb error: %d\n", __func__,
844 				urb->status);
845 	}
846 
847 	if (dec->iso_stream_count)
848 		usb_submit_urb(urb, GFP_ATOMIC);
849 }
850 
851 static void ttusb_dec_setup_urbs(struct ttusb_dec *dec)
852 {
853 	int i, j, buffer_offset = 0;
854 
855 	dprintk("%s\n", __func__);
856 
857 	for (i = 0; i < ISO_BUF_COUNT; i++) {
858 		int frame_offset = 0;
859 		struct urb *urb = dec->iso_urb[i];
860 
861 		urb->dev = dec->udev;
862 		urb->context = dec;
863 		urb->complete = ttusb_dec_process_urb;
864 		urb->pipe = dec->in_pipe;
865 		urb->transfer_flags = URB_ISO_ASAP;
866 		urb->interval = 1;
867 		urb->number_of_packets = FRAMES_PER_ISO_BUF;
868 		urb->transfer_buffer_length = ISO_FRAME_SIZE *
869 					      FRAMES_PER_ISO_BUF;
870 		urb->transfer_buffer = dec->iso_buffer + buffer_offset;
871 		buffer_offset += ISO_FRAME_SIZE * FRAMES_PER_ISO_BUF;
872 
873 		for (j = 0; j < FRAMES_PER_ISO_BUF; j++) {
874 			urb->iso_frame_desc[j].offset = frame_offset;
875 			urb->iso_frame_desc[j].length = ISO_FRAME_SIZE;
876 			frame_offset += ISO_FRAME_SIZE;
877 		}
878 	}
879 }
880 
881 static void ttusb_dec_stop_iso_xfer(struct ttusb_dec *dec)
882 {
883 	int i;
884 
885 	dprintk("%s\n", __func__);
886 
887 	if (mutex_lock_interruptible(&dec->iso_mutex))
888 		return;
889 
890 	dec->iso_stream_count--;
891 
892 	if (!dec->iso_stream_count) {
893 		for (i = 0; i < ISO_BUF_COUNT; i++)
894 			usb_kill_urb(dec->iso_urb[i]);
895 	}
896 
897 	mutex_unlock(&dec->iso_mutex);
898 }
899 
900 /* Setting the interface of the DEC tends to take down the USB communications
901  * for a short period, so it's important not to call this function just before
902  * trying to talk to it.
903  */
904 static int ttusb_dec_set_interface(struct ttusb_dec *dec,
905 				   enum ttusb_dec_interface interface)
906 {
907 	int result = 0;
908 	u8 b[] = { 0x05 };
909 
910 	if (interface != dec->interface) {
911 		switch (interface) {
912 		case TTUSB_DEC_INTERFACE_INITIAL:
913 			result = usb_set_interface(dec->udev, 0, 0);
914 			break;
915 		case TTUSB_DEC_INTERFACE_IN:
916 			result = ttusb_dec_send_command(dec, 0x80, sizeof(b),
917 							b, NULL, NULL);
918 			if (result)
919 				return result;
920 			result = usb_set_interface(dec->udev, 0, 8);
921 			break;
922 		case TTUSB_DEC_INTERFACE_OUT:
923 			result = usb_set_interface(dec->udev, 0, 1);
924 			break;
925 		}
926 
927 		if (result)
928 			return result;
929 
930 		dec->interface = interface;
931 	}
932 
933 	return 0;
934 }
935 
936 static int ttusb_dec_start_iso_xfer(struct ttusb_dec *dec)
937 {
938 	int i, result;
939 
940 	dprintk("%s\n", __func__);
941 
942 	if (mutex_lock_interruptible(&dec->iso_mutex))
943 		return -EAGAIN;
944 
945 	if (!dec->iso_stream_count) {
946 		ttusb_dec_setup_urbs(dec);
947 
948 		dec->packet_state = 0;
949 		dec->v_pes_postbytes = 0;
950 		dec->next_packet_id = 0;
951 
952 		for (i = 0; i < ISO_BUF_COUNT; i++) {
953 			if ((result = usb_submit_urb(dec->iso_urb[i],
954 						     GFP_ATOMIC))) {
955 				printk("%s: failed urb submission %d: error %d\n",
956 				       __func__, i, result);
957 
958 				while (i) {
959 					usb_kill_urb(dec->iso_urb[i - 1]);
960 					i--;
961 				}
962 
963 				mutex_unlock(&dec->iso_mutex);
964 				return result;
965 			}
966 		}
967 	}
968 
969 	dec->iso_stream_count++;
970 
971 	mutex_unlock(&dec->iso_mutex);
972 
973 	return 0;
974 }
975 
976 static int ttusb_dec_start_ts_feed(struct dvb_demux_feed *dvbdmxfeed)
977 {
978 	struct dvb_demux *dvbdmx = dvbdmxfeed->demux;
979 	struct ttusb_dec *dec = dvbdmx->priv;
980 	u8 b0[] = { 0x05 };
981 	int result = 0;
982 
983 	dprintk("%s\n", __func__);
984 
985 	dprintk("  ts_type:");
986 
987 	if (dvbdmxfeed->ts_type & TS_DECODER)
988 		dprintk(" TS_DECODER");
989 
990 	if (dvbdmxfeed->ts_type & TS_PACKET)
991 		dprintk(" TS_PACKET");
992 
993 	if (dvbdmxfeed->ts_type & TS_PAYLOAD_ONLY)
994 		dprintk(" TS_PAYLOAD_ONLY");
995 
996 	dprintk("\n");
997 
998 	switch (dvbdmxfeed->pes_type) {
999 
1000 	case DMX_PES_VIDEO:
1001 		dprintk("  pes_type: DMX_PES_VIDEO\n");
1002 		dec->pid[DMX_PES_PCR] = dvbdmxfeed->pid;
1003 		dec->pid[DMX_PES_VIDEO] = dvbdmxfeed->pid;
1004 		dec->video_filter = dvbdmxfeed->filter;
1005 		ttusb_dec_set_pids(dec);
1006 		break;
1007 
1008 	case DMX_PES_AUDIO:
1009 		dprintk("  pes_type: DMX_PES_AUDIO\n");
1010 		dec->pid[DMX_PES_AUDIO] = dvbdmxfeed->pid;
1011 		dec->audio_filter = dvbdmxfeed->filter;
1012 		ttusb_dec_set_pids(dec);
1013 		break;
1014 
1015 	case DMX_PES_TELETEXT:
1016 		dec->pid[DMX_PES_TELETEXT] = dvbdmxfeed->pid;
1017 		dprintk("  pes_type: DMX_PES_TELETEXT(not supported)\n");
1018 		return -ENOSYS;
1019 
1020 	case DMX_PES_PCR:
1021 		dprintk("  pes_type: DMX_PES_PCR\n");
1022 		dec->pid[DMX_PES_PCR] = dvbdmxfeed->pid;
1023 		ttusb_dec_set_pids(dec);
1024 		break;
1025 
1026 	case DMX_PES_OTHER:
1027 		dprintk("  pes_type: DMX_PES_OTHER(not supported)\n");
1028 		return -ENOSYS;
1029 
1030 	default:
1031 		dprintk("  pes_type: unknown (%d)\n", dvbdmxfeed->pes_type);
1032 		return -EINVAL;
1033 
1034 	}
1035 
1036 	result = ttusb_dec_send_command(dec, 0x80, sizeof(b0), b0, NULL, NULL);
1037 	if (result)
1038 		return result;
1039 
1040 	dec->pva_stream_count++;
1041 	return ttusb_dec_start_iso_xfer(dec);
1042 }
1043 
1044 static int ttusb_dec_start_sec_feed(struct dvb_demux_feed *dvbdmxfeed)
1045 {
1046 	struct ttusb_dec *dec = dvbdmxfeed->demux->priv;
1047 	u8 b0[] = { 0x00, 0x00, 0x00, 0x01,
1048 		    0x00, 0x00, 0x00, 0x00,
1049 		    0x00, 0x00, 0x00, 0x00,
1050 		    0x00, 0x00, 0x00, 0x00,
1051 		    0x00, 0xff, 0x00, 0x00,
1052 		    0x00, 0x00, 0x00, 0x00,
1053 		    0x00, 0x00, 0x00, 0x00,
1054 		    0x00 };
1055 	__be16 pid;
1056 	u8 c[COMMAND_PACKET_SIZE];
1057 	int c_length;
1058 	int result;
1059 	struct filter_info *finfo;
1060 	unsigned long flags;
1061 	u8 x = 1;
1062 
1063 	dprintk("%s\n", __func__);
1064 
1065 	pid = htons(dvbdmxfeed->pid);
1066 	memcpy(&b0[0], &pid, 2);
1067 	memcpy(&b0[4], &x, 1);
1068 	memcpy(&b0[5], &dvbdmxfeed->filter->filter.filter_value[0], 1);
1069 
1070 	result = ttusb_dec_send_command(dec, 0x60, sizeof(b0), b0,
1071 					&c_length, c);
1072 
1073 	if (!result) {
1074 		if (c_length == 2) {
1075 			if (!(finfo = kmalloc(sizeof(struct filter_info),
1076 					      GFP_ATOMIC)))
1077 				return -ENOMEM;
1078 
1079 			finfo->stream_id = c[1];
1080 			finfo->filter = dvbdmxfeed->filter;
1081 
1082 			spin_lock_irqsave(&dec->filter_info_list_lock, flags);
1083 			list_add_tail(&finfo->filter_info_list,
1084 				      &dec->filter_info_list);
1085 			spin_unlock_irqrestore(&dec->filter_info_list_lock,
1086 					       flags);
1087 
1088 			dvbdmxfeed->priv = finfo;
1089 
1090 			dec->filter_stream_count++;
1091 			return ttusb_dec_start_iso_xfer(dec);
1092 		}
1093 
1094 		return -EAGAIN;
1095 	} else
1096 		return result;
1097 }
1098 
1099 static int ttusb_dec_start_feed(struct dvb_demux_feed *dvbdmxfeed)
1100 {
1101 	struct dvb_demux *dvbdmx = dvbdmxfeed->demux;
1102 
1103 	dprintk("%s\n", __func__);
1104 
1105 	if (!dvbdmx->dmx.frontend)
1106 		return -EINVAL;
1107 
1108 	dprintk("  pid: 0x%04X\n", dvbdmxfeed->pid);
1109 
1110 	switch (dvbdmxfeed->type) {
1111 
1112 	case DMX_TYPE_TS:
1113 		return ttusb_dec_start_ts_feed(dvbdmxfeed);
1114 		break;
1115 
1116 	case DMX_TYPE_SEC:
1117 		return ttusb_dec_start_sec_feed(dvbdmxfeed);
1118 		break;
1119 
1120 	default:
1121 		dprintk("  type: unknown (%d)\n", dvbdmxfeed->type);
1122 		return -EINVAL;
1123 
1124 	}
1125 }
1126 
1127 static int ttusb_dec_stop_ts_feed(struct dvb_demux_feed *dvbdmxfeed)
1128 {
1129 	struct ttusb_dec *dec = dvbdmxfeed->demux->priv;
1130 	u8 b0[] = { 0x00 };
1131 
1132 	ttusb_dec_send_command(dec, 0x81, sizeof(b0), b0, NULL, NULL);
1133 
1134 	dec->pva_stream_count--;
1135 
1136 	ttusb_dec_stop_iso_xfer(dec);
1137 
1138 	return 0;
1139 }
1140 
1141 static int ttusb_dec_stop_sec_feed(struct dvb_demux_feed *dvbdmxfeed)
1142 {
1143 	struct ttusb_dec *dec = dvbdmxfeed->demux->priv;
1144 	u8 b0[] = { 0x00, 0x00 };
1145 	struct filter_info *finfo = (struct filter_info *)dvbdmxfeed->priv;
1146 	unsigned long flags;
1147 
1148 	b0[1] = finfo->stream_id;
1149 	spin_lock_irqsave(&dec->filter_info_list_lock, flags);
1150 	list_del(&finfo->filter_info_list);
1151 	spin_unlock_irqrestore(&dec->filter_info_list_lock, flags);
1152 	kfree(finfo);
1153 	ttusb_dec_send_command(dec, 0x62, sizeof(b0), b0, NULL, NULL);
1154 
1155 	dec->filter_stream_count--;
1156 
1157 	ttusb_dec_stop_iso_xfer(dec);
1158 
1159 	return 0;
1160 }
1161 
1162 static int ttusb_dec_stop_feed(struct dvb_demux_feed *dvbdmxfeed)
1163 {
1164 	dprintk("%s\n", __func__);
1165 
1166 	switch (dvbdmxfeed->type) {
1167 	case DMX_TYPE_TS:
1168 		return ttusb_dec_stop_ts_feed(dvbdmxfeed);
1169 		break;
1170 
1171 	case DMX_TYPE_SEC:
1172 		return ttusb_dec_stop_sec_feed(dvbdmxfeed);
1173 		break;
1174 	}
1175 
1176 	return 0;
1177 }
1178 
1179 static void ttusb_dec_free_iso_urbs(struct ttusb_dec *dec)
1180 {
1181 	int i;
1182 
1183 	dprintk("%s\n", __func__);
1184 
1185 	for (i = 0; i < ISO_BUF_COUNT; i++)
1186 		usb_free_urb(dec->iso_urb[i]);
1187 	kfree(dec->iso_buffer);
1188 }
1189 
1190 static int ttusb_dec_alloc_iso_urbs(struct ttusb_dec *dec)
1191 {
1192 	int i;
1193 
1194 	dprintk("%s\n", __func__);
1195 
1196 	dec->iso_buffer = kcalloc(FRAMES_PER_ISO_BUF * ISO_BUF_COUNT,
1197 			ISO_FRAME_SIZE, GFP_KERNEL);
1198 	if (!dec->iso_buffer)
1199 		return -ENOMEM;
1200 
1201 	for (i = 0; i < ISO_BUF_COUNT; i++) {
1202 		struct urb *urb;
1203 
1204 		if (!(urb = usb_alloc_urb(FRAMES_PER_ISO_BUF, GFP_ATOMIC))) {
1205 			ttusb_dec_free_iso_urbs(dec);
1206 			return -ENOMEM;
1207 		}
1208 
1209 		dec->iso_urb[i] = urb;
1210 	}
1211 
1212 	ttusb_dec_setup_urbs(dec);
1213 
1214 	return 0;
1215 }
1216 
1217 static void ttusb_dec_init_tasklet(struct ttusb_dec *dec)
1218 {
1219 	spin_lock_init(&dec->urb_frame_list_lock);
1220 	INIT_LIST_HEAD(&dec->urb_frame_list);
1221 	tasklet_init(&dec->urb_tasklet, ttusb_dec_process_urb_frame_list,
1222 		     (unsigned long)dec);
1223 }
1224 
1225 static int ttusb_init_rc( struct ttusb_dec *dec)
1226 {
1227 	struct input_dev *input_dev;
1228 	u8 b[] = { 0x00, 0x01 };
1229 	int i;
1230 	int err;
1231 
1232 	usb_make_path(dec->udev, dec->rc_phys, sizeof(dec->rc_phys));
1233 	strlcat(dec->rc_phys, "/input0", sizeof(dec->rc_phys));
1234 
1235 	input_dev = input_allocate_device();
1236 	if (!input_dev)
1237 		return -ENOMEM;
1238 
1239 	input_dev->name = "ttusb_dec remote control";
1240 	input_dev->phys = dec->rc_phys;
1241 	input_dev->evbit[0] = BIT_MASK(EV_KEY);
1242 	input_dev->keycodesize = sizeof(u16);
1243 	input_dev->keycodemax = 0x1a;
1244 	input_dev->keycode = rc_keys;
1245 
1246 	for (i = 0; i < ARRAY_SIZE(rc_keys); i++)
1247 		  set_bit(rc_keys[i], input_dev->keybit);
1248 
1249 	err = input_register_device(input_dev);
1250 	if (err) {
1251 		input_free_device(input_dev);
1252 		return err;
1253 	}
1254 
1255 	dec->rc_input_dev = input_dev;
1256 	if (usb_submit_urb(dec->irq_urb, GFP_KERNEL))
1257 		printk("%s: usb_submit_urb failed\n",__func__);
1258 	/* enable irq pipe */
1259 	ttusb_dec_send_command(dec,0xb0,sizeof(b),b,NULL,NULL);
1260 
1261 	return 0;
1262 }
1263 
1264 static void ttusb_dec_init_v_pes(struct ttusb_dec *dec)
1265 {
1266 	dprintk("%s\n", __func__);
1267 
1268 	dec->v_pes[0] = 0x00;
1269 	dec->v_pes[1] = 0x00;
1270 	dec->v_pes[2] = 0x01;
1271 	dec->v_pes[3] = 0xe0;
1272 }
1273 
1274 static int ttusb_dec_init_usb(struct ttusb_dec *dec)
1275 {
1276 	int result;
1277 
1278 	dprintk("%s\n", __func__);
1279 
1280 	mutex_init(&dec->usb_mutex);
1281 	mutex_init(&dec->iso_mutex);
1282 
1283 	dec->command_pipe = usb_sndbulkpipe(dec->udev, COMMAND_PIPE);
1284 	dec->result_pipe = usb_rcvbulkpipe(dec->udev, RESULT_PIPE);
1285 	dec->in_pipe = usb_rcvisocpipe(dec->udev, IN_PIPE);
1286 	dec->out_pipe = usb_sndisocpipe(dec->udev, OUT_PIPE);
1287 	dec->irq_pipe = usb_rcvintpipe(dec->udev, IRQ_PIPE);
1288 
1289 	if(enable_rc) {
1290 		dec->irq_urb = usb_alloc_urb(0, GFP_KERNEL);
1291 		if(!dec->irq_urb) {
1292 			return -ENOMEM;
1293 		}
1294 		dec->irq_buffer = usb_alloc_coherent(dec->udev,IRQ_PACKET_SIZE,
1295 					GFP_KERNEL, &dec->irq_dma_handle);
1296 		if(!dec->irq_buffer) {
1297 			usb_free_urb(dec->irq_urb);
1298 			return -ENOMEM;
1299 		}
1300 		usb_fill_int_urb(dec->irq_urb, dec->udev,dec->irq_pipe,
1301 				 dec->irq_buffer, IRQ_PACKET_SIZE,
1302 				 ttusb_dec_handle_irq, dec, 1);
1303 		dec->irq_urb->transfer_dma = dec->irq_dma_handle;
1304 		dec->irq_urb->transfer_flags |= URB_NO_TRANSFER_DMA_MAP;
1305 	}
1306 
1307 	result = ttusb_dec_alloc_iso_urbs(dec);
1308 	if (result) {
1309 		usb_free_urb(dec->irq_urb);
1310 		usb_free_coherent(dec->udev, IRQ_PACKET_SIZE,
1311 				  dec->irq_buffer, dec->irq_dma_handle);
1312 	}
1313 	return result;
1314 }
1315 
1316 static int ttusb_dec_boot_dsp(struct ttusb_dec *dec)
1317 {
1318 	int i, j, actual_len, result, size, trans_count;
1319 	u8 b0[] = { 0x00, 0x00, 0x00, 0x00,
1320 		    0x00, 0x00, 0x00, 0x00,
1321 		    0x61, 0x00 };
1322 	u8 b1[] = { 0x61 };
1323 	u8 *b;
1324 	char idstring[21];
1325 	const u8 *firmware = NULL;
1326 	size_t firmware_size = 0;
1327 	u16 firmware_csum = 0;
1328 	__be16 firmware_csum_ns;
1329 	__be32 firmware_size_nl;
1330 	u32 crc32_csum, crc32_check;
1331 	__be32 tmp;
1332 	const struct firmware *fw_entry = NULL;
1333 
1334 	dprintk("%s\n", __func__);
1335 
1336 	result = request_firmware(&fw_entry, dec->firmware_name, &dec->udev->dev);
1337 	if (result) {
1338 		printk(KERN_ERR "%s: Firmware (%s) unavailable.\n",
1339 		       __func__, dec->firmware_name);
1340 		return result;
1341 	}
1342 
1343 	firmware = fw_entry->data;
1344 	firmware_size = fw_entry->size;
1345 
1346 	if (firmware_size < 60) {
1347 		printk("%s: firmware size too small for DSP code (%zu < 60).\n",
1348 			__func__, firmware_size);
1349 		release_firmware(fw_entry);
1350 		return -ENOENT;
1351 	}
1352 
1353 	/* a 32 bit checksum over the first 56 bytes of the DSP Code is stored
1354 	   at offset 56 of file, so use it to check if the firmware file is
1355 	   valid. */
1356 	crc32_csum = crc32(~0L, firmware, 56) ^ ~0L;
1357 	memcpy(&tmp, &firmware[56], 4);
1358 	crc32_check = ntohl(tmp);
1359 	if (crc32_csum != crc32_check) {
1360 		printk("%s: crc32 check of DSP code failed (calculated 0x%08x != 0x%08x in file), file invalid.\n",
1361 			__func__, crc32_csum, crc32_check);
1362 		release_firmware(fw_entry);
1363 		return -ENOENT;
1364 	}
1365 	memcpy(idstring, &firmware[36], 20);
1366 	idstring[20] = '\0';
1367 	printk(KERN_INFO "ttusb_dec: found DSP code \"%s\".\n", idstring);
1368 
1369 	firmware_size_nl = htonl(firmware_size);
1370 	memcpy(b0, &firmware_size_nl, 4);
1371 	firmware_csum = crc16(~0, firmware, firmware_size) ^ ~0;
1372 	firmware_csum_ns = htons(firmware_csum);
1373 	memcpy(&b0[6], &firmware_csum_ns, 2);
1374 
1375 	result = ttusb_dec_send_command(dec, 0x41, sizeof(b0), b0, NULL, NULL);
1376 
1377 	if (result) {
1378 		release_firmware(fw_entry);
1379 		return result;
1380 	}
1381 
1382 	trans_count = 0;
1383 	j = 0;
1384 
1385 	b = kmalloc(ARM_PACKET_SIZE, GFP_KERNEL);
1386 	if (b == NULL) {
1387 		release_firmware(fw_entry);
1388 		return -ENOMEM;
1389 	}
1390 
1391 	for (i = 0; i < firmware_size; i += COMMAND_PACKET_SIZE) {
1392 		size = firmware_size - i;
1393 		if (size > COMMAND_PACKET_SIZE)
1394 			size = COMMAND_PACKET_SIZE;
1395 
1396 		b[j + 0] = 0xaa;
1397 		b[j + 1] = trans_count++;
1398 		b[j + 2] = 0xf0;
1399 		b[j + 3] = size;
1400 		memcpy(&b[j + 4], &firmware[i], size);
1401 
1402 		j += COMMAND_PACKET_SIZE + 4;
1403 
1404 		if (j >= ARM_PACKET_SIZE) {
1405 			result = usb_bulk_msg(dec->udev, dec->command_pipe, b,
1406 					      ARM_PACKET_SIZE, &actual_len,
1407 					      100);
1408 			j = 0;
1409 		} else if (size < COMMAND_PACKET_SIZE) {
1410 			result = usb_bulk_msg(dec->udev, dec->command_pipe, b,
1411 					      j - COMMAND_PACKET_SIZE + size,
1412 					      &actual_len, 100);
1413 		}
1414 	}
1415 
1416 	result = ttusb_dec_send_command(dec, 0x43, sizeof(b1), b1, NULL, NULL);
1417 
1418 	release_firmware(fw_entry);
1419 	kfree(b);
1420 
1421 	return result;
1422 }
1423 
1424 static int ttusb_dec_init_stb(struct ttusb_dec *dec)
1425 {
1426 	int result;
1427 	unsigned int mode = 0, model = 0, version = 0;
1428 
1429 	dprintk("%s\n", __func__);
1430 
1431 	result = ttusb_dec_get_stb_state(dec, &mode, &model, &version);
1432 	if (result)
1433 		return result;
1434 
1435 	if (!mode) {
1436 		if (version == 0xABCDEFAB)
1437 			printk(KERN_INFO "ttusb_dec: no version info in Firmware\n");
1438 		else
1439 			printk(KERN_INFO "ttusb_dec: Firmware %x.%02x%c%c\n",
1440 			       version >> 24, (version >> 16) & 0xff,
1441 			       (version >> 8) & 0xff, version & 0xff);
1442 
1443 		result = ttusb_dec_boot_dsp(dec);
1444 		if (result)
1445 			return result;
1446 	} else {
1447 		/* We can't trust the USB IDs that some firmwares
1448 		   give the box */
1449 		switch (model) {
1450 		case 0x00070001:
1451 		case 0x00070008:
1452 		case 0x0007000c:
1453 			ttusb_dec_set_model(dec, TTUSB_DEC3000S);
1454 			break;
1455 		case 0x00070009:
1456 		case 0x00070013:
1457 			ttusb_dec_set_model(dec, TTUSB_DEC2000T);
1458 			break;
1459 		case 0x00070011:
1460 			ttusb_dec_set_model(dec, TTUSB_DEC2540T);
1461 			break;
1462 		default:
1463 			printk(KERN_ERR "%s: unknown model returned by firmware (%08x) - please report\n",
1464 			       __func__, model);
1465 			return -ENOENT;
1466 		}
1467 		if (version >= 0x01770000)
1468 			dec->can_playback = 1;
1469 	}
1470 	return 0;
1471 }
1472 
1473 static int ttusb_dec_init_dvb(struct ttusb_dec *dec)
1474 {
1475 	int result;
1476 
1477 	dprintk("%s\n", __func__);
1478 
1479 	if ((result = dvb_register_adapter(&dec->adapter,
1480 					   dec->model_name, THIS_MODULE,
1481 					   &dec->udev->dev,
1482 					   adapter_nr)) < 0) {
1483 		printk("%s: dvb_register_adapter failed: error %d\n",
1484 		       __func__, result);
1485 
1486 		return result;
1487 	}
1488 
1489 	dec->demux.dmx.capabilities = DMX_TS_FILTERING | DMX_SECTION_FILTERING;
1490 
1491 	dec->demux.priv = (void *)dec;
1492 	dec->demux.filternum = 31;
1493 	dec->demux.feednum = 31;
1494 	dec->demux.start_feed = ttusb_dec_start_feed;
1495 	dec->demux.stop_feed = ttusb_dec_stop_feed;
1496 	dec->demux.write_to_decoder = NULL;
1497 
1498 	if ((result = dvb_dmx_init(&dec->demux)) < 0) {
1499 		printk("%s: dvb_dmx_init failed: error %d\n", __func__,
1500 		       result);
1501 
1502 		dvb_unregister_adapter(&dec->adapter);
1503 
1504 		return result;
1505 	}
1506 
1507 	dec->dmxdev.filternum = 32;
1508 	dec->dmxdev.demux = &dec->demux.dmx;
1509 	dec->dmxdev.capabilities = 0;
1510 
1511 	if ((result = dvb_dmxdev_init(&dec->dmxdev, &dec->adapter)) < 0) {
1512 		printk("%s: dvb_dmxdev_init failed: error %d\n",
1513 		       __func__, result);
1514 
1515 		dvb_dmx_release(&dec->demux);
1516 		dvb_unregister_adapter(&dec->adapter);
1517 
1518 		return result;
1519 	}
1520 
1521 	dec->frontend.source = DMX_FRONTEND_0;
1522 
1523 	if ((result = dec->demux.dmx.add_frontend(&dec->demux.dmx,
1524 						  &dec->frontend)) < 0) {
1525 		printk("%s: dvb_dmx_init failed: error %d\n", __func__,
1526 		       result);
1527 
1528 		dvb_dmxdev_release(&dec->dmxdev);
1529 		dvb_dmx_release(&dec->demux);
1530 		dvb_unregister_adapter(&dec->adapter);
1531 
1532 		return result;
1533 	}
1534 
1535 	if ((result = dec->demux.dmx.connect_frontend(&dec->demux.dmx,
1536 						      &dec->frontend)) < 0) {
1537 		printk("%s: dvb_dmx_init failed: error %d\n", __func__,
1538 		       result);
1539 
1540 		dec->demux.dmx.remove_frontend(&dec->demux.dmx, &dec->frontend);
1541 		dvb_dmxdev_release(&dec->dmxdev);
1542 		dvb_dmx_release(&dec->demux);
1543 		dvb_unregister_adapter(&dec->adapter);
1544 
1545 		return result;
1546 	}
1547 
1548 	dvb_net_init(&dec->adapter, &dec->dvb_net, &dec->demux.dmx);
1549 
1550 	return 0;
1551 }
1552 
1553 static void ttusb_dec_exit_dvb(struct ttusb_dec *dec)
1554 {
1555 	dprintk("%s\n", __func__);
1556 
1557 	dvb_net_release(&dec->dvb_net);
1558 	dec->demux.dmx.close(&dec->demux.dmx);
1559 	dec->demux.dmx.remove_frontend(&dec->demux.dmx, &dec->frontend);
1560 	dvb_dmxdev_release(&dec->dmxdev);
1561 	dvb_dmx_release(&dec->demux);
1562 	if (dec->fe) {
1563 		dvb_unregister_frontend(dec->fe);
1564 		if (dec->fe->ops.release)
1565 			dec->fe->ops.release(dec->fe);
1566 	}
1567 	dvb_unregister_adapter(&dec->adapter);
1568 }
1569 
1570 static void ttusb_dec_exit_rc(struct ttusb_dec *dec)
1571 {
1572 	dprintk("%s\n", __func__);
1573 
1574 	if (dec->rc_input_dev) {
1575 		input_unregister_device(dec->rc_input_dev);
1576 		dec->rc_input_dev = NULL;
1577 	}
1578 }
1579 
1580 
1581 static void ttusb_dec_exit_usb(struct ttusb_dec *dec)
1582 {
1583 	int i;
1584 
1585 	dprintk("%s\n", __func__);
1586 
1587 	if (enable_rc) {
1588 		/* we have to check whether the irq URB is already submitted.
1589 		 * As the irq is submitted after the interface is changed,
1590 		 * this is the best method i figured out.
1591 		 * Any others?*/
1592 		if (dec->interface == TTUSB_DEC_INTERFACE_IN)
1593 			usb_kill_urb(dec->irq_urb);
1594 
1595 		usb_free_urb(dec->irq_urb);
1596 
1597 		usb_free_coherent(dec->udev, IRQ_PACKET_SIZE,
1598 				  dec->irq_buffer, dec->irq_dma_handle);
1599 	}
1600 
1601 	dec->iso_stream_count = 0;
1602 
1603 	for (i = 0; i < ISO_BUF_COUNT; i++)
1604 		usb_kill_urb(dec->iso_urb[i]);
1605 
1606 	ttusb_dec_free_iso_urbs(dec);
1607 }
1608 
1609 static void ttusb_dec_exit_tasklet(struct ttusb_dec *dec)
1610 {
1611 	struct list_head *item;
1612 	struct urb_frame *frame;
1613 
1614 	tasklet_kill(&dec->urb_tasklet);
1615 
1616 	while ((item = dec->urb_frame_list.next) != &dec->urb_frame_list) {
1617 		frame = list_entry(item, struct urb_frame, urb_frame_list);
1618 		list_del(&frame->urb_frame_list);
1619 		kfree(frame);
1620 	}
1621 }
1622 
1623 static void ttusb_dec_init_filters(struct ttusb_dec *dec)
1624 {
1625 	INIT_LIST_HEAD(&dec->filter_info_list);
1626 	spin_lock_init(&dec->filter_info_list_lock);
1627 }
1628 
1629 static void ttusb_dec_exit_filters(struct ttusb_dec *dec)
1630 {
1631 	struct list_head *item;
1632 	struct filter_info *finfo;
1633 
1634 	while ((item = dec->filter_info_list.next) != &dec->filter_info_list) {
1635 		finfo = list_entry(item, struct filter_info, filter_info_list);
1636 		list_del(&finfo->filter_info_list);
1637 		kfree(finfo);
1638 	}
1639 }
1640 
1641 static int fe_send_command(struct dvb_frontend* fe, const u8 command,
1642 			   int param_length, const u8 params[],
1643 			   int *result_length, u8 cmd_result[])
1644 {
1645 	struct ttusb_dec* dec = fe->dvb->priv;
1646 	return ttusb_dec_send_command(dec, command, param_length, params, result_length, cmd_result);
1647 }
1648 
1649 static const struct ttusbdecfe_config fe_config = {
1650 	.send_command = fe_send_command
1651 };
1652 
1653 static int ttusb_dec_probe(struct usb_interface *intf,
1654 			   const struct usb_device_id *id)
1655 {
1656 	struct usb_device *udev;
1657 	struct ttusb_dec *dec;
1658 	int result;
1659 
1660 	dprintk("%s\n", __func__);
1661 
1662 	udev = interface_to_usbdev(intf);
1663 
1664 	if (!(dec = kzalloc(sizeof(struct ttusb_dec), GFP_KERNEL))) {
1665 		printk("%s: couldn't allocate memory.\n", __func__);
1666 		return -ENOMEM;
1667 	}
1668 
1669 	usb_set_intfdata(intf, (void *)dec);
1670 
1671 	switch (id->idProduct) {
1672 	case 0x1006:
1673 		ttusb_dec_set_model(dec, TTUSB_DEC3000S);
1674 		break;
1675 
1676 	case 0x1008:
1677 		ttusb_dec_set_model(dec, TTUSB_DEC2000T);
1678 		break;
1679 
1680 	case 0x1009:
1681 		ttusb_dec_set_model(dec, TTUSB_DEC2540T);
1682 		break;
1683 	}
1684 
1685 	dec->udev = udev;
1686 
1687 	result = ttusb_dec_init_usb(dec);
1688 	if (result)
1689 		goto err_usb;
1690 	result = ttusb_dec_init_stb(dec);
1691 	if (result)
1692 		goto err_stb;
1693 	result = ttusb_dec_init_dvb(dec);
1694 	if (result)
1695 		goto err_stb;
1696 
1697 	dec->adapter.priv = dec;
1698 	switch (id->idProduct) {
1699 	case 0x1006:
1700 		dec->fe = ttusbdecfe_dvbs_attach(&fe_config);
1701 		break;
1702 
1703 	case 0x1008:
1704 	case 0x1009:
1705 		dec->fe = ttusbdecfe_dvbt_attach(&fe_config);
1706 		break;
1707 	}
1708 
1709 	if (dec->fe == NULL) {
1710 		printk("dvb-ttusb-dec: A frontend driver was not found for device [%04x:%04x]\n",
1711 		       le16_to_cpu(dec->udev->descriptor.idVendor),
1712 		       le16_to_cpu(dec->udev->descriptor.idProduct));
1713 	} else {
1714 		if (dvb_register_frontend(&dec->adapter, dec->fe)) {
1715 			printk("budget-ci: Frontend registration failed!\n");
1716 			if (dec->fe->ops.release)
1717 				dec->fe->ops.release(dec->fe);
1718 			dec->fe = NULL;
1719 		}
1720 	}
1721 
1722 	ttusb_dec_init_v_pes(dec);
1723 	ttusb_dec_init_filters(dec);
1724 	ttusb_dec_init_tasklet(dec);
1725 
1726 	dec->active = 1;
1727 
1728 	ttusb_dec_set_interface(dec, TTUSB_DEC_INTERFACE_IN);
1729 
1730 	if (enable_rc)
1731 		ttusb_init_rc(dec);
1732 
1733 	return 0;
1734 err_stb:
1735 	ttusb_dec_exit_usb(dec);
1736 err_usb:
1737 	kfree(dec);
1738 	return result;
1739 }
1740 
1741 static void ttusb_dec_disconnect(struct usb_interface *intf)
1742 {
1743 	struct ttusb_dec *dec = usb_get_intfdata(intf);
1744 
1745 	usb_set_intfdata(intf, NULL);
1746 
1747 	dprintk("%s\n", __func__);
1748 
1749 	if (dec->active) {
1750 		ttusb_dec_exit_tasklet(dec);
1751 		ttusb_dec_exit_filters(dec);
1752 		if(enable_rc)
1753 			ttusb_dec_exit_rc(dec);
1754 		ttusb_dec_exit_usb(dec);
1755 		ttusb_dec_exit_dvb(dec);
1756 	}
1757 
1758 	kfree(dec);
1759 }
1760 
1761 static void ttusb_dec_set_model(struct ttusb_dec *dec,
1762 				enum ttusb_dec_model model)
1763 {
1764 	dec->model = model;
1765 
1766 	switch (model) {
1767 	case TTUSB_DEC2000T:
1768 		dec->model_name = "DEC2000-t";
1769 		dec->firmware_name = "dvb-ttusb-dec-2000t.fw";
1770 		break;
1771 
1772 	case TTUSB_DEC2540T:
1773 		dec->model_name = "DEC2540-t";
1774 		dec->firmware_name = "dvb-ttusb-dec-2540t.fw";
1775 		break;
1776 
1777 	case TTUSB_DEC3000S:
1778 		dec->model_name = "DEC3000-s";
1779 		dec->firmware_name = "dvb-ttusb-dec-3000s.fw";
1780 		break;
1781 	}
1782 }
1783 
1784 static const struct usb_device_id ttusb_dec_table[] = {
1785 	{USB_DEVICE(0x0b48, 0x1006)},	/* DEC3000-s */
1786 	/*{USB_DEVICE(0x0b48, 0x1007)},	   Unconfirmed */
1787 	{USB_DEVICE(0x0b48, 0x1008)},	/* DEC2000-t */
1788 	{USB_DEVICE(0x0b48, 0x1009)},	/* DEC2540-t */
1789 	{}
1790 };
1791 
1792 static struct usb_driver ttusb_dec_driver = {
1793 	.name		= "ttusb-dec",
1794 	.probe		= ttusb_dec_probe,
1795 	.disconnect	= ttusb_dec_disconnect,
1796 	.id_table	= ttusb_dec_table,
1797 };
1798 
1799 module_usb_driver(ttusb_dec_driver);
1800 
1801 MODULE_AUTHOR("Alex Woods <linux-dvb@giblets.org>");
1802 MODULE_DESCRIPTION(DRIVER_NAME);
1803 MODULE_LICENSE("GPL");
1804 MODULE_DEVICE_TABLE(usb, ttusb_dec_table);
1805