summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPan Bian <bianpan2016@163.com>2019-04-17 17:41:23 +0800
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2019-05-25 18:26:46 +0200
commit224354c0a492fac1ecb01a685b139417ab242ca3 (patch)
treee211cc1ea38caf0b5b35b8fda529867e3c90a23a
parent09abe5a6bfedbfd44950f524d7e8690e683ddedc (diff)
downloadlinux-224354c0a492fac1ecb01a685b139417ab242ca3.tar.gz
linux-224354c0a492fac1ecb01a685b139417ab242ca3.tar.bz2
linux-224354c0a492fac1ecb01a685b139417ab242ca3.zip
p54: drop device reference count if fails to enable device
commit 8149069db81853570a665f5e5648c0e526dc0e43 upstream. The function p54p_probe takes an extra reference count of the PCI device. However, the extra reference count is not dropped when it fails to enable the PCI device. This patch fixes the bug. Cc: stable@vger.kernel.org Signed-off-by: Pan Bian <bianpan2016@163.com> Acked-by: Christian Lamparter <chunkeey@gmail.com> Signed-off-by: Kalle Valo <kvalo@codeaurora.org> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
-rw-r--r--drivers/net/wireless/intersil/p54/p54pci.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/drivers/net/wireless/intersil/p54/p54pci.c b/drivers/net/wireless/intersil/p54/p54pci.c
index 27a49068d32d..57ad56435dda 100644
--- a/drivers/net/wireless/intersil/p54/p54pci.c
+++ b/drivers/net/wireless/intersil/p54/p54pci.c
@@ -554,7 +554,7 @@ static int p54p_probe(struct pci_dev *pdev,
err = pci_enable_device(pdev);
if (err) {
dev_err(&pdev->dev, "Cannot enable new PCI device\n");
- return err;
+ goto err_put;
}
mem_addr = pci_resource_start(pdev, 0);
@@ -639,6 +639,7 @@ static int p54p_probe(struct pci_dev *pdev,
pci_release_regions(pdev);
err_disable_dev:
pci_disable_device(pdev);
+err_put:
pci_dev_put(pdev);
return err;
}