drm/amdgpu: simplify runtime suspend
authorAlex Deucher <alexander.deucher@amd.com>
Wed, 20 Nov 2019 19:20:32 +0000 (14:20 -0500)
committerAlex Deucher <alexander.deucher@amd.com>
Fri, 22 Nov 2019 19:27:11 +0000 (14:27 -0500)
In the standard _PR3 case, the pci core handles the pci state.
The driver only needs to handle it in the legacy ATPX case.

This may fix issues with runtime suspend/resume on certain
hybrid graphics laptops.

Acked-by: Evan Quan <evan.quan@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/amdgpu/amdgpu_drv.c

index 348eb2f..459bca6 100644 (file)
@@ -1216,13 +1216,17 @@ static int amdgpu_pmops_runtime_suspend(struct device *dev)
 
        ret = amdgpu_device_suspend(drm_dev, false, false);
        if (amdgpu_device_supports_boco(drm_dev)) {
-               pci_save_state(pdev);
-               pci_disable_device(pdev);
-               pci_ignore_hotplug(pdev);
-               if (amdgpu_is_atpx_hybrid())
+               /* Only need to handle PCI state in the driver for ATPX
+                * PCI core handles it for _PR3.
+                */
+               if (amdgpu_is_atpx_hybrid()) {
+                       pci_ignore_hotplug(pdev);
+               } else {
+                       pci_save_state(pdev);
+                       pci_disable_device(pdev);
+                       pci_ignore_hotplug(pdev);
                        pci_set_power_state(pdev, PCI_D3cold);
-               else if (!amdgpu_has_atpx_dgpu_power_cntl())
-                       pci_set_power_state(pdev, PCI_D3hot);
+               }
                drm_dev->switch_power_state = DRM_SWITCH_POWER_DYNAMIC_OFF;
        } else if (amdgpu_device_supports_baco(drm_dev)) {
                amdgpu_device_baco_enter(drm_dev);
@@ -1244,14 +1248,19 @@ static int amdgpu_pmops_runtime_resume(struct device *dev)
        if (amdgpu_device_supports_boco(drm_dev)) {
                drm_dev->switch_power_state = DRM_SWITCH_POWER_CHANGING;
 
-               if (amdgpu_is_atpx_hybrid() ||
-                   !amdgpu_has_atpx_dgpu_power_cntl())
+               /* Only need to handle PCI state in the driver for ATPX
+                * PCI core handles it for _PR3.
+                */
+               if (amdgpu_is_atpx_hybrid()) {
+                       pci_set_master(pdev);
+               } else {
                        pci_set_power_state(pdev, PCI_D0);
-               pci_restore_state(pdev);
-               ret = pci_enable_device(pdev);
-               if (ret)
-                       return ret;
-               pci_set_master(pdev);
+                       pci_restore_state(pdev);
+                       ret = pci_enable_device(pdev);
+                       if (ret)
+                               return ret;
+                       pci_set_master(pdev);
+               }
        } else if (amdgpu_device_supports_baco(drm_dev)) {
                amdgpu_device_baco_exit(drm_dev);
        }