On Tue, 28 May 2024, Ville Syrjala <ville.syrjala@xxxxxxxxxxxxxxx> wrote: > From: Ville Syrjälä <ville.syrjala@xxxxxxxxxxxxxxx> > > skl_ddb_add_affected_planes() needs the full atomic state. Instead > of digging that out from dubious sources plumb it in explicitly. > > The wm counterpart (skl_wm_add_affected_planes()) already does > things in the proper way. > > Signed-off-by: Ville Syrjälä <ville.syrjala@xxxxxxxxxxxxxxx> Reviewed-by: Jani Nikula <jani.nikula@xxxxxxxxx> > --- > drivers/gpu/drm/i915/display/skl_watermark.c | 19 +++++++++---------- > 1 file changed, 9 insertions(+), 10 deletions(-) > > diff --git a/drivers/gpu/drm/i915/display/skl_watermark.c b/drivers/gpu/drm/i915/display/skl_watermark.c > index 2064f72da675..a2726364b34d 100644 > --- a/drivers/gpu/drm/i915/display/skl_watermark.c > +++ b/drivers/gpu/drm/i915/display/skl_watermark.c > @@ -2429,12 +2429,14 @@ bool skl_ddb_allocation_overlaps(const struct skl_ddb_entry *ddb, > } > > static int > -skl_ddb_add_affected_planes(const struct intel_crtc_state *old_crtc_state, > - struct intel_crtc_state *new_crtc_state) > +skl_ddb_add_affected_planes(struct intel_atomic_state *state, > + struct intel_crtc *crtc) > { > - struct intel_atomic_state *state = to_intel_atomic_state(new_crtc_state->uapi.state); > - struct intel_crtc *crtc = to_intel_crtc(new_crtc_state->uapi.crtc); > - struct drm_i915_private *i915 = to_i915(crtc->base.dev); > + struct drm_i915_private *i915 = to_i915(state->base.dev); > + const struct intel_crtc_state *old_crtc_state = > + intel_atomic_get_old_crtc_state(state, crtc); > + struct intel_crtc_state *new_crtc_state = > + intel_atomic_get_new_crtc_state(state, crtc); > struct intel_plane *plane; > > for_each_intel_plane_on_crtc(&i915->drm, crtc, plane) { > @@ -2489,7 +2491,6 @@ skl_compute_ddb(struct intel_atomic_state *state) > struct drm_i915_private *i915 = to_i915(state->base.dev); > const struct intel_dbuf_state *old_dbuf_state; > struct intel_dbuf_state *new_dbuf_state = NULL; > - const struct intel_crtc_state *old_crtc_state; > struct intel_crtc_state *new_crtc_state; > struct intel_crtc *crtc; > int ret, i; > @@ -2577,14 +2578,12 @@ skl_compute_ddb(struct intel_atomic_state *state) > return ret; > } > > - for_each_oldnew_intel_crtc_in_state(state, crtc, old_crtc_state, > - new_crtc_state, i) { > + for_each_new_intel_crtc_in_state(state, crtc, new_crtc_state, i) { > ret = skl_crtc_allocate_plane_ddb(state, crtc); > if (ret) > return ret; > > - ret = skl_ddb_add_affected_planes(old_crtc_state, > - new_crtc_state); > + ret = skl_ddb_add_affected_planes(state, crtc); > if (ret) > return ret; > } -- Jani Nikula, Intel