diff options
author | Christian König <christian.koenig@amd.com> | 2018-01-31 10:03:19 -0500 |
---|---|---|
committer | Alex Deucher <alexander.deucher@amd.com> | 2018-02-19 14:19:18 -0500 |
commit | 3af81440a9b02e2c6e244539ee567063c3d62292 (patch) | |
tree | 869c184af030c2b386101e5f4b92200836ab74ca /drivers/gpu/drm/amd/amdgpu | |
parent | 58592a095c981a002137221205411f538b9f0fb9 (diff) |
drm/amdgpu: cache the fence to wait for a VMID
Beneficial when a lot of processes are waiting for VMIDs.
Signed-off-by: Christian König <christian.koenig@amd.com>
Reviewed-by: Chunming Zhou <david1.zhou@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
Diffstat (limited to 'drivers/gpu/drm/amd/amdgpu')
-rw-r--r-- | drivers/gpu/drm/amd/amdgpu/amdgpu_ids.c | 7 | ||||
-rw-r--r-- | drivers/gpu/drm/amd/amdgpu/amdgpu_ring.c | 3 | ||||
-rw-r--r-- | drivers/gpu/drm/amd/amdgpu/amdgpu_ring.h | 1 |
3 files changed, 9 insertions, 2 deletions
diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_ids.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_ids.c index 156e026046b5..7d2805729c20 100644 --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_ids.c +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_ids.c | |||
@@ -205,6 +205,9 @@ static int amdgpu_vmid_grab_idle(struct amdgpu_vm *vm, | |||
205 | unsigned i; | 205 | unsigned i; |
206 | int r; | 206 | int r; |
207 | 207 | ||
208 | if (ring->vmid_wait && !dma_fence_is_signaled(ring->vmid_wait)) | ||
209 | return amdgpu_sync_fence(adev, sync, ring->vmid_wait, false); | ||
210 | |||
208 | fences = kmalloc_array(sizeof(void *), id_mgr->num_ids, GFP_KERNEL); | 211 | fences = kmalloc_array(sizeof(void *), id_mgr->num_ids, GFP_KERNEL); |
209 | if (!fences) | 212 | if (!fences) |
210 | return -ENOMEM; | 213 | return -ENOMEM; |
@@ -239,9 +242,9 @@ static int amdgpu_vmid_grab_idle(struct amdgpu_vm *vm, | |||
239 | } | 242 | } |
240 | 243 | ||
241 | r = amdgpu_sync_fence(adev, sync, &array->base, false); | 244 | r = amdgpu_sync_fence(adev, sync, &array->base, false); |
242 | dma_fence_put(&array->base); | 245 | dma_fence_put(ring->vmid_wait); |
246 | ring->vmid_wait = &array->base; | ||
243 | return r; | 247 | return r; |
244 | |||
245 | } | 248 | } |
246 | kfree(fences); | 249 | kfree(fences); |
247 | 250 | ||
diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_ring.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_ring.c index 13044e66dcaf..e223b0f6417b 100644 --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_ring.c +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_ring.c | |||
@@ -360,6 +360,9 @@ void amdgpu_ring_fini(struct amdgpu_ring *ring) | |||
360 | 360 | ||
361 | amdgpu_debugfs_ring_fini(ring); | 361 | amdgpu_debugfs_ring_fini(ring); |
362 | 362 | ||
363 | dma_fence_put(ring->vmid_wait); | ||
364 | ring->vmid_wait = NULL; | ||
365 | |||
363 | ring->adev->rings[ring->idx] = NULL; | 366 | ring->adev->rings[ring->idx] = NULL; |
364 | } | 367 | } |
365 | 368 | ||
diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_ring.h b/drivers/gpu/drm/amd/amdgpu/amdgpu_ring.h index 867f53332305..075976855651 100644 --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_ring.h +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_ring.h | |||
@@ -196,6 +196,7 @@ struct amdgpu_ring { | |||
196 | u64 cond_exe_gpu_addr; | 196 | u64 cond_exe_gpu_addr; |
197 | volatile u32 *cond_exe_cpu_addr; | 197 | volatile u32 *cond_exe_cpu_addr; |
198 | unsigned vm_inv_eng; | 198 | unsigned vm_inv_eng; |
199 | struct dma_fence *vmid_wait; | ||
199 | bool has_compute_vm_bug; | 200 | bool has_compute_vm_bug; |
200 | 201 | ||
201 | atomic_t num_jobs[DRM_SCHED_PRIORITY_MAX]; | 202 | atomic_t num_jobs[DRM_SCHED_PRIORITY_MAX]; |