diff options
author | Chunming Zhou <David1.Zhou@amd.com> | 2016-03-16 23:41:37 -0400 |
---|---|---|
committer | Alex Deucher <alexander.deucher@amd.com> | 2016-05-02 15:04:11 -0400 |
commit | 8e9fbeb522fa3043dc65ef0e383af28843950799 (patch) | |
tree | 512228be6811bee61b5a7bcb9a728e555bbee7a4 /drivers/gpu/drm/amd | |
parent | eca2240fb044e30276ecbb43eab47a46f96c05c4 (diff) |
drm/amdgpu: improve vmid assigment V2
V2: the signaled items on the LRU maintain their order
Signed-off-by: Chunming Zhou <David1.Zhou@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
Diffstat (limited to 'drivers/gpu/drm/amd')
-rw-r--r-- | drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c index b6c011b83641..6630732ea1bd 100644 --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c | |||
@@ -216,6 +216,20 @@ int amdgpu_vm_grab_id(struct amdgpu_vm *vm, struct amdgpu_ring *ring, | |||
216 | struct amdgpu_vm_manager_id, | 216 | struct amdgpu_vm_manager_id, |
217 | list); | 217 | list); |
218 | 218 | ||
219 | if (id->mgr_id->active && !fence_is_signaled(id->mgr_id->active)) { | ||
220 | struct amdgpu_vm_manager_id *mgr_id, *tmp; | ||
221 | struct list_head *head = &adev->vm_manager.ids_lru; | ||
222 | list_for_each_entry_safe(mgr_id, tmp, &adev->vm_manager.ids_lru, list) { | ||
223 | if (mgr_id->active && fence_is_signaled(mgr_id->active)) { | ||
224 | list_move(&mgr_id->list, head); | ||
225 | head = &mgr_id->list; | ||
226 | } | ||
227 | } | ||
228 | id->mgr_id = list_first_entry(&adev->vm_manager.ids_lru, | ||
229 | struct amdgpu_vm_manager_id, | ||
230 | list); | ||
231 | } | ||
232 | |||
219 | r = amdgpu_sync_fence(ring->adev, sync, id->mgr_id->active); | 233 | r = amdgpu_sync_fence(ring->adev, sync, id->mgr_id->active); |
220 | if (!r) { | 234 | if (!r) { |
221 | fence_put(id->mgr_id->active); | 235 | fence_put(id->mgr_id->active); |