]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
spi: cadence-quadspi: clean up disable runtime pm quirk
authorJohan Hovold <johan@kernel.org>
Tue, 21 Apr 2026 12:53:53 +0000 (14:53 +0200)
committerMark Brown <broonie@kernel.org>
Sun, 26 Apr 2026 23:26:38 +0000 (08:26 +0900)
Commit 30dbc1c8d50f ("spi: cadence-qspi: defer runtime support on
socfpga if reset bit is enabled") fixed a warm reset issue on SoCFPGA by
disabling runtime PM on that platform.

Clean up the quirk implementation by never dropping the runtime PM usage
count on probe instead of sprinkling conditionals throughout the driver
which makes the code unnecessarily hard to read and maintain.

Cc: Khairul Anuar Romli <khairul.anuar.romli@altera.com>
Cc: Adrian Ng Ho Yin <adrianhoyin.ng@altera.com>
Cc: Niravkumar L Rabara <nirav.rabara@altera.com>
Cc: Matthew Gerlach <matthew.gerlach@altera.com>
Signed-off-by: Johan Hovold <johan@kernel.org>
Link: https://patch.msgid.link/20260421125354.1534871-6-johan@kernel.org
Signed-off-by: Mark Brown <broonie@kernel.org>
drivers/spi/spi-cadence-quadspi.c

index 057381e56a7fd5531c215aefec3a25000ba1185c..348236ea503dd60c0bb82f0f2f33477d036d5d1e 100644 (file)
@@ -1478,7 +1478,6 @@ static int cqspi_exec_mem_op(struct spi_mem *mem, const struct spi_mem_op *op)
        int ret;
        struct cqspi_st *cqspi = spi_controller_get_devdata(mem->spi->controller);
        struct device *dev = &cqspi->pdev->dev;
-       const struct cqspi_driver_platdata *ddata = of_device_get_match_data(dev);
 
        if (refcount_read(&cqspi->inflight_ops) == 0)
                return -ENODEV;
@@ -1494,18 +1493,15 @@ static int cqspi_exec_mem_op(struct spi_mem *mem, const struct spi_mem_op *op)
                return -EBUSY;
        }
 
-       if (!(ddata && (ddata->quirks & CQSPI_DISABLE_RUNTIME_PM))) {
-               ret = pm_runtime_resume_and_get(dev);
-               if (ret) {
-                       dev_err(&mem->spi->dev, "resume failed with %d\n", ret);
-                       goto dec_inflight_refcount;
-               }
+       ret = pm_runtime_resume_and_get(dev);
+       if (ret) {
+               dev_err(&mem->spi->dev, "resume failed with %d\n", ret);
+               goto dec_inflight_refcount;
        }
 
        ret = cqspi_mem_process(mem, op);
 
-       if (!(ddata && (ddata->quirks & CQSPI_DISABLE_RUNTIME_PM)))
-               pm_runtime_put_autosuspend(dev);
+       pm_runtime_put_autosuspend(dev);
 
        if (ret)
                dev_err(&mem->spi->dev, "operation failed with %d\n", ret);
@@ -1957,13 +1953,11 @@ static int cqspi_probe(struct platform_device *pdev)
        cqspi->current_cs = -1;
        cqspi->sclk = 0;
 
-       if (!(ddata && (ddata->quirks & CQSPI_DISABLE_RUNTIME_PM))) {
-               pm_runtime_set_autosuspend_delay(dev, CQSPI_AUTOSUSPEND_TIMEOUT);
-               pm_runtime_use_autosuspend(dev);
-               pm_runtime_get_noresume(dev);
-               pm_runtime_set_active(dev);
-               pm_runtime_enable(dev);
-       }
+       pm_runtime_set_autosuspend_delay(dev, CQSPI_AUTOSUSPEND_TIMEOUT);
+       pm_runtime_use_autosuspend(dev);
+       pm_runtime_get_noresume(dev);
+       pm_runtime_set_active(dev);
+       pm_runtime_enable(dev);
 
        host->num_chipselect = cqspi->num_chipselect;
 
@@ -1993,12 +1987,11 @@ release_dma_chan:
        if (cqspi->rx_chan)
                dma_release_channel(cqspi->rx_chan);
 disable_rpm:
-       if (!(ddata && (ddata->quirks & CQSPI_DISABLE_RUNTIME_PM))) {
-               pm_runtime_disable(dev);
-               pm_runtime_set_suspended(dev);
-               pm_runtime_put_noidle(dev);
-               pm_runtime_dont_use_autosuspend(dev);
-       }
+       pm_runtime_disable(dev);
+       pm_runtime_set_suspended(dev);
+       pm_runtime_put_noidle(dev);
+       pm_runtime_dont_use_autosuspend(dev);
+
        cqspi_controller_enable(cqspi, 0);
 disable_clks:
        clk_bulk_disable_unprepare(CLK_QSPI_NUM, cqspi->clks);
@@ -2033,12 +2026,10 @@ static void cqspi_remove(struct platform_device *pdev)
                clk_bulk_disable_unprepare(CLK_QSPI_NUM, cqspi->clks);
        }
 
-       if (!(ddata && (ddata->quirks & CQSPI_DISABLE_RUNTIME_PM))) {
-               pm_runtime_disable(&pdev->dev);
-               pm_runtime_set_suspended(&pdev->dev);
-               pm_runtime_put_noidle(&pdev->dev);
-               pm_runtime_dont_use_autosuspend(&pdev->dev);
-       }
+       pm_runtime_disable(&pdev->dev);
+       pm_runtime_set_suspended(&pdev->dev);
+       pm_runtime_put_noidle(&pdev->dev);
+       pm_runtime_dont_use_autosuspend(&pdev->dev);
 }
 
 static int cqspi_runtime_suspend(struct device *dev)