drm/i915/display: Eliminate IS_METEORLAKE checks
Most of the IS_METEORLAKE checks in the display code shouldn't actually be tied to MTL as a platform, but rather to the Xe_LPD+ display IP (which is used in MTL, but may show up again in future platforms). In cases where we're trying to match that specific IP, use a version check against IP_VER(14, 0). For cases where we're just handling new behavior introduced by this IP (but which may also be inherited by future IP as well), use a ver >= 14 check. The one exception here is the stolen memory workaround Wa_13010847436 (which is mislabelled as "Wa_22018444074" in the code). That's truly a MTL-specific issue rather than being tied to any of the IP blocks, so leaving the condition as IS_METEORLAKE is correct there. v2: - cdclk check should be >=, not >. (Gustavo) Signed-off-by: Matt Roper <matthew.d.roper@intel.com> Reviewed-by: Gustavo Sousa <gustavo.sousa@intel.com> Link: https://patchwork.freedesktop.org/patch/msgid/20230821180619.650007-19-matthew.d.roper@intel.com
This commit is contained in:
parent
213454b3af
commit
e388ae97e2
4 changed files with 5 additions and 5 deletions
|
@ -1841,7 +1841,7 @@ static bool cdclk_compute_crawl_and_squash_midpoint(struct drm_i915_private *i91
|
|||
|
||||
static bool pll_enable_wa_needed(struct drm_i915_private *dev_priv)
|
||||
{
|
||||
return ((IS_DG2(dev_priv) || IS_METEORLAKE(dev_priv)) &&
|
||||
return ((IS_DG2(dev_priv) || DISPLAY_VER_FULL(dev_priv) == IP_VER(14, 0)) &&
|
||||
dev_priv->display.cdclk.hw.vco > 0 &&
|
||||
HAS_CDCLK_SQUASH(dev_priv));
|
||||
}
|
||||
|
@ -3590,7 +3590,7 @@ static const struct intel_cdclk_funcs i830_cdclk_funcs = {
|
|||
*/
|
||||
void intel_init_cdclk_hooks(struct drm_i915_private *dev_priv)
|
||||
{
|
||||
if (IS_METEORLAKE(dev_priv)) {
|
||||
if (DISPLAY_VER(dev_priv) >= 14) {
|
||||
dev_priv->display.funcs.cdclk = &mtl_cdclk_funcs;
|
||||
dev_priv->display.cdclk.table = mtl_cdclk_table;
|
||||
} else if (IS_DG2(dev_priv)) {
|
||||
|
|
|
@ -31,7 +31,7 @@
|
|||
|
||||
bool intel_is_c10phy(struct drm_i915_private *i915, enum phy phy)
|
||||
{
|
||||
if (IS_METEORLAKE(i915) && (phy < PHY_C))
|
||||
if (DISPLAY_VER_FULL(i915) == IP_VER(14, 0) && phy < PHY_C)
|
||||
return true;
|
||||
|
||||
return false;
|
||||
|
|
|
@ -1767,7 +1767,7 @@ bool intel_phy_is_tc(struct drm_i915_private *dev_priv, enum phy phy)
|
|||
if (IS_DG2(dev_priv))
|
||||
/* DG2's "TC1" output uses a SNPS PHY */
|
||||
return false;
|
||||
else if (IS_ALDERLAKE_P(dev_priv) || IS_METEORLAKE(dev_priv))
|
||||
else if (IS_ALDERLAKE_P(dev_priv) || DISPLAY_VER_FULL(dev_priv) == IP_VER(14, 0))
|
||||
return phy >= PHY_F && phy <= PHY_I;
|
||||
else if (IS_TIGERLAKE(dev_priv))
|
||||
return phy >= PHY_D && phy <= PHY_I;
|
||||
|
|
|
@ -998,7 +998,7 @@ void intel_dmc_init(struct drm_i915_private *i915)
|
|||
|
||||
INIT_WORK(&dmc->work, dmc_load_work_fn);
|
||||
|
||||
if (IS_METEORLAKE(i915)) {
|
||||
if (DISPLAY_VER_FULL(i915) == IP_VER(14, 0)) {
|
||||
dmc->fw_path = MTL_DMC_PATH;
|
||||
dmc->max_fw_size = XELPDP_DMC_MAX_FW_SIZE;
|
||||
} else if (IS_DG2(i915)) {
|
||||
|
|
Loading…
Add table
Reference in a new issue