1 // SPDX-License-Identifier: GPL-2.0-only
3 * Copyright (C) 2014 Red Hat
4 * Author: Rob Clark <robdclark@gmail.com>
7 #include <drm/drm_atomic_uapi.h>
13 static void msm_atomic_wait_for_commit_done(struct drm_device *dev,
14 struct drm_atomic_state *old_state)
16 struct drm_crtc *crtc;
17 struct drm_crtc_state *new_crtc_state;
18 struct msm_drm_private *priv = old_state->dev->dev_private;
19 struct msm_kms *kms = priv->kms;
22 for_each_new_crtc_in_state(old_state, crtc, new_crtc_state, i) {
23 if (!new_crtc_state->active)
26 if (drm_crtc_vblank_get(crtc))
29 kms->funcs->wait_for_crtc_commit_done(kms, crtc);
31 drm_crtc_vblank_put(crtc);
35 int msm_atomic_prepare_fb(struct drm_plane *plane,
36 struct drm_plane_state *new_state)
38 struct msm_drm_private *priv = plane->dev->dev_private;
39 struct msm_kms *kms = priv->kms;
40 struct drm_gem_object *obj;
41 struct dma_fence *fence;
46 obj = msm_framebuffer_bo(new_state->fb, 0);
47 fence = reservation_object_get_excl_rcu(obj->resv);
49 drm_atomic_set_fence_for_plane(new_state, fence);
51 return msm_framebuffer_prepare(new_state->fb, kms->aspace);
54 void msm_atomic_commit_tail(struct drm_atomic_state *state)
56 struct drm_device *dev = state->dev;
57 struct msm_drm_private *priv = dev->dev_private;
58 struct msm_kms *kms = priv->kms;
60 kms->funcs->prepare_commit(kms, state);
62 drm_atomic_helper_commit_modeset_disables(dev, state);
64 drm_atomic_helper_commit_planes(dev, state, 0);
66 drm_atomic_helper_commit_modeset_enables(dev, state);
68 if (kms->funcs->commit) {
69 DRM_DEBUG_ATOMIC("triggering commit\n");
70 kms->funcs->commit(kms, state);
73 if (!state->legacy_cursor_update)
74 msm_atomic_wait_for_commit_done(dev, state);
76 kms->funcs->complete_commit(kms, state);
78 drm_atomic_helper_commit_hw_done(state);
80 drm_atomic_helper_cleanup_planes(dev, state);