linux-kernel.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH 0/2] drm/vc4: hdmi: Get rid of encoder->crtc, take 2
@ 2021-09-24 13:55 Maxime Ripard
  2021-09-24 13:55 ` [PATCH 1/2] drm/vc4: hdmi: Check the device state in prepare() Maxime Ripard
  2021-09-24 13:55 ` [PATCH 2/2] drm/vc4: hdmi: Remove drm_encoder->crtc usage Maxime Ripard
  0 siblings, 2 replies; 5+ messages in thread
From: Maxime Ripard @ 2021-09-24 13:55 UTC (permalink / raw)
  To: Maarten Lankhorst, Thomas Zimmermann, Maxime Ripard
  Cc: Daniel Vetter, David Airlie, dri-devel, Linus Torvalds,
	linux-kernel, Sudip Mukherjee

Hi,

Following the report from Sudip Mukherjee, the previous version of that patch
got reverted until a fix was found.

While it's not clear yet why we end up in that situation, the culprit is that
the original patch in its ASoC prepare hook was calling the vc4_hdmi_set_n_cts
function that in turned relied on the connector->state->crtc pointer being
non-NULL.

However, no particular caution was being done to make sure that was the case,
eventually leading to a NULL pointer dereference under the "right"
circumstances.

We did however had some checks for the pointers sanity in the original patch,
but they were only enforced when the device was opened, and we were only
checking for the connector->state pointer.

The fix is then two-fold: First, we check that we can actually perform audio
operations in both startup and prepare, since the situation could have changed
between the time the device was opened and the time when we actually start
streaming. Then, the encoder->crtc conversion patch has been changed to check
on connector->state->crtc as well in that sanity check to avoid dereferencing
it if it's NULL.

Let me know what you think,
Maxime

Maxime Ripard (2):
  drm/vc4: hdmi: Check the device state in prepare()
  drm/vc4: hdmi: Remove drm_encoder->crtc usage

 drivers/gpu/drm/vc4/vc4_hdmi.c | 75 ++++++++++++++++++++++++++--------
 1 file changed, 57 insertions(+), 18 deletions(-)

-- 
2.31.1


^ permalink raw reply	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2021-09-26 21:26 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2021-09-24 13:55 [PATCH 0/2] drm/vc4: hdmi: Get rid of encoder->crtc, take 2 Maxime Ripard
2021-09-24 13:55 ` [PATCH 1/2] drm/vc4: hdmi: Check the device state in prepare() Maxime Ripard
2021-09-26 21:24   ` Sudip Mukherjee
2021-09-24 13:55 ` [PATCH 2/2] drm/vc4: hdmi: Remove drm_encoder->crtc usage Maxime Ripard
2021-09-26 21:25   ` Sudip Mukherjee

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).