diff options
author | Michel Dänzer <michel.daenzer@amd.com> | 2019-06-14 18:43:30 +0200 |
---|---|---|
committer | Michel Dänzer <michel@daenzer.net> | 2019-07-01 11:31:59 +0200 |
commit | a1bde9b6d869b65fc911843f9ef0f3e2e64d5797 (patch) | |
tree | 5c83853830c5112a2c5fee8d930feaa4c8c6b7ee /amdgpu | |
parent | b12282db9cef4aa4f9038f0248ecdd30f02bb439 (diff) | |
download | libdrm-a1bde9b6d869b65fc911843f9ef0f3e2e64d5797.tar.gz libdrm-a1bde9b6d869b65fc911843f9ef0f3e2e64d5797.tar.bz2 libdrm-a1bde9b6d869b65fc911843f9ef0f3e2e64d5797.zip |
amdgpu: Add BO handle to table in amdgpu_bo_create
Simplifies its callers.
dev->bo_table_mutex is now always held when amdgpu_bo_create is called
(this was already the case in amdgpu_bo_import).
Reviewed-by: Emil Velikov <emil.l.velikov@gmail.com>
Diffstat (limited to 'amdgpu')
-rw-r--r-- | amdgpu/amdgpu_bo.c | 32 |
1 files changed, 12 insertions, 20 deletions
diff --git a/amdgpu/amdgpu_bo.c b/amdgpu/amdgpu_bo.c index 6c0b8517..5bdb8fe8 100644 --- a/amdgpu/amdgpu_bo.c +++ b/amdgpu/amdgpu_bo.c @@ -53,11 +53,18 @@ static int amdgpu_bo_create(amdgpu_device_handle dev, amdgpu_bo_handle *buf_handle) { struct amdgpu_bo *bo; + int r; bo = calloc(1, sizeof(struct amdgpu_bo)); if (!bo) return -ENOMEM; + r = handle_table_insert(&dev->bo_handles, handle, bo); + if (r) { + free(bo); + return r; + } + atomic_set(&bo->refcount, 1); bo->dev = dev; bo->alloc_size = size; @@ -89,19 +96,14 @@ drm_public int amdgpu_bo_alloc(amdgpu_device_handle dev, if (r) goto out; + pthread_mutex_lock(&dev->bo_table_mutex); r = amdgpu_bo_create(dev, alloc_buffer->alloc_size, args.out.handle, buf_handle); + pthread_mutex_unlock(&dev->bo_table_mutex); if (r) { amdgpu_close_kms_handle(dev->fd, args.out.handle); - goto out; } - pthread_mutex_lock(&dev->bo_table_mutex); - r = handle_table_insert(&dev->bo_handles, (*buf_handle)->handle, - *buf_handle); - pthread_mutex_unlock(&dev->bo_table_mutex); - if (r) - amdgpu_bo_free(*buf_handle); out: return r; } @@ -363,15 +365,12 @@ drm_public int amdgpu_bo_import(amdgpu_device_handle dev, if (r) goto free_bo_handle; - r = handle_table_insert(&dev->bo_handles, bo->handle, bo); - if (r) - goto free_bo_handle; if (flink_name) { bo->flink_name = flink_name; r = handle_table_insert(&dev->bo_flink_names, flink_name, bo); if (r) - goto remove_handle; + goto free_bo_handle; } @@ -380,8 +379,6 @@ drm_public int amdgpu_bo_import(amdgpu_device_handle dev, pthread_mutex_unlock(&dev->bo_table_mutex); return 0; -remove_handle: - handle_table_remove(&dev->bo_handles, bo->handle); free_bo_handle: if (flink_name && open_arg.handle) amdgpu_close_kms_handle(dev->flink_fd, open_arg.handle); @@ -597,18 +594,13 @@ drm_public int amdgpu_create_bo_from_user_mem(amdgpu_device_handle dev, if (r) goto out; + pthread_mutex_lock(&dev->bo_table_mutex); r = amdgpu_bo_create(dev, size, args.handle, buf_handle); + pthread_mutex_unlock(&dev->bo_table_mutex); if (r) { amdgpu_close_kms_handle(dev->fd, args.handle); - goto out; } - pthread_mutex_lock(&dev->bo_table_mutex); - r = handle_table_insert(&dev->bo_handles, (*buf_handle)->handle, - *buf_handle); - pthread_mutex_unlock(&dev->bo_table_mutex); - if (r) - amdgpu_bo_free(*buf_handle); out: return r; } |