Commit 90a79a91 authored by Tvrtko Ursulin's avatar Tvrtko Ursulin Committed by Daniel Vetter

drm/i915: Handle async cancellation in sentinel assert

With the watchdog cancelling requests asynchronously to preempt-to-busy we
need to relax one assert making it apply only to requests not in error.

v2:
 * Check against the correct request!

v3:
 * Simplify the check to avoid the question of when to sample the fence
   error vs sentinel bit.
Signed-off-by: default avatarTvrtko Ursulin <tvrtko.ursulin@intel.com>
Reviewed-by: default avatarMatthew Auld <matthew.auld@intel.com>
Signed-off-by: default avatarDaniel Vetter <daniel.vetter@ffwll.ch>
Link: https://patchwork.freedesktop.org/patch/msgid/20210324121335.2307063-5-tvrtko.ursulin@linux.intel.com
parent 8f922e42
...@@ -757,9 +757,8 @@ assert_pending_valid(const struct intel_engine_execlists *execlists, ...@@ -757,9 +757,8 @@ assert_pending_valid(const struct intel_engine_execlists *execlists,
{ {
struct intel_engine_cs *engine = struct intel_engine_cs *engine =
container_of(execlists, typeof(*engine), execlists); container_of(execlists, typeof(*engine), execlists);
struct i915_request * const *port, *rq; struct i915_request * const *port, *rq, *prev = NULL;
struct intel_context *ce = NULL; struct intel_context *ce = NULL;
bool sentinel = false;
u32 ccid = -1; u32 ccid = -1;
trace_ports(execlists, msg, execlists->pending); trace_ports(execlists, msg, execlists->pending);
...@@ -809,15 +808,20 @@ assert_pending_valid(const struct intel_engine_execlists *execlists, ...@@ -809,15 +808,20 @@ assert_pending_valid(const struct intel_engine_execlists *execlists,
* Sentinels are supposed to be the last request so they flush * Sentinels are supposed to be the last request so they flush
* the current execution off the HW. Check that they are the only * the current execution off the HW. Check that they are the only
* request in the pending submission. * request in the pending submission.
*
* NB: Due to the async nature of preempt-to-busy and request
* cancellation we need to handle the case where request
* becomes a sentinel in parallel to CSB processing.
*/ */
if (sentinel) { if (prev && i915_request_has_sentinel(prev) &&
!READ_ONCE(prev->fence.error)) {
GEM_TRACE_ERR("%s: context:%llx after sentinel in pending[%zd]\n", GEM_TRACE_ERR("%s: context:%llx after sentinel in pending[%zd]\n",
engine->name, engine->name,
ce->timeline->fence_context, ce->timeline->fence_context,
port - execlists->pending); port - execlists->pending);
return false; return false;
} }
sentinel = i915_request_has_sentinel(rq); prev = rq;
/* /*
* We want virtual requests to only be in the first slot so * We want virtual requests to only be in the first slot so
......
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