drm/amdgpu: Add helper function to get buffer domain

Christian König ckoenig.leichtzumerken at gmail.com
Fri May 25 06:49:19 UTC 2018


Am 25.05.2018 um 02:15 schrieb Deepak Sharma:
> Move logic of getting supported domain to a helper
> function
>
> Signed-off-by: Deepak Sharma <Deepak.Sharma at amd.com>
> ---
>   drivers/gpu/drm/amd/amdgpu/amdgpu_gem.c    | 10 +++-------
>   drivers/gpu/drm/amd/amdgpu/amdgpu_object.c | 16 +++++++++++-----
>   drivers/gpu/drm/amd/amdgpu/amdgpu_object.h |  2 +-
>   3 files changed, 15 insertions(+), 13 deletions(-)
>
> diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_gem.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_gem.c
> index 63758db5e2ea..1e9cfbfa9c2a 100644
> --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_gem.c
> +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_gem.c
> @@ -750,19 +750,15 @@ int amdgpu_mode_dumb_create(struct drm_file *file_priv,
>   	struct amdgpu_device *adev = dev->dev_private;
>   	struct drm_gem_object *gobj;
>   	uint32_t handle;
> -	u32 domain = amdgpu_display_supported_domains(adev);
> +	u32 domain;
>   	int r;
>   
>   	args->pitch = amdgpu_align_pitch(adev, args->width,
>   					 DIV_ROUND_UP(args->bpp, 8), 0);
>   	args->size = (u64)args->pitch * args->height;
>   	args->size = ALIGN(args->size, PAGE_SIZE);
> -	if (domain == (AMDGPU_GEM_DOMAIN_VRAM | AMDGPU_GEM_DOMAIN_GTT)) {
> -		domain = AMDGPU_GEM_DOMAIN_VRAM;
> -		if (adev->gmc.real_vram_size <= AMDGPU_SG_THRESHOLD)
> -			domain = AMDGPU_GEM_DOMAIN_GTT;
> -	}
> -
> +	domain = amdgpu_bo_get_domain(adev,
> +				      amdgpu_display_supported_domains(adev));
>   	r = amdgpu_gem_object_create(adev, args->size, 0, domain,
>   				     AMDGPU_GEM_CREATE_CPU_ACCESS_REQUIRED,
>   				     false, NULL, &gobj);
> diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_object.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_object.c
> index 6a9e46ae7f0a..8acffd9990d2 100644
> --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_object.c
> +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_object.c
> @@ -703,11 +703,7 @@ int amdgpu_bo_pin_restricted(struct amdgpu_bo *bo, u32 domain,
>   	/* This assumes only APU display buffers are pinned with (VRAM|GTT).
>   	 * See function amdgpu_display_supported_domains()
>   	 */
> -	if (domain == (AMDGPU_GEM_DOMAIN_VRAM | AMDGPU_GEM_DOMAIN_GTT)) {
> -		domain = AMDGPU_GEM_DOMAIN_VRAM;
> -		if (adev->gmc.real_vram_size <= AMDGPU_SG_THRESHOLD)
> -			domain = AMDGPU_GEM_DOMAIN_GTT;
> -	}
> +	domain = amdgpu_bo_get_domain(adev, domain);
>   
>   	if (bo->pin_count) {
>   		uint32_t mem_type = bo->tbo.mem.mem_type;
> @@ -1066,3 +1062,13 @@ u64 amdgpu_bo_gpu_offset(struct amdgpu_bo *bo)
>   
>   	return bo->tbo.offset;
>   }
> +
> +uint32_t amdgpu_bo_get_domain(struct amdgpu_device *adev, uint32_t domain)

That needs a better name. Something like 
amdgpu_bo_get_preferred_pin_domain() or something like that.

Apart from that looks good to me,
Christian.

> +{
> +	if (domain == (AMDGPU_GEM_DOMAIN_VRAM | AMDGPU_GEM_DOMAIN_GTT)) {
> +		domain = AMDGPU_GEM_DOMAIN_VRAM;
> +		if (adev->gmc.real_vram_size <= AMDGPU_SG_THRESHOLD)
> +			domain = AMDGPU_GEM_DOMAIN_GTT;
> +	}
> +	return domain;
> +}
> diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_object.h b/drivers/gpu/drm/amd/amdgpu/amdgpu_object.h
> index 540e03fa159f..89e05e1f0029 100644
> --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_object.h
> +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_object.h
> @@ -289,7 +289,7 @@ int amdgpu_bo_restore_from_shadow(struct amdgpu_device *adev,
>   				  struct reservation_object *resv,
>   				  struct dma_fence **fence,
>   				  bool direct);
> -
> +uint32_t amdgpu_bo_get_domain(struct amdgpu_device *adev, uint32_t domain);
>   
>   /*
>    * sub allocation



More information about the amd-gfx mailing list