提交 f9576e36 编写于 作者: M Matt Roper

drm/i915/xehp: Support platforms with CCS engines but no RCS

In the past we've always assumed that an RCS engine is present on every
platform.  However now that we have compute engines there may be
platforms that have CCS engines but no RCS, or platforms that are
designed to have both, but have the RCS engine fused off.

Various engine-centric initialization that only needs to be done a
single time for the group of RCS+CCS engines can't rely on being setup
with the RCS now; instead we add a I915_ENGINE_FIRST_RENDER_COMPUTE flag
that will be assigned to a single engine in the group; whichever engine
has this flag will be responsible for some of the general setup
(RCU_MODE programming, initialization of certain workarounds, etc.).
Signed-off-by: NMatt Roper <matthew.d.roper@intel.com>
Reviewed-by: NLucas De Marchi <lucas.demarchi@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20220303223435.2793124-1-matthew.d.roper@intel.com
上级 e1dd8714
...@@ -434,6 +434,11 @@ static int intel_engine_setup(struct intel_gt *gt, enum intel_engine_id id, ...@@ -434,6 +434,11 @@ static int intel_engine_setup(struct intel_gt *gt, enum intel_engine_id id,
if (GRAPHICS_VER(i915) == 12 && engine->class == RENDER_CLASS) if (GRAPHICS_VER(i915) == 12 && engine->class == RENDER_CLASS)
engine->props.preempt_timeout_ms = 0; engine->props.preempt_timeout_ms = 0;
if ((engine->class == COMPUTE_CLASS && !RCS_MASK(engine->gt) &&
__ffs(CCS_MASK(engine->gt)) == engine->instance) ||
engine->class == RENDER_CLASS)
engine->flags |= I915_ENGINE_FIRST_RENDER_COMPUTE;
/* features common between engines sharing EUs */ /* features common between engines sharing EUs */
if (engine->class == RENDER_CLASS || engine->class == COMPUTE_CLASS) { if (engine->class == RENDER_CLASS || engine->class == COMPUTE_CLASS) {
engine->flags |= I915_ENGINE_HAS_RCS_REG_STATE; engine->flags |= I915_ENGINE_HAS_RCS_REG_STATE;
......
...@@ -97,6 +97,7 @@ struct i915_ctx_workarounds { ...@@ -97,6 +97,7 @@ struct i915_ctx_workarounds {
#define I915_MAX_VCS 8 #define I915_MAX_VCS 8
#define I915_MAX_VECS 4 #define I915_MAX_VECS 4
#define I915_MAX_CCS 4 #define I915_MAX_CCS 4
#define I915_MAX_RCS 1
/* /*
* Engine IDs definitions. * Engine IDs definitions.
...@@ -526,6 +527,7 @@ struct intel_engine_cs { ...@@ -526,6 +527,7 @@ struct intel_engine_cs {
#define I915_ENGINE_WANT_FORCED_PREEMPTION BIT(8) #define I915_ENGINE_WANT_FORCED_PREEMPTION BIT(8)
#define I915_ENGINE_HAS_RCS_REG_STATE BIT(9) #define I915_ENGINE_HAS_RCS_REG_STATE BIT(9)
#define I915_ENGINE_HAS_EU_PRIORITY BIT(10) #define I915_ENGINE_HAS_EU_PRIORITY BIT(10)
#define I915_ENGINE_FIRST_RENDER_COMPUTE BIT(11)
unsigned int flags; unsigned int flags;
/* /*
......
...@@ -2911,7 +2911,7 @@ static int execlists_resume(struct intel_engine_cs *engine) ...@@ -2911,7 +2911,7 @@ static int execlists_resume(struct intel_engine_cs *engine)
enable_execlists(engine); enable_execlists(engine);
if (engine->class == RENDER_CLASS) if (engine->flags & I915_ENGINE_FIRST_RENDER_COMPUTE)
xehp_enable_ccs_engines(engine); xehp_enable_ccs_engines(engine);
return 0; return 0;
......
...@@ -2633,7 +2633,7 @@ engine_init_workarounds(struct intel_engine_cs *engine, struct i915_wa_list *wal ...@@ -2633,7 +2633,7 @@ engine_init_workarounds(struct intel_engine_cs *engine, struct i915_wa_list *wal
* to a single RCS/CCS engine's workaround list since * to a single RCS/CCS engine's workaround list since
* they're reset as part of the general render domain reset. * they're reset as part of the general render domain reset.
*/ */
if (engine->class == RENDER_CLASS) if (engine->flags & I915_ENGINE_FIRST_RENDER_COMPUTE)
general_render_compute_wa_init(engine, wal); general_render_compute_wa_init(engine, wal);
if (engine->class == RENDER_CLASS) if (engine->class == RENDER_CLASS)
......
...@@ -335,7 +335,7 @@ static int guc_mmio_regset_init(struct temp_regset *regset, ...@@ -335,7 +335,7 @@ static int guc_mmio_regset_init(struct temp_regset *regset,
ret |= GUC_MMIO_REG_ADD(regset, RING_HWS_PGA(base), false); ret |= GUC_MMIO_REG_ADD(regset, RING_HWS_PGA(base), false);
ret |= GUC_MMIO_REG_ADD(regset, RING_IMR(base), false); ret |= GUC_MMIO_REG_ADD(regset, RING_IMR(base), false);
if (engine->class == RENDER_CLASS && if ((engine->flags & I915_ENGINE_FIRST_RENDER_COMPUTE) &&
CCS_MASK(engine->gt)) CCS_MASK(engine->gt))
ret |= GUC_MMIO_REG_ADD(regset, GEN12_RCU_MODE, true); ret |= GUC_MMIO_REG_ADD(regset, GEN12_RCU_MODE, true);
......
...@@ -3616,7 +3616,7 @@ static int guc_resume(struct intel_engine_cs *engine) ...@@ -3616,7 +3616,7 @@ static int guc_resume(struct intel_engine_cs *engine)
setup_hwsp(engine); setup_hwsp(engine);
start_engine(engine); start_engine(engine);
if (engine->class == RENDER_CLASS) if (engine->flags & I915_ENGINE_FIRST_RENDER_COMPUTE)
xehp_enable_ccs_engines(engine); xehp_enable_ccs_engines(engine);
return 0; return 0;
......
...@@ -1237,6 +1237,8 @@ IS_SUBPLATFORM(const struct drm_i915_private *i915, ...@@ -1237,6 +1237,8 @@ IS_SUBPLATFORM(const struct drm_i915_private *i915,
((gt)->info.engine_mask & \ ((gt)->info.engine_mask & \
GENMASK(first__ + count__ - 1, first__)) >> first__; \ GENMASK(first__ + count__ - 1, first__)) >> first__; \
}) })
#define RCS_MASK(gt) \
ENGINE_INSTANCES_MASK(gt, RCS0, I915_MAX_RCS)
#define VDBOX_MASK(gt) \ #define VDBOX_MASK(gt) \
ENGINE_INSTANCES_MASK(gt, VCS0, I915_MAX_VCS) ENGINE_INSTANCES_MASK(gt, VCS0, I915_MAX_VCS)
#define VEBOX_MASK(gt) \ #define VEBOX_MASK(gt) \
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册