spi: sprd: Don't skip cleanup in remove's error path
authorUwe Kleine-König <u.kleine-koenig@pengutronix.de>
Tue, 7 Mar 2023 21:14:25 +0000 (22:14 +0100)
committerMark Brown <broonie@kernel.org>
Mon, 20 Mar 2023 13:11:37 +0000 (13:11 +0000)
If pm_runtime_resume_and_get() failed before this change, two error
messages were printed. One directly in sprd_spi_remove() and another
by the device core as the return value is non-zero.

The better handling of a failure to resume the device is to do the
software related cleanup anyhow and only skip hardware accesses.
This leaves the device in an unknown state, but there is nothing that can
be done about that.

Even in the error case, return zero to suppress the device core's error
message.

Signed-off-by: Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
Link: https://lore.kernel.org/r/20230307211426.2331483-2-u.kleine-koenig@pengutronix.de
Signed-off-by: Mark Brown <broonie@kernel.org>
drivers/spi/spi-sprd.c

index 65b8075da4eb50a2a1a57a8f474a9f4c1ee4eb5e..45b69b83a7e40c114b6c989619454801ebaa9f3f 100644 (file)
@@ -1008,17 +1008,17 @@ static int sprd_spi_remove(struct platform_device *pdev)
        struct sprd_spi *ss = spi_controller_get_devdata(sctlr);
        int ret;
 
-       ret = pm_runtime_resume_and_get(ss->dev);
-       if (ret < 0) {
+       ret = pm_runtime_get_sync(ss->dev);
+       if (ret < 0)
                dev_err(ss->dev, "failed to resume SPI controller\n");
-               return ret;
-       }
 
        spi_controller_suspend(sctlr);
 
-       if (ss->dma.enable)
-               sprd_spi_dma_release(ss);
-       clk_disable_unprepare(ss->clk);
+       if (ret >= 0) {
+               if (ss->dma.enable)
+                       sprd_spi_dma_release(ss);
+               clk_disable_unprepare(ss->clk);
+       }
        pm_runtime_put_noidle(&pdev->dev);
        pm_runtime_disable(&pdev->dev);