5c40752a1b
commit 95d4b471953411854f9c80b568da7fcf753f3801 upstream. tidss_crtc_atomic_flush() checks if the crtc is enabled, and if not, returns immediately as there's no reason to do any register changes. However, the code checks for 'crtc->state->enable', which does not reflect the actual HW state. We should instead look at the 'crtc->state->active' flag. This causes the tidss_crtc_atomic_flush() to proceed with the flush even if the active state is false, which then causes us to hit the WARN_ON(!crtc->state->event) check. Fix this by checking the active flag, and while at it, fix the related debug print which had "active" and "needs modeset" wrong way. Cc: <stable@vger.kernel.org> Fixes: 32a1795f57ee ("drm/tidss: New driver for TI Keystone platform Display SubSystem") Reviewed-by: Aradhya Bhatia <a-bhatia1@ti.com> Link: https://lore.kernel.org/r/20231109-tidss-probe-v2-10-ac91b5ea35c0@ideasonboard.com Signed-off-by: Tomi Valkeinen <tomi.valkeinen@ideasonboard.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org> |
||
---|---|---|
.. | ||
Kconfig | ||
Makefile | ||
tidss_crtc.c | ||
tidss_crtc.h | ||
tidss_dispc.c | ||
tidss_dispc.h | ||
tidss_dispc_regs.h | ||
tidss_drv.c | ||
tidss_drv.h | ||
tidss_encoder.c | ||
tidss_encoder.h | ||
tidss_irq.c | ||
tidss_irq.h | ||
tidss_kms.c | ||
tidss_kms.h | ||
tidss_plane.c | ||
tidss_plane.h | ||
tidss_scale_coefs.c | ||
tidss_scale_coefs.h |