Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 122333
b: refs/heads/master
c: 7473431
h: refs/heads/master
i:
  122331: 2e1a2ac
v: v3
  • Loading branch information
David Kilroy authored and John W. Linville committed Nov 26, 2008
1 parent 81b0ab5 commit b984c17
Show file tree
Hide file tree
Showing 2 changed files with 39 additions and 16 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: cb71d9bafb37adab50ddce53bb119a84b4966c06
refs/heads/master: 7473431297761fa644a128a497b91e299676f501
53 changes: 38 additions & 15 deletions trunk/drivers/net/wireless/orinoco/orinoco.c
Original file line number Diff line number Diff line change
Expand Up @@ -431,9 +431,9 @@ struct fw_info {
};

const static struct fw_info orinoco_fw[] = {
{ "", "agere_sta_fw.bin", "agere_ap_fw.bin", 0x00390000, 1000 },
{ "", "prism_sta_fw.bin", "prism_ap_fw.bin", 0, 1024 },
{ "symbol_sp24t_prim_fw", "symbol_sp24t_sec_fw", "", 0x00003100, 512 }
{ NULL, "agere_sta_fw.bin", "agere_ap_fw.bin", 0x00390000, 1000 },
{ NULL, "prism_sta_fw.bin", "prism_ap_fw.bin", 0, 1024 },
{ "symbol_sp24t_prim_fw", "symbol_sp24t_sec_fw", NULL, 0x00003100, 512 }
};

/* Structure used to access fields in FW
Expand Down Expand Up @@ -487,18 +487,17 @@ orinoco_dl_firmware(struct orinoco_private *priv,
if (err)
goto free;

if (priv->cached_fw)
fw_entry = priv->cached_fw;
else {
if (!priv->cached_fw) {
err = request_firmware(&fw_entry, firmware, priv->dev);

if (err) {
printk(KERN_ERR "%s: Cannot find firmware %s\n",
dev->name, firmware);
err = -ENOENT;
goto free;
}
priv->cached_fw = fw_entry;
}
} else
fw_entry = priv->cached_fw;

hdr = (const struct orinoco_fw_header *) fw_entry->data;

Expand Down Expand Up @@ -540,11 +539,9 @@ orinoco_dl_firmware(struct orinoco_private *priv,
dev->name, hermes_present(hw));

abort:
/* In case of error, assume firmware was bogus and release it */
if (err) {
priv->cached_fw = NULL;
/* If we requested the firmware, release it. */
if (!priv->cached_fw)
release_firmware(fw_entry);
}

free:
kfree(pda);
Expand Down Expand Up @@ -708,6 +705,30 @@ static int orinoco_download(struct orinoco_private *priv)
return err;
}

static void orinoco_cache_fw(struct orinoco_private *priv, int ap)
{
const struct firmware *fw_entry = NULL;
const char *fw;

if (ap)
fw = orinoco_fw[priv->firmware_type].ap_fw;
else
fw = orinoco_fw[priv->firmware_type].sta_fw;

if (fw) {
if (request_firmware(&fw_entry, fw, priv->dev) == 0)
priv->cached_fw = fw_entry;
}
}

static void orinoco_uncache_fw(struct orinoco_private *priv)
{
if (priv->cached_fw)
release_firmware(priv->cached_fw);

priv->cached_fw = NULL;
}

/********************************************************************/
/* Device methods */
/********************************************************************/
Expand Down Expand Up @@ -3304,6 +3325,8 @@ static int orinoco_init(struct net_device *dev)
}

if (priv->do_fw_download) {
orinoco_cache_fw(priv, 0);

err = orinoco_download(priv);
if (err)
priv->do_fw_download = 0;
Expand Down Expand Up @@ -3553,9 +3576,9 @@ void free_orinocodev(struct net_device *dev)
* when we call tasklet_kill it will run one final time,
* emptying the list */
tasklet_kill(&priv->rx_tasklet);
if (priv->cached_fw)
release_firmware(priv->cached_fw);
priv->cached_fw = NULL;

orinoco_uncache_fw(priv);

priv->wpa_ie_len = 0;
kfree(priv->wpa_ie);
orinoco_mic_free(priv);
Expand Down

0 comments on commit b984c17

Please sign in to comment.