Commit 3d86b930 authored by Tim Gardner's avatar Tim Gardner Committed by John W. Linville

rtlwifi: Fix PCI probe error path orphaned memory

Memory allocated by ieee80211_alloc_hw() will get orphaned
if any subsequent initializations fail.

Also don't pci_set_drvdata(pdev, NULL) until just before disabling
the PCI device. Functions called by rtl_deinit_core(hw) may eventually need
the context (when its actually implemented).

Cc: Larry Finger <Larry.Finger@lwfinger.net>
Cc: Chaoming Li <chaoming_li@realsil.com.cn>
Cc: John W. Linville <linville@tuxdriver.com>
Cc: linux-wireless@vger.kernel.org
Cc: netdev@vger.kernel.org
Cc: linux-kernel@vger.kernel.org
Signed-off-by: default avatarTim Gardner <tim.gardner@canonical.com>
Acked-by: default avatarLarry Finger <Larry.Finger@lwfinger.net>
Signed-off-by: default avatarJohn W. Linville <linville@tuxdriver.com>
parent 885bd8ec
...@@ -1758,8 +1758,8 @@ int __devinit rtl_pci_probe(struct pci_dev *pdev, ...@@ -1758,8 +1758,8 @@ int __devinit rtl_pci_probe(struct pci_dev *pdev,
if (pci_set_consistent_dma_mask(pdev, DMA_BIT_MASK(32))) { if (pci_set_consistent_dma_mask(pdev, DMA_BIT_MASK(32))) {
RT_ASSERT(false, RT_ASSERT(false,
"Unable to obtain 32bit DMA for consistent allocations\n"); "Unable to obtain 32bit DMA for consistent allocations\n");
pci_disable_device(pdev); err = -ENOMEM;
return -ENOMEM; goto fail1;
} }
} }
...@@ -1801,7 +1801,7 @@ int __devinit rtl_pci_probe(struct pci_dev *pdev, ...@@ -1801,7 +1801,7 @@ int __devinit rtl_pci_probe(struct pci_dev *pdev,
err = pci_request_regions(pdev, KBUILD_MODNAME); err = pci_request_regions(pdev, KBUILD_MODNAME);
if (err) { if (err) {
RT_ASSERT(false, "Can't obtain PCI resources\n"); RT_ASSERT(false, "Can't obtain PCI resources\n");
goto fail2; goto fail1;
} }
pmem_start = pci_resource_start(pdev, rtlpriv->cfg->bar_id); pmem_start = pci_resource_start(pdev, rtlpriv->cfg->bar_id);
...@@ -1814,6 +1814,7 @@ int __devinit rtl_pci_probe(struct pci_dev *pdev, ...@@ -1814,6 +1814,7 @@ int __devinit rtl_pci_probe(struct pci_dev *pdev,
rtlpriv->cfg->bar_id, pmem_len); rtlpriv->cfg->bar_id, pmem_len);
if (rtlpriv->io.pci_mem_start == 0) { if (rtlpriv->io.pci_mem_start == 0) {
RT_ASSERT(false, "Can't map PCI mem\n"); RT_ASSERT(false, "Can't map PCI mem\n");
err = -ENOMEM;
goto fail2; goto fail2;
} }
...@@ -1830,8 +1831,10 @@ int __devinit rtl_pci_probe(struct pci_dev *pdev, ...@@ -1830,8 +1831,10 @@ int __devinit rtl_pci_probe(struct pci_dev *pdev,
pci_write_config_byte(pdev, 0x04, 0x07); pci_write_config_byte(pdev, 0x04, 0x07);
/* find adapter */ /* find adapter */
if (!_rtl_pci_find_adapter(pdev, hw)) if (!_rtl_pci_find_adapter(pdev, hw)) {
err = -ENODEV;
goto fail3; goto fail3;
}
/* Init IO handler */ /* Init IO handler */
_rtl_pci_io_handler_init(&pdev->dev, hw); _rtl_pci_io_handler_init(&pdev->dev, hw);
...@@ -1841,6 +1844,7 @@ int __devinit rtl_pci_probe(struct pci_dev *pdev, ...@@ -1841,6 +1844,7 @@ int __devinit rtl_pci_probe(struct pci_dev *pdev,
if (rtlpriv->cfg->ops->init_sw_vars(hw)) { if (rtlpriv->cfg->ops->init_sw_vars(hw)) {
RT_TRACE(rtlpriv, COMP_ERR, DBG_EMERG, "Can't init_sw_vars\n"); RT_TRACE(rtlpriv, COMP_ERR, DBG_EMERG, "Can't init_sw_vars\n");
err = -ENODEV;
goto fail3; goto fail3;
} }
...@@ -1885,7 +1889,6 @@ int __devinit rtl_pci_probe(struct pci_dev *pdev, ...@@ -1885,7 +1889,6 @@ int __devinit rtl_pci_probe(struct pci_dev *pdev,
return 0; return 0;
fail3: fail3:
pci_set_drvdata(pdev, NULL);
rtl_deinit_core(hw); rtl_deinit_core(hw);
_rtl_pci_io_handler_release(hw); _rtl_pci_io_handler_release(hw);
...@@ -1897,10 +1900,12 @@ int __devinit rtl_pci_probe(struct pci_dev *pdev, ...@@ -1897,10 +1900,12 @@ int __devinit rtl_pci_probe(struct pci_dev *pdev,
complete(&rtlpriv->firmware_loading_complete); complete(&rtlpriv->firmware_loading_complete);
fail1: fail1:
if (hw)
ieee80211_free_hw(hw);
pci_set_drvdata(pdev, NULL);
pci_disable_device(pdev); pci_disable_device(pdev);
return -ENODEV; return err;
} }
EXPORT_SYMBOL(rtl_pci_probe); EXPORT_SYMBOL(rtl_pci_probe);
......
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