]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
drm: allow encoder mode_set even when connectors change for crtc
authorAbhinav Kumar <quic_abhinavk@quicinc.com>
Wed, 11 Dec 2024 21:18:42 +0000 (13:18 -0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Fri, 2 May 2025 05:40:50 +0000 (07:40 +0200)
[ Upstream commit 7e182cb4f5567f53417b762ec0d679f0b6f0039d ]

In certain use-cases, a CRTC could switch between two encoders
and because the mode being programmed on the CRTC remains
the same during this switch, the CRTC's mode_changed remains false.
In such cases, the encoder's mode_set also gets skipped.

Skipping mode_set on the encoder for such cases could cause an issue
because even though the same CRTC mode was being used, the encoder
type could have changed like the CRTC could have switched from a
real time encoder to a writeback encoder OR vice-versa.

Allow encoder's mode_set to happen even when connectors changed on a
CRTC and not just when the mode changed.

Signed-off-by: Abhinav Kumar <quic_abhinavk@quicinc.com>
Signed-off-by: Jessica Zhang <quic_jesszhan@quicinc.com>
Reviewed-by: Maxime Ripard <mripard@kernel.org>
Link: https://patchwork.freedesktop.org/patch/msgid/20241211-abhinavk-modeset-fix-v3-1-0de4bf3e7c32@quicinc.com
Signed-off-by: Dmitry Baryshkov <dmitry.baryshkov@linaro.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/gpu/drm/drm_atomic_helper.c

index 0fde260b7edd8f3815b9315e3dbe9dcf5a62c786..dee3b81dec587af7d607ece48acae6f3416431a3 100644 (file)
@@ -1268,7 +1268,7 @@ crtc_set_mode(struct drm_device *dev, struct drm_atomic_state *old_state)
                mode = &new_crtc_state->mode;
                adjusted_mode = &new_crtc_state->adjusted_mode;
 
-               if (!new_crtc_state->mode_changed)
+               if (!new_crtc_state->mode_changed && !new_crtc_state->connectors_changed)
                        continue;
 
                DRM_DEBUG_ATOMIC("modeset on [ENCODER:%d:%s]\n",