[PATCH 12/18] drm/i915/vrr: Introduce intel_vrr_vblank_delay()

Nautiyal, Ankit K ankit.k.nautiyal at intel.com
Fri Jan 3 11:48:03 UTC 2025


On 12/11/2024 2:40 AM, Ville Syrjala wrote:
> From: Ville Syrjälä <ville.syrjala at linux.intel.com>
>
> Introduce a VRR specific function for determining the current
> vblank delay. Currently thus will give the same answer as
> intel_mode_vblank_delay() but that will change later.
>
> Signed-off-by: Ville Syrjälä <ville.syrjala at linux.intel.com>

Reviewed-by: Ankit Nautiyal <ankit.k.nautiyal at intel.com>


> ---
>   drivers/gpu/drm/i915/display/intel_dsb.c    | 18 ++++++++++++++----
>   drivers/gpu/drm/i915/display/intel_vblank.c |  7 ++++++-
>   drivers/gpu/drm/i915/display/intel_vrr.c    |  6 ++++++
>   drivers/gpu/drm/i915/display/intel_vrr.h    |  1 +
>   4 files changed, 27 insertions(+), 5 deletions(-)
>
> diff --git a/drivers/gpu/drm/i915/display/intel_dsb.c b/drivers/gpu/drm/i915/display/intel_dsb.c
> index 673f75703785..89d3496bcbdb 100644
> --- a/drivers/gpu/drm/i915/display/intel_dsb.c
> +++ b/drivers/gpu/drm/i915/display/intel_dsb.c
> @@ -109,9 +109,16 @@ static bool pre_commit_is_vrr_active(struct intel_atomic_state *state,
>   	return old_crtc_state->vrr.enable && !intel_crtc_vrr_disabling(state, crtc);
>   }
>   
> -static int dsb_vblank_delay(const struct intel_crtc_state *crtc_state)
> +static int dsb_vblank_delay(struct intel_atomic_state *state,
> +			    struct intel_crtc *crtc)
>   {
> -	return intel_mode_vblank_delay(&crtc_state->hw.adjusted_mode);
> +	const struct intel_crtc_state *crtc_state =
> +		intel_pre_commit_crtc_state(state, crtc);
> +
> +	if (pre_commit_is_vrr_active(state, crtc))
> +		return intel_vrr_vblank_delay(crtc_state);
> +	else
> +		return intel_mode_vblank_delay(&crtc_state->hw.adjusted_mode);
>   }
>   
>   static int dsb_vtotal(struct intel_atomic_state *state,
> @@ -520,10 +527,11 @@ void intel_dsb_vblank_evade(struct intel_atomic_state *state,
>   		intel_pre_commit_crtc_state(state, crtc);
>   	/* FIXME calibrate sensibly */
>   	int latency = intel_usecs_to_scanlines(&crtc_state->hw.adjusted_mode, 20);
> -	int vblank_delay = dsb_vblank_delay(crtc_state);
>   	int start, end;
>   
>   	if (pre_commit_is_vrr_active(state, crtc)) {
> +		int vblank_delay = intel_vrr_vblank_delay(crtc_state);
> +
>   		end = intel_vrr_vmin_vblank_start(crtc_state);
>   		start = end - vblank_delay - latency;
>   		intel_dsb_wait_scanline_out(state, dsb, start, end);
> @@ -532,6 +540,8 @@ void intel_dsb_vblank_evade(struct intel_atomic_state *state,
>   		start = end - vblank_delay - latency;
>   		intel_dsb_wait_scanline_out(state, dsb, start, end);
>   	} else {
> +		int vblank_delay = intel_mode_vblank_delay(&crtc_state->hw.adjusted_mode);
> +
>   		end = intel_mode_vblank_start(&crtc_state->hw.adjusted_mode);
>   		start = end - vblank_delay - latency;
>   		intel_dsb_wait_scanline_out(state, dsb, start, end);
> @@ -612,7 +622,7 @@ void intel_dsb_wait_vblank_delay(struct intel_atomic_state *state,
>   	const struct intel_crtc_state *crtc_state =
>   		intel_pre_commit_crtc_state(state, crtc);
>   	int usecs = intel_scanlines_to_usecs(&crtc_state->hw.adjusted_mode,
> -					     dsb_vblank_delay(crtc_state)) + 1;
> +					     dsb_vblank_delay(state, crtc)) + 1;
>   
>   	intel_dsb_wait_usec(dsb, usecs);
>   }
> diff --git a/drivers/gpu/drm/i915/display/intel_vblank.c b/drivers/gpu/drm/i915/display/intel_vblank.c
> index 2a99bde457db..fb80e0bef08a 100644
> --- a/drivers/gpu/drm/i915/display/intel_vblank.c
> +++ b/drivers/gpu/drm/i915/display/intel_vblank.c
> @@ -647,6 +647,7 @@ void intel_vblank_evade_init(const struct intel_crtc_state *old_crtc_state,
>   	struct intel_crtc *crtc = to_intel_crtc(new_crtc_state->uapi.crtc);
>   	const struct intel_crtc_state *crtc_state;
>   	const struct drm_display_mode *adjusted_mode;
> +	int vblank_delay;
>   
>   	evade->crtc = crtc;
>   
> @@ -668,8 +669,12 @@ void intel_vblank_evade_init(const struct intel_crtc_state *old_crtc_state,
>   			evade->vblank_start = intel_vrr_vmin_vblank_start(crtc_state);
>   		else
>   			evade->vblank_start = intel_vrr_vmax_vblank_start(crtc_state);
> +
> +		vblank_delay = intel_vrr_vblank_delay(crtc_state);
>   	} else {
>   		evade->vblank_start = intel_mode_vblank_start(adjusted_mode);
> +
> +		vblank_delay = intel_mode_vblank_delay(adjusted_mode);
>   	}
>   
>   	/* FIXME needs to be calibrated sensibly */
> @@ -687,7 +692,7 @@ void intel_vblank_evade_init(const struct intel_crtc_state *old_crtc_state,
>   	 */
>   	if (intel_color_uses_dsb(new_crtc_state) ||
>   	    new_crtc_state->update_m_n || new_crtc_state->update_lrr)
> -		evade->min -= intel_mode_vblank_delay(adjusted_mode);
> +		evade->min -= vblank_delay;
>   }
>   
>   /* must be called with vblank interrupt already enabled! */
> diff --git a/drivers/gpu/drm/i915/display/intel_vrr.c b/drivers/gpu/drm/i915/display/intel_vrr.c
> index 0d40402fe043..a0ddc288c1a3 100644
> --- a/drivers/gpu/drm/i915/display/intel_vrr.c
> +++ b/drivers/gpu/drm/i915/display/intel_vrr.c
> @@ -76,6 +76,12 @@ intel_vrr_check_modeset(struct intel_atomic_state *state)
>   	}
>   }
>   
> +int intel_vrr_vblank_delay(const struct intel_crtc_state *crtc_state)
> +{
> +	return crtc_state->hw.adjusted_mode.crtc_vblank_start -
> +		crtc_state->hw.adjusted_mode.crtc_vdisplay;
> +}
> +
>   /*
>    * Without VRR registers get latched at:
>    *  vblank_start
> diff --git a/drivers/gpu/drm/i915/display/intel_vrr.h b/drivers/gpu/drm/i915/display/intel_vrr.h
> index 75db88ae9cc4..8e8961adce39 100644
> --- a/drivers/gpu/drm/i915/display/intel_vrr.h
> +++ b/drivers/gpu/drm/i915/display/intel_vrr.h
> @@ -30,5 +30,6 @@ int intel_vrr_vmax_vtotal(const struct intel_crtc_state *crtc_state);
>   int intel_vrr_vmin_vtotal(const struct intel_crtc_state *crtc_state);
>   int intel_vrr_vmax_vblank_start(const struct intel_crtc_state *crtc_state);
>   int intel_vrr_vmin_vblank_start(const struct intel_crtc_state *crtc_state);
> +int intel_vrr_vblank_delay(const struct intel_crtc_state *crtc_state);
>   
>   #endif /* __INTEL_VRR_H__ */


More information about the Intel-gfx mailing list