spi: spi-ti-qspi: Free DMA resources
authorTudor Ambarus <tudor.ambarus@microchip.com>
Thu, 18 Feb 2021 13:09:50 +0000 (15:09 +0200)
committerMark Brown <broonie@kernel.org>
Wed, 10 Mar 2021 12:25:09 +0000 (12:25 +0000)
Release the RX channel and free the dma coherent memory when
devm_spi_register_master() fails.

Fixes: 5720ec0a6d26 ("spi: spi-ti-qspi: Add DMA support for QSPI mmap read")
Cc: stable@vger.kernel.org
Signed-off-by: Tudor Ambarus <tudor.ambarus@microchip.com>
Link: https://lore.kernel.org/r/20210218130950.90155-1-tudor.ambarus@microchip.com
Signed-off-by: Mark Brown <broonie@kernel.org>
drivers/spi/spi-ti-qspi.c

index 9417385c092175dc4572e541d111670fcd9d7c04..e06aafe169e0cb5333eb800329154c28196253f1 100644 (file)
@@ -733,6 +733,17 @@ static int ti_qspi_runtime_resume(struct device *dev)
        return 0;
 }
 
+static void ti_qspi_dma_cleanup(struct ti_qspi *qspi)
+{
+       if (qspi->rx_bb_addr)
+               dma_free_coherent(qspi->dev, QSPI_DMA_BUFFER_SIZE,
+                                 qspi->rx_bb_addr,
+                                 qspi->rx_bb_dma_addr);
+
+       if (qspi->rx_chan)
+               dma_release_channel(qspi->rx_chan);
+}
+
 static const struct of_device_id ti_qspi_match[] = {
        {.compatible = "ti,dra7xxx-qspi" },
        {.compatible = "ti,am4372-qspi" },
@@ -886,6 +897,8 @@ no_dma:
        if (!ret)
                return 0;
 
+       ti_qspi_dma_cleanup(qspi);
+
        pm_runtime_disable(&pdev->dev);
 free_master:
        spi_master_put(master);
@@ -904,12 +917,7 @@ static int ti_qspi_remove(struct platform_device *pdev)
        pm_runtime_put_sync(&pdev->dev);
        pm_runtime_disable(&pdev->dev);
 
-       if (qspi->rx_bb_addr)
-               dma_free_coherent(qspi->dev, QSPI_DMA_BUFFER_SIZE,
-                                 qspi->rx_bb_addr,
-                                 qspi->rx_bb_dma_addr);
-       if (qspi->rx_chan)
-               dma_release_channel(qspi->rx_chan);
+       ti_qspi_dma_cleanup(qspi);
 
        return 0;
 }