From: monk.liu Date: Tue, 26 May 2015 02:22:41 +0000 (+0800) Subject: drm/amdgpu: max_pde_used usage should be under protect X-Git-Tag: firefly_0821_release~176^2~1470^2~25^2~16 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=3d5a08c114585e5b9f890807b04d2730dafde5e1;p=firefly-linux-kernel-4.4.55.git drm/amdgpu: max_pde_used usage should be under protect Need to take the lock when accessing this. Signed-off-by: monk.liu Reviewed-by: Christian König Reviewed-by: Jammy Zhou --- diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c index cc6dca2581a6..dcb2d3859cf1 100644 --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c @@ -90,10 +90,13 @@ struct amdgpu_bo_list_entry *amdgpu_vm_get_bos(struct amdgpu_device *adev, struct amdgpu_bo_list_entry *list; unsigned i, idx; + mutex_lock(&vm->mutex); list = drm_malloc_ab(vm->max_pde_used + 2, sizeof(struct amdgpu_bo_list_entry)); - if (!list) + if (!list) { + mutex_unlock(&vm->mutex); return NULL; + } /* add the vm page table to the list */ list[0].robj = vm->page_directory; @@ -116,6 +119,7 @@ struct amdgpu_bo_list_entry *amdgpu_vm_get_bos(struct amdgpu_device *adev, list[idx].tv.shared = true; list_add(&list[idx++].tv.head, head); } + mutex_unlock(&vm->mutex); return list; }