Commit 28066f38 authored by Lucas De Marchi's avatar Lucas De Marchi

drm/i915/lnl: Fix check for TC phy

With MTL adding PICA between the port and the real phy, the path
add for DG2 stopped being followed and newer platforms are simply using
the older path for TC phys. LNL is no different than MTL in this aspect,
so just add it to the mess. In future the phy and port designation and
deciding if it's TC should better be cleaned up.

To make it just a bit better, also change intel_phy_is_snps() to show
this is DG2-only.
Signed-off-by: default avatarLucas De Marchi <lucas.demarchi@intel.com>
Reviewed-by: default avatarGustavo Sousa <gustavo.sousa@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20231026184045.1015655-3-lucas.demarchi@intel.com
parent 10184a8a
...@@ -1784,31 +1784,31 @@ bool intel_phy_is_combo(struct drm_i915_private *dev_priv, enum phy phy) ...@@ -1784,31 +1784,31 @@ bool intel_phy_is_combo(struct drm_i915_private *dev_priv, enum phy phy)
bool intel_phy_is_tc(struct drm_i915_private *dev_priv, enum phy phy) bool intel_phy_is_tc(struct drm_i915_private *dev_priv, enum phy phy)
{ {
/*
* DG2's "TC1", although TC-capable output, doesn't share the same flow
* as other platforms on the display engine side and rather rely on the
* SNPS PHY, that is programmed separately
*/
if (IS_DG2(dev_priv)) if (IS_DG2(dev_priv))
/* DG2's "TC1" output uses a SNPS PHY */
return false; return false;
else if (IS_ALDERLAKE_P(dev_priv) || DISPLAY_VER_FULL(dev_priv) == IP_VER(14, 0))
if (DISPLAY_VER(dev_priv) >= 13)
return phy >= PHY_F && phy <= PHY_I; return phy >= PHY_F && phy <= PHY_I;
else if (IS_TIGERLAKE(dev_priv)) else if (IS_TIGERLAKE(dev_priv))
return phy >= PHY_D && phy <= PHY_I; return phy >= PHY_D && phy <= PHY_I;
else if (IS_ICELAKE(dev_priv)) else if (IS_ICELAKE(dev_priv))
return phy >= PHY_C && phy <= PHY_F; return phy >= PHY_C && phy <= PHY_F;
else
return false; return false;
} }
bool intel_phy_is_snps(struct drm_i915_private *dev_priv, enum phy phy) bool intel_phy_is_snps(struct drm_i915_private *dev_priv, enum phy phy)
{ {
if (phy == PHY_NONE) /*
return false; * For DG2, and for DG2 only, all four "combo" ports and the TC1 port
else if (IS_DG2(dev_priv)) * (PHY E) use Synopsis PHYs. See intel_phy_is_tc().
/* */
* All four "combo" ports and the TC1 port (PHY E) use return IS_DG2(dev_priv) && phy > PHY_NONE && phy <= PHY_E;
* Synopsis PHYs.
*/
return phy <= PHY_E;
return false;
} }
enum phy intel_port_to_phy(struct drm_i915_private *i915, enum port port) enum phy intel_port_to_phy(struct drm_i915_private *i915, enum port port)
......
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