[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