]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
spi: at91-usart: fix controller deregistration
authorJohan Hovold <johan@kernel.org>
Thu, 9 Apr 2026 12:04:02 +0000 (14:04 +0200)
committerMark Brown <broonie@kernel.org>
Thu, 9 Apr 2026 19:08:00 +0000 (20:08 +0100)
Make sure to deregister the controller before disabling and releasing
underlying resources like clocks and DMA during driver unbind.

Fixes: e1892546ff66 ("spi: at91-usart: Add driver for at91-usart as SPI")
Cc: stable@vger.kernel.org # 4.20
Cc: Radu Pirea <radu.pirea@microchip.com>
Signed-off-by: Johan Hovold <johan@kernel.org>
Link: https://patch.msgid.link/20260409120419.388546-4-johan@kernel.org
Signed-off-by: Mark Brown <broonie@kernel.org>
drivers/spi/spi-at91-usart.c

index 76eb3ba75ab18e0ad9a03f01cfbf6d9a72c18c4a..79edc1cd13c0f4010d9e6938dcad89561e2f63df 100644 (file)
@@ -556,7 +556,7 @@ static int at91_usart_spi_probe(struct platform_device *pdev)
        spin_lock_init(&aus->lock);
        init_completion(&aus->xfer_completion);
 
-       ret = devm_spi_register_controller(&pdev->dev, controller);
+       ret = spi_register_controller(controller);
        if (ret)
                goto at91_usart_fail_register_controller;
 
@@ -634,8 +634,14 @@ static void at91_usart_spi_remove(struct platform_device *pdev)
        struct spi_controller *ctlr = platform_get_drvdata(pdev);
        struct at91_usart_spi *aus = spi_controller_get_devdata(ctlr);
 
+       spi_controller_get(ctlr);
+
+       spi_unregister_controller(ctlr);
+
        at91_usart_spi_release_dma(ctlr);
        clk_disable_unprepare(aus->clk);
+
+       spi_controller_put(ctlr);
 }
 
 static const struct dev_pm_ops at91_usart_spi_pm_ops = {