> Subject: [CI 29/32] drm/i915/display: Add .enable_clock on DDI for MTL+
> platforms
> 
> To enable pll clock on DDI we need to move part of the pll enabling
> sequence to a ddi clock enabling function.
> 
> Simlilarly, we do the pll disabling sequence.

Avoid using We do , we need keep it imperative with that fixed

Reviewed-by: Suraj Kandpal <[email protected]>

> 
> Signed-off-by: Imre Deak <[email protected]>
> Signed-off-by: Mika Kahola <[email protected]>
> ---
>  drivers/gpu/drm/i915/display/intel_cx0_phy.c  | 34 +++++++++++++------
> drivers/gpu/drm/i915/display/intel_cx0_phy.h  |  7 +++-
>  drivers/gpu/drm/i915/display/intel_ddi.c      |  6 ++--
>  drivers/gpu/drm/i915/display/intel_dpll_mgr.c | 25 ++++++++++++++
>  4 files changed, 58 insertions(+), 14 deletions(-)
> 
> diff --git a/drivers/gpu/drm/i915/display/intel_cx0_phy.c
> b/drivers/gpu/drm/i915/display/intel_cx0_phy.c
> index 15ba3522b5b3..b82a1f891eae 100644
> --- a/drivers/gpu/drm/i915/display/intel_cx0_phy.c
> +++ b/drivers/gpu/drm/i915/display/intel_cx0_phy.c
> @@ -3301,7 +3301,6 @@ static void intel_cx0pll_enable(struct
> intel_encoder *encoder,
>        * Frequency Change. We handle this step in bxt_set_cdclk().
>        */
> 
> -     /* TODO: enable TBT-ALT mode */
>       intel_cx0_phy_transaction_end(encoder, wakeref);  }
> 
> @@ -3367,8 +3366,7 @@ static int intel_mtl_tbt_clock_select(struct
> intel_display *display,
>       }
>  }
> 
> -static void intel_mtl_tbt_pll_enable(struct intel_encoder *encoder,
> -                                  const struct intel_crtc_state *crtc_state)
> +static void intel_mtl_tbt_pll_enable_clock(struct intel_encoder
> +*encoder, int port_clock)
>  {
>       struct intel_display *display = to_intel_display(encoder);
>       enum phy phy = intel_encoder_to_phy(encoder); @@ -3382,7
> +3380,7 @@ static void intel_mtl_tbt_pll_enable(struct intel_encoder
> *encoder,
> 
>       mask = XELPDP_DDI_CLOCK_SELECT_MASK(display);
>       val |= XELPDP_DDI_CLOCK_SELECT_PREP(display,
> -                                         intel_mtl_tbt_clock_select(display,
> crtc_state->port_clock));
> +                                         intel_mtl_tbt_clock_select(display,
> port_clock));
> 
>       mask |= XELPDP_FORWARD_CLOCK_UNGATE;
>       val |= XELPDP_FORWARD_CLOCK_UNGATE;
> @@ -3423,18 +3421,26 @@ static void intel_mtl_tbt_pll_enable(struct
> intel_encoder *encoder,
>        * clock frequency.
>        */
>       intel_de_write(display, DDI_CLK_VALFREQ(encoder->port),
> -                    crtc_state->port_clock);
> +                    port_clock);
>  }
> 
>  void intel_mtl_pll_enable(struct intel_encoder *encoder,
> -                       const struct intel_crtc_state *crtc_state)
> +                       struct intel_dpll *pll,
> +                       const struct intel_dpll_hw_state *dpll_hw_state) {
> +     intel_cx0pll_enable(encoder, &dpll_hw_state->cx0pll); }
> +
> +void intel_mtl_pll_enable_clock(struct intel_encoder *encoder,
> +                             const struct intel_crtc_state *crtc_state)
>  {
>       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_enable(encoder, crtc_state);
> +             intel_mtl_tbt_pll_enable_clock(encoder, crtc_state-
> >port_clock);
>       else
> -             intel_cx0pll_enable(encoder, &crtc_state-
> >dpll_hw_state.cx0pll);
> +             /* TODO: remove when PLL mgr is in place. */
> +             intel_mtl_pll_enable(encoder, NULL, &crtc_state-
> >dpll_hw_state);
>  }
> 
>  /*
> @@ -3550,7 +3556,7 @@ static bool intel_cx0_pll_is_enabled(struct
> intel_encoder *encoder)
>                            intel_cx0_get_pclk_pll_request(lane);
>  }
> 
> -static void intel_mtl_tbt_pll_disable(struct intel_encoder *encoder)
> +static void intel_mtl_tbt_pll_disable_clock(struct intel_encoder
> +*encoder)
>  {
>       struct intel_display *display = to_intel_display(encoder);
>       enum phy phy = intel_encoder_to_phy(encoder); @@ -3590,13
> +3596,19 @@ static void intel_mtl_tbt_pll_disable(struct intel_encoder
> *encoder)  }
> 
>  void intel_mtl_pll_disable(struct intel_encoder *encoder)
> +{
> +     intel_cx0pll_disable(encoder);
> +}
> +
> +void intel_mtl_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(encoder);
> +             intel_mtl_tbt_pll_disable_clock(encoder);
>       else
> -             intel_cx0pll_disable(encoder);
> +             /* TODO: remove when PLL mgr is in place. */
> +             intel_mtl_pll_disable(encoder);
>  }
> 
>  enum icl_port_dpll_id
> diff --git a/drivers/gpu/drm/i915/display/intel_cx0_phy.h
> b/drivers/gpu/drm/i915/display/intel_cx0_phy.h
> index 13eaf6d280ff..13fa001129f7 100644
> --- a/drivers/gpu/drm/i915/display/intel_cx0_phy.h
> +++ b/drivers/gpu/drm/i915/display/intel_cx0_phy.h
> @@ -17,17 +17,22 @@ struct intel_crtc;
>  struct intel_crtc_state;
>  struct intel_cx0pll_state;
>  struct intel_display;
> +struct intel_dpll;
>  struct intel_dpll_hw_state;
>  struct intel_encoder;
>  struct intel_hdmi;
> 
>  bool intel_encoder_is_c10phy(struct intel_encoder *encoder);  void
> intel_mtl_pll_enable(struct intel_encoder *encoder,
> -                       const struct intel_crtc_state *crtc_state);
> +                       struct intel_dpll *pll,
> +                       const struct intel_dpll_hw_state *dpll_hw_state);
>  void intel_mtl_pll_disable(struct intel_encoder *encoder);  enum
> icl_port_dpll_id  intel_mtl_port_pll_type(struct intel_encoder *encoder,
>                       const struct intel_crtc_state *crtc_state);
> +void intel_mtl_pll_enable_clock(struct intel_encoder *encoder,
> +                             const struct intel_crtc_state *crtc_state); void
> +intel_mtl_pll_disable_clock(struct intel_encoder *encoder);
> 
>  int intel_cx0pll_calc_state(const struct intel_crtc_state *crtc_state,
>                           struct intel_encoder *encoder,
> diff --git a/drivers/gpu/drm/i915/display/intel_ddi.c
> b/drivers/gpu/drm/i915/display/intel_ddi.c
> index 870140340342..d0bfa7f397dc 100644
> --- a/drivers/gpu/drm/i915/display/intel_ddi.c
> +++ b/drivers/gpu/drm/i915/display/intel_ddi.c
> @@ -88,6 +88,8 @@
>  #include "skl_scaler.h"
>  #include "skl_universal_plane.h"
> 
> +struct intel_dpll;
> +
>  static const u8 index_to_dp_signal_levels[] = {
>       [0] = DP_TRAIN_VOLTAGE_SWING_LEVEL_0 |
> DP_TRAIN_PRE_EMPH_LEVEL_0,
>       [1] = DP_TRAIN_VOLTAGE_SWING_LEVEL_0 |
> DP_TRAIN_PRE_EMPH_LEVEL_1, @@ -5232,8 +5234,8 @@ void
> intel_ddi_init(struct intel_display *display,
>       encoder->pipe_mask = ~0;
> 
>       if (DISPLAY_VER(display) >= 14) {
> -             encoder->enable_clock = intel_mtl_pll_enable;
> -             encoder->disable_clock = intel_mtl_pll_disable;
> +             encoder->enable_clock = intel_mtl_pll_enable_clock;
> +             encoder->disable_clock = intel_mtl_pll_disable_clock;
>               encoder->port_pll_type = intel_mtl_port_pll_type;
>               encoder->get_config = mtl_ddi_get_config;
>       } else if (display->platform.dg2) {
> diff --git a/drivers/gpu/drm/i915/display/intel_dpll_mgr.c
> b/drivers/gpu/drm/i915/display/intel_dpll_mgr.c
> index 6cc85a9a781f..8220ef69f685 100644
> --- a/drivers/gpu/drm/i915/display/intel_dpll_mgr.c
> +++ b/drivers/gpu/drm/i915/display/intel_dpll_mgr.c
> @@ -4391,7 +4391,32 @@ static int mtl_pll_get_freq(struct intel_display
> *display,
>       return intel_cx0pll_calc_port_clock(encoder, &dpll_hw_state-
> >cx0pll);  }
> 
> +static void mtl_pll_enable(struct intel_display *display,
> +                        struct intel_dpll *pll,
> +                        const struct intel_dpll_hw_state *dpll_hw_state) {
> +     struct intel_encoder *encoder = get_intel_encoder(display, pll);
> +
> +     if (drm_WARN_ON(display->drm, !encoder))
> +             return;
> +
> +     intel_mtl_pll_enable(encoder, pll, dpll_hw_state); }
> +
> +static void mtl_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_mtl_pll_disable(encoder);
> +}
> +
>  static const struct intel_dpll_funcs mtl_pll_funcs = {
> +     .enable = mtl_pll_enable,
> +     .disable = mtl_pll_disable,
>       .get_hw_state = mtl_pll_get_hw_state,
>       .get_freq = mtl_pll_get_freq,
>  };
> --
> 2.34.1

Reply via email to