Takashi Iwai 4488c4
From 680ec0549a055eb464dce6ffb4bfb736ef87236e Mon Sep 17 00:00:00 2001
Takashi Iwai 4488c4
From: Christophe JAILLET <christophe.jaillet@wanadoo.fr>
Takashi Iwai 4488c4
Date: Sun, 9 May 2021 21:12:27 +0200
Takashi Iwai 4488c4
Subject: [PATCH] spi: spi-fsl-dspi: Fix a resource leak in an error handling path
Takashi Iwai 4488c4
Git-commit: 680ec0549a055eb464dce6ffb4bfb736ef87236e
Takashi Iwai 4488c4
Patch-mainline: v5.13 or v5.13-rc4 (next release)
Takashi Iwai 4488c4
References: git-fixes
Takashi Iwai 4488c4
Takashi Iwai 4488c4
'dspi_request_dma()' should be undone by a 'dspi_release_dma()' call in the
Takashi Iwai 4488c4
error handling path of the probe function, as already done in the remove
Takashi Iwai 4488c4
function
Takashi Iwai 4488c4
Takashi Iwai 4488c4
Fixes: 90ba37033cb9 ("spi: spi-fsl-dspi: Add DMA support for Vybrid")
Takashi Iwai 4488c4
Signed-off-by: Christophe JAILLET <christophe.jaillet@wanadoo.fr>
Takashi Iwai 4488c4
Reviewed-by: Vladimir Oltean <olteanv@gmail.com>
Takashi Iwai 4488c4
Link: https://lore.kernel.org/r/d51caaac747277a1099ba8dea07acd85435b857e.1620587472.git.christophe.jaillet@wanadoo.fr
Takashi Iwai 4488c4
Signed-off-by: Mark Brown <broonie@kernel.org>
Takashi Iwai 4488c4
Acked-by: Takashi Iwai <tiwai@suse.de>
Takashi Iwai 4488c4
Takashi Iwai 4488c4
---
Takashi Iwai 4488c4
 drivers/spi/spi-fsl-dspi.c | 4 +++-
Takashi Iwai 4488c4
 1 file changed, 3 insertions(+), 1 deletion(-)
Takashi Iwai 4488c4
Takashi Iwai 4488c4
diff --git a/drivers/spi/spi-fsl-dspi.c b/drivers/spi/spi-fsl-dspi.c
Takashi Iwai 4488c4
index 028736687488..fb45e6af6638 100644
Takashi Iwai 4488c4
--- a/drivers/spi/spi-fsl-dspi.c
Takashi Iwai 4488c4
+++ b/drivers/spi/spi-fsl-dspi.c
Takashi Iwai 4488c4
@@ -1375,11 +1375,13 @@ static int dspi_probe(struct platform_device *pdev)
Takashi Iwai 4488c4
 	ret = spi_register_controller(ctlr);
Takashi Iwai 4488c4
 	if (ret != 0) {
Takashi Iwai 4488c4
 		dev_err(&pdev->dev, "Problem registering DSPI ctlr\n");
Takashi Iwai 4488c4
-		goto out_free_irq;
Takashi Iwai 4488c4
+		goto out_release_dma;
Takashi Iwai 4488c4
 	}
Takashi Iwai 4488c4
 
Takashi Iwai 4488c4
 	return ret;
Takashi Iwai 4488c4
 
Takashi Iwai 4488c4
+out_release_dma:
Takashi Iwai 4488c4
+	dspi_release_dma(dspi);
Takashi Iwai 4488c4
 out_free_irq:
Takashi Iwai 4488c4
 	if (dspi->irq)
Takashi Iwai 4488c4
 		free_irq(dspi->irq, dspi);
Takashi Iwai 4488c4
-- 
Takashi Iwai 4488c4
2.26.2
Takashi Iwai 4488c4