[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