[PATCH] drm/amd/amdgpu: decrease ttm bo priority to fix performance drop when VRAM pressure

Christian König deathsimple at vodafone.de
Mon Mar 27 14:47:35 UTC 2017


Am 27.03.2017 um 14:05 schrieb Roger.He:
> 1. When VRAM pressue and trigger huge evictions there is performance drop,
>     this patch fix it.
> 2. Also reserve priority for KFD using
>
> Change-Id: Idcd2db65be69d62bcbd7dfaa3bcf9bc964d6d122
> Signed-off-by: Roger.He <Hongbo.He at amd.com>

Reviewed-by: Christian König <christian.koenig at amd.com>

> ---
>   drivers/gpu/drm/amd/amdgpu/amdgpu_object.c | 4 +---
>   include/drm/ttm/ttm_bo_driver.h            | 2 +-
>   2 files changed, 2 insertions(+), 4 deletions(-)
>
> diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_object.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_object.c
> index 434c931..d6b2de9 100644
> --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_object.c
> +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_object.c
> @@ -405,10 +405,8 @@ int amdgpu_bo_create_restricted(struct amdgpu_device *adev,
>   	if (unlikely(r != 0))
>   		return r;
>   
> -	bo->tbo.priority = ilog2(bo->tbo.num_pages);
>   	if (kernel)
> -		bo->tbo.priority *= 2;
> -	bo->tbo.priority = min(bo->tbo.priority, TTM_MAX_BO_PRIORITY - 1);
> +		bo->tbo.priority = 1;
>   
>   	if (flags & AMDGPU_GEM_CREATE_VRAM_CLEARED &&
>   	    bo->tbo.mem.placement & TTM_PL_FLAG_VRAM) {
> diff --git a/include/drm/ttm/ttm_bo_driver.h b/include/drm/ttm/ttm_bo_driver.h
> index c3d74be..7777d14 100644
> --- a/include/drm/ttm/ttm_bo_driver.h
> +++ b/include/drm/ttm/ttm_bo_driver.h
> @@ -42,7 +42,7 @@
>   #include <linux/spinlock.h>
>   #include <linux/reservation.h>
>   
> -#define TTM_MAX_BO_PRIORITY	16U
> +#define TTM_MAX_BO_PRIORITY	4U
>   
>   struct ttm_backend_func {
>   	/**




More information about the amd-gfx mailing list