diff options
author | Chunming Zhou <David1.Zhou@amd.com> | 2015-11-17 22:17:39 -0500 |
---|---|---|
committer | Alex Deucher <alexander.deucher@amd.com> | 2015-11-20 18:22:23 -0500 |
commit | 69b576a1bc8b466ae7bff0208f1c139dbaaf802c (patch) | |
tree | a5d2d94a0a026181a0834b9d3c78979da3ed5725 /drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c | |
parent | d66f8e48f1201620eeb0a11df4c2071f7ee35750 (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.c | 17 |
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 | ||