diff options
author | Christophe JAILLET <christophe.jaillet@wanadoo.fr> | 2023-05-20 09:38:22 +0200 |
---|---|---|
committer | Kalle Valo <kvalo@kernel.org> | 2023-05-25 19:15:40 +0300 |
commit | 67a81d911c01225f426cc6bee2373df044c1a9b7 (patch) | |
tree | 153ae3805c2f4043274d6016e78314ffe05e599a | |
parent | 925244325159824385209e3e0e3f91fa6bf0646c (diff) | |
download | linux-67a81d911c01225f426cc6bee2373df044c1a9b7.tar.gz linux-67a81d911c01225f426cc6bee2373df044c1a9b7.tar.bz2 linux-67a81d911c01225f426cc6bee2373df044c1a9b7.zip |
wifi: orinoco: Fix an error handling path in orinoco_cs_probe()
Should orinoco_cs_config() fail, some resources need to be released as
already done in the remove function.
While at it, remove a useless and erroneous comment. The probe is
orinoco_cs_probe(), not orinoco_cs_attach().
Fixes: 15b99ac17295 ("[PATCH] pcmcia: add return value to _config() functions")
Signed-off-by: Christophe JAILLET <christophe.jaillet@wanadoo.fr>
Signed-off-by: Kalle Valo <kvalo@kernel.org>
Link: https://lore.kernel.org/r/e24735ce4d82901d5f7ea08419eea53bfdde3d65.1684568286.git.christophe.jaillet@wanadoo.fr
-rw-r--r-- | drivers/net/wireless/intersil/orinoco/orinoco_cs.c | 13 |
1 files changed, 11 insertions, 2 deletions
diff --git a/drivers/net/wireless/intersil/orinoco/orinoco_cs.c b/drivers/net/wireless/intersil/orinoco/orinoco_cs.c index a956f965a1e5..03bfd2482656 100644 --- a/drivers/net/wireless/intersil/orinoco/orinoco_cs.c +++ b/drivers/net/wireless/intersil/orinoco/orinoco_cs.c @@ -96,6 +96,7 @@ orinoco_cs_probe(struct pcmcia_device *link) { struct orinoco_private *priv; struct orinoco_pccard *card; + int ret; priv = alloc_orinocodev(sizeof(*card), &link->dev, orinoco_cs_hard_reset, NULL); @@ -107,8 +108,16 @@ orinoco_cs_probe(struct pcmcia_device *link) card->p_dev = link; link->priv = priv; - return orinoco_cs_config(link); -} /* orinoco_cs_attach */ + ret = orinoco_cs_config(link); + if (ret) + goto err_free_orinocodev; + + return 0; + +err_free_orinocodev: + free_orinocodev(priv); + return ret; +} static void orinoco_cs_detach(struct pcmcia_device *link) { |