Commit a50185cb authored by Simon Sandström's avatar Simon Sandström Committed by Greg Kroah-Hartman

staging: kpc2000: simplify error handling in kp2000_pcie_probe

We can get rid of a few iounmaps in the middle of the function by
re-ordering the error handling labels and adding two new labels.
Signed-off-by: default avatarSimon Sandström <simon@nikanor.nu>
Reviewed-by: default avatarDan Carpenter <dan.carpenter@oracle.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 0234961d
...@@ -351,12 +351,11 @@ static int kp2000_pcie_probe(struct pci_dev *pdev, ...@@ -351,12 +351,11 @@ static int kp2000_pcie_probe(struct pci_dev *pdev,
err = pci_request_region(pcard->pdev, REG_BAR, KP_DRIVER_NAME_KP2000); err = pci_request_region(pcard->pdev, REG_BAR, KP_DRIVER_NAME_KP2000);
if (err) { if (err) {
iounmap(pcard->regs_bar_base);
dev_err(&pcard->pdev->dev, dev_err(&pcard->pdev->dev,
"probe: failed to acquire PCI region (%d)\n", "probe: failed to acquire PCI region (%d)\n",
err); err);
err = -ENODEV; err = -ENODEV;
goto err_disable_device; goto err_unmap_regs;
} }
pcard->regs_base_resource.start = reg_bar_phys_addr; pcard->regs_base_resource.start = reg_bar_phys_addr;
...@@ -374,7 +373,7 @@ static int kp2000_pcie_probe(struct pci_dev *pdev, ...@@ -374,7 +373,7 @@ static int kp2000_pcie_probe(struct pci_dev *pdev,
dev_err(&pcard->pdev->dev, dev_err(&pcard->pdev->dev,
"probe: DMA_BAR could not remap memory to virtual space\n"); "probe: DMA_BAR could not remap memory to virtual space\n");
err = -ENODEV; err = -ENODEV;
goto err_unmap_regs; goto err_release_regs;
} }
dev_dbg(&pcard->pdev->dev, dev_dbg(&pcard->pdev->dev,
"probe: DMA_BAR virt hardware address start [%p]\n", "probe: DMA_BAR virt hardware address start [%p]\n",
...@@ -384,11 +383,10 @@ static int kp2000_pcie_probe(struct pci_dev *pdev, ...@@ -384,11 +383,10 @@ static int kp2000_pcie_probe(struct pci_dev *pdev,
err = pci_request_region(pcard->pdev, DMA_BAR, "kp2000_pcie"); err = pci_request_region(pcard->pdev, DMA_BAR, "kp2000_pcie");
if (err) { if (err) {
iounmap(pcard->dma_bar_base);
dev_err(&pcard->pdev->dev, dev_err(&pcard->pdev->dev,
"probe: failed to acquire PCI region (%d)\n", err); "probe: failed to acquire PCI region (%d)\n", err);
err = -ENODEV; err = -ENODEV;
goto err_unmap_regs; goto err_unmap_dma;
} }
pcard->dma_base_resource.start = dma_bar_phys_addr; pcard->dma_base_resource.start = dma_bar_phys_addr;
...@@ -400,7 +398,7 @@ static int kp2000_pcie_probe(struct pci_dev *pdev, ...@@ -400,7 +398,7 @@ static int kp2000_pcie_probe(struct pci_dev *pdev,
pcard->sysinfo_regs_base = pcard->regs_bar_base; pcard->sysinfo_regs_base = pcard->regs_bar_base;
err = read_system_regs(pcard); err = read_system_regs(pcard);
if (err) if (err)
goto err_unmap_dma; goto err_release_dma;
// Disable all "user" interrupts because they're not used yet. // Disable all "user" interrupts because they're not used yet.
writeq(0xFFFFFFFFFFFFFFFF, writeq(0xFFFFFFFFFFFFFFFF,
...@@ -438,14 +436,14 @@ static int kp2000_pcie_probe(struct pci_dev *pdev, ...@@ -438,14 +436,14 @@ static int kp2000_pcie_probe(struct pci_dev *pdev,
if (err) { if (err) {
dev_err(&pcard->pdev->dev, dev_err(&pcard->pdev->dev,
"CANNOT use DMA mask %0llx\n", DMA_BIT_MASK(64)); "CANNOT use DMA mask %0llx\n", DMA_BIT_MASK(64));
goto err_unmap_dma; goto err_release_dma;
} }
dev_dbg(&pcard->pdev->dev, dev_dbg(&pcard->pdev->dev,
"Using DMA mask %0llx\n", dma_get_mask(PCARD_TO_DEV(pcard))); "Using DMA mask %0llx\n", dma_get_mask(PCARD_TO_DEV(pcard)));
err = pci_enable_msi(pcard->pdev); err = pci_enable_msi(pcard->pdev);
if (err < 0) if (err < 0)
goto err_unmap_dma; goto err_release_dma;
rv = request_irq(pcard->pdev->irq, kp2000_irq_handler, IRQF_SHARED, rv = request_irq(pcard->pdev->irq, kp2000_irq_handler, IRQF_SHARED,
pcard->name, pcard); pcard->name, pcard);
...@@ -478,14 +476,14 @@ static int kp2000_pcie_probe(struct pci_dev *pdev, ...@@ -478,14 +476,14 @@ static int kp2000_pcie_probe(struct pci_dev *pdev,
free_irq(pcard->pdev->irq, pcard); free_irq(pcard->pdev->irq, pcard);
err_disable_msi: err_disable_msi:
pci_disable_msi(pcard->pdev); pci_disable_msi(pcard->pdev);
err_release_dma:
pci_release_region(pdev, DMA_BAR);
err_unmap_dma: err_unmap_dma:
iounmap(pcard->dma_bar_base); iounmap(pcard->dma_bar_base);
pci_release_region(pdev, DMA_BAR); err_release_regs:
pcard->dma_bar_base = NULL; pci_release_region(pdev, REG_BAR);
err_unmap_regs: err_unmap_regs:
iounmap(pcard->regs_bar_base); iounmap(pcard->regs_bar_base);
pci_release_region(pdev, REG_BAR);
pcard->regs_bar_base = NULL;
err_disable_device: err_disable_device:
pci_disable_device(pcard->pdev); pci_disable_device(pcard->pdev);
err_remove_ida: err_remove_ida:
......
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