[PATCH v2 3/4] drm/i915/alpm: Calculate ALPM Entry check

Hogander, Jouni jouni.hogander at intel.com
Mon Jan 29 07:33:45 UTC 2024


On Mon, 2024-01-29 at 02:08 +0000, Murthy, Arun R wrote:
> 
> 
> > -----Original Message-----
> > From: Intel-gfx <intel-gfx-bounces at lists.freedesktop.org> On Behalf
> > Of Jouni
> > Högander
> > Sent: Friday, January 5, 2024 7:45 PM
> > To: intel-gfx at lists.freedesktop.org
> > Subject: [PATCH v2 3/4] drm/i915/alpm: Calculate ALPM Entry check
> > 
> > ALPM Entry Check represents the number of lines needed to put the
> > main link
> > to sleep and keep it in the sleep state before it can be taken out
> > of the SLEEP
> > state (eDP requires the main link to be in the SLEEP state for a
> > minimum of
> > 5us).
> > 
> > Bspec: 71477
> > 
> > Signed-off-by: Jouni Högander <jouni.hogander at intel.com>
> > ---
> >  .../drm/i915/display/intel_display_types.h    |  3 ++
> >  drivers/gpu/drm/i915/display/intel_psr.c      | 28
> > +++++++++++++++++++
> >  2 files changed, 31 insertions(+)
> > 
> > diff --git a/drivers/gpu/drm/i915/display/intel_display_types.h
> > b/drivers/gpu/drm/i915/display/intel_display_types.h
> > index 889a8b34b7ac..7eddef859ff4 100644
> > --- a/drivers/gpu/drm/i915/display/intel_display_types.h
> > +++ b/drivers/gpu/drm/i915/display/intel_display_types.h
> > @@ -1680,6 +1680,9 @@ struct intel_pps {  struct alpm_parameters {
> >         u8 io_wake_lines;
> >         u8 fast_wake_lines;
> > +
> > +       /* LNL and beyond */
> > +       u8 check_entry_lines;
> >  };
> > 
> >  struct intel_psr {
> > diff --git a/drivers/gpu/drm/i915/display/intel_psr.c
> > b/drivers/gpu/drm/i915/display/intel_psr.c
> > index 1709ebb31215..7fbd18f21c3b 100644
> > --- a/drivers/gpu/drm/i915/display/intel_psr.c
> > +++ b/drivers/gpu/drm/i915/display/intel_psr.c
> > @@ -1099,6 +1099,28 @@ static bool
> > _compute_psr2_sdp_prior_scanline_indication(struct intel_dp
> > *intel_d
> >         return true;
> >  }
> > 
> > +static bool _lnl_compute_alpm_params(struct intel_dp *intel_dp,
> > +                                    struct intel_crtc_state
> > *crtc_state) {
> > +       struct drm_i915_private *i915 = dp_to_i915(intel_dp);
> > +       struct alpm_parameters *alpm_params = &intel_dp-
> > >psr.alpm_params;
> > +       int check_entry_lines;
> > +
> > +       /* ALPM Entry Check = 2 + CEILING( 5us /tline ) */
> > +       check_entry_lines = 2 +
> > +               intel_usecs_to_scanlines(&crtc_state-
> > >hw.adjusted_mode, 5);
> > +
> > +       if (check_entry_lines > 15)
> > +               return false;
> > +
> > +       if (i915->display.params.psr_safest_params)
> > +               check_entry_lines = 15;
> > +
> > +       alpm_params->check_entry_lines = check_entry_lines;
> > +
> > +       return true;
> > +}
> > +
> >  static bool _compute_alpm_params(struct intel_dp *intel_dp,
> >                                  struct intel_crtc_state
> > *crtc_state)  { @@ -
> > 1114,6 +1136,8 @@ static bool _compute_alpm_params(struct intel_dp
> > *intel_dp,
> >                  * it is not enough -> use 45 us.
> >                  */
> >                 fast_wake_time = 45;
> > +
> > +               /* TODO: Check how we can use ALPM_CTL fast wake
> > extended
> > field */
> >                 max_wake_lines = 12;
> >         } else {
> >                 io_wake_time = 50;
> > @@ -1130,6 +1154,10 @@ static bool _compute_alpm_params(struct
> > intel_dp
> > *intel_dp,
> >             fast_wake_lines > max_wake_lines)
> >                 return false;
> > 
> > +       if (DISPLAY_VER(i915) >= 20 &&
> > !_lnl_compute_alpm_params(intel_dp,
> > +                                                               
> > crtc_state))
> The function name _lnl_*** indicates it should be display ver 20. So
> can this display ver check be moved to _lnl_*** ?

Yes, I can do that.

BR,

Jouni Högander

> 
> Thanks and Regards,
> Arun R Murthy
> -------------------
> > +               return false;
> > +
> >         if (i915->display.params.psr_safest_params)
> >                 io_wake_lines = fast_wake_lines = max_wake_lines;
> > 
> > --
> > 2.34.1
> 



More information about the Intel-gfx mailing list