ptp: ocp: Fix a resource leak in an error handling path

If an error occurs after a successful 'pci_ioremap_bar()' call, it must be
undone by a corresponding 'pci_iounmap()' call, as already done in the
remove function.

Fixes: a7e1abad13 ("ptp: Add clock driver for the OpenCompute TimeCard.")
Signed-off-by: Christophe JAILLET <christophe.jaillet@wanadoo.fr>
Acked-by: Richard Cochran <richardcochran@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
Christophe JAILLET 2021-05-12 13:15:29 +02:00 committed by David S. Miller
parent e5cc361e21
commit 9c1bb37f8c

View File

@ -324,7 +324,7 @@ ptp_ocp_probe(struct pci_dev *pdev, const struct pci_device_id *id)
if (!bp->base) { if (!bp->base) {
dev_err(&pdev->dev, "io_remap bar0\n"); dev_err(&pdev->dev, "io_remap bar0\n");
err = -ENOMEM; err = -ENOMEM;
goto out; goto out_release_regions;
} }
bp->reg = bp->base + OCP_REGISTER_OFFSET; bp->reg = bp->base + OCP_REGISTER_OFFSET;
bp->tod = bp->base + TOD_REGISTER_OFFSET; bp->tod = bp->base + TOD_REGISTER_OFFSET;
@ -347,6 +347,8 @@ ptp_ocp_probe(struct pci_dev *pdev, const struct pci_device_id *id)
return 0; return 0;
out: out:
pci_iounmap(pdev, bp->base);
out_release_regions:
pci_release_regions(pdev); pci_release_regions(pdev);
out_disable: out_disable:
pci_disable_device(pdev); pci_disable_device(pdev);