[PATCH] irqchip/riscv-aplic: Register syscore operations only once

liu.xuemei1 at zte.com.cn liu.xuemei1 at zte.com.cn
Mon Mar 9 01:11:40 PDT 2026


From: Jessica Liu <liu.xuemei1 at zte.com.cn>

We can have multiple APLIC instances so setup global state
and resgister syscore operations only once.

Fixes: 95a8ddde3660 ("irqchip/riscv-aplic: Preserve APLIC states across suspend/resume")
Signed-off-by: Jessica Liu <liu.xuemei1 at zte.com.cn>
---
 drivers/irqchip/irq-riscv-aplic-main.c | 5 ++++-
 1 file changed, 4 insertions(+), 1 deletion(-)

diff --git a/drivers/irqchip/irq-riscv-aplic-main.c b/drivers/irqchip/irq-riscv-aplic-main.c
index 4495ca26abf5..8299e0da6577 100644
--- a/drivers/irqchip/irq-riscv-aplic-main.c
+++ b/drivers/irqchip/irq-riscv-aplic-main.c
@@ -20,6 +20,7 @@
 #include "irq-riscv-aplic-main.h"

 static LIST_HEAD(aplics);
+static bool aplic_global_setup_done __ro_after_init;

 static void aplic_restore_states(struct aplic_priv *priv)
 {
@@ -375,8 +376,10 @@ static int aplic_probe(struct platform_device *pdev)
 	if (rc)
 		dev_err_probe(dev, rc, "failed to setup APLIC in %s mode\n",
 			      msi_mode ? "MSI" : "direct");
-	else
+	else if (!aplic_global_setup_done) {
 		register_syscore(&aplic_syscore);
+		aplic_global_setup_done = true;
+	}

 #ifdef CONFIG_ACPI
 	if (!acpi_disabled)
-- 
2.27.0



More information about the linux-riscv mailing list