V4L/DVB (13495): pvrusb2: Support 16KB FX2 firmware
authorMike Isely <isely@pobox.com>
Wed, 25 Nov 2009 05:49:21 +0000 (02:49 -0300)
committerMauro Carvalho Chehab <mchehab@redhat.com>
Sat, 5 Dec 2009 20:42:09 +0000 (18:42 -0200)
New FX2 firmware from Hauppauge is no longer 8KB in size - it's 16KB.
This is true for HVR-1950 and HVR-1900 devices.  Without this change,
new pvrusb2 users with that hardware are unable to use the driver
(because the CD shipped with the hardware only has the 16KB firmware).

Signed-off-by: Mike Isely <isely@pobox.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
drivers/media/video/pvrusb2/pvrusb2-devattr.c
drivers/media/video/pvrusb2/pvrusb2-devattr.h
drivers/media/video/pvrusb2/pvrusb2-hdw.c

index e4d7c13cab8797d697c725a36323854ab01d0065..ef4ff411b39d7c7609637d7eff5e5081844f86c2 100644 (file)
@@ -456,6 +456,7 @@ static const struct pvr2_device_desc pvr2_device_750xx = {
                .flag_has_analogtuner = !0,
                .flag_has_composite = !0,
                .flag_has_svideo = !0,
+               .flag_fx2_16kb = !0,
                .signal_routing_scheme = PVR2_ROUTING_SCHEME_HAUPPAUGE,
                .digital_control_scheme = PVR2_DIGITAL_SCHEME_HAUPPAUGE,
                .default_std_mask = V4L2_STD_NTSC_M,
@@ -478,6 +479,7 @@ static const struct pvr2_device_desc pvr2_device_751xx = {
                .flag_has_analogtuner = !0,
                .flag_has_composite = !0,
                .flag_has_svideo = !0,
+               .flag_fx2_16kb = !0,
                .signal_routing_scheme = PVR2_ROUTING_SCHEME_HAUPPAUGE,
                .digital_control_scheme = PVR2_DIGITAL_SCHEME_HAUPPAUGE,
                .default_std_mask = V4L2_STD_NTSC_M,
index ea04ecf8aa39a0a33d291c5726f8fc52d3526fce..e5b9594eb5f6266acbdbe757740c5be47b5e7d4b 100644 (file)
@@ -176,6 +176,7 @@ struct pvr2_device_desc {
        unsigned int flag_has_analogtuner:1;   /* Has analog tuner */
        unsigned int flag_has_composite:1;     /* Has composite input */
        unsigned int flag_has_svideo:1;        /* Has s-video input */
+       unsigned int flag_fx2_16kb:1;          /* 16KB FX2 firmware OK here */
 };
 
 extern struct usb_device_id pvr2_device_table[];
index 4c1a2a534427a8555a5fd8c653a9e396d80bab13..9be04772c723d69cab313a02fa3d4859ae8c0293 100644 (file)
@@ -1474,8 +1474,19 @@ static int pvr2_upload_firmware1(struct pvr2_hdw *hdw)
 
        pipe = usb_sndctrlpipe(hdw->usb_dev, 0);
 
-       if (fw_entry->size != 0x2000){
-               pvr2_trace(PVR2_TRACE_ERROR_LEGS,"wrong fx2 firmware size");
+       if ((fw_entry->size != 0x2000) &&
+           (!(hdw->hdw_desc->flag_fx2_16kb && (fw_entry->size == 0x4000)))) {
+               if (hdw->hdw_desc->flag_fx2_16kb) {
+                       pvr2_trace(PVR2_TRACE_ERROR_LEGS,
+                                  "Wrong fx2 firmware size"
+                                  " (expected 8192 or 16384, got %u)",
+                                  fw_entry->size);
+               } else {
+                       pvr2_trace(PVR2_TRACE_ERROR_LEGS,
+                                  "Wrong fx2 firmware size"
+                                  " (expected 8192, got %u)",
+                                  fw_entry->size);
+               }
                release_firmware(fw_entry);
                return -ENOMEM;
        }