diff options
Diffstat (limited to 'drivers/gpu/drm/amd')
| -rw-r--r-- | drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c | 8 | ||||
| -rw-r--r-- | drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c | 8 | ||||
| -rw-r--r-- | drivers/gpu/drm/amd/amdgpu/sdma_v4_0.c | 8 | 
3 files changed, 21 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 58f5b1015de1..107756dd1b25 100644 --- a/drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c +++ b/drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c @@ -4840,10 +4840,16 @@ static int gfx_v9_0_cp_ecc_error_irq(struct amdgpu_device *adev,  				  struct amdgpu_irq_src *source,  				  struct amdgpu_iv_entry *entry)  { +	struct ras_common_if *ras_if = adev->gfx.ras_if;  	struct ras_dispatch_if ih_data = { -		.head = *adev->gfx.ras_if,  		.entry = entry,  	}; + +	if (!ras_if) +		return 0; + +	ih_data.head = *ras_if; +  	DRM_ERROR("CP ECC ERROR IRQ\n");  	amdgpu_ras_interrupt_dispatch(adev, &ih_data);  	return 0; diff --git a/drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c b/drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c index f7de53335804..3fd79e07944d 100644 --- a/drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c +++ b/drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c @@ -248,10 +248,16 @@ static int gmc_v9_0_process_ecc_irq(struct amdgpu_device *adev,  		struct amdgpu_irq_src *source,  		struct amdgpu_iv_entry *entry)  { +	struct ras_common_if *ras_if = adev->gmc.ras_if;  	struct ras_dispatch_if ih_data = { -		.head = *adev->gmc.ras_if,  		.entry = entry,  	}; + +	if (!ras_if) +		return 0; + +	ih_data.head = *ras_if; +  	amdgpu_ras_interrupt_dispatch(adev, &ih_data);  	return 0;  } diff --git a/drivers/gpu/drm/amd/amdgpu/sdma_v4_0.c b/drivers/gpu/drm/amd/amdgpu/sdma_v4_0.c index 31d5b3fdd5cd..1ec60f54b992 100644 --- a/drivers/gpu/drm/amd/amdgpu/sdma_v4_0.c +++ b/drivers/gpu/drm/amd/amdgpu/sdma_v4_0.c @@ -1865,10 +1865,16 @@ static int sdma_v4_0_process_ecc_irq(struct amdgpu_device *adev,  				      struct amdgpu_irq_src *source,  				      struct amdgpu_iv_entry *entry)  { +	struct ras_common_if *ras_if = adev->sdma.ras_if;  	struct ras_dispatch_if ih_data = { -		.head = *adev->sdma.ras_if,  		.entry = entry,  	}; + +	if (!ras_if) +		return 0; + +	ih_data.head = *ras_if; +  	amdgpu_ras_interrupt_dispatch(adev, &ih_data);  	return 0;  }  | 

