Maxime Ripard ddadd40892
drm: Introduce an atomic_commit_setup function
Private objects storing a state shared across all CRTCs need to be
carefully handled to avoid a use-after-free issue.

The proper way to do this to track all the commits using that shared
state and wait for the previous commits to be done before going on with
the current one to avoid the reordering of commits that could occur.

However, this commit setup needs to be done after
drm_atomic_helper_setup_commit(), because before the CRTC commit
structure hasn't been allocated before, and before the workqueue is
scheduled, because we would be potentially reordered already otherwise.

That means that drivers currently have to roll their own
drm_atomic_helper_commit() function, even though it would be identical
if not for the commit setup.

Let's introduce a hook to do so that would be called as part of
drm_atomic_helper_commit, allowing us to reuse the atomic helpers.

Reviewed-by: Daniel Vetter <daniel.vetter@ffwll.ch>
Suggested-by: Daniel Vetter <daniel.vetter@ffwll.ch>
Signed-off-by: Maxime Ripard <maxime@cerno.tech>
Link: https://patchwork.freedesktop.org/patch/msgid/20201204151138.1739736-2-maxime@cerno.tech
2020-12-15 11:33:08 +01:00
..
2020-12-14 14:20:46 +01:00
2019-10-31 15:03:10 -07:00
2020-11-16 20:48:20 +01:00
2020-11-06 10:31:26 +01:00
2020-11-16 20:48:20 +01:00
2020-04-22 10:41:35 +10:00
2020-04-22 10:41:35 +10:00
2020-06-24 09:17:34 +02:00
2020-09-17 13:39:44 +02:00
2020-11-20 11:55:41 +01:00
2020-07-16 18:16:31 -04:00
2020-07-16 18:16:31 -04:00
2020-11-06 14:09:30 +02:00
2019-12-18 16:09:12 -05:00