spi: spi-fsl-dspi: Fix a resource leak in an error handling path

commit 680ec0549a055eb464dce6ffb4bfb736ef87236e upstream.

'dspi_request_dma()' should be undone by a 'dspi_release_dma()' call in the
error handling path of the probe function, as already done in the remove
function

Fixes: 90ba37033c ("spi: spi-fsl-dspi: Add DMA support for Vybrid")
Signed-off-by: Christophe JAILLET <christophe.jaillet@wanadoo.fr>
Reviewed-by: Vladimir Oltean <olteanv@gmail.com>
Link: https://lore.kernel.org/r/d51caaac747277a1099ba8dea07acd85435b857e.1620587472.git.christophe.jaillet@wanadoo.fr
Signed-off-by: Mark Brown <broonie@kernel.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
Christophe JAILLET 2021-05-09 21:12:27 +02:00 committed by Greg Kroah-Hartman
parent 6da24cfc83
commit fe6921e3b8

View File

@ -1375,11 +1375,13 @@ static int dspi_probe(struct platform_device *pdev)
ret = spi_register_controller(ctlr); ret = spi_register_controller(ctlr);
if (ret != 0) { if (ret != 0) {
dev_err(&pdev->dev, "Problem registering DSPI ctlr\n"); dev_err(&pdev->dev, "Problem registering DSPI ctlr\n");
goto out_free_irq; goto out_release_dma;
} }
return ret; return ret;
out_release_dma:
dspi_release_dma(dspi);
out_free_irq: out_free_irq:
if (dspi->irq) if (dspi->irq)
free_irq(dspi->irq, dspi); free_irq(dspi->irq, dspi);