Commit d2a31d02 authored by Matthew Brost's avatar Matthew Brost Committed by Matt Roper

drm/i915: Update i915_scheduler to operate on i915_sched_engine

Rather passing around an intel_engine_cs in the scheduling code, pass
around a i915_sched_engine.

v3:
 (Jason Ekstrand)
  Add READ_ONCE around rq->engine in lock_sched_engine
Signed-off-by: default avatarMatthew Brost <matthew.brost@intel.com>
Reviewed-by: default avatarJason Ekstrand <jason@jlekstrand.net>
Signed-off-by: default avatarMatt Roper <matthew.d.roper@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20210618010638.98941-8-matthew.brost@intel.com
parent 71ed6011
...@@ -382,7 +382,8 @@ __unwind_incomplete_requests(struct intel_engine_cs *engine) ...@@ -382,7 +382,8 @@ __unwind_incomplete_requests(struct intel_engine_cs *engine)
GEM_BUG_ON(rq_prio(rq) == I915_PRIORITY_INVALID); GEM_BUG_ON(rq_prio(rq) == I915_PRIORITY_INVALID);
if (rq_prio(rq) != prio) { if (rq_prio(rq) != prio) {
prio = rq_prio(rq); prio = rq_prio(rq);
pl = i915_sched_lookup_priolist(engine, prio); pl = i915_sched_lookup_priolist(engine->sched_engine,
prio);
} }
GEM_BUG_ON(i915_sched_engine_is_empty(engine->sched_engine)); GEM_BUG_ON(i915_sched_engine_is_empty(engine->sched_engine));
...@@ -1096,7 +1097,8 @@ static void defer_active(struct intel_engine_cs *engine) ...@@ -1096,7 +1097,8 @@ static void defer_active(struct intel_engine_cs *engine)
if (!rq) if (!rq)
return; return;
defer_request(rq, i915_sched_lookup_priolist(engine, rq_prio(rq))); defer_request(rq, i915_sched_lookup_priolist(engine->sched_engine,
rq_prio(rq)));
} }
static bool static bool
...@@ -2083,7 +2085,7 @@ static void __execlists_unhold(struct i915_request *rq) ...@@ -2083,7 +2085,7 @@ static void __execlists_unhold(struct i915_request *rq)
i915_request_clear_hold(rq); i915_request_clear_hold(rq);
list_move_tail(&rq->sched.link, list_move_tail(&rq->sched.link,
i915_sched_lookup_priolist(rq->engine, i915_sched_lookup_priolist(rq->engine->sched_engine,
rq_prio(rq))); rq_prio(rq)));
set_bit(I915_FENCE_FLAG_PQUEUE, &rq->fence.flags); set_bit(I915_FENCE_FLAG_PQUEUE, &rq->fence.flags);
...@@ -2452,7 +2454,8 @@ static void queue_request(struct intel_engine_cs *engine, ...@@ -2452,7 +2454,8 @@ static void queue_request(struct intel_engine_cs *engine,
{ {
GEM_BUG_ON(!list_empty(&rq->sched.link)); GEM_BUG_ON(!list_empty(&rq->sched.link));
list_add_tail(&rq->sched.link, list_add_tail(&rq->sched.link,
i915_sched_lookup_priolist(engine, rq_prio(rq))); i915_sched_lookup_priolist(engine->sched_engine,
rq_prio(rq)));
set_bit(I915_FENCE_FLAG_PQUEUE, &rq->fence.flags); set_bit(I915_FENCE_FLAG_PQUEUE, &rq->fence.flags);
} }
......
...@@ -503,7 +503,7 @@ static inline void queue_request(struct intel_engine_cs *engine, ...@@ -503,7 +503,7 @@ static inline void queue_request(struct intel_engine_cs *engine,
{ {
GEM_BUG_ON(!list_empty(&rq->sched.link)); GEM_BUG_ON(!list_empty(&rq->sched.link));
list_add_tail(&rq->sched.link, list_add_tail(&rq->sched.link,
i915_sched_lookup_priolist(engine, prio)); i915_sched_lookup_priolist(engine->sched_engine, prio));
set_bit(I915_FENCE_FLAG_PQUEUE, &rq->fence.flags); set_bit(I915_FENCE_FLAG_PQUEUE, &rq->fence.flags);
} }
......
...@@ -61,14 +61,13 @@ static void assert_priolists(struct i915_sched_engine * const sched_engine) ...@@ -61,14 +61,13 @@ static void assert_priolists(struct i915_sched_engine * const sched_engine)
} }
struct list_head * struct list_head *
i915_sched_lookup_priolist(struct intel_engine_cs *engine, int prio) i915_sched_lookup_priolist(struct i915_sched_engine *sched_engine, int prio)
{ {
struct i915_sched_engine * const sched_engine = engine->sched_engine;
struct i915_priolist *p; struct i915_priolist *p;
struct rb_node **parent, *rb; struct rb_node **parent, *rb;
bool first = true; bool first = true;
lockdep_assert_held(&engine->sched_engine->lock); lockdep_assert_held(&sched_engine->lock);
assert_priolists(sched_engine); assert_priolists(sched_engine);
if (unlikely(sched_engine->no_priolist)) if (unlikely(sched_engine->no_priolist))
...@@ -130,13 +129,13 @@ struct sched_cache { ...@@ -130,13 +129,13 @@ struct sched_cache {
struct list_head *priolist; struct list_head *priolist;
}; };
static struct intel_engine_cs * static struct i915_sched_engine *
sched_lock_engine(const struct i915_sched_node *node, lock_sched_engine(struct i915_sched_node *node,
struct intel_engine_cs *locked, struct i915_sched_engine *locked,
struct sched_cache *cache) struct sched_cache *cache)
{ {
const struct i915_request *rq = node_to_request(node); const struct i915_request *rq = node_to_request(node);
struct intel_engine_cs *engine; struct i915_sched_engine *sched_engine;
GEM_BUG_ON(!locked); GEM_BUG_ON(!locked);
...@@ -146,14 +145,14 @@ sched_lock_engine(const struct i915_sched_node *node, ...@@ -146,14 +145,14 @@ sched_lock_engine(const struct i915_sched_node *node,
* engine lock. The simple ploy we use is to take the lock then * engine lock. The simple ploy we use is to take the lock then
* check that the rq still belongs to the newly locked engine. * check that the rq still belongs to the newly locked engine.
*/ */
while (locked != (engine = READ_ONCE(rq->engine))) { while (locked != (sched_engine = READ_ONCE(rq->engine)->sched_engine)) {
spin_unlock(&locked->sched_engine->lock); spin_unlock(&locked->lock);
memset(cache, 0, sizeof(*cache)); memset(cache, 0, sizeof(*cache));
spin_lock(&engine->sched_engine->lock); spin_lock(&sched_engine->lock);
locked = engine; locked = sched_engine;
} }
GEM_BUG_ON(locked != engine); GEM_BUG_ON(locked != sched_engine);
return locked; return locked;
} }
...@@ -161,7 +160,7 @@ static void __i915_schedule(struct i915_sched_node *node, ...@@ -161,7 +160,7 @@ static void __i915_schedule(struct i915_sched_node *node,
const struct i915_sched_attr *attr) const struct i915_sched_attr *attr)
{ {
const int prio = max(attr->priority, node->attr.priority); const int prio = max(attr->priority, node->attr.priority);
struct intel_engine_cs *engine; struct i915_sched_engine *sched_engine;
struct i915_dependency *dep, *p; struct i915_dependency *dep, *p;
struct i915_dependency stack; struct i915_dependency stack;
struct sched_cache cache; struct sched_cache cache;
...@@ -236,23 +235,24 @@ static void __i915_schedule(struct i915_sched_node *node, ...@@ -236,23 +235,24 @@ static void __i915_schedule(struct i915_sched_node *node,
} }
memset(&cache, 0, sizeof(cache)); memset(&cache, 0, sizeof(cache));
engine = node_to_request(node)->engine; sched_engine = node_to_request(node)->engine->sched_engine;
spin_lock(&engine->sched_engine->lock); spin_lock(&sched_engine->lock);
/* Fifo and depth-first replacement ensure our deps execute before us */ /* Fifo and depth-first replacement ensure our deps execute before us */
engine = sched_lock_engine(node, engine, &cache); sched_engine = lock_sched_engine(node, sched_engine, &cache);
list_for_each_entry_safe_reverse(dep, p, &dfs, dfs_link) { list_for_each_entry_safe_reverse(dep, p, &dfs, dfs_link) {
INIT_LIST_HEAD(&dep->dfs_link); INIT_LIST_HEAD(&dep->dfs_link);
node = dep->signaler; node = dep->signaler;
engine = sched_lock_engine(node, engine, &cache); sched_engine = lock_sched_engine(node, sched_engine, &cache);
lockdep_assert_held(&engine->sched_engine->lock); lockdep_assert_held(&sched_engine->lock);
/* Recheck after acquiring the engine->timeline.lock */ /* Recheck after acquiring the engine->timeline.lock */
if (prio <= node->attr.priority || node_signaled(node)) if (prio <= node->attr.priority || node_signaled(node))
continue; continue;
GEM_BUG_ON(node_to_request(node)->engine != engine); GEM_BUG_ON(node_to_request(node)->engine->sched_engine !=
sched_engine);
WRITE_ONCE(node->attr.priority, prio); WRITE_ONCE(node->attr.priority, prio);
...@@ -270,17 +270,17 @@ static void __i915_schedule(struct i915_sched_node *node, ...@@ -270,17 +270,17 @@ static void __i915_schedule(struct i915_sched_node *node,
if (i915_request_in_priority_queue(node_to_request(node))) { if (i915_request_in_priority_queue(node_to_request(node))) {
if (!cache.priolist) if (!cache.priolist)
cache.priolist = cache.priolist =
i915_sched_lookup_priolist(engine, i915_sched_lookup_priolist(sched_engine,
prio); prio);
list_move_tail(&node->link, cache.priolist); list_move_tail(&node->link, cache.priolist);
} }
/* Defer (tasklet) submission until after all of our updates. */ /* Defer (tasklet) submission until after all of our updates. */
if (engine->sched_engine->kick_backend) if (sched_engine->kick_backend)
engine->sched_engine->kick_backend(node_to_request(node), prio); sched_engine->kick_backend(node_to_request(node), prio);
} }
spin_unlock(&engine->sched_engine->lock); spin_unlock(&sched_engine->lock);
} }
void i915_schedule(struct i915_request *rq, const struct i915_sched_attr *attr) void i915_schedule(struct i915_request *rq, const struct i915_sched_attr *attr)
......
...@@ -39,7 +39,7 @@ void i915_schedule(struct i915_request *request, ...@@ -39,7 +39,7 @@ void i915_schedule(struct i915_request *request,
const struct i915_sched_attr *attr); const struct i915_sched_attr *attr);
struct list_head * struct list_head *
i915_sched_lookup_priolist(struct intel_engine_cs *engine, int prio); i915_sched_lookup_priolist(struct i915_sched_engine *sched_engine, int prio);
void __i915_priolist_free(struct i915_priolist *p); void __i915_priolist_free(struct i915_priolist *p);
static inline void i915_priolist_free(struct i915_priolist *p) static inline void i915_priolist_free(struct i915_priolist *p)
......
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