Hi Alex:

According to my understanding, in our driver, amdgpu_device_suspend/resume. the 
paremeter 'suspend' or 'resume' mean the apdpter is set to D3, and we need 
power on it at resume. In S4 , the function freeze() , thraw() , poweroff() and 
restore() is special for hibernation,  S3 process could not call these 
functions.  so far, according to  my experiment, we must reset asic if adapter 
is not power down in S4, otherwise, it will be GFX(compute) , SDMA ring test 
failure on VI(not sure it will be on SI), it seems that aisc reset is not must 
on CI.

I do not review our runtime PM code, but, based on currently code ,  I can be 
sure that asic must be reset if it is suspended without powerdown.

BTW, driver dpm does not work when resume back after hibernation on CI.

Thanks
JimQu

________________________________________
发件人: Deucher, Alexander
发送时间: 2016年9月7日 19:15:22
收件人: Qu, Jim; amd-gfx@lists.freedesktop.org
抄送: Qu, Jim
主题: RE: [PATCH v2] drm/amd/amdgpu: S4 issue for amdgpu

> -----Original Message-----
> From: amd-gfx [mailto:amd-gfx-boun...@lists.freedesktop.org] On Behalf
> Of jimqu
> Sent: Saturday, September 03, 2016 2:57 AM
> To: amd-gfx@lists.freedesktop.org
> Cc: Qu, Jim
> Subject: [PATCH v2] drm/amd/amdgpu: S4 issue for amdgpu
>
> reset the asic if adapter is not powerdown when doing freeze()
> thaw() and restore(), in order to get a valid state of adapter.
>
> Change-Id: Ibb03ab3c2ce6ef3c83affbe767308dc22474f563
> Signed-off-by: JimQu <jim...@amd.com>
> ---
>  drivers/gpu/drm/amd/amdgpu/amdgpu_device.c | 19 +++++++++++++-----
> -
>  drivers/gpu/drm/amd/amdgpu/amdgpu_drv.c    | 18 ++++++++++++++++--
>  2 files changed, 29 insertions(+), 8 deletions(-)
>
> diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_device.c
> b/drivers/gpu/drm/amd/amdgpu/amdgpu_device.c
> index 6510514..f17fc6d 100644
> --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_device.c
> +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_device.c
> @@ -1937,6 +1937,10 @@ int amdgpu_device_suspend(struct drm_device
> *dev, bool suspend, bool fbcon)
>               /* Shut down the device */
>               pci_disable_device(dev->pdev);
>               pci_set_power_state(dev->pdev, PCI_D3hot);
> +     } else {
> +             r = amdgpu_asic_reset(adev);
> +             if (r)
> +                     DRM_ERROR("amdgpu asic reset failed\n");

Do we want to guard this with a separate parameter?   Are there use cases where 
we may not want D3 or GPU reset?  Runtime pm for PX comes to mind.  That said, 
it probably won't hurt in that case either.

Alex

>       }
>
>       if (fbcon) {
> @@ -1967,22 +1971,25 @@ int amdgpu_device_resume(struct drm_device
> *dev, bool resume, bool fbcon)
>           dev->switch_power_state ==
> DRM_SWITCH_POWER_DYNAMIC_OFF)
>               return 0;
>
> -     if (fbcon) {
> +     if (fbcon)
>               console_lock();
> -     }
> +
>       if (resume) {
>               pci_set_power_state(dev->pdev, PCI_D0);
>               pci_restore_state(dev->pdev);
> -             if (pci_enable_device(dev->pdev)) {
> +             if (r = pci_enable_device(dev->pdev)) {
>                       if (fbcon)
>                               console_unlock();
> -                     return -1;
> +                     return r;
>               }
>       }
>
>       /* post card */
> -     if (!amdgpu_card_posted(adev))
> -             amdgpu_atom_asic_init(adev->mode_info.atom_context);
> +     if (!amdgpu_card_posted(adev) || !resume) {
> +             r = amdgpu_atom_asic_init(adev-
> >mode_info.atom_context);
> +             if (r)
> +                     DRM_ERROR("amdgpu asic init failed\n");
> +     }
>
>       r = amdgpu_resume(adev);
>       if (r)
> diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_drv.c
> b/drivers/gpu/drm/amd/amdgpu/amdgpu_drv.c
> index 21b8cd6..c00f4a8 100644
> --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_drv.c
> +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_drv.c
> @@ -520,6 +520,20 @@ static int amdgpu_pmops_thaw(struct device *dev)
>       return amdgpu_device_resume(drm_dev, false, true);
>  }
>
> +static int amdgpu_pmops_poweroff(struct device *dev)
> +{
> +     struct pci_dev *pdev = to_pci_dev(dev);
> +     struct drm_device *drm_dev = pci_get_drvdata(pdev);
> +     return amdgpu_device_suspend(drm_dev, true, true);
> +}
> +
> +static int amdgpu_pmops_restore(struct device *dev)
> +{
> +     struct pci_dev *pdev = to_pci_dev(dev);
> +     struct drm_device *drm_dev = pci_get_drvdata(pdev);
> +     return amdgpu_device_resume(drm_dev, false, true);
> +}
> +
>  static int amdgpu_pmops_runtime_suspend(struct device *dev)
>  {
>       struct pci_dev *pdev = to_pci_dev(dev);
> @@ -622,8 +636,8 @@ static const struct dev_pm_ops amdgpu_pm_ops = {
>       .resume = amdgpu_pmops_resume,
>       .freeze = amdgpu_pmops_freeze,
>       .thaw = amdgpu_pmops_thaw,
> -     .poweroff = amdgpu_pmops_freeze,
> -     .restore = amdgpu_pmops_resume,
> +     .poweroff = amdgpu_pmops_poweroff,
> +     .restore = amdgpu_pmops_restore,
>       .runtime_suspend = amdgpu_pmops_runtime_suspend,
>       .runtime_resume = amdgpu_pmops_runtime_resume,
>       .runtime_idle = amdgpu_pmops_runtime_idle,
> --
> 1.9.1
>
> _______________________________________________
> amd-gfx mailing list
> amd-gfx@lists.freedesktop.org
> https://lists.freedesktop.org/mailman/listinfo/amd-gfx
_______________________________________________
amd-gfx mailing list
amd-gfx@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/amd-gfx

Reply via email to