]> 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>
Wed, 28 Jan 2026 20:16:34 +0000 (15:16 -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>
(cherry picked from commit 17b2c526fd8026d8e0f4c0e7f94fc517e3901589)

drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c

index 1ea5a250440f6076ae3af3f2130fb71256e53740..a8a59126b2d2b0c1730eb545e7ab7ab729ce8096 100644 (file)
@@ -7754,10 +7754,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) {