[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