If IP suspend fails the callers should be notified so that they can
potentially react.

Signed-off-by: Mario Limonciello <[email protected]>
---
 drivers/gpu/drm/amd/amdgpu/amdgpu_device.c | 11 ++++++++---
 1 file changed, 8 insertions(+), 3 deletions(-)

diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_device.c 
b/drivers/gpu/drm/amd/amdgpu/amdgpu_device.c
index 1ad54dda6bcb..e16cf64dddba 100644
--- a/drivers/gpu/drm/amd/amdgpu/amdgpu_device.c
+++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_device.c
@@ -3855,8 +3855,9 @@ static int amdgpu_device_ip_suspend_phase2(struct 
amdgpu_device *adev)
                    adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_PSP)
                        continue;
 
-               /* XXX handle errors */
                r = amdgpu_ip_block_suspend(&adev->ip_blocks[i]);
+               if (r)
+                       return r;
 
                /* handle putting the SMC in the appropriate state */
                if (!amdgpu_sriov_vf(adev)) {
@@ -5216,7 +5217,9 @@ int amdgpu_device_suspend(struct drm_device *dev, bool 
notify_clients)
 
        amdgpu_ras_suspend(adev);
 
-       amdgpu_device_ip_suspend_phase1(adev);
+       r = amdgpu_device_ip_suspend_phase1(adev);
+       if (r)
+               return r;
 
        amdgpu_amdkfd_suspend(adev, !amdgpu_sriov_vf(adev) && !adev->in_runpm);
        amdgpu_userq_suspend(adev);
@@ -5229,7 +5232,9 @@ int amdgpu_device_suspend(struct drm_device *dev, bool 
notify_clients)
 
        amdgpu_fence_driver_hw_fini(adev);
 
-       amdgpu_device_ip_suspend_phase2(adev);
+       r = amdgpu_device_ip_suspend_phase2(adev);
+       if (r)
+               return r;
 
        if (amdgpu_sriov_vf(adev))
                amdgpu_virt_release_full_gpu(adev, false);
-- 
2.51.0

Reply via email to