Commit aef61349 authored by Daniele Ceraolo Spurio's avatar Daniele Ceraolo Spurio Committed by Rodrigo Vivi

drm/xe: add GSCCS ring ops

Like the BCS, the GSCCS doesn't have any special HW that needs handling
when emitting commands, so we can re-use the same emit_job code. To make
it clear that this is now a shared low-level function, it has been
renamed to use the "simple" postfix, instead of "copy", to indicate that
it applies to all engines that don't need any additional engine-specific
handling.
Signed-off-by: default avatarDaniele Ceraolo Spurio <daniele.ceraolospurio@intel.com>
Reviewed-by: default avatarMatt Roper <matthew.d.roper@intel.com>
Link: https://lore.kernel.org/r/20230817201831.1583172-5-daniele.ceraolospurio@intel.comSigned-off-by: default avatarRodrigo Vivi <rodrigo.vivi@intel.com>
parent 3d2b5d4e
...@@ -205,7 +205,8 @@ static u32 get_ppgtt_flag(struct xe_sched_job *job) ...@@ -205,7 +205,8 @@ static u32 get_ppgtt_flag(struct xe_sched_job *job)
return !(job->q->flags & EXEC_QUEUE_FLAG_WA) ? BIT(8) : 0; return !(job->q->flags & EXEC_QUEUE_FLAG_WA) ? BIT(8) : 0;
} }
static void __emit_job_gen12_copy(struct xe_sched_job *job, struct xe_lrc *lrc, /* for engines that don't require any special HW handling (no EUs, no aux inval, etc) */
static void __emit_job_gen12_simple(struct xe_sched_job *job, struct xe_lrc *lrc,
u64 batch_addr, u32 seqno) u64 batch_addr, u32 seqno)
{ {
u32 dw[MAX_JOB_SIZE_DW], i = 0; u32 dw[MAX_JOB_SIZE_DW], i = 0;
...@@ -374,6 +375,15 @@ static void emit_migration_job_gen12(struct xe_sched_job *job, ...@@ -374,6 +375,15 @@ static void emit_migration_job_gen12(struct xe_sched_job *job,
xe_lrc_write_ring(lrc, dw, i * sizeof(*dw)); xe_lrc_write_ring(lrc, dw, i * sizeof(*dw));
} }
static void emit_job_gen12_gsc(struct xe_sched_job *job)
{
XE_WARN_ON(job->q->width > 1); /* no parallel submission for GSCCS */
__emit_job_gen12_simple(job, job->q->lrc,
job->batch_addr[0],
xe_sched_job_seqno(job));
}
static void emit_job_gen12_copy(struct xe_sched_job *job) static void emit_job_gen12_copy(struct xe_sched_job *job)
{ {
int i; int i;
...@@ -385,7 +395,7 @@ static void emit_job_gen12_copy(struct xe_sched_job *job) ...@@ -385,7 +395,7 @@ static void emit_job_gen12_copy(struct xe_sched_job *job)
} }
for (i = 0; i < job->q->width; ++i) for (i = 0; i < job->q->width; ++i)
__emit_job_gen12_copy(job, job->q->lrc + i, __emit_job_gen12_simple(job, job->q->lrc + i,
job->batch_addr[i], job->batch_addr[i],
xe_sched_job_seqno(job)); xe_sched_job_seqno(job));
} }
...@@ -411,6 +421,10 @@ static void emit_job_gen12_render_compute(struct xe_sched_job *job) ...@@ -411,6 +421,10 @@ static void emit_job_gen12_render_compute(struct xe_sched_job *job)
xe_sched_job_seqno(job)); xe_sched_job_seqno(job));
} }
static const struct xe_ring_ops ring_ops_gen12_gsc = {
.emit_job = emit_job_gen12_gsc,
};
static const struct xe_ring_ops ring_ops_gen12_copy = { static const struct xe_ring_ops ring_ops_gen12_copy = {
.emit_job = emit_job_gen12_copy, .emit_job = emit_job_gen12_copy,
}; };
...@@ -427,6 +441,8 @@ const struct xe_ring_ops * ...@@ -427,6 +441,8 @@ const struct xe_ring_ops *
xe_ring_ops_get(struct xe_gt *gt, enum xe_engine_class class) xe_ring_ops_get(struct xe_gt *gt, enum xe_engine_class class)
{ {
switch (class) { switch (class) {
case XE_ENGINE_CLASS_OTHER:
return &ring_ops_gen12_gsc;
case XE_ENGINE_CLASS_COPY: case XE_ENGINE_CLASS_COPY:
return &ring_ops_gen12_copy; return &ring_ops_gen12_copy;
case XE_ENGINE_CLASS_VIDEO_DECODE: case XE_ENGINE_CLASS_VIDEO_DECODE:
......
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