Commit 708ea872 authored by Chris Wilson's avatar Chris Wilson Committed by Rodrigo Vivi

drm/i915: Only reset seqno if actually idle

Before we can reset the seqno, we have to be sure the engines are idle.
In debugfs/i915_drop_caches_set, we do wait_for_idle but allow ourselves
to be interrupted. We should only proceed to reset the seqno then if we
were not interrupted, and so also avoid overwriting the error status.

References: https://bugs.freedesktop.org/show_bug.cgi?id=108133
Fixes: 6b048706 ("drm/i915: Forcibly flush unwanted requests in drop-caches")
Signed-off-by: default avatarChris Wilson <chris@chris-wilson.co.uk>
Cc: Joonas Lahtinen <joonas.lahtinen@linux.intel.com>
Reviewed-by: default avatarJoonas Lahtinen <joonas.lahtinen@linux.intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20181004082119.24970-1-chris@chris-wilson.co.uk
(cherry picked from commit 88a83f3c)
Signed-off-by: default avatarRodrigo Vivi <rodrigo.vivi@intel.com>
parent 9b273901
...@@ -4189,7 +4189,7 @@ i915_drop_caches_set(void *data, u64 val) ...@@ -4189,7 +4189,7 @@ i915_drop_caches_set(void *data, u64 val)
I915_WAIT_LOCKED, I915_WAIT_LOCKED,
MAX_SCHEDULE_TIMEOUT); MAX_SCHEDULE_TIMEOUT);
if (val & DROP_RESET_SEQNO) { if (ret == 0 && val & DROP_RESET_SEQNO) {
intel_runtime_pm_get(i915); intel_runtime_pm_get(i915);
ret = i915_gem_set_global_seqno(&i915->drm, 1); ret = i915_gem_set_global_seqno(&i915->drm, 1);
intel_runtime_pm_put(i915); intel_runtime_pm_put(i915);
......
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