From: Ville Syrjälä <[email protected]>

Clean up the main commit_tail() codepath a bit by pulling
the post plane update steps that need to performed after
readout into their own little function
(intel_post_plane_update_after_readout()).

Signed-off-by: Ville Syrjälä <[email protected]>
---
 drivers/gpu/drm/i915/display/intel_display.c | 25 +++++++++++++-------
 1 file changed, 17 insertions(+), 8 deletions(-)

diff --git a/drivers/gpu/drm/i915/display/intel_display.c 
b/drivers/gpu/drm/i915/display/intel_display.c
index 591fe3b4ace8..5776f9514346 100644
--- a/drivers/gpu/drm/i915/display/intel_display.c
+++ b/drivers/gpu/drm/i915/display/intel_display.c
@@ -1117,6 +1117,22 @@ static void intel_post_plane_update(struct 
intel_atomic_state *state,
                intel_encoders_audio_enable(state, crtc);
 }
 
+static void intel_post_plane_update_after_readout(struct intel_atomic_state 
*state,
+                                                 struct intel_crtc *crtc)
+{
+       const struct intel_crtc_state *new_crtc_state =
+               intel_atomic_get_new_crtc_state(state, crtc);
+
+       /* Must be done after gamma readout due to HSW split gamma vs. IPS w/a 
*/
+       hsw_ips_post_update(state, crtc);
+
+       /*
+        * Activate DRRS after state readout to avoid
+        * dp_m_n vs. dp_m2_n2 confusion on BDW+.
+        */
+       intel_drrs_activate(new_crtc_state);
+}
+
 static void intel_crtc_enable_flip_done(struct intel_atomic_state *state,
                                        struct intel_crtc *crtc)
 {
@@ -7479,14 +7495,7 @@ static void intel_atomic_commit_tail(struct 
intel_atomic_state *state)
 
                intel_modeset_verify_crtc(state, crtc);
 
-               /* Must be done after gamma readout due to HSW split gamma vs. 
IPS w/a */
-               hsw_ips_post_update(state, crtc);
-
-               /*
-                * Activate DRRS after state readout to avoid
-                * dp_m_n vs. dp_m2_n2 confusion on BDW+.
-                */
-               intel_drrs_activate(new_crtc_state);
+               intel_post_plane_update_after_readout(state, crtc);
 
                /*
                 * DSB cleanup is done in cleanup_work aligning with framebuffer
-- 
2.44.2

Reply via email to