spi: zynqmp-gqspi: Use devm_spi_alloc_host()
authorJinjie Ruan <ruanjinjie@huawei.com>
Mon, 26 Aug 2024 12:14:20 +0000 (20:14 +0800)
committerMark Brown <broonie@kernel.org>
Fri, 30 Aug 2024 14:14:17 +0000 (15:14 +0100)
Use devm_spi_alloc_host() so that there's no need to call
spi_controller_put() in the error path.

Signed-off-by: Jinjie Ruan <ruanjinjie@huawei.com>
Acked-by: Michal Simek <michal.simek@amd.com>
Link: https://patch.msgid.link/20240826121421.3384792-2-ruanjinjie@huawei.com
Signed-off-by: Mark Brown <broonie@kernel.org>
drivers/spi/spi-zynqmp-gqspi.c

index 99524a3c9f382e580d40d4c8b8ad41df09471ab2..0448bcb2b45c5d207842475c139724f2ff1aa899 100644 (file)
@@ -1224,7 +1224,7 @@ static int zynqmp_qspi_probe(struct platform_device *pdev)
        u32 num_cs;
        const struct qspi_platform_data *p_data;
 
-       ctlr = spi_alloc_host(&pdev->dev, sizeof(*xqspi));
+       ctlr = devm_spi_alloc_host(&pdev->dev, sizeof(*xqspi));
        if (!ctlr)
                return -ENOMEM;
 
@@ -1238,29 +1238,25 @@ static int zynqmp_qspi_probe(struct platform_device *pdev)
                xqspi->has_tapdelay = true;
 
        xqspi->regs = devm_platform_ioremap_resource(pdev, 0);
-       if (IS_ERR(xqspi->regs)) {
-               ret = PTR_ERR(xqspi->regs);
-               goto remove_ctlr;
-       }
+       if (IS_ERR(xqspi->regs))
+               return PTR_ERR(xqspi->regs);
 
        xqspi->pclk = devm_clk_get(&pdev->dev, "pclk");
        if (IS_ERR(xqspi->pclk)) {
                dev_err(dev, "pclk clock not found.\n");
-               ret = PTR_ERR(xqspi->pclk);
-               goto remove_ctlr;
+               return PTR_ERR(xqspi->pclk);
        }
 
        xqspi->refclk = devm_clk_get(&pdev->dev, "ref_clk");
        if (IS_ERR(xqspi->refclk)) {
                dev_err(dev, "ref_clk clock not found.\n");
-               ret = PTR_ERR(xqspi->refclk);
-               goto remove_ctlr;
+               return PTR_ERR(xqspi->refclk);
        }
 
        ret = clk_prepare_enable(xqspi->pclk);
        if (ret) {
                dev_err(dev, "Unable to enable APB clock.\n");
-               goto remove_ctlr;
+               return ret;
        }
 
        ret = clk_prepare_enable(xqspi->refclk);
@@ -1346,8 +1342,6 @@ clk_dis_all:
        clk_disable_unprepare(xqspi->refclk);
 clk_dis_pclk:
        clk_disable_unprepare(xqspi->pclk);
-remove_ctlr:
-       spi_controller_put(ctlr);
 
        return ret;
 }