Commit 099a132b authored by Ville Syrjälä's avatar Ville Syrjälä

drm/i915: Use explicit old crtc state in skl_compute_wm()

skl_compute_wm() wants to compare the old and new watermarks. Currently
it gets at the old watermarks via crtc->state, which is confusing since
it can point at either the old or the new state depending on where
in the sequence we are. In this case it is correct since we have not yet
swapped the states, but let's make it super clear what this is doing
by using the explicit old state.

Cc: Stanislav Lisovskiy <stanislav.lisovskiy@intel.com>
Signed-off-by: default avatarVille Syrjälä <ville.syrjala@linux.intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20181113172330.26069-1-ville.syrjala@linux.intel.comReviewed-by: default avatarRodrigo Vivi <rodrigo.vivi@intel.com>
parent a889580c
...@@ -5526,6 +5526,7 @@ skl_compute_wm(struct drm_atomic_state *state) ...@@ -5526,6 +5526,7 @@ skl_compute_wm(struct drm_atomic_state *state)
{ {
struct drm_crtc *crtc; struct drm_crtc *crtc;
struct drm_crtc_state *cstate; struct drm_crtc_state *cstate;
struct drm_crtc_state *old_crtc_state;
struct intel_atomic_state *intel_state = to_intel_atomic_state(state); struct intel_atomic_state *intel_state = to_intel_atomic_state(state);
struct skl_ddb_values *results = &intel_state->wm_results; struct skl_ddb_values *results = &intel_state->wm_results;
struct skl_pipe_wm *pipe_wm; struct skl_pipe_wm *pipe_wm;
...@@ -5553,11 +5554,11 @@ skl_compute_wm(struct drm_atomic_state *state) ...@@ -5553,11 +5554,11 @@ skl_compute_wm(struct drm_atomic_state *state)
* should allow skl_update_pipe_wm() to return failure in cases where * should allow skl_update_pipe_wm() to return failure in cases where
* no suitable watermark values can be found. * no suitable watermark values can be found.
*/ */
for_each_new_crtc_in_state(state, crtc, cstate, i) { for_each_oldnew_crtc_in_state(state, crtc, old_crtc_state, cstate, i) {
struct intel_crtc_state *intel_cstate = struct intel_crtc_state *intel_cstate =
to_intel_crtc_state(cstate); to_intel_crtc_state(cstate);
const struct skl_pipe_wm *old_pipe_wm = const struct skl_pipe_wm *old_pipe_wm =
&to_intel_crtc_state(crtc->state)->wm.skl.optimal; &to_intel_crtc_state(old_crtc_state)->wm.skl.optimal;
pipe_wm = &intel_cstate->wm.skl.optimal; pipe_wm = &intel_cstate->wm.skl.optimal;
ret = skl_update_pipe_wm(cstate, old_pipe_wm, pipe_wm, &changed); ret = skl_update_pipe_wm(cstate, old_pipe_wm, pipe_wm, &changed);
......
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