Commit ae2f5c00 authored by Chris Wilson's avatar Chris Wilson

drm/i915/execlists: Avoid kicking the submission too early for rescheduling

If the request is still waiting on external fences, it has not yet been
submitted to the HW queue and so we can forgo kicking the submission
tasklet when re-evaluating its priority.

This should have no impact other than reducing the number of tasklet
wakeups under signal heavy workloads (e.g. switching between engines).

v2: Use prebaked container_of()

References: f6322edd ("drm/i915/preemption: Allow preemption between submission ports")
Signed-off-by: default avatarChris Wilson <chris@chris-wilson.co.uk>
Cc: Michał Winiarski <michal.winiarski@intel.com>
Cc: Michel Thierry <michel.thierry@intel.com>
Cc: Mika Kuoppala <mika.kuoppala@linux.intel.com>
Cc: Tvrtko Ursulin <tvrtko.ursulin@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20180326115044.2505-2-chris@chris-wilson.co.ukReviewed-by: default avatarMika Kuoppala <mika.kuoppala@linux.intel.com>
parent 90408713
...@@ -1060,12 +1060,16 @@ static void queue_request(struct intel_engine_cs *engine, ...@@ -1060,12 +1060,16 @@ static void queue_request(struct intel_engine_cs *engine,
list_add_tail(&pt->link, &lookup_priolist(engine, pt, prio)->requests); list_add_tail(&pt->link, &lookup_priolist(engine, pt, prio)->requests);
} }
static void __submit_queue(struct intel_engine_cs *engine, int prio)
{
engine->execlists.queue_priority = prio;
tasklet_hi_schedule(&engine->execlists.tasklet);
}
static void submit_queue(struct intel_engine_cs *engine, int prio) static void submit_queue(struct intel_engine_cs *engine, int prio)
{ {
if (prio > engine->execlists.queue_priority) { if (prio > engine->execlists.queue_priority)
engine->execlists.queue_priority = prio; __submit_queue(engine, prio);
tasklet_hi_schedule(&engine->execlists.tasklet);
}
} }
static void execlists_submit_request(struct i915_request *request) static void execlists_submit_request(struct i915_request *request)
...@@ -1198,7 +1202,10 @@ static void execlists_schedule(struct i915_request *request, int prio) ...@@ -1198,7 +1202,10 @@ static void execlists_schedule(struct i915_request *request, int prio)
__list_del_entry(&pt->link); __list_del_entry(&pt->link);
queue_request(engine, pt, prio); queue_request(engine, pt, prio);
} }
submit_queue(engine, prio);
if (prio > engine->execlists.queue_priority &&
i915_sw_fence_done(&pt_to_request(pt)->submit))
__submit_queue(engine, prio);
} }
spin_unlock_irq(&engine->timeline->lock); spin_unlock_irq(&engine->timeline->lock);
......
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