[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-Id: <20251217-multi_waitq_scm-v11-3-f21e50e792b8@oss.qualcomm.com>
Date: Wed, 17 Dec 2025 20:04:21 +0530
From: Shivendra Pratap <shivendra.pratap@....qualcomm.com>
To: Bjorn Andersson <andersson@...nel.org>,
Konrad Dybcio <konradybcio@...nel.org>
Cc: Bartosz Golaszewski <brgl@...ev.pl>, linux-arm-msm@...r.kernel.org,
linux-kernel@...r.kernel.org,
Unnathi Chalicheemala <unnathi.chalicheemala@....qualcomm.com>,
Shivendra Pratap <shivendra.pratap@....qualcomm.com>,
Mukesh Ojha <mukesh.ojha@....qualcomm.com>,
Bartosz Golaszewski <brgl@...nel.org>
Subject: [PATCH v11 3/3] firmware: qcom_scm: Use TASK_IDLE state in
wait_for_wq_completion()
From: Unnathi Chalicheemala <unnathi.chalicheemala@....qualcomm.com>
When the kernel issues an SMC (Secure Monitor Call) and the firmware
requests the kernel to wait, the waiting thread enters an
uninterruptible (D) state. In case of an extended wait request by the
firmware, any device suspend request, cannot proceed because of the
thread stuck in D state. This blocks the device suspend.
Replace wait_for_completion() with wait_for_completion_state(...,
TASK_IDLE), so that the waiting thread, show up in TASK_IDLE state,
instead of TASK_UNINTERRUPTIBLE (D state). This allows the thread to
block until completion, without blocking the device suspend.
Reviewed-by: Mukesh Ojha <mukesh.ojha@....qualcomm.com>
Reviewed-by: Bartosz Golaszewski <brgl@...nel.org>
Signed-off-by: Unnathi Chalicheemala <unnathi.chalicheemala@....qualcomm.com>
Signed-off-by: Shivendra Pratap <shivendra.pratap@....qualcomm.com>
---
drivers/firmware/qcom/qcom_scm.c | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/drivers/firmware/qcom/qcom_scm.c b/drivers/firmware/qcom/qcom_scm.c
index e16dbf18f731be9b0098dd683f478c8c8fdeaf20..3d8eee354cad55773d9b827ee8e32aab1f192510 100644
--- a/drivers/firmware/qcom/qcom_scm.c
+++ b/drivers/firmware/qcom/qcom_scm.c
@@ -2305,7 +2305,7 @@ int qcom_scm_wait_for_wq_completion(u32 wq_ctx)
if (IS_ERR(wq))
return PTR_ERR(wq);
- wait_for_completion(wq);
+ wait_for_completion_state(wq, TASK_IDLE);
return 0;
}
--
2.34.1
Powered by blists - more mailing lists