drm/xe: Reorder WAs to consider the platform
Now that number of platforms is growing, it's getting hard to know the workarounds for each platform. Split the entries inside the same table so the workarounds checking IP version are listed first, followed by each platform. Next step when it grows too much is to split in smaller tables. Signed-off-by: Lucas De Marchi <lucas.demarchi@intel.com> Reviewed-by: Matt Roper <matthew.d.roper@intel.com> Link: https://lore.kernel.org/r/20230314003012.2600353-6-lucas.demarchi@intel.com Signed-off-by: Rodrigo Vivi <rodrigo.vivi@intel.com>
This commit is contained in:
parent
6647e2fe23
commit
6b5ccd6360
@ -99,6 +99,24 @@ static const struct xe_rtp_entry gt_was[] = {
|
||||
XE_RTP_ACTIONS(SET(VDBOX_CGCTL3F10(0), IECPUNIT_CLKGATE_DIS)),
|
||||
XE_RTP_ENTRY_FLAG(FOREACH_ENGINE),
|
||||
},
|
||||
{ XE_RTP_NAME("14011059788"),
|
||||
XE_RTP_RULES(GRAPHICS_VERSION_RANGE(1200, 1210)),
|
||||
XE_RTP_ACTIONS(SET(GEN10_DFR_RATIO_EN_AND_CHICKEN, DFR_DISABLE))
|
||||
},
|
||||
|
||||
/* DG1 */
|
||||
|
||||
{ XE_RTP_NAME("1409420604"),
|
||||
XE_RTP_RULES(PLATFORM(DG1)),
|
||||
XE_RTP_ACTIONS(SET(SUBSLICE_UNIT_LEVEL_CLKGATE2, CPSSUNIT_CLKGATE_DIS))
|
||||
},
|
||||
{ XE_RTP_NAME("1408615072"),
|
||||
XE_RTP_RULES(PLATFORM(DG1)),
|
||||
XE_RTP_ACTIONS(SET(UNSLICE_UNIT_LEVEL_CLKGATE2, VSUNIT_CLKGATE_DIS_TGL))
|
||||
},
|
||||
|
||||
/* DG2 */
|
||||
|
||||
{ XE_RTP_NAME("16010515920"),
|
||||
XE_RTP_RULES(SUBPLATFORM(DG2, G10),
|
||||
STEP(A0, B0),
|
||||
@ -162,47 +180,15 @@ static const struct xe_rtp_entry gt_was[] = {
|
||||
XE_RTP_RULES(PLATFORM(DG2)),
|
||||
XE_RTP_ACTIONS(CLR(GEN7_MISCCPCTL, GEN12_DOP_CLOCK_GATE_RENDER_ENABLE))
|
||||
},
|
||||
{ XE_RTP_NAME("14011059788"),
|
||||
XE_RTP_RULES(GRAPHICS_VERSION_RANGE(1200, 1210)),
|
||||
XE_RTP_ACTIONS(SET(GEN10_DFR_RATIO_EN_AND_CHICKEN, DFR_DISABLE))
|
||||
},
|
||||
{ XE_RTP_NAME("1409420604"),
|
||||
XE_RTP_RULES(PLATFORM(DG1)),
|
||||
XE_RTP_ACTIONS(SET(SUBSLICE_UNIT_LEVEL_CLKGATE2, CPSSUNIT_CLKGATE_DIS))
|
||||
},
|
||||
{ XE_RTP_NAME("1408615072"),
|
||||
XE_RTP_RULES(PLATFORM(DG1)),
|
||||
XE_RTP_ACTIONS(SET(UNSLICE_UNIT_LEVEL_CLKGATE2, VSUNIT_CLKGATE_DIS_TGL))
|
||||
},
|
||||
{}
|
||||
};
|
||||
|
||||
static const struct xe_rtp_entry engine_was[] = {
|
||||
{ XE_RTP_NAME("14015227452"),
|
||||
XE_RTP_RULES(PLATFORM(DG2), ENGINE_CLASS(RENDER)),
|
||||
XE_RTP_ACTIONS(SET(GEN9_ROW_CHICKEN4, XEHP_DIS_BBL_SYSPIPE,
|
||||
XE_RTP_ACTION_FLAG(MASKED_REG)))
|
||||
},
|
||||
{ XE_RTP_NAME("1606931601"),
|
||||
XE_RTP_RULES(GRAPHICS_VERSION_RANGE(1200, 1210), ENGINE_CLASS(RENDER)),
|
||||
XE_RTP_ACTIONS(SET(GEN8_ROW_CHICKEN2, GEN12_DISABLE_EARLY_READ,
|
||||
XE_RTP_ACTION_FLAG(MASKED_REG)))
|
||||
},
|
||||
{ XE_RTP_NAME("22010931296, 18011464164, 14010919138"),
|
||||
XE_RTP_RULES(GRAPHICS_VERSION(1200), ENGINE_CLASS(RENDER)),
|
||||
XE_RTP_ACTIONS(SET(GEN7_FF_THREAD_MODE,
|
||||
GEN12_FF_TESSELATION_DOP_GATE_DISABLE))
|
||||
},
|
||||
{ XE_RTP_NAME("14010826681, 1606700617, 22010271021"),
|
||||
XE_RTP_RULES(GRAPHICS_VERSION_RANGE(1200, 1210), ENGINE_CLASS(RENDER)),
|
||||
XE_RTP_ACTIONS(SET(GEN9_CS_DEBUG_MODE1, FF_DOP_CLOCK_GATE_DISABLE,
|
||||
XE_RTP_ACTION_FLAG(MASKED_REG)))
|
||||
},
|
||||
{ XE_RTP_NAME("18019627453"),
|
||||
XE_RTP_RULES(PLATFORM(DG2), ENGINE_CLASS(RENDER)),
|
||||
XE_RTP_ACTIONS(SET(GEN9_CS_DEBUG_MODE1, FF_DOP_CLOCK_GATE_DISABLE,
|
||||
XE_RTP_ACTION_FLAG(MASKED_REG)))
|
||||
},
|
||||
{ XE_RTP_NAME("1409804808"),
|
||||
XE_RTP_RULES(GRAPHICS_VERSION(1200),
|
||||
ENGINE_CLASS(RENDER),
|
||||
@ -217,18 +203,14 @@ static const struct xe_rtp_entry engine_was[] = {
|
||||
XE_RTP_ACTIONS(SET(GEN9_ROW_CHICKEN4, GEN12_DISABLE_TDL_PUSH,
|
||||
XE_RTP_ACTION_FLAG(MASKED_REG)))
|
||||
},
|
||||
{ XE_RTP_NAME("1607297627, 1607030317, 1607186500"),
|
||||
XE_RTP_RULES(PLATFORM(TIGERLAKE), ENGINE_CLASS(RENDER)),
|
||||
XE_RTP_ACTIONS(SET(RING_PSMI_CTL(RENDER_RING_BASE),
|
||||
GEN12_WAIT_FOR_EVENT_POWER_DOWN_DISABLE |
|
||||
GEN8_RC_SEMA_IDLE_MSG_DISABLE,
|
||||
{ XE_RTP_NAME("1606931601"),
|
||||
XE_RTP_RULES(GRAPHICS_VERSION_RANGE(1200, 1210), ENGINE_CLASS(RENDER)),
|
||||
XE_RTP_ACTIONS(SET(GEN8_ROW_CHICKEN2, GEN12_DISABLE_EARLY_READ,
|
||||
XE_RTP_ACTION_FLAG(MASKED_REG)))
|
||||
},
|
||||
{ XE_RTP_NAME("1607297627, 1607030317, 1607186500"),
|
||||
XE_RTP_RULES(PLATFORM(ROCKETLAKE), ENGINE_CLASS(RENDER)),
|
||||
XE_RTP_ACTIONS(SET(RING_PSMI_CTL(RENDER_RING_BASE),
|
||||
GEN12_WAIT_FOR_EVENT_POWER_DOWN_DISABLE |
|
||||
GEN8_RC_SEMA_IDLE_MSG_DISABLE,
|
||||
{ XE_RTP_NAME("14010826681, 1606700617, 22010271021"),
|
||||
XE_RTP_RULES(GRAPHICS_VERSION_RANGE(1200, 1210), ENGINE_CLASS(RENDER)),
|
||||
XE_RTP_ACTIONS(SET(GEN9_CS_DEBUG_MODE1, FF_DOP_CLOCK_GATE_DISABLE,
|
||||
XE_RTP_ACTION_FLAG(MASKED_REG)))
|
||||
},
|
||||
{ XE_RTP_NAME("1406941453"),
|
||||
@ -242,6 +224,39 @@ static const struct xe_rtp_entry engine_was[] = {
|
||||
GEN9_FFSC_PERCTX_PREEMPT_CTRL,
|
||||
XE_RTP_ACTION_FLAG(MASKED_REG)))
|
||||
},
|
||||
|
||||
/* TGL */
|
||||
|
||||
{ XE_RTP_NAME("1607297627, 1607030317, 1607186500"),
|
||||
XE_RTP_RULES(PLATFORM(TIGERLAKE), ENGINE_CLASS(RENDER)),
|
||||
XE_RTP_ACTIONS(SET(RING_PSMI_CTL(RENDER_RING_BASE),
|
||||
GEN12_WAIT_FOR_EVENT_POWER_DOWN_DISABLE |
|
||||
GEN8_RC_SEMA_IDLE_MSG_DISABLE,
|
||||
XE_RTP_ACTION_FLAG(MASKED_REG)))
|
||||
},
|
||||
|
||||
/* RKL */
|
||||
|
||||
{ XE_RTP_NAME("1607297627, 1607030317, 1607186500"),
|
||||
XE_RTP_RULES(PLATFORM(ROCKETLAKE), ENGINE_CLASS(RENDER)),
|
||||
XE_RTP_ACTIONS(SET(RING_PSMI_CTL(RENDER_RING_BASE),
|
||||
GEN12_WAIT_FOR_EVENT_POWER_DOWN_DISABLE |
|
||||
GEN8_RC_SEMA_IDLE_MSG_DISABLE,
|
||||
XE_RTP_ACTION_FLAG(MASKED_REG)))
|
||||
},
|
||||
|
||||
/* DG2 */
|
||||
|
||||
{ XE_RTP_NAME("14015227452"),
|
||||
XE_RTP_RULES(PLATFORM(DG2), ENGINE_CLASS(RENDER)),
|
||||
XE_RTP_ACTIONS(SET(GEN9_ROW_CHICKEN4, XEHP_DIS_BBL_SYSPIPE,
|
||||
XE_RTP_ACTION_FLAG(MASKED_REG)))
|
||||
},
|
||||
{ XE_RTP_NAME("18019627453"),
|
||||
XE_RTP_RULES(PLATFORM(DG2), ENGINE_CLASS(RENDER)),
|
||||
XE_RTP_ACTIONS(SET(GEN9_CS_DEBUG_MODE1, FF_DOP_CLOCK_GATE_DISABLE,
|
||||
XE_RTP_ACTION_FLAG(MASKED_REG)))
|
||||
},
|
||||
{}
|
||||
};
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user