> Subject: [PATCH v2 18/24] drm/i915/lt_phy: Add .disable_clock hook on DDI
> 
> Disable PLL clock on DDI by moving part of the PLL disabling sequence into a
> DDI clock disabling function.
> 

Commit message needs to be something like
"Add new pll_disable_clock functions so that they can be hooked up to 
dpll->disable.
This is just a wrapper over the exitisting intel_xe3plpd_pll_disable to make it 
compatible
With dpll->disable function"


> Signed-off-by: Mika Kahola <[email protected]>
> ---
>  drivers/gpu/drm/i915/display/intel_ddi.c      |  2 +-
>  drivers/gpu/drm/i915/display/intel_dpll_mgr.c | 12 ++++++++++++
>  drivers/gpu/drm/i915/display/intel_lt_phy.c   | 11 +++++++++++
>  drivers/gpu/drm/i915/display/intel_lt_phy.h   |  1 +
>  4 files changed, 25 insertions(+), 1 deletion(-)
> 
> diff --git a/drivers/gpu/drm/i915/display/intel_ddi.c
> b/drivers/gpu/drm/i915/display/intel_ddi.c
> index 51403d09c477..191ae7cf81fb 100644
> --- a/drivers/gpu/drm/i915/display/intel_ddi.c
> +++ b/drivers/gpu/drm/i915/display/intel_ddi.c
> @@ -5299,7 +5299,7 @@ void intel_ddi_init(struct intel_display *display,
> 
>       if (HAS_LT_PHY(display)) {
>               encoder->enable_clock = intel_xe3plpd_pll_enable_clock;
> -             encoder->disable_clock = intel_xe3plpd_pll_disable;
> +             encoder->disable_clock = intel_xe3plpd_pll_disable_clock;
>               encoder->port_pll_type = intel_mtl_port_pll_type;
>               encoder->get_config = xe3plpd_ddi_get_config;
>       } else if (DISPLAY_VER(display) >= 14) { diff --git
> a/drivers/gpu/drm/i915/display/intel_dpll_mgr.c
> b/drivers/gpu/drm/i915/display/intel_dpll_mgr.c
> index 54c7a255b3a5..28c560417409 100644
> --- a/drivers/gpu/drm/i915/display/intel_dpll_mgr.c
> +++ b/drivers/gpu/drm/i915/display/intel_dpll_mgr.c
> @@ -4607,8 +4607,20 @@ static void xe3plpd_pll_enable(struct intel_display
> *display,
>       intel_xe3plpd_pll_enable(encoder, pll, dpll_hw_state);  }
> 
> +static void xe3plpd_pll_disable(struct intel_display *display,
> +                             struct intel_dpll *pll)
> +{
> +     struct intel_encoder *encoder = get_intel_encoder(display, pll);
> +
> +     if (drm_WARN_ON(display->drm, !encoder))
> +             return;
> +
> +     intel_xe3plpd_pll_disable(encoder);
> +}
> +
>  static const struct intel_dpll_funcs xe3plpd_pll_funcs = {
>       .enable = xe3plpd_pll_enable,
> +     .disable = xe3plpd_pll_disable,
>       .get_hw_state = xe3plpd_pll_get_hw_state,
>       .get_freq = xe3plpd_pll_get_freq,
>  };
> diff --git a/drivers/gpu/drm/i915/display/intel_lt_phy.c
> b/drivers/gpu/drm/i915/display/intel_lt_phy.c
> index 6bc32d1734a7..3230d2e28d9c 100644
> --- a/drivers/gpu/drm/i915/display/intel_lt_phy.c
> +++ b/drivers/gpu/drm/i915/display/intel_lt_phy.c
> @@ -2309,6 +2309,17 @@ void intel_xe3plpd_pll_disable(struct
> intel_encoder *encoder)
>               intel_mtl_tbt_pll_disable_clock(encoder);
>       else
>               intel_lt_phy_pll_disable(encoder);
> +}
> +
> +void intel_xe3plpd_pll_disable_clock(struct intel_encoder *encoder) {
> +     struct intel_digital_port *dig_port = enc_to_dig_port(encoder);
> +
> +     if (intel_tc_port_in_tbt_alt_mode(dig_port))
> +             intel_mtl_tbt_pll_disable_clock(encoder);

This is already called inside intel_mtl_tbt_pll_disable clock.
Is there any specific reason to add a wrapper around this other than naming if 
not
You can drop this wrapper and proceed without the below change
-               encoder->disable_clock = intel_xe3plpd_pll_disable;
+               encoder->disable_clock = intel_xe3plpd_pll_disable_clock;

Regards,
Suraj Kandpal

> +     else
> +             /* TODO: remove when PLL mgr is in place. */
> +             intel_xe3plpd_pll_disable(encoder);
> 
>  }
> 
> diff --git a/drivers/gpu/drm/i915/display/intel_lt_phy.h
> b/drivers/gpu/drm/i915/display/intel_lt_phy.h
> index 9188ce980119..3838e9326773 100644
> --- a/drivers/gpu/drm/i915/display/intel_lt_phy.h
> +++ b/drivers/gpu/drm/i915/display/intel_lt_phy.h
> @@ -49,5 +49,6 @@ void intel_xe3plpd_pll_disable(struct intel_encoder
> *encoder);  void intel_lt_phy_verify_plls(struct intel_display *display);  
> void
> intel_xe3plpd_pll_enable_clock(struct intel_encoder *encoder,
>                                   const struct intel_crtc_state *crtc_state);
> +void intel_xe3plpd_pll_disable_clock(struct intel_encoder *encoder);
> 
>  #endif /* __INTEL_LT_PHY_H__ */
> --
> 2.43.0

Reply via email to