Commit 09af6037 authored by Ville Syrjälä's avatar Ville Syrjälä

drm/i915: Make vrr_{enabling,disabling}() usable outside intel_display.c

Give vrr_enabling() and vrr_disabling() slightly fancier names, and
pass in the whole atomic state so that they'll be easier to use.
We'll need to call at least the disabling part from the DSB code
soon enough (so that we can do vblank evasions/etc. correctly on
the DSB).
Signed-off-by: default avatarVille Syrjälä <ville.syrjala@linux.intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20240624191032.27333-3-ville.syrjala@linux.intel.comReviewed-by: default avatarAnimesh Manna <animesh.manna@intel.com>
parent 3b0974d7
...@@ -1014,9 +1014,14 @@ static bool cmrr_params_changed(const struct intel_crtc_state *old_crtc_state, ...@@ -1014,9 +1014,14 @@ static bool cmrr_params_changed(const struct intel_crtc_state *old_crtc_state,
old_crtc_state->cmrr.cmrr_n != new_crtc_state->cmrr.cmrr_n; old_crtc_state->cmrr.cmrr_n != new_crtc_state->cmrr.cmrr_n;
} }
static bool vrr_enabling(const struct intel_crtc_state *old_crtc_state, static bool intel_crtc_vrr_enabling(struct intel_atomic_state *state,
const struct intel_crtc_state *new_crtc_state) struct intel_crtc *crtc)
{ {
const struct intel_crtc_state *old_crtc_state =
intel_atomic_get_old_crtc_state(state, crtc);
const struct intel_crtc_state *new_crtc_state =
intel_atomic_get_new_crtc_state(state, crtc);
if (!new_crtc_state->hw.active) if (!new_crtc_state->hw.active)
return false; return false;
...@@ -1026,9 +1031,14 @@ static bool vrr_enabling(const struct intel_crtc_state *old_crtc_state, ...@@ -1026,9 +1031,14 @@ static bool vrr_enabling(const struct intel_crtc_state *old_crtc_state,
vrr_params_changed(old_crtc_state, new_crtc_state))); vrr_params_changed(old_crtc_state, new_crtc_state)));
} }
static bool vrr_disabling(const struct intel_crtc_state *old_crtc_state, static bool intel_crtc_vrr_disabling(struct intel_atomic_state *state,
const struct intel_crtc_state *new_crtc_state) struct intel_crtc *crtc)
{ {
const struct intel_crtc_state *old_crtc_state =
intel_atomic_get_old_crtc_state(state, crtc);
const struct intel_crtc_state *new_crtc_state =
intel_atomic_get_new_crtc_state(state, crtc);
if (!old_crtc_state->hw.active) if (!old_crtc_state->hw.active)
return false; return false;
...@@ -1181,7 +1191,7 @@ static void intel_pre_plane_update(struct intel_atomic_state *state, ...@@ -1181,7 +1191,7 @@ static void intel_pre_plane_update(struct intel_atomic_state *state,
intel_atomic_get_new_crtc_state(state, crtc); intel_atomic_get_new_crtc_state(state, crtc);
enum pipe pipe = crtc->pipe; enum pipe pipe = crtc->pipe;
if (vrr_disabling(old_crtc_state, new_crtc_state)) { if (intel_crtc_vrr_disabling(state, crtc)) {
intel_vrr_disable(old_crtc_state); intel_vrr_disable(old_crtc_state);
intel_crtc_update_active_timings(old_crtc_state, false); intel_crtc_update_active_timings(old_crtc_state, false);
} }
...@@ -6830,8 +6840,6 @@ static void commit_pipe_post_planes(struct intel_atomic_state *state, ...@@ -6830,8 +6840,6 @@ static void commit_pipe_post_planes(struct intel_atomic_state *state,
struct intel_crtc *crtc) struct intel_crtc *crtc)
{ {
struct drm_i915_private *dev_priv = to_i915(state->base.dev); struct drm_i915_private *dev_priv = to_i915(state->base.dev);
const struct intel_crtc_state *old_crtc_state =
intel_atomic_get_old_crtc_state(state, crtc);
const struct intel_crtc_state *new_crtc_state = const struct intel_crtc_state *new_crtc_state =
intel_atomic_get_new_crtc_state(state, crtc); intel_atomic_get_new_crtc_state(state, crtc);
...@@ -6844,7 +6852,7 @@ static void commit_pipe_post_planes(struct intel_atomic_state *state, ...@@ -6844,7 +6852,7 @@ static void commit_pipe_post_planes(struct intel_atomic_state *state,
!intel_crtc_needs_modeset(new_crtc_state)) !intel_crtc_needs_modeset(new_crtc_state))
skl_detach_scalers(new_crtc_state); skl_detach_scalers(new_crtc_state);
if (vrr_enabling(old_crtc_state, new_crtc_state)) if (intel_crtc_vrr_enabling(state, crtc))
intel_vrr_enable(new_crtc_state); intel_vrr_enable(new_crtc_state);
} }
...@@ -6944,7 +6952,7 @@ static void intel_update_crtc(struct intel_atomic_state *state, ...@@ -6944,7 +6952,7 @@ static void intel_update_crtc(struct intel_atomic_state *state,
* *
* FIXME Should be synchronized with the start of vblank somehow... * FIXME Should be synchronized with the start of vblank somehow...
*/ */
if (vrr_enabling(old_crtc_state, new_crtc_state) || if (intel_crtc_vrr_enabling(state, crtc) ||
new_crtc_state->update_m_n || new_crtc_state->update_lrr) new_crtc_state->update_m_n || new_crtc_state->update_lrr)
intel_crtc_update_active_timings(new_crtc_state, intel_crtc_update_active_timings(new_crtc_state,
new_crtc_state->vrr.enable); new_crtc_state->vrr.enable);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment