[Intel-gfx] [PATCH 03/11] drm/i915: Wait until the intel_wakeref idle callback is complete

Chris Wilson chris at chris-wilson.co.uk
Sat Nov 16 17:51:31 UTC 2019


When waiting for idle, serialise with any ongoing callback so that it
will have completed before completing the wait.

Signed-off-by: Chris Wilson <chris at chris-wilson.co.uk>
---
 drivers/gpu/drm/i915/intel_wakeref.c | 18 ++++++++++++++++--
 1 file changed, 16 insertions(+), 2 deletions(-)

diff --git a/drivers/gpu/drm/i915/intel_wakeref.c b/drivers/gpu/drm/i915/intel_wakeref.c
index 8084cded62db..1241e3a3c024 100644
--- a/drivers/gpu/drm/i915/intel_wakeref.c
+++ b/drivers/gpu/drm/i915/intel_wakeref.c
@@ -98,10 +98,24 @@ void __intel_wakeref_init(struct intel_wakeref *wf,
 	INIT_WORK(&wf->work, __intel_wakeref_put_work);
 }
 
+static bool is_idle_wait(struct intel_wakeref *wf)
+{
+	bool result;
+
+	if (intel_wakeref_is_active(wf))
+		return false;
+
+	/* serialise with the wf->put() callback; wait until finished */
+	mutex_lock(&wf->mutex);
+	result = !intel_wakeref_is_active(wf);
+	mutex_unlock(&wf->mutex);
+
+	return result;
+}
+
 int intel_wakeref_wait_for_idle(struct intel_wakeref *wf)
 {
-	return wait_var_event_killable(&wf->wakeref,
-				       !intel_wakeref_is_active(wf));
+	return wait_var_event_killable(&wf->wakeref, is_idle_wait(wf));
 }
 
 static void wakeref_auto_timeout(struct timer_list *t)
-- 
2.24.0



More information about the Intel-gfx mailing list