[PATCH 1/2] drm/amdgpu: Change PG enable sequence

Quan, Evan Evan.Quan at amd.com
Tue Jun 5 10:22:23 UTC 2018


> /* skip CG for VCE/UVD, it's handled specially */
The comment should be fixed as this is for pg not cg.
With that fixed, the patch is Reviewed-by: Evan Quan <evan.quan at amd.com>

> -----Original Message-----
> From: amd-gfx [mailto:amd-gfx-bounces at lists.freedesktop.org] On Behalf
> Of Rex Zhu
> Sent: Tuesday, June 05, 2018 4:03 PM
> To: amd-gfx at lists.freedesktop.org
> Cc: Zhu, Rex <Rex.Zhu at amd.com>
> Subject: [PATCH 1/2] drm/amdgpu: Change PG enable sequence
> 
> Enable PG state after CG enabled.
> 
> Signed-off-by: Rex Zhu <Rex.Zhu at amd.com>
> ---
>  drivers/gpu/drm/amd/amdgpu/amdgpu_device.c | 29
> +++++++++++++++++++++++++++++
>  drivers/gpu/drm/amd/amdgpu/gfx_v8_0.c      |  4 ----
>  drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c      |  5 -----
>  3 files changed, 29 insertions(+), 9 deletions(-)
> 
> diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_device.c
> b/drivers/gpu/drm/amd/amdgpu/amdgpu_device.c
> index 7a085f6..4003038 100644
> --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_device.c
> +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_device.c
> @@ -1734,6 +1734,34 @@ static int
> amdgpu_device_ip_late_set_cg_state(struct amdgpu_device *adev)
>  	return 0;
>  }
> 
> +static int amdgpu_device_ip_late_set_pg_state(struct amdgpu_device
> +*adev) {
> +	int i = 0;
> +
> +	if (amdgpu_emu_mode == 1)
> +		return 0;
> +
> +	for (i = 0; i < adev->num_ip_blocks; i++) {
> +		if (!adev->ip_blocks[i].status.valid)
> +			continue;
> +		/* skip CG for VCE/UVD, it's handled specially */
> +		if (adev->ip_blocks[i].version->type !=
> AMD_IP_BLOCK_TYPE_UVD &&
> +		    adev->ip_blocks[i].version->type !=
> AMD_IP_BLOCK_TYPE_VCE &&
> +		    adev->ip_blocks[i].version->type !=
> AMD_IP_BLOCK_TYPE_VCN &&
> +		    adev->ip_blocks[i].version->funcs-
> >set_powergating_state) {
> +			/* enable powergating to save power */
> +			r = adev->ip_blocks[i].version->funcs-
> >set_powergating_state((void *)adev,
> +
> 	     AMD_PG_STATE_GATE);
> +			if (r) {
> +				DRM_ERROR("set_powergating_state(gate)
> of IP block <%s> failed %d\n",
> +					  adev->ip_blocks[i].version->funcs-
> >name, r);
> +				return r;
> +			}
> +		}
> +	}
> +	return 0;
> +}
> +
>  /**
>   * amdgpu_device_ip_late_init - run late init for hardware IPs
>   *
> @@ -1891,6 +1919,7 @@ static void
> amdgpu_device_ip_late_init_func_handler(struct work_struct *work)
>  	struct amdgpu_device *adev =
>  		container_of(work, struct amdgpu_device,
> late_init_work.work);
>  	amdgpu_device_ip_late_set_cg_state(adev);
> +	amdgpu_device_ip_late_set_pg_state(adev);
>  }
> 
>  /**
> diff --git a/drivers/gpu/drm/amd/amdgpu/gfx_v8_0.c
> b/drivers/gpu/drm/amd/amdgpu/gfx_v8_0.c
> index 50ba9c9..37fc55e 100644
> --- a/drivers/gpu/drm/amd/amdgpu/gfx_v8_0.c
> +++ b/drivers/gpu/drm/amd/amdgpu/gfx_v8_0.c
> @@ -5542,10 +5542,6 @@ static int gfx_v8_0_late_init(void *handle)
>  	if (r)
>  		return r;
> 
> -	amdgpu_device_ip_set_powergating_state(adev,
> -					       AMD_IP_BLOCK_TYPE_GFX,
> -					       AMD_PG_STATE_GATE);
> -
>  	return 0;
>  }
> 
> diff --git a/drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c
> b/drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c
> index c188616..c382969 100644
> --- a/drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c
> +++ b/drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c
> @@ -3406,11 +3406,6 @@ static int gfx_v9_0_late_init(void *handle)
>  	if (r)
>  		return r;
> 
> -	r = amdgpu_device_ip_set_powergating_state(adev,
> AMD_IP_BLOCK_TYPE_GFX,
> -						   AMD_PG_STATE_GATE);
> -	if (r)
> -		return r;
> -
>  	return 0;
>  }
> 
> --
> 1.9.1
> 
> _______________________________________________
> amd-gfx mailing list
> amd-gfx at lists.freedesktop.org
> https://lists.freedesktop.org/mailman/listinfo/amd-gfx


More information about the amd-gfx mailing list