> -----Original Message-----
> From: Intel-xe <intel-xe-boun...@lists.freedesktop.org> On Behalf Of Imre Deak
> Sent: Tuesday, 5 August 2025 10.37
> To: intel-gfx@lists.freedesktop.org; intel...@lists.freedesktop.org
> Cc: sta...@vger.kernel.org; Lin, Charlton <charlton....@intel.com>; 
> Almahallawy, Khaled <khaled.almahall...@intel.com>
> Subject: [PATCH 01/19] drm/i915/lnl+/tc: Fix handling of an 
> enabled/disconnected dp-alt sink
> 
> The TypeC PHY HW readout during driver loading and system resume determines 
> which TypeC mode the PHY is in (legacy/DP-
> alt/TBT-alt) and whether the PHY is connected, based on the PHY's Owned and 
> Ready flags.
> For the PHY to be in DP-alt or legacy mode and for the PHY to be in the 
> connected state in these modes, both the Owned (set by
> the BIOS/driver) and the Ready (set by the HW) flags should be set.
> 
> On ICL-MTL the HW kept the PHY's Ready flag set after the driver connected 
> the PHY by acquiring the PHY ownership (by setting
> the Owned flag), until the driver disconnected the PHY by releasing the PHY 
> ownership (by clearing the Owned flag). On LNL+ this
> has changed, in that the HW clears the Ready flag as soon as the sink gets 
> disconnected, even if the PHY ownership was acquired
> already and hence the PHY is being used by the display.
> 
> When inheriting the HW state from BIOS for a PHY connected in DP-alt mode on 
> which the sink got disconnected - i.e. in a case
> where the sink was connected while BIOS/GOP was running and so the sink got 
> enabled connecting the PHY, but the user
> disconnected the sink by the time the driver loaded - the PHY Owned but not 
> Ready state must be accounted for on LNL+
> according to the above. Do that by assuming on LNL+ that the PHY is connected 
> in DP-alt mode whenever the PHY Owned flag is
> set, regardless of the PHY Ready flag.
> 
> This fixes a problem on LNL+, where the PHY TypeC mode / connected state was 
> detected incorrectly for a DP-alt sink, which got
> connected and then disconnected by the user in the above way.
> 
> Cc: sta...@vger.kernel.org # v6.8+
> Reported-by: Charlton Lin <charlton....@intel.com>
> Tested-by: Khaled Almahallawy <khaled.almahall...@intel.com>

Reviewed-by: Mika Kahola <mika.kah...@intel.com>

> Signed-off-by: Imre Deak <imre.d...@intel.com>
> ---
>  drivers/gpu/drm/i915/display/intel_tc.c | 16 ++++++++++------
>  1 file changed, 10 insertions(+), 6 deletions(-)
> 
> diff --git a/drivers/gpu/drm/i915/display/intel_tc.c 
> b/drivers/gpu/drm/i915/display/intel_tc.c
> index 3bc57579fe53e..73a08bd84a70a 100644
> --- a/drivers/gpu/drm/i915/display/intel_tc.c
> +++ b/drivers/gpu/drm/i915/display/intel_tc.c
> @@ -1226,14 +1226,18 @@ static void tc_phy_get_hw_state(struct intel_tc_port 
> *tc)
>       tc->phy_ops->get_hw_state(tc);
>  }
> 
> -static bool tc_phy_is_ready_and_owned(struct intel_tc_port *tc,
> -                                   bool phy_is_ready, bool phy_is_owned)
> +static bool tc_phy_in_legacy_or_dp_alt_mode(struct intel_tc_port *tc,
> +                                         bool phy_is_ready, bool 
> phy_is_owned)
>  {
>       struct intel_display *display = to_intel_display(tc->dig_port);
> 
> -     drm_WARN_ON(display->drm, phy_is_owned && !phy_is_ready);
> +     if (DISPLAY_VER(display) < 20) {
> +             drm_WARN_ON(display->drm, phy_is_owned && !phy_is_ready);
> 
> -     return phy_is_ready && phy_is_owned;
> +             return phy_is_ready && phy_is_owned;
> +     } else {
> +             return phy_is_owned;
> +     }
>  }
> 
>  static bool tc_phy_is_connected(struct intel_tc_port *tc, @@ -1244,7 +1248,7 
> @@ static bool tc_phy_is_connected(struct
> intel_tc_port *tc,
>       bool phy_is_owned = tc_phy_is_owned(tc);
>       bool is_connected;
> 
> -     if (tc_phy_is_ready_and_owned(tc, phy_is_ready, phy_is_owned))
> +     if (tc_phy_in_legacy_or_dp_alt_mode(tc, phy_is_ready, phy_is_owned))
>               is_connected = port_pll_type == ICL_PORT_DPLL_MG_PHY;
>       else
>               is_connected = port_pll_type == ICL_PORT_DPLL_DEFAULT; @@ 
> -1352,7 +1356,7 @@
> tc_phy_get_current_mode(struct intel_tc_port *tc)
>       phy_is_ready = tc_phy_is_ready(tc);
>       phy_is_owned = tc_phy_is_owned(tc);
> 
> -     if (!tc_phy_is_ready_and_owned(tc, phy_is_ready, phy_is_owned)) {
> +     if (!tc_phy_in_legacy_or_dp_alt_mode(tc, phy_is_ready, phy_is_owned))
> +{
>               mode = get_tc_mode_in_phy_not_owned_state(tc, live_mode);
>       } else {
>               drm_WARN_ON(display->drm, live_mode == TC_PORT_TBT_ALT);
> --
> 2.49.1

Reply via email to