linux-kernel.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH] powerpc/pasemi: Fix PCI device reference leak on error path
@ 2025-08-29  6:34 Miaoqian Lin
  2025-09-02 14:34 ` Markus Elfring
  0 siblings, 1 reply; 2+ messages in thread
From: Miaoqian Lin @ 2025-08-29  6:34 UTC (permalink / raw)
  To: Madhavan Srinivasan, Michael Ellerman, Nicholas Piggin,
	Christophe Leroy, Miaoqian Lin, Jeff Garzik, Olof Johansson,
	linuxppc-dev, linux-kernel

Fix iob_pdev reference leak in pasemi_dma_init() when dma_pdev
allocation fails. Ensure pci_dev_put(iob_pdev) is called on
both success and error paths.

Fixes: 8ee9d8577935 ("pasemi: DMA engine management library")
Signed-off-by: Miaoqian Lin <linmq006@gmail.com>
---
 arch/powerpc/platforms/pasemi/dma_lib.c | 6 +++++-
 1 file changed, 5 insertions(+), 1 deletion(-)

diff --git a/arch/powerpc/platforms/pasemi/dma_lib.c b/arch/powerpc/platforms/pasemi/dma_lib.c
index 1be1f18f6f09..0ba05c39c276 100644
--- a/arch/powerpc/platforms/pasemi/dma_lib.c
+++ b/arch/powerpc/platforms/pasemi/dma_lib.c
@@ -530,7 +530,7 @@ int pasemi_dma_init(void)
 		BUG();
 		pr_warn("Can't find DMA controller\n");
 		err = -ENODEV;
-		goto out;
+		goto out_put_iob;
 	}
 	dma_regs = map_onedev(dma_pdev, 0);
 	base_hw_irq = virq_to_hw(dma_pdev->irq);
@@ -617,5 +617,9 @@ int pasemi_dma_init(void)
 out:
 	spin_unlock(&init_lock);
 	return err;
+
+out_put_iob:
+	pci_dev_put(iob_pdev);
+	goto out;
 }
 EXPORT_SYMBOL(pasemi_dma_init);
-- 
2.35.1


^ permalink raw reply related	[flat|nested] 2+ messages in thread

* Re: [PATCH] powerpc/pasemi: Fix PCI device reference leak on error path
  2025-08-29  6:34 [PATCH] powerpc/pasemi: Fix PCI device reference leak on error path Miaoqian Lin
@ 2025-09-02 14:34 ` Markus Elfring
  0 siblings, 0 replies; 2+ messages in thread
From: Markus Elfring @ 2025-09-02 14:34 UTC (permalink / raw)
  To: Miaoqian Lin, linuxppc-dev
  Cc: LKML, Christophe Leroy, Madhavan Srinivasan, Michael Ellerman,
	Nicholas Piggin, Olof Johansson

> Fix iob_pdev reference leak in pasemi_dma_init() when dma_pdev
> allocation fails. Ensure pci_dev_put(iob_pdev) is called on
> both success and error paths.

How do you think about to increase the application of scope-based resource management?


…
> +++ b/arch/powerpc/platforms/pasemi/dma_lib.c
> @@ -530,7 +530,7 @@ int pasemi_dma_init(void)
>  		BUG();
>  		pr_warn("Can't find DMA controller\n");
>  		err = -ENODEV;
> -		goto out;

Is it sufficient to add the function call “pci_dev_put(iob_pdev)”
in this if branch?


> +		goto out_put_iob;
>  	}
>  	dma_regs = map_onedev(dma_pdev, 0);
…

Regards,
Markus

^ permalink raw reply	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2025-09-02 14:34 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2025-08-29  6:34 [PATCH] powerpc/pasemi: Fix PCI device reference leak on error path Miaoqian Lin
2025-09-02 14:34 ` Markus Elfring

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).