Commit 2745bdda authored by Ville Syrjälä's avatar Ville Syrjälä

drm/i915: Stop clobbering old crtc state during state check

The state checker overwrites the old crtc state with the
current hardware state. While that does save a kmalloc() it seems
rather dubious as there might still be something that we need
in the old crtc state.

Stop doing that and just allocate a temporary state for the state
checker. Should the extra malloc during the commit phase turn out
too annoying we could of course preallocate one for each crtc, but
let's proceed with the straightforward approch for now.

And while at it let's mark the new crtc state as const to make
sure the state checker doesn't mess it up.
Signed-off-by: default avatarVille Syrjälä <ville.syrjala@linux.intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20231004155607.7719-3-ville.syrjala@linux.intel.comReviewed-by: default avatarJani Nikula <jani.nikula@intel.com>
parent 12e03c80
...@@ -156,21 +156,20 @@ verify_encoder_state(struct drm_i915_private *dev_priv, struct intel_atomic_stat ...@@ -156,21 +156,20 @@ verify_encoder_state(struct drm_i915_private *dev_priv, struct intel_atomic_stat
} }
static void static void
verify_crtc_state(struct intel_crtc *crtc, verify_crtc_state(struct intel_atomic_state *state,
struct intel_crtc_state *old_crtc_state, struct intel_crtc *crtc)
struct intel_crtc_state *new_crtc_state)
{ {
struct drm_device *dev = crtc->base.dev; struct drm_device *dev = crtc->base.dev;
struct drm_i915_private *dev_priv = to_i915(dev); struct drm_i915_private *dev_priv = to_i915(dev);
struct intel_encoder *encoder; const struct intel_crtc_state *new_crtc_state =
struct intel_crtc_state *pipe_config = old_crtc_state; intel_atomic_get_new_crtc_state(state, crtc);
struct drm_atomic_state *state = old_crtc_state->uapi.state; struct intel_crtc_state *pipe_config;
struct intel_crtc *master_crtc; struct intel_crtc *master_crtc;
struct intel_encoder *encoder;
__drm_atomic_helper_crtc_destroy_state(&old_crtc_state->uapi); pipe_config = intel_crtc_state_alloc(crtc);
intel_crtc_free_hw_state(old_crtc_state); if (!pipe_config)
intel_crtc_state_reset(old_crtc_state, crtc); return;
old_crtc_state->uapi.state = state;
drm_dbg_kms(&dev_priv->drm, "[CRTC:%d:%s]\n", crtc->base.base.id, drm_dbg_kms(&dev_priv->drm, "[CRTC:%d:%s]\n", crtc->base.base.id,
crtc->base.name); crtc->base.name);
...@@ -236,7 +235,7 @@ void intel_modeset_verify_crtc(struct intel_crtc *crtc, ...@@ -236,7 +235,7 @@ void intel_modeset_verify_crtc(struct intel_crtc *crtc,
intel_wm_state_verify(crtc, new_crtc_state); intel_wm_state_verify(crtc, new_crtc_state);
verify_connector_state(state, crtc); verify_connector_state(state, crtc);
verify_crtc_state(crtc, old_crtc_state, new_crtc_state); verify_crtc_state(state, crtc);
intel_shared_dpll_state_verify(crtc, old_crtc_state, new_crtc_state); intel_shared_dpll_state_verify(crtc, old_crtc_state, new_crtc_state);
intel_mpllb_state_verify(state, new_crtc_state); intel_mpllb_state_verify(state, new_crtc_state);
intel_c10pll_state_verify(state, new_crtc_state); intel_c10pll_state_verify(state, new_crtc_state);
......
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