]> git.karo-electronics.de Git - linux-beck.git/commitdiff
[media] go7007: remember boot firmware
authorHans Verkuil <hans.verkuil@cisco.com>
Sat, 9 Mar 2013 13:37:52 +0000 (10:37 -0300)
committerMauro Carvalho Chehab <mchehab@redhat.com>
Sun, 24 Mar 2013 15:41:56 +0000 (12:41 -0300)
Don't load it everytime you stop encoding. Instead remember it.
Another reason for not loading it every time is that this could
be called from within the release() file operation, which turns
out to be deadly.

Signed-off-by: Hans Verkuil <hans.verkuil@cisco.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
drivers/staging/media/go7007/go7007-driver.c
drivers/staging/media/go7007/go7007-priv.h

index 09d0ef4984d39900f70545e94da6eb554217644a..db9a4b3a71136b0b7b1a8095650913b032a5f927 100644 (file)
@@ -95,34 +95,34 @@ static int go7007_load_encoder(struct go7007 *go)
        int fw_len, rv = 0;
        u16 intr_val, intr_data;
 
-       if (request_firmware(&fw_entry, fw_name, go->dev)) {
-               v4l2_err(go, "unable to load firmware from file "
-                       "\"%s\"\n", fw_name);
-               return -1;
-       }
-       if (fw_entry->size < 16 || memcmp(fw_entry->data, "WISGO7007FW", 11)) {
-               v4l2_err(go, "file \"%s\" does not appear to be "
-                               "go7007 firmware\n", fw_name);
-               release_firmware(fw_entry);
-               return -1;
-       }
-       fw_len = fw_entry->size - 16;
-       bounce = kmemdup(fw_entry->data + 16, fw_len, GFP_KERNEL);
-       if (bounce == NULL) {
-               v4l2_err(go, "unable to allocate %d bytes for "
-                               "firmware transfer\n", fw_len);
+       if (go->boot_fw == NULL) {
+               if (request_firmware(&fw_entry, fw_name, go->dev)) {
+                       v4l2_err(go, "unable to load firmware from file \"%s\"\n", fw_name);
+                       return -1;
+               }
+               if (fw_entry->size < 16 || memcmp(fw_entry->data, "WISGO7007FW", 11)) {
+                       v4l2_err(go, "file \"%s\" does not appear to be go7007 firmware\n", fw_name);
+                       release_firmware(fw_entry);
+                       return -1;
+               }
+               fw_len = fw_entry->size - 16;
+               bounce = kmemdup(fw_entry->data + 16, fw_len, GFP_KERNEL);
+               if (bounce == NULL) {
+                       v4l2_err(go, "unable to allocate %d bytes for firmware transfer\n", fw_len);
+                       release_firmware(fw_entry);
+                       return -1;
+               }
                release_firmware(fw_entry);
-               return -1;
+               go->boot_fw_len = fw_len;
+               go->boot_fw = bounce;
        }
-       release_firmware(fw_entry);
        if (go7007_interface_reset(go) < 0 ||
-                       go7007_send_firmware(go, bounce, fw_len) < 0 ||
-                       go7007_read_interrupt(go, &intr_val, &intr_data) < 0 ||
+           go7007_send_firmware(go, go->boot_fw, go->boot_fw_len) < 0 ||
+           go7007_read_interrupt(go, &intr_val, &intr_data) < 0 ||
                        (intr_val & ~0x1) != 0x5a5a) {
                v4l2_err(go, "error transferring firmware\n");
                rv = -1;
        }
-       kfree(bounce);
        return rv;
 }
 
@@ -675,6 +675,7 @@ void go7007_remove(struct go7007 *go)
 
        if (go->audio_enabled)
                go7007_snd_remove(go);
+       kfree(go->boot_fw);
        go7007_v4l2_remove(go);
 }
 EXPORT_SYMBOL(go7007_remove);
index daae6ddc46890ad1e282d22d86d370d670b7fed0..d390120e4db42954f7a3b9e72203e6300cb7a6f4 100644 (file)
@@ -178,6 +178,8 @@ struct go7007 {
        int channel_number; /* for multi-channel boards like Adlink PCI-MPG24 */
        char name[64];
        struct video_device *video_dev;
+       void *boot_fw;
+       unsigned boot_fw_len;
        struct v4l2_device v4l2_dev;
        int ref_count;
        enum { STATUS_INIT, STATUS_ONLINE, STATUS_SHUTDOWN } status;