summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChris Wilson <chris@chris-wilson.co.uk>2017-09-21 22:09:03 +0100
committerChris Wilson <chris@chris-wilson.co.uk>2017-09-22 12:47:59 +0100
commita3df2c857c103b1103c9d578d68193a6fbe63c61 (patch)
tree25553efb2c96cf7087995ecd24773c646b2090b8
parentde4d2106f88ad7d98bf3adc602885d1d9071b644 (diff)
downloadop-kernel-dev-a3df2c857c103b1103c9d578d68193a6fbe63c61.zip
op-kernel-dev-a3df2c857c103b1103c9d578d68193a6fbe63c61.tar.gz
drm/i915: Confirm request->global_seqno after spin completion
After we see our target seqno has been completed by the hw, we need to confirm that it still matches the request (as it may have been preempted before the spin completes). If the request no longer matches the target seqno, we need to restart the wait to reacquire that seqno. Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk> Cc: Tvrtko Ursulin <tvrtko.ursulin@intel.com> Cc: Michal Winiarski <michal.winiarski@intel.com> Link: https://patchwork.freedesktop.org/patch/msgid/20170921210903.18337-1-chris@chris-wilson.co.uk Reviewed-by: MichaƂ Winiarski <michal.winiarski@intel.com>
-rw-r--r--drivers/gpu/drm/i915/i915_gem_request.c5
1 files changed, 1 insertions, 4 deletions
diff --git a/drivers/gpu/drm/i915/i915_gem_request.c b/drivers/gpu/drm/i915/i915_gem_request.c
index 813a3b5..289fb08 100644
--- a/drivers/gpu/drm/i915/i915_gem_request.c
+++ b/drivers/gpu/drm/i915/i915_gem_request.c
@@ -1040,12 +1040,9 @@ bool __i915_spin_request(const struct drm_i915_gem_request *req,
irq = atomic_read(&engine->irq_count);
timeout_us += local_clock_us(&cpu);
do {
- if (seqno != i915_gem_request_global_seqno(req))
- break;
-
if (i915_seqno_passed(intel_engine_get_seqno(req->engine),
seqno))
- return true;
+ return seqno == i915_gem_request_global_seqno(req);
/* Seqno are meant to be ordered *before* the interrupt. If
* we see an interrupt without a corresponding seqno advance,
OpenPOWER on IntegriCloud