aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c
diff options
context:
space:
mode:
authorChunming Zhou <David1.Zhou@amd.com>2015-11-17 22:17:39 -0500
committerAlex Deucher <alexander.deucher@amd.com>2015-11-20 18:22:23 -0500
commit69b576a1bc8b466ae7bff0208f1c139dbaaf802c (patch)
treea5d2d94a0a026181a0834b9d3c78979da3ed5725 /drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c
parentd66f8e48f1201620eeb0a11df4c2071f7ee35750 (diff)
drm/amdgpu: add mutex for ba_va->valids/invalids
Signed-off-by: Chunming Zhou <David1.Zhou@amd.com> Reviewed-by: Christian König <christian.koenig@amd.com>
Diffstat (limited to 'drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c')
-rw-r--r--drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c17
1 files changed, 11 insertions, 6 deletions
diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c
index 159ce54bbd8d..d6904ef742f0 100644
--- a/drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c
+++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c
@@ -922,8 +922,9 @@ int amdgpu_vm_clear_invalids(struct amdgpu_device *adev,
922 bo_va = list_first_entry(&vm->invalidated, 922 bo_va = list_first_entry(&vm->invalidated,
923 struct amdgpu_bo_va, vm_status); 923 struct amdgpu_bo_va, vm_status);
924 spin_unlock(&vm->status_lock); 924 spin_unlock(&vm->status_lock);
925 925 mutex_lock(&bo_va->mutex);
926 r = amdgpu_vm_bo_update(adev, bo_va, NULL); 926 r = amdgpu_vm_bo_update(adev, bo_va, NULL);
927 mutex_unlock(&bo_va->mutex);
927 if (r) 928 if (r)
928 return r; 929 return r;
929 930
@@ -967,7 +968,7 @@ struct amdgpu_bo_va *amdgpu_vm_bo_add(struct amdgpu_device *adev,
967 INIT_LIST_HEAD(&bo_va->valids); 968 INIT_LIST_HEAD(&bo_va->valids);
968 INIT_LIST_HEAD(&bo_va->invalids); 969 INIT_LIST_HEAD(&bo_va->invalids);
969 INIT_LIST_HEAD(&bo_va->vm_status); 970 INIT_LIST_HEAD(&bo_va->vm_status);
970 971 mutex_init(&bo_va->mutex);
971 list_add_tail(&bo_va->bo_list, &bo->va); 972 list_add_tail(&bo_va->bo_list, &bo->va);
972 973
973 return bo_va; 974 return bo_va;
@@ -1045,7 +1046,9 @@ int amdgpu_vm_bo_map(struct amdgpu_device *adev,
1045 mapping->offset = offset; 1046 mapping->offset = offset;
1046 mapping->flags = flags; 1047 mapping->flags = flags;
1047 1048
1049 mutex_lock(&bo_va->mutex);
1048 list_add(&mapping->list, &bo_va->invalids); 1050 list_add(&mapping->list, &bo_va->invalids);
1051 mutex_unlock(&bo_va->mutex);
1049 spin_lock(&vm->it_lock); 1052 spin_lock(&vm->it_lock);
1050 interval_tree_insert(&mapping->it, &vm->va); 1053 interval_tree_insert(&mapping->it, &vm->va);
1051 spin_unlock(&vm->it_lock); 1054 spin_unlock(&vm->it_lock);
@@ -1121,7 +1124,7 @@ int amdgpu_vm_bo_unmap(struct amdgpu_device *adev,
1121 bool valid = true; 1124 bool valid = true;
1122 1125
1123 saddr /= AMDGPU_GPU_PAGE_SIZE; 1126 saddr /= AMDGPU_GPU_PAGE_SIZE;
1124 1127 mutex_lock(&bo_va->mutex);
1125 list_for_each_entry(mapping, &bo_va->valids, list) { 1128 list_for_each_entry(mapping, &bo_va->valids, list) {
1126 if (mapping->it.start == saddr) 1129 if (mapping->it.start == saddr)
1127 break; 1130 break;
@@ -1135,10 +1138,12 @@ int amdgpu_vm_bo_unmap(struct amdgpu_device *adev,
1135 break; 1138 break;
1136 } 1139 }
1137 1140
1138 if (&mapping->list == &bo_va->invalids) 1141 if (&mapping->list == &bo_va->invalids) {
1142 mutex_unlock(&bo_va->mutex);
1139 return -ENOENT; 1143 return -ENOENT;
1144 }
1140 } 1145 }
1141 1146 mutex_unlock(&bo_va->mutex);
1142 list_del(&mapping->list); 1147 list_del(&mapping->list);
1143 spin_lock(&vm->it_lock); 1148 spin_lock(&vm->it_lock);
1144 interval_tree_remove(&mapping->it, &vm->va); 1149 interval_tree_remove(&mapping->it, &vm->va);
@@ -1190,8 +1195,8 @@ void amdgpu_vm_bo_rmv(struct amdgpu_device *adev,
1190 spin_unlock(&vm->it_lock); 1195 spin_unlock(&vm->it_lock);
1191 kfree(mapping); 1196 kfree(mapping);
1192 } 1197 }
1193
1194 fence_put(bo_va->last_pt_update); 1198 fence_put(bo_va->last_pt_update);
1199 mutex_destroy(&bo_va->mutex);
1195 kfree(bo_va); 1200 kfree(bo_va);
1196} 1201}
1197 1202