Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 1f2d9bdc authored by Daniel Vetter's avatar Daniel Vetter Committed by Maarten Lankhorst
Browse files

drm/atomic-helper: always track connector commits, too



It's useful for syncing async connector work like link retraining.

v2: Make it work (Manasi&Ville)

Cc: Manasi Navare <manasi.d.navare@intel.com>
Cc: Maarten Lankhorst <maarten.lankhorst@linux.intel.com>
Cc: Ville Syrjälä <ville.syrjala@linux.intel.com>
Signed-off-by: default avatarDaniel Vetter <daniel.vetter@intel.com>
Reviewed-by: default avatarMaarten Lankhorst <maarten.lankhorst@linux.intel.com>
Signed-off-by: default avatarMaarten Lankhorst <maarten.lankhorst@linux.intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20171110105313.16718-1-daniel.vetter@ffwll.ch
parent 3df67458
Loading
Loading
Loading
Loading
+3 −9
Original line number Diff line number Diff line
@@ -1793,11 +1793,8 @@ int drm_atomic_helper_setup_commit(struct drm_atomic_state *state,
		    !try_wait_for_completion(&old_conn_state->commit->flip_done))
			return -EBUSY;

		/* commit tracked through new_crtc_state->commit, no need to do it explicitly */
		if (new_conn_state->crtc)
			continue;

		commit = crtc_or_fake_commit(state, old_conn_state->crtc);
		/* Always track connectors explicitly for e.g. link retraining. */
		commit = crtc_or_fake_commit(state, new_conn_state->crtc ?: old_conn_state->crtc);
		if (!commit)
			return -ENOMEM;

@@ -1811,10 +1808,7 @@ int drm_atomic_helper_setup_commit(struct drm_atomic_state *state,
		    !try_wait_for_completion(&old_plane_state->commit->flip_done))
			return -EBUSY;

		/*
		 * Unlike connectors, always track planes explicitly for
		 * async pageflip support.
		 */
		/* Always track planes explicitly for async pageflip support. */
		commit = crtc_or_fake_commit(state, new_plane_state->crtc ?: old_plane_state->crtc);
		if (!commit)
			return -ENOMEM;