diff options
author | Trigger Huang <trigger.huang@amd.com> | 2017-08-08 06:42:51 -0400 |
---|---|---|
committer | Alex Deucher <alexander.deucher@amd.com> | 2017-08-15 14:46:17 -0400 |
commit | 41cc07cff24d55661a76efc07d70e80a97af4276 (patch) | |
tree | 63f3dc06902deac404851f6ee0bd23a1d28b8651 /drivers/gpu/drm/amd/amdgpu/amdgpu_ring.c | |
parent | 5dcd33459b0039ea0be978ce6ef3e7f5dcc778d8 (diff) |
drm/amdgpu: don't finish the ring if not initialized
If a ring is not initialized, it also should not be finished.
For example, in Vega10's SR-IOV environment, UVD's decode ring is not
initialized, but will be finnished in amdgpu_uvd_sw_fini, because UVD
driver put all the uvd decode ring's finish operation into
amdgpu_uvd_sw_fini function, while not uvd_vXXX_0_sw_fini. This will
lead to amdgpu module unloading failure.
Signed-off-by: Trigger Huang <trigger.huang@amd.com>
Reviewed-by: Monk Liu <monk.liu@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/amdgpu_ring.c')
-rw-r--r-- | drivers/gpu/drm/amd/amdgpu/amdgpu_ring.c | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_ring.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_ring.c index 70447567438a..6c5646b48d1a 100644 --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_ring.c +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_ring.c | |||
@@ -261,6 +261,10 @@ void amdgpu_ring_fini(struct amdgpu_ring *ring) | |||
261 | { | 261 | { |
262 | ring->ready = false; | 262 | ring->ready = false; |
263 | 263 | ||
264 | /* Not to finish a ring which is not initialized */ | ||
265 | if (!(ring->adev) || !(ring->adev->rings[ring->idx])) | ||
266 | return; | ||
267 | |||
264 | amdgpu_wb_free(ring->adev, ring->rptr_offs); | 268 | amdgpu_wb_free(ring->adev, ring->rptr_offs); |
265 | amdgpu_wb_free(ring->adev, ring->wptr_offs); | 269 | amdgpu_wb_free(ring->adev, ring->wptr_offs); |
266 | 270 | ||