]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
drm/i915/ddi: Fix cleanup after DP connector init failure
authorImre Deak <imre.deak@intel.com>
Thu, 7 May 2026 06:59:39 +0000 (09:59 +0300)
committerImre Deak <imre.deak@intel.com>
Mon, 11 May 2026 07:01:43 +0000 (10:01 +0300)
Fix the error path during DDI encoder/connector initialization by
calling the missing TC port cleanup function.

This fixes the leaked TC port state.

Reviewed-by: Jouni Högander <jouni.hogander@intel.com>
Signed-off-by: Imre Deak <imre.deak@intel.com>
Link: https://patch.msgid.link/20260507065940.2046690-1-imre.deak@intel.com
drivers/gpu/drm/i915/display/intel_ddi.c

index 2681940a5cfe35aba4941dc50b44161bf5920216..e37cc32ee83ed2af00786f047de87208da35376b 100644 (file)
@@ -5411,7 +5411,7 @@ void intel_ddi_init(struct intel_display *display,
        if (need_aux_ch(encoder, init_dp)) {
                dig_port->aux_ch = intel_dp_aux_ch(encoder);
                if (dig_port->aux_ch == AUX_CH_NONE)
-                       goto err;
+                       goto err_aux_ch_init;
        }
 
        /*
@@ -5447,7 +5447,7 @@ void intel_ddi_init(struct intel_display *display,
                dig_port->unlock = intel_tc_port_unlock;
 
                if (intel_tc_port_init(dig_port, is_legacy) < 0)
-                       goto err;
+                       goto err_aux_ch_init;
        }
 
        drm_WARN_ON(display->drm, port > PORT_I);
@@ -5478,7 +5478,7 @@ void intel_ddi_init(struct intel_display *display,
 
        if (init_dp) {
                if (intel_ddi_init_dp_connector(dig_port))
-                       goto err;
+                       goto err_dp_connector_init;
 
                dig_port->hpd_pulse = intel_dp_hpd_pulse;
 
@@ -5492,12 +5492,15 @@ void intel_ddi_init(struct intel_display *display,
         */
        if (encoder->type != INTEL_OUTPUT_EDP && init_hdmi) {
                if (intel_ddi_init_hdmi_connector(dig_port))
-                       goto err;
+                       goto err_dp_connector_init;
        }
 
        return;
 
-err:
+err_dp_connector_init:
+       if (intel_encoder_is_tc(encoder))
+               intel_tc_port_cleanup(dig_port);
+err_aux_ch_init:
        drm_encoder_cleanup(&encoder->base);
        kfree(dig_port);
 }