]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
drm/amd/display: Clear HDMI HPD pending work only if it is enabled
authorIvan Lipski <ivan.lipski@amd.com>
Fri, 16 Jan 2026 15:03:54 +0000 (10:03 -0500)
committerAlex Deucher <alexander.deucher@amd.com>
Tue, 20 Jan 2026 22:17:54 +0000 (17:17 -0500)
[Why&How]
On amdgpu_dm_connector_destroy(), the driver attempts to cancel pending
HDMI HPD work without checking if the HDMI HPD is enabled.

Added a check that it is enabled before clearing it.

Fixes: 6a681cd90345 ("drm/amd/display: Add an hdmi_hpd_debounce_delay_ms module")
Signed-off-by: Ivan Lipski <ivan.lipski@amd.com>
Reviewed-by: Mario Limonciello (AMD) <superm1@kernel.org>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c

index cb13a2b0de62ab88ab8638d7c9a563496609f5c7..da8bc02c0f5bb5bd94799813abb8186825848fa5 100644 (file)
@@ -7768,10 +7768,12 @@ static void amdgpu_dm_connector_destroy(struct drm_connector *connector)
                drm_dp_mst_topology_mgr_destroy(&aconnector->mst_mgr);
 
        /* Cancel and flush any pending HDMI HPD debounce work */
-       cancel_delayed_work_sync(&aconnector->hdmi_hpd_debounce_work);
-       if (aconnector->hdmi_prev_sink) {
-               dc_sink_release(aconnector->hdmi_prev_sink);
-               aconnector->hdmi_prev_sink = NULL;
+       if (aconnector->hdmi_hpd_debounce_delay_ms) {
+               cancel_delayed_work_sync(&aconnector->hdmi_hpd_debounce_work);
+               if (aconnector->hdmi_prev_sink) {
+                       dc_sink_release(aconnector->hdmi_prev_sink);
+                       aconnector->hdmi_prev_sink = NULL;
+               }
        }
 
        if (aconnector->bl_idx != -1) {