From 6ae56042c19afe8d6be91b5d80ba85d695fa982d Mon Sep 17 00:00:00 2001 From: Alan Cox Date: Thu, 27 Aug 2009 10:59:21 +0100 Subject: [PATCH] Staging: et131x: Take a kref for the PCI pointer we cache Signed-off-by: Alan Cox Signed-off-by: Greg Kroah-Hartman --- drivers/staging/et131x/et131x_initpci.c | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/drivers/staging/et131x/et131x_initpci.c b/drivers/staging/et131x/et131x_initpci.c index 86bd55d2aeac..5485dd7ee4ee 100644 --- a/drivers/staging/et131x/et131x_initpci.c +++ b/drivers/staging/et131x/et131x_initpci.c @@ -742,6 +742,7 @@ void __devexit et131x_pci_remove(struct pci_dev *pdev) unregister_netdev(netdev); et131x_adapter_memory_free(adapter); iounmap(adapter->CSRAddress); + pci_dev_put(adapter->pdev); free_netdev(netdev); pci_release_regions(pdev); pci_disable_device(pdev); @@ -878,7 +879,7 @@ int __devinit et131x_pci_setup(struct pci_dev *pdev, /* Allocate private adapter struct and copy in relevant information */ adapter = netdev_priv(netdev); - adapter->pdev = pdev; + adapter->pdev = pci_dev_get(pdev); adapter->netdev = netdev; /* Do the same for the netdev struct */ @@ -1022,6 +1023,7 @@ err_mem_free: err_iounmap: iounmap(adapter->CSRAddress); err_free_dev: + pci_dev_put(pdev); free_netdev(netdev); err_release_res: pci_release_regions(pdev); -- 2.34.1