[PATCH 10/14] drm/atomic-helper: Disable planes when suspending
Ying Liu
gnuiyl at gmail.com
Wed May 25 09:30:05 UTC 2016
On Tue, May 24, 2016 at 7:00 PM, Daniel Vetter <daniel at ffwll.ch> wrote:
> On Tue, May 24, 2016 at 06:10:49PM +0800, Liu Ying wrote:
>> 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>
>
> Recommended way is to call drm_atomic_helper_disable_planes_on_crtc in
> your crtc's ->disable() callback if your hw needs this. This is a general
> problem (test e.g. dpms), not just an issue in suspend code.
It looks legacy fbdev unblank operation fails after call that function
in ->disable(). I made the change on top of this patch set.
If you have any idea, please help out here.
Regards,
Liu Ying
>
> Also unsetting the planes from state has a semantic meaning: It unpins the
> backing storage, which is definitely not what we want for suspend/resume.
> -Daniel
>
>> ---
>> 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
>>
>> _______________________________________________
>> dri-devel mailing list
>> dri-devel at lists.freedesktop.org
>> https://lists.freedesktop.org/mailman/listinfo/dri-devel
>
> --
> Daniel Vetter
> Software Engineer, Intel Corporation
> http://blog.ffwll.ch
More information about the dri-devel
mailing list