]> git.baikalelectronics.ru Git - kernel.git/commitdiff
drm/i915: Don't set undefined bits in dirty_pipes
authorVille Syrjälä <ville.syrjala@linux.intel.com>
Fri, 11 Oct 2019 20:09:45 +0000 (23:09 +0300)
committerVille Syrjälä <ville.syrjala@linux.intel.com>
Fri, 29 Nov 2019 19:49:16 +0000 (21:49 +0200)
skl_commit_modeset_enables() straight up compares dirty_pipes
with a bitmask of already committed pipes. If we set bits in
dirty_pipes for non-existent pipes that comparison will never
work right. So let's limit ourselves to bits that exist.

And we'll do the same for the active_pipes_changed bitmask.

Signed-off-by: Ville Syrjälä <ville.syrjala@linux.intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20191011200949.7839-5-ville.syrjala@linux.intel.com
Reviewed-by: Stanislav Lisovskiy <stanislav.lisovskiy@intel.com>
drivers/gpu/drm/i915/intel_pm.c

index 558bf2c42cb8c8a5c4cfe1b48b4e16ecb0b3a06a..eaf6397c5c3887f39fe3d43f03939fd39ffc6903 100644 (file)
@@ -5360,7 +5360,7 @@ skl_ddb_add_affected_pipes(struct intel_atomic_state *state)
                if (ret)
                        return ret;
 
-               state->active_pipe_changes = ~0;
+               state->active_pipe_changes = INTEL_INFO(dev_priv)->pipe_mask;
 
                /*
                 * We usually only initialize state->active_pipes if we
@@ -5386,7 +5386,7 @@ skl_ddb_add_affected_pipes(struct intel_atomic_state *state)
         * to grab the lock on *all* CRTC's.
         */
        if (state->active_pipe_changes || state->modeset) {
-               state->wm_results.dirty_pipes = ~0;
+               state->wm_results.dirty_pipes = INTEL_INFO(dev_priv)->pipe_mask;
 
                ret = intel_add_all_pipes(state);
                if (ret)