diff options
| author | Sunil Khatri <sunil.khatri@amd.com> | 2024-10-17 17:04:27 +0300 | 
|---|---|---|
| committer | Alex Deucher <alexander.deucher@amd.com> | 2024-10-23 00:50:39 +0300 | 
| commit | 502d76308d45a9ef79b9266c5a090e9e6954faaa (patch) | |
| tree | ef164d1642eda454e7faf8654ce46d874732b90c /drivers/gpu/drm/amd/amdgpu/aldebaran.c | |
| parent | e095026f0066eca05268b20a6f378cf31bedc54b (diff) | |
| download | linux-502d76308d45a9ef79b9266c5a090e9e6954faaa.tar.xz | |
drm/amdgpu: validate resume before function call
Before making a function call to resume, validate
the function pointer like we do in sw_init.
Use the helper function amdgpu_ip_block_resume where
same checks and calls are repeated.
Signed-off-by: Sunil Khatri <sunil.khatri@amd.com>
Reviewed-by: Christian König <christian.koenig@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
Diffstat (limited to 'drivers/gpu/drm/amd/amdgpu/aldebaran.c')
| -rw-r--r-- | drivers/gpu/drm/amd/amdgpu/aldebaran.c | 13 | 
1 files changed, 4 insertions, 9 deletions
diff --git a/drivers/gpu/drm/amd/amdgpu/aldebaran.c b/drivers/gpu/drm/amd/amdgpu/aldebaran.c index 07f195a89e9a..3a588fecb0c5 100644 --- a/drivers/gpu/drm/amd/amdgpu/aldebaran.c +++ b/drivers/gpu/drm/amd/amdgpu/aldebaran.c @@ -239,7 +239,7 @@ static int aldebaran_mode2_restore_ip(struct amdgpu_device *adev)  		dev_err(adev->dev, "Failed to get BIF handle\n");  		return -EINVAL;  	} -	r = cmn_block->version->funcs->resume(cmn_block); +	r = amdgpu_ip_block_resume(cmn_block);  	if (r)  		return r; @@ -275,15 +275,10 @@ static int aldebaran_mode2_restore_ip(struct amdgpu_device *adev)  		      adev->ip_blocks[i].version->type ==  			      AMD_IP_BLOCK_TYPE_SDMA))  			continue; -		r = adev->ip_blocks[i].version->funcs->resume(&adev->ip_blocks[i]); -		if (r) { -			dev_err(adev->dev, -				"resume of IP block <%s> failed %d\n", -				adev->ip_blocks[i].version->funcs->name, r); -			return r; -		} -		adev->ip_blocks[i].status.hw = true; +		r = amdgpu_ip_block_resume(&adev->ip_blocks[i]); +		if (r) +			return r;  	}  	for (i = 0; i < adev->num_ip_blocks; i++) {  | 
