[PATCH v2 4/6] drm/fsl-dcu: Use drm_mode_config_helper_suspend/resume()
Stefan Agner
stefan at agner.ch
Thu Nov 9 17:18:41 UTC 2017
On 2017-11-09 17:49, Noralf Trønnes wrote:
> Den 09.11.2017 15.34, skrev Stefan Agner:
>> On 2017-11-06 20:18, Noralf Trønnes wrote:
>>> Replace driver's code with the generic helpers that do the same thing.
>> Tested using:
>> echo devices > /sys/power/pm_test
>> echo freeze > /sys/power/state
>>
>>
>> Note, currently I do get, but even without this patches, so this is
>> something else:
>>
>> [ 930.992433] ------------[ cut here ]------------
>> [ 930.992494] WARNING: CPU: 0 PID: 361 at
>> drivers/gpu/drm/drm_atomic_helper.c:1249
>> drm_atomic_helper_wait_for_vblanks.part.1+0x284/0x288
>> [ 930.992502] [CRTC:28:crtc-0] vblank wait timed out
>>
>>
>> Tested-by: Stefan Agner <stefan at agner.ch>
>> Acked-by: Stefan Agner <stefan at agner.ch>
>>
>> Will you take the patch through drm-misc?
>
> Yes if that's fine with you, thanks for testing.
Yes, fine for me!
Thanks,
Stefan
>
> Noralf.
>
>> --
>> Stefan
>>
>>
>>
>>> Cc: Stefan Agner <stefan at agner.ch>
>>> Cc: Alison Wang <alison.wang at freescale.com>
>>> Signed-off-by: Noralf Trønnes <noralf at tronnes.org>
>>> ---
>>> drivers/gpu/drm/fsl-dcu/fsl_dcu_drm_drv.c | 24 ++++++------------------
>>> drivers/gpu/drm/fsl-dcu/fsl_dcu_drm_drv.h | 1 -
>>> 2 files changed, 6 insertions(+), 19 deletions(-)
>>>
>>> diff --git a/drivers/gpu/drm/fsl-dcu/fsl_dcu_drm_drv.c
>>> b/drivers/gpu/drm/fsl-dcu/fsl_dcu_drm_drv.c
>>> index 58e9e0601a61..1a9ee657bbac 100644
>>> --- a/drivers/gpu/drm/fsl-dcu/fsl_dcu_drm_drv.c
>>> +++ b/drivers/gpu/drm/fsl-dcu/fsl_dcu_drm_drv.c
>>> @@ -27,6 +27,7 @@
>>> #include <drm/drm_crtc_helper.h>
>>> #include <drm/drm_fb_cma_helper.h>
>>> #include <drm/drm_gem_cma_helper.h>
>>> +#include <drm/drm_modeset_helper.h>
>>> #include "fsl_dcu_drm_crtc.h"
>>> #include "fsl_dcu_drm_drv.h"
>>> @@ -188,26 +189,17 @@ static struct drm_driver fsl_dcu_drm_driver = {
>>> static int fsl_dcu_drm_pm_suspend(struct device *dev)
>>> {
>>> struct fsl_dcu_drm_device *fsl_dev = dev_get_drvdata(dev);
>>> + int ret;
>>> if (!fsl_dev)
>>> return 0;
>>> disable_irq(fsl_dev->irq);
>>> - drm_kms_helper_poll_disable(fsl_dev->drm);
>>> - console_lock();
>>> - drm_fbdev_cma_set_suspend(fsl_dev->fbdev, 1);
>>> - console_unlock();
>>> -
>>> - fsl_dev->state = drm_atomic_helper_suspend(fsl_dev->drm);
>>> - if (IS_ERR(fsl_dev->state)) {
>>> - console_lock();
>>> - drm_fbdev_cma_set_suspend(fsl_dev->fbdev, 0);
>>> - console_unlock();
>>> -
>>> - drm_kms_helper_poll_enable(fsl_dev->drm);
>>> + ret = drm_mode_config_helper_suspend(fsl_dev->drm);
>>> + if (ret) {
>>> enable_irq(fsl_dev->irq);
>>> - return PTR_ERR(fsl_dev->state);
>>> + return ret;
>>> }
>>> clk_disable_unprepare(fsl_dev->pix_clk);
>>> @@ -233,13 +225,9 @@ static int fsl_dcu_drm_pm_resume(struct device *dev)
>>> if (fsl_dev->tcon)
>>> fsl_tcon_bypass_enable(fsl_dev->tcon);
>>> fsl_dcu_drm_init_planes(fsl_dev->drm);
>>> - drm_atomic_helper_resume(fsl_dev->drm, fsl_dev->state);
>>> - console_lock();
>>> - drm_fbdev_cma_set_suspend(fsl_dev->fbdev, 0);
>>> - console_unlock();
>>> + drm_mode_config_helper_resume(fsl_dev->drm);
>>> - drm_kms_helper_poll_enable(fsl_dev->drm);
>>> enable_irq(fsl_dev->irq);
>>> return 0;
>>> diff --git a/drivers/gpu/drm/fsl-dcu/fsl_dcu_drm_drv.h
>>> b/drivers/gpu/drm/fsl-dcu/fsl_dcu_drm_drv.h
>>> index da9bfd432ca6..93bfb98012d4 100644
>>> --- a/drivers/gpu/drm/fsl-dcu/fsl_dcu_drm_drv.h
>>> +++ b/drivers/gpu/drm/fsl-dcu/fsl_dcu_drm_drv.h
>>> @@ -196,7 +196,6 @@ struct fsl_dcu_drm_device {
>>> struct drm_encoder encoder;
>>> struct fsl_dcu_drm_connector connector;
>>> const struct fsl_dcu_soc_data *soc;
>>> - struct drm_atomic_state *state;
>>> };
>>> int fsl_dcu_drm_modeset_init(struct fsl_dcu_drm_device *fsl_dev);
More information about the dri-devel
mailing list