[PATCH 1/3] drm/amdgpu: parameterize ttm BO destroy callback
Christian König
christian.koenig at amd.com
Mon Jun 14 17:10:15 UTC 2021
Am 14.06.21 um 16:32 schrieb Nirmoy Das:
> Make provision to pass different ttm BO destroy callback
> while creating a amdgpu_bo.
>
> Signed-off-by: Nirmoy Das <nirmoy.das at amd.com>
> ---
> drivers/gpu/drm/amd/amdgpu/amdgpu_object.c | 28 ++++++++++++++++++----
> 1 file changed, 24 insertions(+), 4 deletions(-)
>
> diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_object.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_object.c
> index 9092ac12a270..71a65525eac4 100644
> --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_object.c
> +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_object.c
> @@ -522,15 +522,17 @@ bool amdgpu_bo_support_uswc(u64 bo_flags)
> * @adev: amdgpu device object
> * @bp: parameters to be used for the buffer object
> * @bo_ptr: pointer to the buffer object pointer
> + * @destroy: ttm bo destroy callback
> *
> - * Creates an &amdgpu_bo buffer object.
> + * Creates an &amdgpu_bo buffer object with a specified ttm bo destroy callback.
> *
> * Returns:
> * 0 for success or a negative error code on failure.
> */
> -int amdgpu_bo_create(struct amdgpu_device *adev,
> +static int amdgpu_bo_do_create(struct amdgpu_device *adev,
Please don't. Rather expose an amdgpu_vm_bo_create function.
> struct amdgpu_bo_param *bp,
> - struct amdgpu_bo **bo_ptr)
> + struct amdgpu_bo **bo_ptr,
> + void (*destroy)(struct ttm_buffer_object *))
That rather belongs into the amdgpu_bo_param structure.
> {
> struct ttm_operation_ctx ctx = {
> .interruptible = (bp->type != ttm_bo_type_kernel),
> @@ -594,7 +596,7 @@ int amdgpu_bo_create(struct amdgpu_device *adev,
>
> r = ttm_bo_init_reserved(&adev->mman.bdev, &bo->tbo, size, bp->type,
> &bo->placement, page_align, &ctx, NULL,
> - bp->resv, &amdgpu_bo_destroy);
> + bp->resv, destroy);
> if (unlikely(r != 0))
> return r;
>
> @@ -638,6 +640,24 @@ int amdgpu_bo_create(struct amdgpu_device *adev,
> return r;
> }
>
> +/**
> + * amdgpu_bo_create - create an &amdgpu_bo buffer object
> + * @adev: amdgpu device object
> + * @bp: parameters to be used for the buffer object
> + * @bo_ptr: pointer to the buffer object pointer
> + *
> + * Creates an &amdgpu_bo buffer object.
> + *
> + * Returns:
> + * 0 for success or a negative error code on failure.
> + */
> +int amdgpu_bo_create(struct amdgpu_device *adev,
> + struct amdgpu_bo_param *bp,
> + struct amdgpu_bo **bo_ptr)
> +{
> + return amdgpu_bo_do_create(adev, bp, bo_ptr, &amdgpu_bo_destroy);
> +}
> +
> /**
> * amdgpu_bo_create_user - create an &amdgpu_bo_user buffer object
> * @adev: amdgpu device object
More information about the amd-gfx
mailing list