Skip to content

Commit 6e062b6

Browse files
committed
drm/i915/execlists: Mark up priority boost on preemption
Record the priority boost we giving to the preempted client or else we may end up in a situation where the priority queue no longer matches the request priority order and so we can end up in an infinite loop of preempting the same pair of requests. Fixes: e9eaf82 ("drm/i915: Priority boost for waiting clients") Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk> Cc: Tvrtko Ursulin <tvrtko.ursulin@intel.com> Reviewed-by: Tvrtko Ursulin <tvrtko.ursulin@intel.com> Link: https://patchwork.freedesktop.org/patch/msgid/20190123135155.21562-1-chris@chris-wilson.co.uk
1 parent 03ca3cf commit 6e062b6

File tree

1 file changed

+4
-0
lines changed

1 file changed

+4
-0
lines changed

drivers/gpu/drm/i915/intel_lrc.c

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -302,6 +302,7 @@ static void __unwind_incomplete_requests(struct intel_engine_cs *engine)
302302
*/
303303
if (!(prio & I915_PRIORITY_NEWCLIENT)) {
304304
prio |= I915_PRIORITY_NEWCLIENT;
305+
active->sched.attr.priority = prio;
305306
list_move_tail(&active->sched.link,
306307
i915_sched_lookup_priolist(engine, prio));
307308
}
@@ -625,6 +626,9 @@ static void execlists_dequeue(struct intel_engine_cs *engine)
625626
int i;
626627

627628
priolist_for_each_request_consume(rq, rn, p, i) {
629+
GEM_BUG_ON(last &&
630+
need_preempt(engine, last, rq_prio(rq)));
631+
628632
/*
629633
* Can we combine this request with the current port?
630634
* It has to be the same context/ringbuffer and not

0 commit comments

Comments
 (0)