diff options
Diffstat (limited to 'drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c')
| -rw-r--r-- | drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c | 9 | 
1 files changed, 6 insertions, 3 deletions
| diff --git a/drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c b/drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c index 90f64b8bc358..be289f0fff37 100644 --- a/drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c +++ b/drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c @@ -4374,9 +4374,12 @@ static int gfx_v9_0_ecc_late_init(void *handle)  	struct amdgpu_device *adev = (struct amdgpu_device *)handle;  	int r; -	r = gfx_v9_0_do_edc_gds_workarounds(adev); -	if (r) -		return r; +	/* limit gds clearing operation in cold boot sequence */ +	if (!adev->in_suspend) { +		r = gfx_v9_0_do_edc_gds_workarounds(adev); +		if (r) +			return r; +	}  	/* requires IBs so do in late init after IB pool is initialized */  	r = gfx_v9_0_do_edc_gpr_workarounds(adev); | 

