提交 c39f51cc 编写于 作者: M Matthew Brost 提交者: John Harrison

drm/i915/guc: Unwind context requests in reverse order

When unwinding requests on a reset context, if other requests in the
context are in the priority list the requests could be resubmitted out
of seqno order. Traverse the list of active requests in reverse and
append to the head of the priority list to fix this.

Fixes: eb5e7da7 ("drm/i915/guc: Reset implementation for new GuC interface")
Signed-off-by: NMatthew Brost <matthew.brost@intel.com>
Reviewed-by: NDaniele Ceraolo Spurio <daniele.ceraolospurio@intel.com>
Cc: <stable@vger.kernel.org>
Signed-off-by: NJohn Harrison <John.C.Harrison@Intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20210909164744.31249-4-matthew.brost@intel.com
上级 669b949c
...@@ -806,9 +806,9 @@ __unwind_incomplete_requests(struct intel_context *ce) ...@@ -806,9 +806,9 @@ __unwind_incomplete_requests(struct intel_context *ce)
spin_lock_irqsave(&sched_engine->lock, flags); spin_lock_irqsave(&sched_engine->lock, flags);
spin_lock(&ce->guc_active.lock); spin_lock(&ce->guc_active.lock);
list_for_each_entry_safe(rq, rn, list_for_each_entry_safe_reverse(rq, rn,
&ce->guc_active.requests, &ce->guc_active.requests,
sched.link) { sched.link) {
if (i915_request_completed(rq)) if (i915_request_completed(rq))
continue; continue;
...@@ -825,7 +825,7 @@ __unwind_incomplete_requests(struct intel_context *ce) ...@@ -825,7 +825,7 @@ __unwind_incomplete_requests(struct intel_context *ce)
} }
GEM_BUG_ON(i915_sched_engine_is_empty(sched_engine)); GEM_BUG_ON(i915_sched_engine_is_empty(sched_engine));
list_add_tail(&rq->sched.link, pl); list_add(&rq->sched.link, pl);
set_bit(I915_FENCE_FLAG_PQUEUE, &rq->fence.flags); set_bit(I915_FENCE_FLAG_PQUEUE, &rq->fence.flags);
spin_lock(&ce->guc_active.lock); spin_lock(&ce->guc_active.lock);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册