[PATCH 1/3] drm/amdgpu: parameterize ttm BO destroy callback
Das, Nirmoy
nirmoy.das at amd.com
Mon Jun 14 17:40:47 UTC 2021
On 6/14/2021 7:10 PM, Christian König wrote:
>
>
> 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.
I misinterpret Teams conversation. I will resend.
Thanks,
Nirmoy
>
>
>> {
>> 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