Commit 09b18938 authored by Mateusz Kulikowski's avatar Mateusz Kulikowski Committed by Greg Kroah-Hartman

staging: rtl8192e: Add _rtl92e_fw_prepare

Add function to request and prepare firmware image.
Signed-off-by: default avatarMateusz Kulikowski <mateusz.kulikowski@gmail.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 51dac5f0
...@@ -167,6 +167,36 @@ static bool _rtl92e_fw_check_ready(struct net_device *dev, ...@@ -167,6 +167,36 @@ static bool _rtl92e_fw_check_ready(struct net_device *dev,
return rt_status; return rt_status;
} }
static bool _rtl92e_fw_prepare(struct net_device *dev, struct rt_fw_blob *blob,
const char *name, u8 padding)
{
const struct firmware *fw;
int rc, i;
bool ret = true;
rc = request_firmware(&fw, name, &dev->dev);
if (rc < 0)
return false;
if (round_up(fw->size, 4) > MAX_FW_SIZE - padding) {
netdev_err(dev, "Firmware image %s too big for the device.\n",
name);
ret = false;
goto out;
}
if (padding)
memset(blob->data, 0, padding);
if (fw->size % 4)
memset(blob->data + padding + fw->size, 0, 4);
memcpy(blob->data + padding, fw->data, fw->size);
blob->size = round_up(fw->size, 4) + padding;
out:
release_firmware(fw);
return ret;
}
bool rtl92e_init_fw(struct net_device *dev) bool rtl92e_init_fw(struct net_device *dev)
{ {
struct r8192_priv *priv = rtllib_priv(dev); struct r8192_priv *priv = rtllib_priv(dev);
...@@ -202,39 +232,16 @@ bool rtl92e_init_fw(struct net_device *dev) ...@@ -202,39 +232,16 @@ bool rtl92e_init_fw(struct net_device *dev)
RTL8192E_MAIN_IMG_FW, RTL8192E_MAIN_IMG_FW,
RTL8192E_DATA_IMG_FW RTL8192E_DATA_IMG_FW
}; };
const struct firmware *fw_entry; int pad = 0;
int rc;
if (i == FW_INIT_STEP1_MAIN)
rc = request_firmware(&fw_entry, pad = 128;
fw_name[i],
&priv->pdev->dev); if (!_rtl92e_fw_prepare(dev,
if (rc < 0) { &pfirmware->blobs[i],
RT_TRACE(COMP_FIRMWARE, fw_name[i],
"request firmware fail!\n"); pad))
goto download_firmware_fail;
}
if (fw_entry->size > MAX_FW_SIZE) {
RT_TRACE(COMP_FIRMWARE,
"img file size exceed the container struct buffer fail!\n");
release_firmware(fw_entry);
goto download_firmware_fail; goto download_firmware_fail;
}
if (i != FW_INIT_STEP1_MAIN) {
memcpy(pfirmware->blobs[i].data,
fw_entry->data, fw_entry->size);
pfirmware->blobs[i].size =
fw_entry->size;
} else {
memset(pfirmware->blobs[i].data,
0, 128);
memcpy(&pfirmware->blobs[i].data[128],
fw_entry->data, fw_entry->size);
pfirmware->blobs[i].size =
fw_entry->size + 128;
}
release_firmware(fw_entry);
} }
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment