diff options
Diffstat (limited to 'linux/drivers/media/dvb')
-rw-r--r-- | linux/drivers/media/dvb/ttusb-dec/ttusb_dec.c | 38 |
1 files changed, 18 insertions, 20 deletions
diff --git a/linux/drivers/media/dvb/ttusb-dec/ttusb_dec.c b/linux/drivers/media/dvb/ttusb-dec/ttusb_dec.c index cf4a8dc8d..663cce947 100644 --- a/linux/drivers/media/dvb/ttusb-dec/ttusb_dec.c +++ b/linux/drivers/media/dvb/ttusb-dec/ttusb_dec.c @@ -388,7 +388,8 @@ static void ttusb_dec_process_urb(struct urb *urb, struct pt_regs *ptregs) } #if LINUX_VERSION_CODE >= KERNEL_VERSION(2,5,0) - usb_submit_urb(urb URB_MEM_FLAG); + if (dec->iso_stream_count) + usb_submit_urb(urb URB_MEM_FLAG); #endif } @@ -447,6 +448,18 @@ static void ttusb_dec_stop_iso_xfer(struct ttusb_dec *dec) up(&dec->iso_sem); } +/* Setting the interface of the DEC tends to take down the USB communications + * for a short period, so it's important not to call this function just before + * trying to talk to it. + */ +static void ttusb_dec_set_streaming_interface(struct ttusb_dec *dec) +{ + if (!dec->interface) { + usb_set_interface(dec->udev, 0, 8); + dec->interface = 8; + } +} + static int ttusb_dec_start_iso_xfer(struct ttusb_dec *dec) { int i, result; @@ -456,16 +469,6 @@ static int ttusb_dec_start_iso_xfer(struct ttusb_dec *dec) if (down_interruptible(&dec->iso_sem)) return -EAGAIN; -#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,5,0) - if (!dec->interface) { - /* Can't do this at mod init time - weird. - * Seems to work up here for 2.5 - */ - usb_set_interface(dec->udev, 0, 8); - dec->interface = 8; - } -#endif - if (!dec->iso_stream_count) { u8 b0[] = { 0x05 }; @@ -498,15 +501,7 @@ static int ttusb_dec_start_iso_xfer(struct ttusb_dec *dec) up(&dec->iso_sem); #if LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0) - if (!dec->interface) { - /* Can't do this at mod init time - weird. - * Don't stick this at the top of this function either - - * it will cause the send_command to time out trying to get - * a result - */ - usb_set_interface(dec->udev, 0, 8); - dec->interface = 8; - } + ttusb_dec_set_streaming_interface(dec); #endif return 0; @@ -867,6 +862,8 @@ static void ttusb_dec_exit_usb(struct ttusb_dec *dec) dprintk("%s\n", __FUNCTION__); + dec->iso_stream_count = 0; + for (i = 0; i < ISO_BUF_COUNT; i++) usb_unlink_urb(dec->iso_urb[i]); @@ -926,6 +923,7 @@ static int ttusb_dec_probe(struct usb_interface *intf, ttusb_dec_init_v_pes(dec); usb_set_intfdata(intf, (void *)dec); + ttusb_dec_set_streaming_interface(dec); return 0; } |