|
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 |
|