media: af9015: refactor firmware download
authorAntti Palosaari <crope@iki.fi>
Mon, 26 Jun 2017 10:02:59 +0000 (06:02 -0400)
committerMauro Carvalho Chehab <mchehab@s-opensource.com>
Wed, 21 Mar 2018 18:12:55 +0000 (14:12 -0400)
Small revise, no functional changes.

Signed-off-by: Antti Palosaari <crope@iki.fi>
Signed-off-by: Mauro Carvalho Chehab <mchehab@s-opensource.com>
drivers/media/usb/dvb-usb-v2/af9015.c

index 8e2f704c6ca5ba3720f9b01c8bd283e99f6b6fb7..ffd4b225e4398665a04a0cd1ebe69b54fd98f547 100644 (file)
@@ -350,52 +350,47 @@ static int af9015_identify_state(struct dvb_usb_device *d, const char **name)
 }
 
 static int af9015_download_firmware(struct dvb_usb_device *d,
-       const struct firmware *fw)
+                                   const struct firmware *firmware)
 {
        struct af9015_state *state = d_to_priv(d);
        struct usb_interface *intf = d->intf;
-       int i, len, remaining, ret;
+       int ret, i, rem;
        struct req_t req = {DOWNLOAD_FIRMWARE, 0, 0, 0, 0, 0, NULL};
-       u16 checksum = 0;
+       u16 checksum;
 
        dev_dbg(&intf->dev, "\n");
 
-       /* calc checksum */
-       for (i = 0; i < fw->size; i++)
-               checksum += fw->data[i];
+       /* Calc checksum, we need it when copy firmware to slave demod */
+       for (i = 0, checksum = 0; i < firmware->size; i++)
+               checksum += firmware->data[i];
 
-       state->firmware_size = fw->size;
+       state->firmware_size = firmware->size;
        state->firmware_checksum = checksum;
 
-       #define FW_ADDR 0x5100 /* firmware start address */
-       #define LEN_MAX 55 /* max packet size */
-       for (remaining = fw->size; remaining > 0; remaining -= LEN_MAX) {
-               len = remaining;
-               if (len > LEN_MAX)
-                       len = LEN_MAX;
-
-               req.data_len = len;
-               req.data = (u8 *) &fw->data[fw->size - remaining];
-               req.addr = FW_ADDR + fw->size - remaining;
-
+       #define LEN_MAX (BUF_LEN - REQ_HDR_LEN) /* Max payload size */
+       for (rem = firmware->size; rem > 0; rem -= LEN_MAX) {
+               req.data_len = min(LEN_MAX, rem);
+               req.data = (u8 *) &firmware->data[firmware->size - rem];
+               req.addr = 0x5100 + firmware->size - rem;
                ret = af9015_ctrl_msg(d, &req);
                if (ret) {
                        dev_err(&intf->dev, "firmware download failed %d\n",
                                ret);
-                       goto error;
+                       goto err;
                }
        }
 
-       /* firmware loaded, request boot */
        req.cmd = BOOT;
        req.data_len = 0;
        ret = af9015_ctrl_msg(d, &req);
        if (ret) {
                dev_err(&intf->dev, "firmware boot failed %d\n", ret);
-               goto error;
+               goto err;
        }
 
-error:
+       return 0;
+err:
+       dev_dbg(&intf->dev, "failed %d\n", ret);
        return ret;
 }