[PATCH 14/18] drm/i915/vrr: Fix vmin/vmax/flipline on TGL when using vblank delay
Nautiyal, Ankit K
ankit.k.nautiyal at intel.com
Fri Jan 3 12:03:50 UTC 2025
On 12/11/2024 2:40 AM, Ville Syrjala wrote:
> From: Ville Syrjälä <ville.syrjala at linux.intel.com>
>
> Turns out that TGL needs its vmin/vmax/flipling adjusted based
typo: flipline
> on the vblank delay, otherwise the hardware pushes the vtotals
> fiurther out. Make it so.
Typo: further
>
> Signed-off-by: Ville Syrjälä <ville.syrjala at linux.intel.com>
LGTM.
Reviewed-by: Ankit Nautiyal <ankit.k.nautiyal at intel.com>
> ---
> drivers/gpu/drm/i915/display/intel_vrr.c | 32 +++++++++++++++++++-----
> 1 file changed, 26 insertions(+), 6 deletions(-)
>
> diff --git a/drivers/gpu/drm/i915/display/intel_vrr.c b/drivers/gpu/drm/i915/display/intel_vrr.c
> index 15017254d250..c08dd1e5cffc 100644
> --- a/drivers/gpu/drm/i915/display/intel_vrr.c
> +++ b/drivers/gpu/drm/i915/display/intel_vrr.c
> @@ -118,30 +118,41 @@ static int intel_vrr_vblank_exit_length(const struct intel_crtc_state *crtc_stat
> if (DISPLAY_VER(display) >= 13)
> return crtc_state->vrr.guardband;
> else
> - /* The hw imposes the extra scanline before frame start */
> + /* hardware imposes one extra scanline somewhere */
> return crtc_state->vrr.pipeline_full + crtc_state->framestart_delay + 1;
> }
>
> int intel_vrr_vmin_vtotal(const struct intel_crtc_state *crtc_state)
> {
> + struct intel_display *display = to_intel_display(crtc_state);
> +
> /* Min vblank actually determined by flipline */
> - return intel_vrr_vmin_flipline(crtc_state);
> + if (DISPLAY_VER(display) >= 13)
> + return intel_vrr_vmin_flipline(crtc_state);
> + else
> + return intel_vrr_vmin_flipline(crtc_state) +
> + intel_vrr_vblank_delay(crtc_state);
> }
>
> int intel_vrr_vmax_vtotal(const struct intel_crtc_state *crtc_state)
> {
> - return crtc_state->vrr.vmax;
> + struct intel_display *display = to_intel_display(crtc_state);
> +
> + if (DISPLAY_VER(display) >= 13)
> + return crtc_state->vrr.vmax;
> + else
> + return crtc_state->vrr.vmax +
> + intel_vrr_vblank_delay(crtc_state);
> }
>
> int intel_vrr_vmin_vblank_start(const struct intel_crtc_state *crtc_state)
> {
> - /* Min vblank actually determined by flipline */
> - return intel_vrr_vmin_flipline(crtc_state) - intel_vrr_vblank_exit_length(crtc_state);
> + return intel_vrr_vmin_vtotal(crtc_state) - intel_vrr_vblank_exit_length(crtc_state);
> }
>
> int intel_vrr_vmax_vblank_start(const struct intel_crtc_state *crtc_state)
> {
> - return crtc_state->vrr.vmax - intel_vrr_vblank_exit_length(crtc_state);
> + return intel_vrr_vmax_vtotal(crtc_state) - intel_vrr_vblank_exit_length(crtc_state);
> }
>
> static bool
> @@ -290,9 +301,18 @@ void intel_vrr_compute_config_late(struct intel_crtc_state *crtc_state)
> crtc_state->vrr.guardband =
> crtc_state->vrr.vmin - adjusted_mode->crtc_vblank_start;
> } else {
> + /* hardware imposes one extra scanline somewhere */
> crtc_state->vrr.pipeline_full =
> min(255, crtc_state->vrr.vmin - adjusted_mode->crtc_vblank_start -
> crtc_state->framestart_delay - 1);
> +
> + /*
> + * vmin/vmax/flipline also need to be adjusted by
> + * the vblank delay to maintain correct vtotals.
> + */
> + crtc_state->vrr.vmin -= intel_vrr_vblank_delay(crtc_state);
> + crtc_state->vrr.vmax -= intel_vrr_vblank_delay(crtc_state);
> + crtc_state->vrr.flipline -= intel_vrr_vblank_delay(crtc_state);
> }
> }
>
More information about the Intel-gfx
mailing list