提交 9c1bb37f 编写于 作者: C Christophe JAILLET 提交者: David S. Miller

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: a7e1abad ("ptp: Add clock driver for the OpenCompute TimeCard.")
Signed-off-by: NChristophe JAILLET <christophe.jaillet@wanadoo.fr>
Acked-by: NRichard Cochran <richardcochran@gmail.com>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 e5cc361e
...@@ -324,7 +324,7 @@ ptp_ocp_probe(struct pci_dev *pdev, const struct pci_device_id *id) ...@@ -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) ...@@ -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);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册