Commit 34880b18 authored by Andrzej Hajda's avatar Andrzej Hajda

drm/i915/selftests: wait for active idle event in i915_active_unlock_wait

After i915_active_unlock_wait i915_active can be still non-idle due
to barrier async handling in signal_irq_work. As a result one can observe
following errors:
bcs0: heartbeat pulse did not flush idle tasks
*ERROR* pulse active pulse_active [i915]:pulse_retire [i915]
*ERROR* pulse    count: 0
*ERROR* pulse    preallocated barriers? no

To prevent it let's wait explicitly for idleness.

v2: wait only in live_idle tests
Signed-off-by: default avatarAndrzej Hajda <andrzej.hajda@intel.com>
Reviewed-by: default avatarAndi Shyti <andi.shyti@linux.intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20231205-selftest_wait_for_active_idle_event-v2-1-1437d0bf9829@intel.com
parent cf9cb028
...@@ -84,7 +84,7 @@ static struct pulse *pulse_create(void) ...@@ -84,7 +84,7 @@ static struct pulse *pulse_create(void)
static void pulse_unlock_wait(struct pulse *p) static void pulse_unlock_wait(struct pulse *p)
{ {
i915_active_unlock_wait(&p->active); wait_var_event_timeout(&p->active, i915_active_is_idle(&p->active), HZ);
} }
static int __live_idle_pulse(struct intel_engine_cs *engine, static int __live_idle_pulse(struct intel_engine_cs *engine,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment