[PATCH 2/2] drm/amdgpu: when suspend, set boot state instand of disable dpm.

Alex Deucher alexdeucher at gmail.com
Fri Oct 21 15:05:05 UTC 2016


On Fri, Oct 21, 2016 at 6:13 AM, Rex Zhu <Rex.Zhu at amd.com> wrote:
> fix pm-hibernat bug, when suspend/resume, dpm start failed.
>
> Change-Id: I03784f0049563b11721ebe905d9bea40ecc82170
> Signed-off-by: Rex Zhu <Rex.Zhu at amd.com>
> ---
>  drivers/gpu/drm/amd/amdgpu/ci_dpm.c | 17 ++++++++++++-----
>  1 file changed, 12 insertions(+), 5 deletions(-)
>
> diff --git a/drivers/gpu/drm/amd/amdgpu/ci_dpm.c b/drivers/gpu/drm/amd/amdgpu/ci_dpm.c
> index 966e5bf..27b1fb4 100644
> --- a/drivers/gpu/drm/amd/amdgpu/ci_dpm.c
> +++ b/drivers/gpu/drm/amd/amdgpu/ci_dpm.c
> @@ -5276,7 +5276,7 @@ static int ci_dpm_enable(struct amdgpu_device *adev)
>         int ret;
>
>         if (amdgpu_ci_is_smc_running(adev))
> -               return -EINVAL;
> +               return 0;


I think this hunk should be a separate patch.  Also, should we
actually return here or just print a message?

>         if (pi->voltage_control != CISLANDS_VOLTAGE_CONTROL_NONE) {
>                 ci_enable_voltage_control(adev);
>                 ret = ci_construct_voltage_tables(adev);
> @@ -6345,12 +6345,17 @@ static int ci_dpm_suspend(void *handle)
>
>         if (adev->pm.dpm_enabled) {
>                 mutex_lock(&adev->pm.mutex);
> -               /* disable dpm */
> -               ci_dpm_disable(adev);
> -               /* reset the power state */
> -               adev->pm.dpm.current_ps = adev->pm.dpm.requested_ps = adev->pm.dpm.boot_ps;
> +               amdgpu_irq_put(adev, &adev->pm.dpm.thermal.irq,
> +                              AMDGPU_THERMAL_IRQ_LOW_TO_HIGH);
> +               amdgpu_irq_put(adev, &adev->pm.dpm.thermal.irq,
> +                              AMDGPU_THERMAL_IRQ_HIGH_TO_LOW);
> +               adev->pm.dpm.user_state = POWER_STATE_TYPE_INTERNAL_BOOT;
> +               adev->pm.dpm.state = POWER_STATE_TYPE_INTERNAL_BOOT;


Ideally we would save the selected state before forcing it to boot
mode in suspend and then restore the user state in resume.

Alex

>                 mutex_unlock(&adev->pm.mutex);
> +               amdgpu_pm_compute_clocks(adev);
> +
>         }
> +
>         return 0;
>  }
>
> @@ -6368,6 +6373,8 @@ static int ci_dpm_resume(void *handle)
>                         adev->pm.dpm_enabled = false;
>                 else
>                         adev->pm.dpm_enabled = true;
> +               adev->pm.dpm.user_state = POWER_STATE_TYPE_BALANCED;
> +               adev->pm.dpm.state = POWER_STATE_TYPE_BALANCED;
>                 mutex_unlock(&adev->pm.mutex);
>                 if (adev->pm.dpm_enabled)
>                         amdgpu_pm_compute_clocks(adev);
> --
> 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