]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
spi: octeon: switch to managed controller allocation
authorJohan Hovold <johan@kernel.org>
Wed, 29 Apr 2026 09:13:20 +0000 (11:13 +0200)
committerMark Brown <broonie@kernel.org>
Mon, 4 May 2026 13:09:21 +0000 (22:09 +0900)
Switch to device managed controller allocation to simplify error
handling and to avoid having to take another reference during
deregistration.

Signed-off-by: Johan Hovold <johan@kernel.org>
Link: https://patch.msgid.link/20260429091333.165363-7-johan@kernel.org
Signed-off-by: Mark Brown <broonie@kernel.org>
drivers/spi/spi-cavium-octeon.c

index b95bfa6a301327dddef1bb0996af921884252558..28c922c7206855447eec08b2d49dbe4835499ca4 100644 (file)
@@ -23,17 +23,15 @@ static int octeon_spi_probe(struct platform_device *pdev)
        struct octeon_spi *p;
        int err = -ENOENT;
 
-       host = spi_alloc_host(&pdev->dev, sizeof(struct octeon_spi));
+       host = devm_spi_alloc_host(&pdev->dev, sizeof(struct octeon_spi));
        if (!host)
                return -ENOMEM;
        p = spi_controller_get_devdata(host);
        platform_set_drvdata(pdev, host);
 
        reg_base = devm_platform_ioremap_resource(pdev, 0);
-       if (IS_ERR(reg_base)) {
-               err = PTR_ERR(reg_base);
-               goto fail;
-       }
+       if (IS_ERR(reg_base))
+               return PTR_ERR(reg_base);
 
        p->register_base = reg_base;
        p->sys_freq = octeon_get_io_clock_rate();
@@ -57,15 +55,12 @@ static int octeon_spi_probe(struct platform_device *pdev)
        err = spi_register_controller(host);
        if (err) {
                dev_err(&pdev->dev, "register host failed: %d\n", err);
-               goto fail;
+               return err;
        }
 
        dev_info(&pdev->dev, "OCTEON SPI bus driver\n");
 
        return 0;
-fail:
-       spi_controller_put(host);
-       return err;
 }
 
 static void octeon_spi_remove(struct platform_device *pdev)
@@ -73,14 +68,10 @@ static void octeon_spi_remove(struct platform_device *pdev)
        struct spi_controller *host = platform_get_drvdata(pdev);
        struct octeon_spi *p = spi_controller_get_devdata(host);
 
-       spi_controller_get(host);
-
        spi_unregister_controller(host);
 
        /* Clear the CSENA* and put everything in a known state. */
        writeq(0, p->register_base + OCTEON_SPI_CFG(p));
-
-       spi_controller_put(host);
 }
 
 static const struct of_device_id octeon_spi_match[] = {