[PATCH] media: qcom: iris: guard IRQ handler with runtime PM check
From: Hungyu Lin
Date: Thu Jun 04 2026 - 02:51:56 EST
Use pm_runtime_get_if_in_use() before accessing hardware
registers in the threaded IRQ handler. Skip interrupt processing
when the device is not in use.
Signed-off-by: Hungyu Lin <dennylin0707@xxxxxxxxx>
---
drivers/media/platform/qcom/iris/iris_hfi_common.c | 7 +++++++
1 file changed, 7 insertions(+)
diff --git a/drivers/media/platform/qcom/iris/iris_hfi_common.c b/drivers/media/platform/qcom/iris/iris_hfi_common.c
index 621c66593d88..ffb2e65f90f8 100644
--- a/drivers/media/platform/qcom/iris/iris_hfi_common.c
+++ b/drivers/media/platform/qcom/iris/iris_hfi_common.c
@@ -104,6 +104,11 @@ irqreturn_t iris_hfi_isr_handler(int irq, void *data)
if (!core)
return IRQ_NONE;
+ if (!pm_runtime_get_if_in_use(core->dev)) {
+ enable_irq(irq);
+ return IRQ_HANDLED;
+ }
+
mutex_lock(&core->lock);
pm_runtime_mark_last_busy(core->dev);
iris_vpu_clear_interrupt(core);
@@ -111,6 +116,8 @@ irqreturn_t iris_hfi_isr_handler(int irq, void *data)
core->hfi_response_ops->hfi_response_handler(core);
+ pm_runtime_put_autosuspend(core->dev);
+
if (!iris_vpu_watchdog(core, core->intr_status))
enable_irq(irq);
--
2.34.1