diff options
Diffstat (limited to 'linux/drivers/media/dvb/ttusb-dec')
-rw-r--r-- | linux/drivers/media/dvb/ttusb-dec/Kconfig | 22 | ||||
-rw-r--r-- | linux/drivers/media/dvb/ttusb-dec/Makefile | 11 | ||||
-rw-r--r-- | linux/drivers/media/dvb/ttusb-dec/ttusb_dec.c | 58 |
3 files changed, 56 insertions, 35 deletions
diff --git a/linux/drivers/media/dvb/ttusb-dec/Kconfig b/linux/drivers/media/dvb/ttusb-dec/Kconfig index 5b17e103f..6e56764f6 100644 --- a/linux/drivers/media/dvb/ttusb-dec/Kconfig +++ b/linux/drivers/media/dvb/ttusb-dec/Kconfig @@ -1,6 +1,6 @@ config DVB_TTUSB_DEC tristate "Technotrend/Hauppauge USB DEC devices" - depends on DVB_CORE && USB && !STANDALONE + depends on DVB_CORE && USB && FW_LOADER help Support for external USB adapters designed by Technotrend and produced by Hauppauge, shipped under the brand name 'DEC2000-t' @@ -11,24 +11,16 @@ config DVB_TTUSB_DEC an external software decoder to watch TV on your computer. The DEC devices require firmware in order to boot into a mode in - which they are slaves to the PC. These are required at compile - time. The firmware can be obtained and put into the default + which they are slaves to the PC. See + linux/Documentation/dvb/FIRMWARE for details. + + The firmware can be obtained and put into the default locations as follows: wget http://hauppauge.lightpath.net/de/dec215a.exe unzip -j dec215a.exe Software/Oem/STB/App/Boot/STB_PC_T.bin - mv STB_PC_T.bin /etc/dvb/dec2000t.bin + mv STB_PC_T.bin /usr/lib/hotplug/firmware/dec2000t.bin unzip -j dec215a.exe Software/Oem/STB/App/Boot/STB_PC_S.bin - mv STB_PC_S.bin /etc/dvb/dec3000s.bin + mv STB_PC_S.bin /usr/lib/hotplug/firmware/dec3000s.bin Say Y if you own such a device and want to use it. - -config DVB_TTUSB_DEC2000T_FIRMWARE_FILE - string "Full pathname of dec2000t.bin firmware file" - depends on DVB_TTUSB_DEC - default "/etc/dvb/dec2000t.bin" - -config DVB_TTUSB_DEC3000S_FIRMWARE_FILE - string "Full pathname of dec3000s.bin firmware file" - depends on DVB_TTUSB_DEC - default "/etc/dvb/dec3000s.bin" diff --git a/linux/drivers/media/dvb/ttusb-dec/Makefile b/linux/drivers/media/dvb/ttusb-dec/Makefile index 7e404d618..bf4e38740 100644 --- a/linux/drivers/media/dvb/ttusb-dec/Makefile +++ b/linux/drivers/media/dvb/ttusb-dec/Makefile @@ -1,14 +1,3 @@ - obj-$(CONFIG_DVB_TTUSB_DEC) += ttusb_dec.o EXTRA_CFLAGS = -Idrivers/media/dvb/dvb-core/ - -host-progs := fdump - -$(obj)/ttusb_dec.o: $(obj)/dsp_dec2000t.h $(obj)/dsp_dec3000s.h - -$(obj)/dsp_dec2000t.h: $(patsubst "%", %, $(CONFIG_DVB_TTUSB_DEC2000T_FIRMWARE_FILE)) $(obj)/fdump - $(obj)/fdump $< dsp_dec2000t > $@ - -$(obj)/dsp_dec3000s.h: $(patsubst "%", %, $(CONFIG_DVB_TTUSB_DEC3000S_FIRMWARE_FILE)) $(obj)/fdump - $(obj)/fdump $< dsp_dec3000s > $@ diff --git a/linux/drivers/media/dvb/ttusb-dec/ttusb_dec.c b/linux/drivers/media/dvb/ttusb-dec/ttusb_dec.c index 66fe0e6d5..4341591bc 100644 --- a/linux/drivers/media/dvb/ttusb-dec/ttusb_dec.c +++ b/linux/drivers/media/dvb/ttusb-dec/ttusb_dec.c @@ -28,6 +28,9 @@ #include <linux/usb.h> #include <linux/version.h> #include <linux/interrupt.h> +#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,5,0) +#include <linux/firmware.h> +#endif #include "dmxdev.h" #include "dvb_demux.h" @@ -66,6 +69,7 @@ enum ttusb_model { struct ttusb_dec { enum ttusb_model model; char *model_name; + char *firmware_name; /* DVB bits */ struct dvb_adapter *adapter; @@ -110,6 +114,8 @@ struct ttusb_dec { struct list_head urb_frame_list; struct tasklet_struct urb_tasklet; spinlock_t urb_frame_list_lock; + + int active; /* Loaded successfully */ }; struct urb_frame { @@ -821,8 +827,10 @@ static void ttusb_dec_init_usb(struct ttusb_dec *dec) ttusb_dec_alloc_iso_urbs(dec); } +#if LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0) #include "dsp_dec2000t.h" #include "dsp_dec3000s.h" +#endif static int ttusb_dec_boot_dsp(struct ttusb_dec *dec) { @@ -836,19 +844,36 @@ static int ttusb_dec_boot_dsp(struct ttusb_dec *dec) u32 firmware_csum = 0; u32 firmware_size_nl; u32 firmware_csum_nl; +#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,5,0) + const struct firmware *fw_entry = NULL; +#endif dprintk("%s\n", __FUNCTION__); +#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,5,0) + if (request_firmware(&fw_entry, dec->firmware_name, &dec->udev->dev)) { + printk(KERN_ERR "%s: Firmware (%s) unavailable.\n", + __FUNCTION__, dec->firmware_name); + return 1; + } + + firmware = fw_entry->data; + firmware_size = fw_entry->size; +#endif switch (dec->model) { case TTUSB_DEC2000T: +#if LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0) firmware = &dsp_dec2000t[0]; firmware_size = sizeof(dsp_dec2000t); +#endif firmware_csum = 0x1bc86100; break; case TTUSB_DEC3000S: +#if LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0) firmware = &dsp_dec3000s[0]; firmware_size = sizeof(dsp_dec3000s); +#endif firmware_csum = 0x00000000; break; } @@ -896,7 +921,7 @@ static int ttusb_dec_boot_dsp(struct ttusb_dec *dec) return result; } -static void ttusb_dec_init_stb(struct ttusb_dec *dec) +static int ttusb_dec_init_stb(struct ttusb_dec *dec) { u8 c[COMMAND_PACKET_SIZE]; int c_length; @@ -906,9 +931,14 @@ static void ttusb_dec_init_stb(struct ttusb_dec *dec) result = ttusb_dec_send_command(dec, 0x08, 0, NULL, &c_length, c); - if (!result) + if (!result) { if (c_length != 0x0c || (c_length == 0x0c && c[9] != 0x63)) - ttusb_dec_boot_dsp(dec); + return ttusb_dec_boot_dsp(dec); + else + return 0; + } + else + return result; } static int ttusb_dec_init_dvb(struct ttusb_dec *dec) @@ -1309,6 +1339,8 @@ static int ttusb_dec_probe(struct usb_interface *intf, printk("%s: couldn't allocate memory.\n", __FUNCTION__); return -ENOMEM; } + + usb_set_intfdata(intf, (void *)dec); #endif memset(dec, 0, sizeof(struct ttusb_dec)); @@ -1317,27 +1349,33 @@ static int ttusb_dec_probe(struct usb_interface *intf, case 0x1006: dec->model = TTUSB_DEC3000S; dec->model_name = "DEC3000-s"; + dec->firmware_name = "dec3000s.bin"; break; case 0x1008: dec->model = TTUSB_DEC2000T; dec->model_name = "DEC2000-t"; + dec->firmware_name = "dec2000t.bin"; break; } dec->udev = udev; ttusb_dec_init_usb(dec); - ttusb_dec_init_stb(dec); + if (ttusb_dec_init_stb(dec)) { + ttusb_dec_exit_usb(dec); + return 0; + } ttusb_dec_init_dvb(dec); ttusb_dec_init_frontend(dec); ttusb_dec_init_v_pes(dec); ttusb_dec_init_tasklet(dec); + dec->active = 1; + #if LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0) return (void *)dec; #else - usb_set_intfdata(intf, (void *)dec); ttusb_dec_set_streaming_interface(dec); return 0; @@ -1358,10 +1396,12 @@ static void ttusb_dec_disconnect(struct usb_interface *intf) dprintk("%s\n", __FUNCTION__); - ttusb_dec_exit_tasklet(dec); - ttusb_dec_exit_usb(dec); - ttusb_dec_exit_frontend(dec); - ttusb_dec_exit_dvb(dec); + if (dec->active) { + ttusb_dec_exit_tasklet(dec); + ttusb_dec_exit_usb(dec); + ttusb_dec_exit_frontend(dec); + ttusb_dec_exit_dvb(dec); + } kfree(dec); } |