* [PATCH 01/20] spi: amlogic-spisg: fix controller deregistration
[not found] <20260409120419.388546-1-johan@kernel.org>
@ 2026-04-09 12:04 ` Johan Hovold
2026-04-09 12:04 ` [PATCH 02/20] spi: aspeed-smc: " Johan Hovold
` (18 subsequent siblings)
19 siblings, 0 replies; 25+ messages in thread
From: Johan Hovold @ 2026-04-09 12:04 UTC (permalink / raw)
To: Mark Brown
Cc: Sunny Luo, Xianwei Zhao, Chin-Ting Kuo, Cédric Le Goater,
Radu Pirea, William Zhang, Kursad Oney, Jonas Gorski, linux-spi,
linux-kernel, Johan Hovold, stable
Make sure to deregister the controller before disabling underlying
resources like clocks during driver unbind.
Fixes: cef9991e04ae ("spi: Add Amlogic SPISG driver")
Cc: stable@vger.kernel.org # 6.17: b8db95529979
Cc: stable@vger.kernel.org # 6.17
Cc: Sunny Luo <sunny.luo@amlogic.com>
Signed-off-by: Johan Hovold <johan@kernel.org>
---
drivers/spi/spi-amlogic-spisg.c | 4 +++-
1 file changed, 3 insertions(+), 1 deletion(-)
diff --git a/drivers/spi/spi-amlogic-spisg.c b/drivers/spi/spi-amlogic-spisg.c
index da8ec35115da..19c5eba412ef 100644
--- a/drivers/spi/spi-amlogic-spisg.c
+++ b/drivers/spi/spi-amlogic-spisg.c
@@ -800,7 +800,7 @@ static int aml_spisg_probe(struct platform_device *pdev)
goto out_clk;
}
- ret = devm_spi_register_controller(dev, ctlr);
+ ret = spi_register_controller(ctlr);
if (ret) {
dev_err(&pdev->dev, "spi controller registration failed\n");
goto out_clk;
@@ -823,6 +823,8 @@ static void aml_spisg_remove(struct platform_device *pdev)
{
struct spisg_device *spisg = platform_get_drvdata(pdev);
+ spi_unregister_controller(spisg->controller);
+
if (!pm_runtime_suspended(&pdev->dev)) {
pinctrl_pm_select_sleep_state(&spisg->pdev->dev);
clk_disable_unprepare(spisg->core);
--
2.52.0
^ permalink raw reply related [flat|nested] 25+ messages in thread
* [PATCH 02/20] spi: aspeed-smc: fix controller deregistration
[not found] <20260409120419.388546-1-johan@kernel.org>
2026-04-09 12:04 ` [PATCH 01/20] spi: amlogic-spisg: fix controller deregistration Johan Hovold
@ 2026-04-09 12:04 ` Johan Hovold
2026-04-09 12:04 ` [PATCH 03/20] spi: at91-usart: " Johan Hovold
` (17 subsequent siblings)
19 siblings, 0 replies; 25+ messages in thread
From: Johan Hovold @ 2026-04-09 12:04 UTC (permalink / raw)
To: Mark Brown
Cc: Sunny Luo, Xianwei Zhao, Chin-Ting Kuo, Cédric Le Goater,
Radu Pirea, William Zhang, Kursad Oney, Jonas Gorski, linux-spi,
linux-kernel, Johan Hovold, stable
Make sure to deregister the controller before disabling it to allow
SPI device drivers to do I/O during deregistration.
Fixes: e3228ed92893 ("spi: spi-mem: Convert Aspeed SMC driver to spi-mem")
Cc: stable@vger.kernel.org # 5.19
Cc: Cédric Le Goater <clg@kaod.org>
Signed-off-by: Johan Hovold <johan@kernel.org>
---
drivers/spi/spi-aspeed-smc.c | 9 ++++++---
1 file changed, 6 insertions(+), 3 deletions(-)
diff --git a/drivers/spi/spi-aspeed-smc.c b/drivers/spi/spi-aspeed-smc.c
index 9c286e534bf0..c21323e07d3c 100644
--- a/drivers/spi/spi-aspeed-smc.c
+++ b/drivers/spi/spi-aspeed-smc.c
@@ -972,7 +972,7 @@ static int aspeed_spi_probe(struct platform_device *pdev)
return -ENOMEM;
aspi = spi_controller_get_devdata(ctlr);
- platform_set_drvdata(pdev, aspi);
+ platform_set_drvdata(pdev, ctlr);
aspi->data = data;
aspi->dev = dev;
@@ -1021,7 +1021,7 @@ static int aspeed_spi_probe(struct platform_device *pdev)
return ret;
}
- ret = devm_spi_register_controller(dev, ctlr);
+ ret = spi_register_controller(ctlr);
if (ret)
dev_err(&pdev->dev, "spi_register_controller failed\n");
@@ -1030,7 +1030,10 @@ static int aspeed_spi_probe(struct platform_device *pdev)
static void aspeed_spi_remove(struct platform_device *pdev)
{
- struct aspeed_spi *aspi = platform_get_drvdata(pdev);
+ struct spi_controller *ctlr = platform_get_drvdata(pdev);
+ struct aspeed_spi *aspi = spi_controller_get_devdata(ctlr);
+
+ spi_unregister_controller(ctlr);
aspeed_spi_enable(aspi, false);
}
--
2.52.0
^ permalink raw reply related [flat|nested] 25+ messages in thread
* [PATCH 03/20] spi: at91-usart: fix controller deregistration
[not found] <20260409120419.388546-1-johan@kernel.org>
2026-04-09 12:04 ` [PATCH 01/20] spi: amlogic-spisg: fix controller deregistration Johan Hovold
2026-04-09 12:04 ` [PATCH 02/20] spi: aspeed-smc: " Johan Hovold
@ 2026-04-09 12:04 ` Johan Hovold
2026-04-09 12:04 ` [PATCH 04/20] spi: atmel: " Johan Hovold
` (16 subsequent siblings)
19 siblings, 0 replies; 25+ messages in thread
From: Johan Hovold @ 2026-04-09 12:04 UTC (permalink / raw)
To: Mark Brown
Cc: Sunny Luo, Xianwei Zhao, Chin-Ting Kuo, Cédric Le Goater,
Radu Pirea, William Zhang, Kursad Oney, Jonas Gorski, linux-spi,
linux-kernel, Johan Hovold, stable, Radu Pirea
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>
---
drivers/spi/spi-at91-usart.c | 8 +++++++-
1 file changed, 7 insertions(+), 1 deletion(-)
diff --git a/drivers/spi/spi-at91-usart.c b/drivers/spi/spi-at91-usart.c
index 76eb3ba75ab1..79edc1cd13c0 100644
--- a/drivers/spi/spi-at91-usart.c
+++ b/drivers/spi/spi-at91-usart.c
@@ -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 = {
--
2.52.0
^ permalink raw reply related [flat|nested] 25+ messages in thread
* [PATCH 04/20] spi: atmel: fix controller deregistration
[not found] <20260409120419.388546-1-johan@kernel.org>
` (2 preceding siblings ...)
2026-04-09 12:04 ` [PATCH 03/20] spi: at91-usart: " Johan Hovold
@ 2026-04-09 12:04 ` Johan Hovold
2026-04-09 12:04 ` [PATCH 05/20] spi: bcm63xx: " Johan Hovold
` (15 subsequent siblings)
19 siblings, 0 replies; 25+ messages in thread
From: Johan Hovold @ 2026-04-09 12:04 UTC (permalink / raw)
To: Mark Brown
Cc: Sunny Luo, Xianwei Zhao, Chin-Ting Kuo, Cédric Le Goater,
Radu Pirea, William Zhang, Kursad Oney, Jonas Gorski, linux-spi,
linux-kernel, Johan Hovold, stable
Make sure to deregister the controller before disabling underlying
resources like clocks during driver unbind.
Fixes: 754ce4f29937 ("[PATCH] SPI: atmel_spi driver")
Cc: stable@vger.kernel.org # 2.6.21
Signed-off-by: Johan Hovold <johan@kernel.org>
---
drivers/spi/spi-atmel.c | 8 +++++++-
1 file changed, 7 insertions(+), 1 deletion(-)
diff --git a/drivers/spi/spi-atmel.c b/drivers/spi/spi-atmel.c
index 445d645585bf..42db85d7ff8e 100644
--- a/drivers/spi/spi-atmel.c
+++ b/drivers/spi/spi-atmel.c
@@ -1654,7 +1654,7 @@ static int atmel_spi_probe(struct platform_device *pdev)
pm_runtime_set_active(&pdev->dev);
pm_runtime_enable(&pdev->dev);
- ret = devm_spi_register_controller(&pdev->dev, host);
+ ret = spi_register_controller(host);
if (ret)
goto out_free_dma;
@@ -1688,8 +1688,12 @@ static void atmel_spi_remove(struct platform_device *pdev)
struct spi_controller *host = platform_get_drvdata(pdev);
struct atmel_spi *as = spi_controller_get_devdata(host);
+ spi_controller_get(host);
+
pm_runtime_get_sync(&pdev->dev);
+ spi_unregister_controller(host);
+
/* reset the hardware and block queue progress */
if (as->use_dma) {
atmel_spi_stop_dma(host);
@@ -1716,6 +1720,8 @@ static void atmel_spi_remove(struct platform_device *pdev)
pm_runtime_put_noidle(&pdev->dev);
pm_runtime_disable(&pdev->dev);
+
+ spi_controller_put(host);
}
static int atmel_spi_runtime_suspend(struct device *dev)
--
2.52.0
^ permalink raw reply related [flat|nested] 25+ messages in thread
* [PATCH 05/20] spi: bcm63xx: fix controller deregistration
[not found] <20260409120419.388546-1-johan@kernel.org>
` (3 preceding siblings ...)
2026-04-09 12:04 ` [PATCH 04/20] spi: atmel: " Johan Hovold
@ 2026-04-09 12:04 ` Johan Hovold
2026-04-09 12:04 ` [PATCH 06/20] spi: bcm63xx-hsspi: " Johan Hovold
` (14 subsequent siblings)
19 siblings, 0 replies; 25+ messages in thread
From: Johan Hovold @ 2026-04-09 12:04 UTC (permalink / raw)
To: Mark Brown
Cc: Sunny Luo, Xianwei Zhao, Chin-Ting Kuo, Cédric Le Goater,
Radu Pirea, William Zhang, Kursad Oney, Jonas Gorski, linux-spi,
linux-kernel, Johan Hovold, stable, Florian Fainelli
Make sure to deregister the controller before disabling underlying
resources like clocks during driver unbind.
Fixes: b42dfed83d95 ("spi: add Broadcom BCM63xx SPI controller driver")
Cc: stable@vger.kernel.org # 3.4
Cc: Florian Fainelli <florian@openwrt.org>
Signed-off-by: Johan Hovold <johan@kernel.org>
---
drivers/spi/spi-bcm63xx.c | 8 +++++++-
1 file changed, 7 insertions(+), 1 deletion(-)
diff --git a/drivers/spi/spi-bcm63xx.c b/drivers/spi/spi-bcm63xx.c
index 47266bb23a33..40cd7efc4b54 100644
--- a/drivers/spi/spi-bcm63xx.c
+++ b/drivers/spi/spi-bcm63xx.c
@@ -602,7 +602,7 @@ static int bcm63xx_spi_probe(struct platform_device *pdev)
goto out_clk_disable;
/* register and we are done */
- ret = devm_spi_register_controller(dev, host);
+ ret = spi_register_controller(host);
if (ret) {
dev_err(dev, "spi register failed\n");
goto out_clk_disable;
@@ -625,11 +625,17 @@ static void bcm63xx_spi_remove(struct platform_device *pdev)
struct spi_controller *host = platform_get_drvdata(pdev);
struct bcm63xx_spi *bs = spi_controller_get_devdata(host);
+ spi_controller_get(host);
+
+ spi_unregister_controller(host);
+
/* reset spi block */
bcm_spi_writeb(bs, 0, SPI_INT_MASK);
/* HW shutdown */
clk_disable_unprepare(bs->clk);
+
+ spi_controller_put(host);
}
static int bcm63xx_spi_suspend(struct device *dev)
--
2.52.0
^ permalink raw reply related [flat|nested] 25+ messages in thread
* [PATCH 06/20] spi: bcm63xx-hsspi: fix controller deregistration
[not found] <20260409120419.388546-1-johan@kernel.org>
` (4 preceding siblings ...)
2026-04-09 12:04 ` [PATCH 05/20] spi: bcm63xx: " Johan Hovold
@ 2026-04-09 12:04 ` Johan Hovold
2026-04-09 12:04 ` [PATCH 07/20] spi: bcmbca-hsspi: " Johan Hovold
` (13 subsequent siblings)
19 siblings, 0 replies; 25+ messages in thread
From: Johan Hovold @ 2026-04-09 12:04 UTC (permalink / raw)
To: Mark Brown
Cc: Sunny Luo, Xianwei Zhao, Chin-Ting Kuo, Cédric Le Goater,
Radu Pirea, William Zhang, Kursad Oney, Jonas Gorski, linux-spi,
linux-kernel, Johan Hovold, stable
Make sure to deregister the controller before disabling underlying
resources like interrupts during driver unbind to allow SPI drivers to
do I/O during deregistration.
Note that clocks were also disabled before the recent commit
e532e21a246d ("spi: bcm63xx-hsspi: Simplify clock handling with
devm_clk_get_enabled()").
Fixes: 7d255695804f ("spi/bcm63xx-hsspi: use devm_register_master()")
Cc: stable@vger.kernel.org # 3.14
Cc: Jonas Gorski <jonas.gorski@gmail.com>
Signed-off-by: Johan Hovold <johan@kernel.org>
---
drivers/spi/spi-bcm63xx-hsspi.c | 8 +++++++-
1 file changed, 7 insertions(+), 1 deletion(-)
diff --git a/drivers/spi/spi-bcm63xx-hsspi.c b/drivers/spi/spi-bcm63xx-hsspi.c
index 266eabd3715b..e935e8ab9cfd 100644
--- a/drivers/spi/spi-bcm63xx-hsspi.c
+++ b/drivers/spi/spi-bcm63xx-hsspi.c
@@ -857,7 +857,7 @@ static int bcm63xx_hsspi_probe(struct platform_device *pdev)
}
/* register and we are done */
- ret = devm_spi_register_controller(dev, host);
+ ret = spi_register_controller(host);
if (ret)
goto out_sysgroup_disable;
@@ -880,9 +880,15 @@ static void bcm63xx_hsspi_remove(struct platform_device *pdev)
struct spi_controller *host = platform_get_drvdata(pdev);
struct bcm63xx_hsspi *bs = spi_controller_get_devdata(host);
+ spi_controller_get(host);
+
+ spi_unregister_controller(host);
+
/* reset the hardware and block queue progress */
__raw_writel(0, bs->regs + HSSPI_INT_MASK_REG);
sysfs_remove_group(&pdev->dev.kobj, &bcm63xx_hsspi_group);
+
+ spi_controller_put(host);
}
#ifdef CONFIG_PM_SLEEP
--
2.52.0
^ permalink raw reply related [flat|nested] 25+ messages in thread
* [PATCH 07/20] spi: bcmbca-hsspi: fix controller deregistration
[not found] <20260409120419.388546-1-johan@kernel.org>
` (5 preceding siblings ...)
2026-04-09 12:04 ` [PATCH 06/20] spi: bcm63xx-hsspi: " Johan Hovold
@ 2026-04-09 12:04 ` Johan Hovold
2026-04-09 12:04 ` [PATCH 08/20] spi: octeon: " Johan Hovold
` (12 subsequent siblings)
19 siblings, 0 replies; 25+ messages in thread
From: Johan Hovold @ 2026-04-09 12:04 UTC (permalink / raw)
To: Mark Brown
Cc: Sunny Luo, Xianwei Zhao, Chin-Ting Kuo, Cédric Le Goater,
Radu Pirea, William Zhang, Kursad Oney, Jonas Gorski, linux-spi,
linux-kernel, Johan Hovold, stable
Make sure to deregister the controller before disabling underlying
resources like interrupts during driver unbind to allow SPI drivers to
do I/O during deregistration.
Note that clocks were also disabled before the recent commit
e532e21a246d ("spi: bcm63xx-hsspi: Simplify clock handling with
devm_clk_get_enabled()").
Fixes: a38a2233f23b ("spi: bcmbca-hsspi: Add driver for newer HSSPI controller")
Cc: stable@vger.kernel.org # 6.3: deb269e0394f
Cc: stable@vger.kernel.org # 6.3
Cc: William Zhang <william.zhang@broadcom.com>
Signed-off-by: Johan Hovold <johan@kernel.org>
---
drivers/spi/spi-bcmbca-hsspi.c | 4 +++-
1 file changed, 3 insertions(+), 1 deletion(-)
diff --git a/drivers/spi/spi-bcmbca-hsspi.c b/drivers/spi/spi-bcmbca-hsspi.c
index 2e22345115fd..09c1472ae4fa 100644
--- a/drivers/spi/spi-bcmbca-hsspi.c
+++ b/drivers/spi/spi-bcmbca-hsspi.c
@@ -538,7 +538,7 @@ static int bcmbca_hsspi_probe(struct platform_device *pdev)
return dev_err_probe(dev, ret, "couldn't register sysfs group\n");
/* register and we are done */
- ret = devm_spi_register_controller(dev, host);
+ ret = spi_register_controller(host);
if (ret)
goto out_sysgroup_disable;
@@ -556,6 +556,8 @@ static void bcmbca_hsspi_remove(struct platform_device *pdev)
struct spi_controller *host = platform_get_drvdata(pdev);
struct bcmbca_hsspi *bs = spi_controller_get_devdata(host);
+ spi_unregister_controller(host);
+
/* reset the hardware and block queue progress */
__raw_writel(0, bs->regs + HSSPI_INT_MASK_REG);
sysfs_remove_group(&pdev->dev.kobj, &bcmbca_hsspi_group);
--
2.52.0
^ permalink raw reply related [flat|nested] 25+ messages in thread
* [PATCH 08/20] spi: octeon: fix controller deregistration
[not found] <20260409120419.388546-1-johan@kernel.org>
` (6 preceding siblings ...)
2026-04-09 12:04 ` [PATCH 07/20] spi: bcmbca-hsspi: " Johan Hovold
@ 2026-04-09 12:04 ` Johan Hovold
2026-04-09 12:04 ` [PATCH 09/20] spi: cavium-thunderx: " Johan Hovold
` (11 subsequent siblings)
19 siblings, 0 replies; 25+ messages in thread
From: Johan Hovold @ 2026-04-09 12:04 UTC (permalink / raw)
To: Mark Brown
Cc: Sunny Luo, Xianwei Zhao, Chin-Ting Kuo, Cédric Le Goater,
Radu Pirea, William Zhang, Kursad Oney, Jonas Gorski, linux-spi,
linux-kernel, Johan Hovold, stable, Jingoo Han
Make sure to deregister the controller before disabling it to avoid
hanging or leaking resources associated with the queue when the queue is
non-empty.
Fixes: 22ad2d8df77d ("spi: octeon: use devm_spi_register_master()")
Cc: stable@vger.kernel.org # 3.13
Cc: Jingoo Han <jg1.han@samsung.com>
Signed-off-by: Johan Hovold <johan@kernel.org>
---
drivers/spi/spi-cavium-octeon.c | 8 +++++++-
1 file changed, 7 insertions(+), 1 deletion(-)
diff --git a/drivers/spi/spi-cavium-octeon.c b/drivers/spi/spi-cavium-octeon.c
index 155085a053a1..b95bfa6a3013 100644
--- a/drivers/spi/spi-cavium-octeon.c
+++ b/drivers/spi/spi-cavium-octeon.c
@@ -54,7 +54,7 @@ static int octeon_spi_probe(struct platform_device *pdev)
host->bits_per_word_mask = SPI_BPW_MASK(8);
host->max_speed_hz = OCTEON_SPI_MAX_CLOCK_HZ;
- err = devm_spi_register_controller(&pdev->dev, host);
+ err = spi_register_controller(host);
if (err) {
dev_err(&pdev->dev, "register host failed: %d\n", err);
goto fail;
@@ -73,8 +73,14 @@ 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[] = {
--
2.52.0
^ permalink raw reply related [flat|nested] 25+ messages in thread
* [PATCH 09/20] spi: cavium-thunderx: fix controller deregistration
[not found] <20260409120419.388546-1-johan@kernel.org>
` (7 preceding siblings ...)
2026-04-09 12:04 ` [PATCH 08/20] spi: octeon: " Johan Hovold
@ 2026-04-09 12:04 ` Johan Hovold
2026-04-09 12:04 ` [PATCH 10/20] spi: coldfire-qspi: " Johan Hovold
` (10 subsequent siblings)
19 siblings, 0 replies; 25+ messages in thread
From: Johan Hovold @ 2026-04-09 12:04 UTC (permalink / raw)
To: Mark Brown
Cc: Sunny Luo, Xianwei Zhao, Chin-Ting Kuo, Cédric Le Goater,
Radu Pirea, William Zhang, Kursad Oney, Jonas Gorski, linux-spi,
linux-kernel, Johan Hovold, stable, Jan Glauber
Make sure to deregister the controller before disabling it to avoid
hanging or leaking resources associated with the queue when the queue
non-empty.
Fixes: 7347a6c7af8d ("spi: octeon: Add ThunderX driver")
Cc: stable@vger.kernel.org # 4.9
Cc: Jan Glauber <jan.glauber@gmail.com>
Signed-off-by: Johan Hovold <johan@kernel.org>
---
drivers/spi/spi-cavium-thunderx.c | 8 +++++++-
1 file changed, 7 insertions(+), 1 deletion(-)
diff --git a/drivers/spi/spi-cavium-thunderx.c b/drivers/spi/spi-cavium-thunderx.c
index 99aac40a1bba..f1a9aa696c87 100644
--- a/drivers/spi/spi-cavium-thunderx.c
+++ b/drivers/spi/spi-cavium-thunderx.c
@@ -70,7 +70,7 @@ static int thunderx_spi_probe(struct pci_dev *pdev,
pci_set_drvdata(pdev, host);
- ret = devm_spi_register_controller(dev, host);
+ ret = spi_register_controller(host);
if (ret)
goto error;
@@ -90,8 +90,14 @@ static void thunderx_spi_remove(struct pci_dev *pdev)
if (!p)
return;
+ spi_controller_get(host);
+
+ spi_unregister_controller(host);
+
/* Put everything in a known state. */
writeq(0, p->register_base + OCTEON_SPI_CFG(p));
+
+ spi_controller_put(host);
}
static const struct pci_device_id thunderx_spi_pci_id_table[] = {
--
2.52.0
^ permalink raw reply related [flat|nested] 25+ messages in thread
* [PATCH 10/20] spi: coldfire-qspi: fix controller deregistration
[not found] <20260409120419.388546-1-johan@kernel.org>
` (8 preceding siblings ...)
2026-04-09 12:04 ` [PATCH 09/20] spi: cavium-thunderx: " Johan Hovold
@ 2026-04-09 12:04 ` Johan Hovold
2026-04-09 12:04 ` [PATCH 11/20] spi: dln2: " Johan Hovold
` (9 subsequent siblings)
19 siblings, 0 replies; 25+ messages in thread
From: Johan Hovold @ 2026-04-09 12:04 UTC (permalink / raw)
To: Mark Brown
Cc: Sunny Luo, Xianwei Zhao, Chin-Ting Kuo, Cédric Le Goater,
Radu Pirea, William Zhang, Kursad Oney, Jonas Gorski, linux-spi,
linux-kernel, Johan Hovold, stable, Steven King
Make sure to deregister the controller before disabling underlying
resources like clocks (via runtime pm) during driver unbind.
Fixes: 34b8c6617366 ("spi: Add Freescale/Motorola Coldfire QSPI driver")
Cc: stable@vger.kernel.org # 2.6.34
Cc: Steven King <sfking@fdwdc.com>
Signed-off-by: Johan Hovold <johan@kernel.org>
---
drivers/spi/spi-coldfire-qspi.c | 10 ++++++++--
1 file changed, 8 insertions(+), 2 deletions(-)
diff --git a/drivers/spi/spi-coldfire-qspi.c b/drivers/spi/spi-coldfire-qspi.c
index fdf37636cb9f..b45f44de85dc 100644
--- a/drivers/spi/spi-coldfire-qspi.c
+++ b/drivers/spi/spi-coldfire-qspi.c
@@ -410,9 +410,9 @@ static int mcfqspi_probe(struct platform_device *pdev)
platform_set_drvdata(pdev, host);
pm_runtime_enable(&pdev->dev);
- status = devm_spi_register_controller(&pdev->dev, host);
+ status = spi_register_controller(host);
if (status) {
- dev_dbg(&pdev->dev, "devm_spi_register_controller failed\n");
+ dev_dbg(&pdev->dev, "failed to register controller\n");
goto fail1;
}
@@ -436,11 +436,17 @@ static void mcfqspi_remove(struct platform_device *pdev)
struct spi_controller *host = platform_get_drvdata(pdev);
struct mcfqspi *mcfqspi = spi_controller_get_devdata(host);
+ spi_controller_get(host);
+
+ spi_unregister_controller(host);
+
pm_runtime_disable(&pdev->dev);
/* disable the hardware (set the baud rate to 0) */
mcfqspi_wr_qmr(mcfqspi, MCFQSPI_QMR_MSTR);
mcfqspi_cs_teardown(mcfqspi);
+
+ spi_controller_put(host);
}
#ifdef CONFIG_PM_SLEEP
--
2.52.0
^ permalink raw reply related [flat|nested] 25+ messages in thread
* [PATCH 11/20] spi: dln2: fix controller deregistration
[not found] <20260409120419.388546-1-johan@kernel.org>
` (9 preceding siblings ...)
2026-04-09 12:04 ` [PATCH 10/20] spi: coldfire-qspi: " Johan Hovold
@ 2026-04-09 12:04 ` Johan Hovold
2026-04-09 12:04 ` [PATCH 12/20] spi: ep93xx: " Johan Hovold
` (8 subsequent siblings)
19 siblings, 0 replies; 25+ messages in thread
From: Johan Hovold @ 2026-04-09 12:04 UTC (permalink / raw)
To: Mark Brown
Cc: Sunny Luo, Xianwei Zhao, Chin-Ting Kuo, Cédric Le Goater,
Radu Pirea, William Zhang, Kursad Oney, Jonas Gorski, linux-spi,
linux-kernel, Johan Hovold, stable, Laurentiu Palcu
Make sure to deregister the controller before disabling it to allow
SPI device drivers to do I/O during deregistration.
Fixes: 3d8c0d749da3 ("spi: add support for DLN-2 USB-SPI adapter")
Cc: stable@vger.kernel.org # 4.0
Cc: Laurentiu Palcu <laurentiu.palcu@intel.com>
Signed-off-by: Johan Hovold <johan@kernel.org>
---
drivers/spi/spi-dln2.c | 8 +++++++-
1 file changed, 7 insertions(+), 1 deletion(-)
diff --git a/drivers/spi/spi-dln2.c b/drivers/spi/spi-dln2.c
index d90282960ab6..392f0d05f508 100644
--- a/drivers/spi/spi-dln2.c
+++ b/drivers/spi/spi-dln2.c
@@ -758,7 +758,7 @@ static int dln2_spi_probe(struct platform_device *pdev)
pm_runtime_set_active(&pdev->dev);
pm_runtime_enable(&pdev->dev);
- ret = devm_spi_register_controller(&pdev->dev, host);
+ ret = spi_register_controller(host);
if (ret < 0) {
dev_err(&pdev->dev, "Failed to register host\n");
goto exit_register;
@@ -783,10 +783,16 @@ static void dln2_spi_remove(struct platform_device *pdev)
struct spi_controller *host = platform_get_drvdata(pdev);
struct dln2_spi *dln2 = spi_controller_get_devdata(host);
+ spi_controller_get(host);
+
+ spi_unregister_controller(host);
+
pm_runtime_disable(&pdev->dev);
if (dln2_spi_enable(dln2, false) < 0)
dev_err(&pdev->dev, "Failed to disable SPI module\n");
+
+ spi_controller_put(host);
}
#ifdef CONFIG_PM_SLEEP
--
2.52.0
^ permalink raw reply related [flat|nested] 25+ messages in thread
* [PATCH 12/20] spi: ep93xx: fix controller deregistration
[not found] <20260409120419.388546-1-johan@kernel.org>
` (10 preceding siblings ...)
2026-04-09 12:04 ` [PATCH 11/20] spi: dln2: " Johan Hovold
@ 2026-04-09 12:04 ` Johan Hovold
2026-04-09 12:04 ` [PATCH 13/20] spi: fsl-espi: " Johan Hovold
` (7 subsequent siblings)
19 siblings, 0 replies; 25+ messages in thread
From: Johan Hovold @ 2026-04-09 12:04 UTC (permalink / raw)
To: Mark Brown
Cc: Sunny Luo, Xianwei Zhao, Chin-Ting Kuo, Cédric Le Goater,
Radu Pirea, William Zhang, Kursad Oney, Jonas Gorski, linux-spi,
linux-kernel, Johan Hovold, stable
Make sure to deregister the controller before releasing underlying
resources like DMA during driver unbind.
Fixes: 011f23a3c2f2 ("spi/ep93xx: implemented driver for Cirrus EP93xx SPI controller")
Cc: stable@vger.kernel.org # 2.6.35
Signed-off-by: Johan Hovold <johan@kernel.org>
---
drivers/spi/spi-ep93xx.c | 8 +++++++-
1 file changed, 7 insertions(+), 1 deletion(-)
diff --git a/drivers/spi/spi-ep93xx.c b/drivers/spi/spi-ep93xx.c
index 90d5f3ea6508..db50018050e5 100644
--- a/drivers/spi/spi-ep93xx.c
+++ b/drivers/spi/spi-ep93xx.c
@@ -689,7 +689,7 @@ static int ep93xx_spi_probe(struct platform_device *pdev)
/* make sure that the hardware is disabled */
writel(0, espi->mmio + SSPCR1);
- error = devm_spi_register_controller(&pdev->dev, host);
+ error = spi_register_controller(host);
if (error) {
dev_err(&pdev->dev, "failed to register SPI host\n");
goto fail_free_dma;
@@ -713,7 +713,13 @@ static void ep93xx_spi_remove(struct platform_device *pdev)
struct spi_controller *host = platform_get_drvdata(pdev);
struct ep93xx_spi *espi = spi_controller_get_devdata(host);
+ spi_controller_get(host);
+
+ spi_unregister_controller(host);
+
ep93xx_spi_release_dma(espi);
+
+ spi_controller_put(host);
}
static const struct of_device_id ep93xx_spi_of_ids[] = {
--
2.52.0
^ permalink raw reply related [flat|nested] 25+ messages in thread
* [PATCH 13/20] spi: fsl-espi: fix controller deregistration
[not found] <20260409120419.388546-1-johan@kernel.org>
` (11 preceding siblings ...)
2026-04-09 12:04 ` [PATCH 12/20] spi: ep93xx: " Johan Hovold
@ 2026-04-09 12:04 ` Johan Hovold
2026-04-09 12:04 ` [PATCH 14/20] spi: fsl: " Johan Hovold
` (6 subsequent siblings)
19 siblings, 0 replies; 25+ messages in thread
From: Johan Hovold @ 2026-04-09 12:04 UTC (permalink / raw)
To: Mark Brown
Cc: Sunny Luo, Xianwei Zhao, Chin-Ting Kuo, Cédric Le Goater,
Radu Pirea, William Zhang, Kursad Oney, Jonas Gorski, linux-spi,
linux-kernel, Johan Hovold, stable, Heiner Kallweit
Make sure to deregister the controller before disabling runtime PM
(which can leave the controller disabled) to allow SPI device drivers to
do I/O during deregistration.
Fixes: e9abb4db8d10 ("spi: fsl-espi: add runtime PM")
Cc: stable@vger.kernel.org # 4.3
Cc: Heiner Kallweit <hkallweit1@gmail.com>
Signed-off-by: Johan Hovold <johan@kernel.org>
---
drivers/spi/spi-fsl-espi.c | 10 +++++++++-
1 file changed, 9 insertions(+), 1 deletion(-)
diff --git a/drivers/spi/spi-fsl-espi.c b/drivers/spi/spi-fsl-espi.c
index 56270f8fdc17..45b9974ae911 100644
--- a/drivers/spi/spi-fsl-espi.c
+++ b/drivers/spi/spi-fsl-espi.c
@@ -718,7 +718,7 @@ static int fsl_espi_probe(struct device *dev, struct resource *mem,
pm_runtime_enable(dev);
pm_runtime_get_sync(dev);
- ret = devm_spi_register_controller(dev, host);
+ ret = spi_register_controller(host);
if (ret < 0)
goto err_pm;
@@ -782,7 +782,15 @@ static int of_fsl_espi_probe(struct platform_device *ofdev)
static void of_fsl_espi_remove(struct platform_device *dev)
{
+ struct spi_controller *host = platform_get_drvdata(dev);
+
+ spi_controller_get(host);
+
+ spi_unregister_controller(host);
+
pm_runtime_disable(&dev->dev);
+
+ spi_controller_put(host);
}
#ifdef CONFIG_PM_SLEEP
--
2.52.0
^ permalink raw reply related [flat|nested] 25+ messages in thread
* [PATCH 14/20] spi: fsl: fix controller deregistration
[not found] <20260409120419.388546-1-johan@kernel.org>
` (12 preceding siblings ...)
2026-04-09 12:04 ` [PATCH 13/20] spi: fsl-espi: " Johan Hovold
@ 2026-04-09 12:04 ` Johan Hovold
2026-04-09 13:11 ` Johan Hovold
2026-04-09 12:04 ` [PATCH 15/20] spi: img-spfi: " Johan Hovold
` (5 subsequent siblings)
19 siblings, 1 reply; 25+ messages in thread
From: Johan Hovold @ 2026-04-09 12:04 UTC (permalink / raw)
To: Mark Brown
Cc: Sunny Luo, Xianwei Zhao, Chin-Ting Kuo, Cédric Le Goater,
Radu Pirea, William Zhang, Kursad Oney, Jonas Gorski, linux-spi,
linux-kernel, Johan Hovold, stable, Heiner Kallweit
Make sure to deregister the controller before releasing underlying
resources like DMA during driver unbind.
Fixes: 4178b6b1b595 ("spi: fsl-(e)spi: migrate to using devm_ functions to simplify cleanup")
Cc: stable@vger.kernel.org # 4.3
Cc: Heiner Kallweit <hkallweit1@gmail.com>
Signed-off-by: Johan Hovold <johan@kernel.org>
---
drivers/spi/spi-fsl-spi.c | 8 +++++++-
1 file changed, 7 insertions(+), 1 deletion(-)
diff --git a/drivers/spi/spi-fsl-spi.c b/drivers/spi/spi-fsl-spi.c
index bf3fc3ce0cc2..2681ed8daf2b 100644
--- a/drivers/spi/spi-fsl-spi.c
+++ b/drivers/spi/spi-fsl-spi.c
@@ -614,7 +614,7 @@ static struct spi_controller *fsl_spi_probe(struct device *dev,
mpc8xxx_spi_write_reg(®_base->mode, regval);
- ret = devm_spi_register_controller(dev, host);
+ ret = spi_register_controller(host);
if (ret < 0)
goto err_probe;
@@ -751,7 +751,13 @@ static void plat_mpc8xxx_spi_remove(struct platform_device *pdev)
struct spi_controller *host = platform_get_drvdata(pdev);
struct mpc8xxx_spi *mpc8xxx_spi = spi_controller_get_devdata(host);
+ spi_controller_get(host);
+
+ spi_unregister_controller(host);
+
fsl_spi_cpm_free(mpc8xxx_spi);
+
+ spi_controller_put(host);
}
MODULE_ALIAS("platform:mpc8xxx_spi");
--
2.52.0
^ permalink raw reply related [flat|nested] 25+ messages in thread
* [PATCH 15/20] spi: img-spfi: fix controller deregistration
[not found] <20260409120419.388546-1-johan@kernel.org>
` (13 preceding siblings ...)
2026-04-09 12:04 ` [PATCH 14/20] spi: fsl: " Johan Hovold
@ 2026-04-09 12:04 ` Johan Hovold
2026-04-09 12:04 ` [PATCH 16/20] spi: lantiq-ssc: " Johan Hovold
` (4 subsequent siblings)
19 siblings, 0 replies; 25+ messages in thread
From: Johan Hovold @ 2026-04-09 12:04 UTC (permalink / raw)
To: Mark Brown
Cc: Sunny Luo, Xianwei Zhao, Chin-Ting Kuo, Cédric Le Goater,
Radu Pirea, William Zhang, Kursad Oney, Jonas Gorski, linux-spi,
linux-kernel, Johan Hovold, stable, Andrew Bresticker
Make sure to deregister the controller before disabling and releasing
underlying resources like clocks and DMA during driver unbind.
Fixes: deba25800a12 ("spi: Add driver for IMG SPFI controller")
Cc: stable@vger.kernel.org # 3.19
Cc: Andrew Bresticker <abrestic@chromium.org>
Signed-off-by: Johan Hovold <johan@kernel.org>
---
drivers/spi/spi-img-spfi.c | 8 +++++++-
1 file changed, 7 insertions(+), 1 deletion(-)
diff --git a/drivers/spi/spi-img-spfi.c b/drivers/spi/spi-img-spfi.c
index 902fb64815c9..57625a3ce2f2 100644
--- a/drivers/spi/spi-img-spfi.c
+++ b/drivers/spi/spi-img-spfi.c
@@ -643,7 +643,7 @@ static int img_spfi_probe(struct platform_device *pdev)
pm_runtime_set_active(spfi->dev);
pm_runtime_enable(spfi->dev);
- ret = devm_spi_register_controller(spfi->dev, host);
+ ret = spi_register_controller(host);
if (ret)
goto disable_pm;
@@ -669,6 +669,10 @@ static void img_spfi_remove(struct platform_device *pdev)
struct spi_controller *host = platform_get_drvdata(pdev);
struct img_spfi *spfi = spi_controller_get_devdata(host);
+ spi_controller_get(host);
+
+ spi_unregister_controller(host);
+
if (spfi->tx_ch)
dma_release_channel(spfi->tx_ch);
if (spfi->rx_ch)
@@ -679,6 +683,8 @@ static void img_spfi_remove(struct platform_device *pdev)
clk_disable_unprepare(spfi->spfi_clk);
clk_disable_unprepare(spfi->sys_clk);
}
+
+ spi_controller_put(host);
}
#ifdef CONFIG_PM
--
2.52.0
^ permalink raw reply related [flat|nested] 25+ messages in thread
* [PATCH 16/20] spi: lantiq-ssc: fix controller deregistration
[not found] <20260409120419.388546-1-johan@kernel.org>
` (14 preceding siblings ...)
2026-04-09 12:04 ` [PATCH 15/20] spi: img-spfi: " Johan Hovold
@ 2026-04-09 12:04 ` Johan Hovold
2026-04-09 12:04 ` [PATCH 17/20] spi: meson-spicc: " Johan Hovold
` (3 subsequent siblings)
19 siblings, 0 replies; 25+ messages in thread
From: Johan Hovold @ 2026-04-09 12:04 UTC (permalink / raw)
To: Mark Brown
Cc: Sunny Luo, Xianwei Zhao, Chin-Ting Kuo, Cédric Le Goater,
Radu Pirea, William Zhang, Kursad Oney, Jonas Gorski, linux-spi,
linux-kernel, Johan Hovold, stable, Hauke Mehrtens
Make sure to deregister the controller before releasing underlying
resources like clocks during driver unbind.
Fixes: 17f84b793c01 ("spi: lantiq-ssc: add support for Lantiq SSC SPI controller")
Cc: stable@vger.kernel.org # 4.11
Cc: Hauke Mehrtens <hauke@hauke-m.de>
Signed-off-by: Johan Hovold <johan@kernel.org>
---
drivers/spi/spi-lantiq-ssc.c | 8 +++++++-
1 file changed, 7 insertions(+), 1 deletion(-)
diff --git a/drivers/spi/spi-lantiq-ssc.c b/drivers/spi/spi-lantiq-ssc.c
index f83cb63c9d0c..75b9af8cb5db 100644
--- a/drivers/spi/spi-lantiq-ssc.c
+++ b/drivers/spi/spi-lantiq-ssc.c
@@ -994,7 +994,7 @@ static int lantiq_ssc_probe(struct platform_device *pdev)
"Lantiq SSC SPI controller (Rev %i, TXFS %u, RXFS %u, DMA %u)\n",
revision, spi->tx_fifo_size, spi->rx_fifo_size, supports_dma);
- err = devm_spi_register_controller(dev, host);
+ err = spi_register_controller(host);
if (err) {
dev_err(dev, "failed to register spi host\n");
goto err_wq_destroy;
@@ -1016,6 +1016,10 @@ static void lantiq_ssc_remove(struct platform_device *pdev)
{
struct lantiq_ssc_spi *spi = platform_get_drvdata(pdev);
+ spi_controller_get(spi->host);
+
+ spi_unregister_controller(spi->host);
+
lantiq_ssc_writel(spi, 0, LTQ_SPI_IRNEN);
lantiq_ssc_writel(spi, 0, LTQ_SPI_CLC);
rx_fifo_flush(spi);
@@ -1024,6 +1028,8 @@ static void lantiq_ssc_remove(struct platform_device *pdev)
destroy_workqueue(spi->wq);
clk_put(spi->fpi_clk);
+
+ spi_controller_put(spi->host);
}
static struct platform_driver lantiq_ssc_driver = {
--
2.52.0
^ permalink raw reply related [flat|nested] 25+ messages in thread
* [PATCH 17/20] spi: meson-spicc: fix controller deregistration
[not found] <20260409120419.388546-1-johan@kernel.org>
` (15 preceding siblings ...)
2026-04-09 12:04 ` [PATCH 16/20] spi: lantiq-ssc: " Johan Hovold
@ 2026-04-09 12:04 ` Johan Hovold
2026-04-09 12:04 ` [PATCH 18/20] spi: microchip-core-qspi: " Johan Hovold
` (2 subsequent siblings)
19 siblings, 0 replies; 25+ messages in thread
From: Johan Hovold @ 2026-04-09 12:04 UTC (permalink / raw)
To: Mark Brown
Cc: Sunny Luo, Xianwei Zhao, Chin-Ting Kuo, Cédric Le Goater,
Radu Pirea, William Zhang, Kursad Oney, Jonas Gorski, linux-spi,
linux-kernel, Johan Hovold, stable, Neil Armstrong
Make sure to deregister the controller before disabling it to allow SPI
device drivers to do I/O during deregistration.
Fixes: 454fa271bc4e ("spi: Add Meson SPICC driver")
Cc: stable@vger.kernel.org # 4.13
Cc: Neil Armstrong <neil.armstrong@linaro.org>
Signed-off-by: Johan Hovold <johan@kernel.org>
---
drivers/spi/spi-meson-spicc.c | 8 +++++++-
1 file changed, 7 insertions(+), 1 deletion(-)
diff --git a/drivers/spi/spi-meson-spicc.c b/drivers/spi/spi-meson-spicc.c
index 57768da3205d..b80f9f457b66 100644
--- a/drivers/spi/spi-meson-spicc.c
+++ b/drivers/spi/spi-meson-spicc.c
@@ -1081,7 +1081,7 @@ static int meson_spicc_probe(struct platform_device *pdev)
}
}
- ret = devm_spi_register_controller(&pdev->dev, host);
+ ret = spi_register_controller(host);
if (ret) {
dev_err(&pdev->dev, "spi registration failed\n");
goto out_host;
@@ -1099,8 +1099,14 @@ static void meson_spicc_remove(struct platform_device *pdev)
{
struct meson_spicc_device *spicc = platform_get_drvdata(pdev);
+ spi_controller_get(spicc->host);
+
+ spi_unregister_controller(spicc->host);
+
/* Disable SPI */
writel(0, spicc->base + SPICC_CONREG);
+
+ spi_controller_put(spicc->host);
}
static const struct meson_spicc_data meson_spicc_gx_data = {
--
2.52.0
^ permalink raw reply related [flat|nested] 25+ messages in thread
* [PATCH 18/20] spi: microchip-core-qspi: fix controller deregistration
[not found] <20260409120419.388546-1-johan@kernel.org>
` (16 preceding siblings ...)
2026-04-09 12:04 ` [PATCH 17/20] spi: meson-spicc: " Johan Hovold
@ 2026-04-09 12:04 ` Johan Hovold
2026-04-09 16:13 ` Conor Dooley
2026-04-09 12:04 ` [PATCH 19/20] spi: microchip-core-spi: " Johan Hovold
2026-04-09 12:04 ` [PATCH 20/20] spi: mpfs: " Johan Hovold
19 siblings, 1 reply; 25+ messages in thread
From: Johan Hovold @ 2026-04-09 12:04 UTC (permalink / raw)
To: Mark Brown
Cc: Sunny Luo, Xianwei Zhao, Chin-Ting Kuo, Cédric Le Goater,
Radu Pirea, William Zhang, Kursad Oney, Jonas Gorski, linux-spi,
linux-kernel, Johan Hovold, stable, Naga Sureshkumar Relli
Make sure to deregister the controller before disabling underlying
resources like interrupts during driver unbind.
Fixes: 8596124c4c1b ("spi: microchip-core-qspi: Add support for microchip fpga qspi controllers")
Cc: stable@vger.kernel.org # 6.1
Cc: Naga Sureshkumar Relli <nagasuresh.relli@microchip.com>
Signed-off-by: Johan Hovold <johan@kernel.org>
---
drivers/spi/spi-microchip-core-qspi.c | 12 ++++++++----
1 file changed, 8 insertions(+), 4 deletions(-)
diff --git a/drivers/spi/spi-microchip-core-qspi.c b/drivers/spi/spi-microchip-core-qspi.c
index aafe6cbf2aea..eab059fb0bc2 100644
--- a/drivers/spi/spi-microchip-core-qspi.c
+++ b/drivers/spi/spi-microchip-core-qspi.c
@@ -692,7 +692,7 @@ static int mchp_coreqspi_probe(struct platform_device *pdev)
return -ENOMEM;
qspi = spi_controller_get_devdata(ctlr);
- platform_set_drvdata(pdev, qspi);
+ platform_set_drvdata(pdev, ctlr);
qspi->regs = devm_platform_ioremap_resource(pdev, 0);
if (IS_ERR(qspi->regs))
@@ -732,7 +732,7 @@ static int mchp_coreqspi_probe(struct platform_device *pdev)
ctlr->num_chipselect = 2;
ctlr->use_gpio_descriptors = true;
- ret = devm_spi_register_controller(&pdev->dev, ctlr);
+ ret = spi_register_controller(ctlr);
if (ret)
return dev_err_probe(&pdev->dev, ret,
"spi_register_controller failed\n");
@@ -742,9 +742,13 @@ static int mchp_coreqspi_probe(struct platform_device *pdev)
static void mchp_coreqspi_remove(struct platform_device *pdev)
{
- struct mchp_coreqspi *qspi = platform_get_drvdata(pdev);
- u32 control = readl_relaxed(qspi->regs + REG_CONTROL);
+ struct spi_controller *ctlr = platform_get_drvdata(pdev);
+ struct mchp_coreqspi *qspi = spi_controller_get_devdata(ctlr);
+ u32 control;
+ spi_unregister_controller(ctlr);
+
+ control = readl_relaxed(qspi->regs + REG_CONTROL);
mchp_coreqspi_disable_ints(qspi);
control &= ~CONTROL_ENABLE;
writel_relaxed(control, qspi->regs + REG_CONTROL);
--
2.52.0
^ permalink raw reply related [flat|nested] 25+ messages in thread
* [PATCH 19/20] spi: microchip-core-spi: fix controller deregistration
[not found] <20260409120419.388546-1-johan@kernel.org>
` (17 preceding siblings ...)
2026-04-09 12:04 ` [PATCH 18/20] spi: microchip-core-qspi: " Johan Hovold
@ 2026-04-09 12:04 ` Johan Hovold
2026-04-09 16:10 ` Conor Dooley
2026-04-09 12:04 ` [PATCH 20/20] spi: mpfs: " Johan Hovold
19 siblings, 1 reply; 25+ messages in thread
From: Johan Hovold @ 2026-04-09 12:04 UTC (permalink / raw)
To: Mark Brown
Cc: Sunny Luo, Xianwei Zhao, Chin-Ting Kuo, Cédric Le Goater,
Radu Pirea, William Zhang, Kursad Oney, Jonas Gorski, linux-spi,
linux-kernel, Johan Hovold, stable, Prajna Rajendra Kumar
Make sure to deregister the controller before disabling underlying
resources like interrupts during driver unbind.
Fixes: 059f545832be ("spi: add support for microchip "soft" spi controller")
Cc: stable@vger.kernel.org # 6.19
Cc: Prajna Rajendra Kumar <prajna.rajendrakumar@microchip.com>
Signed-off-by: Johan Hovold <johan@kernel.org>
---
drivers/spi/spi-microchip-core-spi.c | 4 +++-
1 file changed, 3 insertions(+), 1 deletion(-)
diff --git a/drivers/spi/spi-microchip-core-spi.c b/drivers/spi/spi-microchip-core-spi.c
index a4c128ae391b..be01c178e2b0 100644
--- a/drivers/spi/spi-microchip-core-spi.c
+++ b/drivers/spi/spi-microchip-core-spi.c
@@ -384,7 +384,7 @@ static int mchp_corespi_probe(struct platform_device *pdev)
mchp_corespi_init(host, spi);
- ret = devm_spi_register_controller(dev, host);
+ ret = spi_register_controller(host);
if (ret) {
mchp_corespi_disable_ints(spi);
mchp_corespi_disable(spi);
@@ -399,6 +399,8 @@ static void mchp_corespi_remove(struct platform_device *pdev)
struct spi_controller *host = platform_get_drvdata(pdev);
struct mchp_corespi *spi = spi_controller_get_devdata(host);
+ spi_unregister_controller(host);
+
mchp_corespi_disable_ints(spi);
mchp_corespi_disable(spi);
}
--
2.52.0
^ permalink raw reply related [flat|nested] 25+ messages in thread
* [PATCH 20/20] spi: mpfs: fix controller deregistration
[not found] <20260409120419.388546-1-johan@kernel.org>
` (18 preceding siblings ...)
2026-04-09 12:04 ` [PATCH 19/20] spi: microchip-core-spi: " Johan Hovold
@ 2026-04-09 12:04 ` Johan Hovold
2026-04-09 16:13 ` Conor Dooley
19 siblings, 1 reply; 25+ messages in thread
From: Johan Hovold @ 2026-04-09 12:04 UTC (permalink / raw)
To: Mark Brown
Cc: Sunny Luo, Xianwei Zhao, Chin-Ting Kuo, Cédric Le Goater,
Radu Pirea, William Zhang, Kursad Oney, Jonas Gorski, linux-spi,
linux-kernel, Johan Hovold, stable, Conor Dooley
Make sure to deregister the controller before disabling underlying
resources like interrupts during driver unbind.
Fixes: 9ac8d17694b6 ("spi: add support for microchip fpga spi controllers")
Cc: stable@vger.kernel.org # 6.0
Cc: Conor Dooley <conor.dooley@microchip.com>
Signed-off-by: Johan Hovold <johan@kernel.org>
---
drivers/spi/spi-mpfs.c | 4 +++-
1 file changed, 3 insertions(+), 1 deletion(-)
diff --git a/drivers/spi/spi-mpfs.c b/drivers/spi/spi-mpfs.c
index 64d15a6188ac..989a379b0700 100644
--- a/drivers/spi/spi-mpfs.c
+++ b/drivers/spi/spi-mpfs.c
@@ -574,7 +574,7 @@ static int mpfs_spi_probe(struct platform_device *pdev)
mpfs_spi_init(host, spi);
- ret = devm_spi_register_controller(&pdev->dev, host);
+ ret = spi_register_controller(host);
if (ret) {
mpfs_spi_disable_ints(spi);
mpfs_spi_disable(spi);
@@ -592,6 +592,8 @@ static void mpfs_spi_remove(struct platform_device *pdev)
struct spi_controller *host = platform_get_drvdata(pdev);
struct mpfs_spi *spi = spi_controller_get_devdata(host);
+ spi_unregister_controller(host);
+
mpfs_spi_disable_ints(spi);
mpfs_spi_disable(spi);
}
--
2.52.0
^ permalink raw reply related [flat|nested] 25+ messages in thread
* Re: [PATCH 14/20] spi: fsl: fix controller deregistration
2026-04-09 12:04 ` [PATCH 14/20] spi: fsl: " Johan Hovold
@ 2026-04-09 13:11 ` Johan Hovold
0 siblings, 0 replies; 25+ messages in thread
From: Johan Hovold @ 2026-04-09 13:11 UTC (permalink / raw)
To: Mark Brown
Cc: Sunny Luo, Xianwei Zhao, Chin-Ting Kuo, Cédric Le Goater,
Radu Pirea, William Zhang, Kursad Oney, Jonas Gorski, linux-spi,
linux-kernel, stable, Heiner Kallweit
On Thu, Apr 09, 2026 at 02:04:13PM +0200, Johan Hovold wrote:
> Make sure to deregister the controller before releasing underlying
> resources like DMA during driver unbind.
>
> Fixes: 4178b6b1b595 ("spi: fsl-(e)spi: migrate to using devm_ functions to simplify cleanup")
> Cc: stable@vger.kernel.org # 4.3
> Cc: Heiner Kallweit <hkallweit1@gmail.com>
> Signed-off-by: Johan Hovold <johan@kernel.org>
> @@ -614,7 +614,7 @@ static struct spi_controller *fsl_spi_probe(struct device *dev,
>
> mpc8xxx_spi_write_reg(®_base->mode, regval);
>
> - ret = devm_spi_register_controller(dev, host);
> + ret = spi_register_controller(host);
> if (ret < 0)
> goto err_probe;
>
> @@ -751,7 +751,13 @@ static void plat_mpc8xxx_spi_remove(struct platform_device *pdev)
> struct spi_controller *host = platform_get_drvdata(pdev);
> struct mpc8xxx_spi *mpc8xxx_spi = spi_controller_get_devdata(host);
>
> + spi_controller_get(host);
> +
> + spi_unregister_controller(host);
> +
> fsl_spi_cpm_free(mpc8xxx_spi);
> +
> + spi_controller_put(host);
> }
I missed that this module registers two platform drivers so this patch
will need another spin (reported by Sashiko).
Johan
^ permalink raw reply [flat|nested] 25+ messages in thread
* Re: [PATCH 19/20] spi: microchip-core-spi: fix controller deregistration
2026-04-09 12:04 ` [PATCH 19/20] spi: microchip-core-spi: " Johan Hovold
@ 2026-04-09 16:10 ` Conor Dooley
0 siblings, 0 replies; 25+ messages in thread
From: Conor Dooley @ 2026-04-09 16:10 UTC (permalink / raw)
To: Johan Hovold
Cc: Mark Brown, Sunny Luo, Xianwei Zhao, Chin-Ting Kuo,
Cédric Le Goater, Radu Pirea, William Zhang, Kursad Oney,
Jonas Gorski, linux-spi, linux-kernel, stable,
Prajna Rajendra Kumar
[-- Attachment #1: Type: text/plain, Size: 476 bytes --]
On Thu, Apr 09, 2026 at 02:04:18PM +0200, Johan Hovold wrote:
> Make sure to deregister the controller before disabling underlying
> resources like interrupts during driver unbind.
>
> Fixes: 059f545832be ("spi: add support for microchip "soft" spi controller")
> Cc: stable@vger.kernel.org # 6.19
> Cc: Prajna Rajendra Kumar <prajna.rajendrakumar@microchip.com>
> Signed-off-by: Johan Hovold <johan@kernel.org>
Acked-by: Conor Dooley <conor.dooley@microchip.com>
[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 228 bytes --]
^ permalink raw reply [flat|nested] 25+ messages in thread
* Re: [PATCH 18/20] spi: microchip-core-qspi: fix controller deregistration
2026-04-09 12:04 ` [PATCH 18/20] spi: microchip-core-qspi: " Johan Hovold
@ 2026-04-09 16:13 ` Conor Dooley
2026-04-09 17:27 ` Mark Brown
0 siblings, 1 reply; 25+ messages in thread
From: Conor Dooley @ 2026-04-09 16:13 UTC (permalink / raw)
To: Johan Hovold
Cc: Mark Brown, Sunny Luo, Xianwei Zhao, Chin-Ting Kuo,
Cédric Le Goater, Radu Pirea, William Zhang, Kursad Oney,
Jonas Gorski, linux-spi, linux-kernel, stable,
Naga Sureshkumar Relli
[-- Attachment #1: Type: text/plain, Size: 695 bytes --]
On Thu, Apr 09, 2026 at 02:04:17PM +0200, Johan Hovold wrote:
> Make sure to deregister the controller before disabling underlying
> resources like interrupts during driver unbind.
>
> Fixes: 8596124c4c1b ("spi: microchip-core-qspi: Add support for microchip fpga qspi controllers")
> Cc: stable@vger.kernel.org # 6.1
> Cc: Naga Sureshkumar Relli <nagasuresh.relli@microchip.com>
Where are you getting these CCs from? I am listed as maintainer for this
driver but didn't get CCed, only seeing this because I am CCed on
another patch in the set. Please use get_maintainer.pl.
> Signed-off-by: Johan Hovold <johan@kernel.org>
Acked-by: Conor Dooley <conor.dooley@microchip.com>
[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 228 bytes --]
^ permalink raw reply [flat|nested] 25+ messages in thread
* Re: [PATCH 20/20] spi: mpfs: fix controller deregistration
2026-04-09 12:04 ` [PATCH 20/20] spi: mpfs: " Johan Hovold
@ 2026-04-09 16:13 ` Conor Dooley
0 siblings, 0 replies; 25+ messages in thread
From: Conor Dooley @ 2026-04-09 16:13 UTC (permalink / raw)
To: Johan Hovold
Cc: Mark Brown, Sunny Luo, Xianwei Zhao, Chin-Ting Kuo,
Cédric Le Goater, Radu Pirea, William Zhang, Kursad Oney,
Jonas Gorski, linux-spi, linux-kernel, stable, Conor Dooley
[-- Attachment #1: Type: text/plain, Size: 457 bytes --]
On Thu, Apr 09, 2026 at 02:04:19PM +0200, Johan Hovold wrote:
> Make sure to deregister the controller before disabling underlying
> resources like interrupts during driver unbind.
>
> Fixes: 9ac8d17694b6 ("spi: add support for microchip fpga spi controllers")
> Cc: stable@vger.kernel.org # 6.0
> Cc: Conor Dooley <conor.dooley@microchip.com>
> Signed-off-by: Johan Hovold <johan@kernel.org>
Acked-by: Conor Dooley <conor.dooley@microchip.com>
[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 228 bytes --]
^ permalink raw reply [flat|nested] 25+ messages in thread
* Re: [PATCH 18/20] spi: microchip-core-qspi: fix controller deregistration
2026-04-09 16:13 ` Conor Dooley
@ 2026-04-09 17:27 ` Mark Brown
0 siblings, 0 replies; 25+ messages in thread
From: Mark Brown @ 2026-04-09 17:27 UTC (permalink / raw)
To: Conor Dooley
Cc: Johan Hovold, Sunny Luo, Xianwei Zhao, Chin-Ting Kuo,
Cédric Le Goater, Radu Pirea, William Zhang, Kursad Oney,
Jonas Gorski, linux-spi, linux-kernel, stable,
Naga Sureshkumar Relli
[-- Attachment #1: Type: text/plain, Size: 719 bytes --]
On Thu, Apr 09, 2026 at 05:13:07PM +0100, Conor Dooley wrote:
> On Thu, Apr 09, 2026 at 02:04:17PM +0200, Johan Hovold wrote:
> > Make sure to deregister the controller before disabling underlying
> > resources like interrupts during driver unbind.
> > Fixes: 8596124c4c1b ("spi: microchip-core-qspi: Add support for microchip fpga qspi controllers")
> > Cc: stable@vger.kernel.org # 6.1
> > Cc: Naga Sureshkumar Relli <nagasuresh.relli@microchip.com>
> Where are you getting these CCs from? I am listed as maintainer for this
> driver but didn't get CCed, only seeing this because I am CCed on
> another patch in the set. Please use get_maintainer.pl.
They're the author of the commit referenced in the Fixes: tag.
[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 488 bytes --]
^ permalink raw reply [flat|nested] 25+ messages in thread
end of thread, other threads:[~2026-04-09 17:28 UTC | newest]
Thread overview: 25+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
[not found] <20260409120419.388546-1-johan@kernel.org>
2026-04-09 12:04 ` [PATCH 01/20] spi: amlogic-spisg: fix controller deregistration Johan Hovold
2026-04-09 12:04 ` [PATCH 02/20] spi: aspeed-smc: " Johan Hovold
2026-04-09 12:04 ` [PATCH 03/20] spi: at91-usart: " Johan Hovold
2026-04-09 12:04 ` [PATCH 04/20] spi: atmel: " Johan Hovold
2026-04-09 12:04 ` [PATCH 05/20] spi: bcm63xx: " Johan Hovold
2026-04-09 12:04 ` [PATCH 06/20] spi: bcm63xx-hsspi: " Johan Hovold
2026-04-09 12:04 ` [PATCH 07/20] spi: bcmbca-hsspi: " Johan Hovold
2026-04-09 12:04 ` [PATCH 08/20] spi: octeon: " Johan Hovold
2026-04-09 12:04 ` [PATCH 09/20] spi: cavium-thunderx: " Johan Hovold
2026-04-09 12:04 ` [PATCH 10/20] spi: coldfire-qspi: " Johan Hovold
2026-04-09 12:04 ` [PATCH 11/20] spi: dln2: " Johan Hovold
2026-04-09 12:04 ` [PATCH 12/20] spi: ep93xx: " Johan Hovold
2026-04-09 12:04 ` [PATCH 13/20] spi: fsl-espi: " Johan Hovold
2026-04-09 12:04 ` [PATCH 14/20] spi: fsl: " Johan Hovold
2026-04-09 13:11 ` Johan Hovold
2026-04-09 12:04 ` [PATCH 15/20] spi: img-spfi: " Johan Hovold
2026-04-09 12:04 ` [PATCH 16/20] spi: lantiq-ssc: " Johan Hovold
2026-04-09 12:04 ` [PATCH 17/20] spi: meson-spicc: " Johan Hovold
2026-04-09 12:04 ` [PATCH 18/20] spi: microchip-core-qspi: " Johan Hovold
2026-04-09 16:13 ` Conor Dooley
2026-04-09 17:27 ` Mark Brown
2026-04-09 12:04 ` [PATCH 19/20] spi: microchip-core-spi: " Johan Hovold
2026-04-09 16:10 ` Conor Dooley
2026-04-09 12:04 ` [PATCH 20/20] spi: mpfs: " Johan Hovold
2026-04-09 16:13 ` Conor Dooley
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox