]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
drm/i915/display: stop passing i to for_each_pipe_crtc_modeset_{enable, disable}()
authorJani Nikula <jani.nikula@intel.com>
Wed, 13 May 2026 07:58:40 +0000 (10:58 +0300)
committerJani Nikula <jani.nikula@intel.com>
Tue, 26 May 2026 22:08:27 +0000 (01:08 +0300)
Refactor for_each_pipe_crtc_modeset_{enable,disable}() and their
underlying for_each_crtc_in_masks{,_reverse}() helpers to utilize
__UNIQUE_ID() to avoid having to pass the for loop variable to them.

Reviewed-by: Ville Syrjälä <ville.syrjala@linux.intel.com>
Link: https://patch.msgid.link/2270d4a10663bb55d5b16902b02798234f440517.1778659089.git.jani.nikula@intel.com
Signed-off-by: Jani Nikula <jani.nikula@intel.com>
drivers/gpu/drm/i915/display/intel_ddi.c
drivers/gpu/drm/i915/display/intel_display.c
drivers/gpu/drm/i915/display/intel_display.h
drivers/gpu/drm/i915/display/intel_dp_mst.c

index ad6b28e78cc56f1b5dad20604dafe074f7b58a96..205978c9feb6db0611b67ccff2ce636ded845045 100644 (file)
@@ -3230,9 +3230,8 @@ static void intel_ddi_post_disable_hdmi_or_sst(struct intel_atomic_state *state,
        struct intel_dp *intel_dp = enc_to_intel_dp(encoder);
        struct intel_crtc *pipe_crtc;
        bool is_hdmi = intel_crtc_has_type(old_crtc_state, INTEL_OUTPUT_HDMI);
-       int i;
 
-       for_each_pipe_crtc_modeset_disable(display, pipe_crtc, old_crtc_state, i) {
+       for_each_pipe_crtc_modeset_disable(display, pipe_crtc, old_crtc_state) {
                const struct intel_crtc_state *old_pipe_crtc_state =
                        intel_atomic_get_old_crtc_state(state, pipe_crtc);
 
@@ -3259,7 +3258,7 @@ static void intel_ddi_post_disable_hdmi_or_sst(struct intel_atomic_state *state,
 
        intel_ddi_disable_transcoder_func(old_crtc_state);
 
-       for_each_pipe_crtc_modeset_disable(display, pipe_crtc, old_crtc_state, i) {
+       for_each_pipe_crtc_modeset_disable(display, pipe_crtc, old_crtc_state) {
                const struct intel_crtc_state *old_pipe_crtc_state =
                        intel_atomic_get_old_crtc_state(state, pipe_crtc);
 
@@ -3516,7 +3515,6 @@ static void intel_ddi_enable(struct intel_atomic_state *state,
        struct intel_crtc *pipe_crtc;
        enum transcoder cpu_transcoder = crtc_state->cpu_transcoder;
        bool is_hdmi = intel_crtc_has_type(crtc_state, INTEL_OUTPUT_HDMI);
-       int i;
 
        /* 128b/132b SST */
        if (!is_hdmi && intel_dp_is_uhbr(crtc_state)) {
@@ -3550,7 +3548,7 @@ static void intel_ddi_enable(struct intel_atomic_state *state,
 
        intel_ddi_wait_for_fec_status(encoder, crtc_state, true);
 
-       for_each_pipe_crtc_modeset_enable(display, pipe_crtc, crtc_state, i) {
+       for_each_pipe_crtc_modeset_enable(display, pipe_crtc, crtc_state) {
                const struct intel_crtc_state *pipe_crtc_state =
                        intel_atomic_get_new_crtc_state(state, pipe_crtc);
 
index 290bbefece4ac260748211ad56797575f2058e65..3d91495905e8076a15a022954daf90fae8bc9f20 100644 (file)
@@ -1654,11 +1654,10 @@ static void hsw_crtc_enable(struct intel_atomic_state *state,
                intel_atomic_get_new_crtc_state(state, crtc);
        enum transcoder cpu_transcoder = new_crtc_state->cpu_transcoder;
        struct intel_crtc *pipe_crtc;
-       int i;
 
        if (drm_WARN_ON(display->drm, crtc->active))
                return;
-       for_each_pipe_crtc_modeset_enable(display, pipe_crtc, new_crtc_state, i) {
+       for_each_pipe_crtc_modeset_enable(display, pipe_crtc, new_crtc_state) {
                const struct intel_crtc_state *new_pipe_crtc_state =
                        intel_atomic_get_new_crtc_state(state, pipe_crtc);
 
@@ -1672,7 +1671,7 @@ static void hsw_crtc_enable(struct intel_atomic_state *state,
 
        intel_encoders_pre_enable(state, crtc);
 
-       for_each_pipe_crtc_modeset_enable(display, pipe_crtc, new_crtc_state, i) {
+       for_each_pipe_crtc_modeset_enable(display, pipe_crtc, new_crtc_state) {
                const struct intel_crtc_state *pipe_crtc_state =
                        intel_atomic_get_new_crtc_state(state, pipe_crtc);
 
@@ -1690,7 +1689,7 @@ static void hsw_crtc_enable(struct intel_atomic_state *state,
        if (!transcoder_is_dsi(cpu_transcoder))
                hsw_configure_cpu_transcoder(new_crtc_state);
 
-       for_each_pipe_crtc_modeset_enable(display, pipe_crtc, new_crtc_state, i) {
+       for_each_pipe_crtc_modeset_enable(display, pipe_crtc, new_crtc_state) {
                const struct intel_crtc_state *pipe_crtc_state =
                        intel_atomic_get_new_crtc_state(state, pipe_crtc);
 
@@ -1720,7 +1719,7 @@ static void hsw_crtc_enable(struct intel_atomic_state *state,
 
        intel_encoders_enable(state, crtc);
 
-       for_each_pipe_crtc_modeset_enable(display, pipe_crtc, new_crtc_state, i) {
+       for_each_pipe_crtc_modeset_enable(display, pipe_crtc, new_crtc_state) {
                const struct intel_crtc_state *pipe_crtc_state =
                        intel_atomic_get_new_crtc_state(state, pipe_crtc);
                enum pipe hsw_workaround_pipe;
@@ -1788,7 +1787,6 @@ static void hsw_crtc_disable(struct intel_atomic_state *state,
        const struct intel_crtc_state *old_crtc_state =
                intel_atomic_get_old_crtc_state(state, crtc);
        struct intel_crtc *pipe_crtc;
-       int i;
 
        /*
         * FIXME collapse everything to one hook.
@@ -1801,7 +1799,7 @@ static void hsw_crtc_disable(struct intel_atomic_state *state,
 
        intel_encoders_post_pll_disable(state, crtc);
 
-       for_each_pipe_crtc_modeset_disable(display, pipe_crtc, old_crtc_state, i) {
+       for_each_pipe_crtc_modeset_disable(display, pipe_crtc, old_crtc_state) {
                const struct intel_crtc_state *old_pipe_crtc_state =
                        intel_atomic_get_old_crtc_state(state, pipe_crtc);
 
index a24d16d02f96bd16f60b3b156ffad09a02b517fd..1963dbc802217b25f224ddeab5b264f13baab3ba 100644 (file)
@@ -325,29 +325,29 @@ enum phy_fia {
                             ((connector) = to_intel_connector((__state)->base.connectors[__i].ptr), \
                             (new_connector_state) = to_intel_digital_connector_state((__state)->base.connectors[__i].new_state), 1))
 
-#define for_each_crtc_in_masks(display, crtc, first_pipes, second_pipes, i) \
-       for ((i) = 0; \
+#define __for_each_crtc_in_masks(display, crtc, first_pipes, second_pipes, i) \
+       for (int (i) = 0; \
             (i) < (I915_MAX_PIPES * 2) && ((crtc) = intel_crtc_for_pipe(display, (i) % I915_MAX_PIPES), 1); \
             (i)++) \
                for_each_if((crtc) && ((first_pipes) | ((second_pipes) << I915_MAX_PIPES)) & BIT(i))
 
-#define for_each_crtc_in_masks_reverse(display, crtc, first_pipes, second_pipes, i) \
-       for ((i) = (I915_MAX_PIPES * 2 - 1); \
+#define __for_each_crtc_in_masks_reverse(display, crtc, first_pipes, second_pipes, i) \
+       for (int (i) = (I915_MAX_PIPES * 2 - 1); \
             (i) >= 0 && ((crtc) = intel_crtc_for_pipe(display, (i) % I915_MAX_PIPES), 1); \
             (i)--) \
                for_each_if((crtc) && ((first_pipes) | ((second_pipes) << I915_MAX_PIPES)) & BIT(i))
 
-#define for_each_pipe_crtc_modeset_disable(display, crtc, crtc_state, i) \
-       for_each_crtc_in_masks(display, crtc, \
-                              _intel_modeset_primary_pipes(crtc_state), \
-                              _intel_modeset_secondary_pipes(crtc_state), \
-                              i)
-
-#define for_each_pipe_crtc_modeset_enable(display, crtc, crtc_state, i) \
-       for_each_crtc_in_masks_reverse(display, crtc, \
-                                      _intel_modeset_primary_pipes(crtc_state), \
-                                      _intel_modeset_secondary_pipes(crtc_state), \
-                                      i)
+#define for_each_pipe_crtc_modeset_disable(display, crtc, crtc_state) \
+       __for_each_crtc_in_masks(display, crtc, \
+                                _intel_modeset_primary_pipes(crtc_state), \
+                                _intel_modeset_secondary_pipes(crtc_state), \
+                                __UNIQUE_ID(i))
+
+#define for_each_pipe_crtc_modeset_enable(display, crtc, crtc_state) \
+       __for_each_crtc_in_masks_reverse(display, crtc,                 \
+                                        _intel_modeset_primary_pipes(crtc_state), \
+                                        _intel_modeset_secondary_pipes(crtc_state), \
+                                        __UNIQUE_ID(i))
 
 int intel_atomic_check(struct drm_device *dev, struct drm_atomic_commit *state);
 u8 intel_calc_enabled_pipes(struct intel_atomic_state *state,
index be8febe3d234e699b0840cbedc3b2898ffe6639b..724d3ee23350272be7885afa75b437f55d87e3af 100644 (file)
@@ -1065,14 +1065,13 @@ static void mst_stream_post_disable(struct intel_atomic_state *state,
                drm_atomic_get_mst_payload_state(new_mst_state, connector->mst.port);
        struct intel_crtc *pipe_crtc;
        bool last_mst_stream;
-       int i;
 
        last_mst_stream = intel_dp_mst_dec_active_streams(intel_dp);
 
        drm_WARN_ON(display->drm, DISPLAY_VER(display) >= 12 && last_mst_stream &&
                    !intel_dp_mst_is_master_trans(old_crtc_state));
 
-       for_each_pipe_crtc_modeset_disable(display, pipe_crtc, old_crtc_state, i) {
+       for_each_pipe_crtc_modeset_disable(display, pipe_crtc, old_crtc_state) {
                const struct intel_crtc_state *old_pipe_crtc_state =
                        intel_atomic_get_old_crtc_state(state, pipe_crtc);
 
@@ -1099,7 +1098,7 @@ static void mst_stream_post_disable(struct intel_atomic_state *state,
 
        intel_ddi_disable_transcoder_func(old_crtc_state);
 
-       for_each_pipe_crtc_modeset_disable(display, pipe_crtc, old_crtc_state, i) {
+       for_each_pipe_crtc_modeset_disable(display, pipe_crtc, old_crtc_state) {
                const struct intel_crtc_state *old_pipe_crtc_state =
                        intel_atomic_get_old_crtc_state(state, pipe_crtc);
 
@@ -1310,7 +1309,7 @@ static void mst_stream_enable(struct intel_atomic_state *state,
        enum transcoder trans = pipe_config->cpu_transcoder;
        bool first_mst_stream = intel_dp_mst_active_streams(intel_dp) == 1;
        struct intel_crtc *pipe_crtc;
-       int ret, i;
+       int ret;
 
        drm_WARN_ON(display->drm, pipe_config->has_pch_encoder);
 
@@ -1355,7 +1354,7 @@ static void mst_stream_enable(struct intel_atomic_state *state,
 
        intel_enable_transcoder(pipe_config);
 
-       for_each_pipe_crtc_modeset_enable(display, pipe_crtc, pipe_config, i) {
+       for_each_pipe_crtc_modeset_enable(display, pipe_crtc, pipe_config) {
                const struct intel_crtc_state *pipe_crtc_state =
                        intel_atomic_get_new_crtc_state(state, pipe_crtc);