[PATCH 10/14] drm/atomic-helper: Disable planes when suspending

Liu Ying gnuiyl at gmail.com
Tue May 24 10:10:49 UTC 2016


We should disable planes explicitly when suspending.
Especially, this is meaningful for those display controllers which
don't support active planes without relevant CRTCs being enabled.

Signed-off-by: Liu Ying <gnuiyl at gmail.com>
---
 drivers/gpu/drm/drm_atomic_helper.c | 18 +++++++++++++++++-
 1 file changed, 17 insertions(+), 1 deletion(-)

diff --git a/drivers/gpu/drm/drm_atomic_helper.c b/drivers/gpu/drm/drm_atomic_helper.c
index 4befe25..5331d95 100644
--- a/drivers/gpu/drm/drm_atomic_helper.c
+++ b/drivers/gpu/drm/drm_atomic_helper.c
@@ -1967,7 +1967,7 @@ commit:
  *
  * Loops through all connectors, finding those that aren't turned off and then
  * turns them off by setting their DPMS mode to OFF and deactivating the CRTC
- * that they are connected to.
+ * that they are connected to.  The relevant planes are deactivated as well.
  *
  * This is used for example in suspend/resume to disable all currently active
  * functions when suspending.
@@ -1997,6 +1997,7 @@ int drm_atomic_helper_disable_all(struct drm_device *dev,
 	drm_for_each_connector(conn, dev) {
 		struct drm_crtc *crtc = conn->state->crtc;
 		struct drm_crtc_state *crtc_state;
+		struct drm_plane *plane;
 
 		if (!crtc || conn->dpms != DRM_MODE_DPMS_ON)
 			continue;
@@ -2008,6 +2009,21 @@ int drm_atomic_helper_disable_all(struct drm_device *dev,
 		}
 
 		crtc_state->active = false;
+
+		drm_for_each_plane_mask(plane, dev, crtc_state->plane_mask) {
+			struct drm_plane_state *plane_state;
+
+			plane_state = drm_atomic_get_plane_state(state, plane);
+			if (IS_ERR(plane_state)) {
+				err = PTR_ERR(plane_state);
+				goto free;
+			}
+
+			err = drm_atomic_set_crtc_for_plane(plane_state, NULL);
+			if (err != 0)
+				goto free;
+			drm_atomic_set_fb_for_plane(plane_state, NULL);
+		}
 	}
 
 	err = drm_atomic_commit(state);
-- 
2.7.4



More information about the dri-devel mailing list