drm/i915/selftests: wait for active idle event in i915_active_unlock_wait
authorAndrzej Hajda <andrzej.hajda@intel.com>
Tue, 5 Dec 2023 13:09:37 +0000 (14:09 +0100)
committerAndrzej Hajda <andrzej.hajda@intel.com>
Fri, 8 Dec 2023 11:19:26 +0000 (12:19 +0100)
commit34880b18733efff60b68d074ff74d018ffc309a7
treea51a06f51e612bbccce98ec31f1925b0521f32ea
parentcf9cb028ac56696ff879af1154c4b2f0b12701fd
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: Andrzej Hajda <andrzej.hajda@intel.com>
Reviewed-by: Andi 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
drivers/gpu/drm/i915/gt/selftest_engine_heartbeat.c