drm/amd/pm: Update intermediate power state for SI
authorLijo Lazar <lijo.lazar@amd.com>
Thu, 23 Sep 2021 03:58:43 +0000 (11:58 +0800)
committerAlex Deucher <alexander.deucher@amd.com>
Thu, 23 Sep 2021 20:35:19 +0000 (16:35 -0400)
commit7f19e11d0e936548ce4b8e4ec36d5680c7ffea20
tree61492de971d14fd7eb7a94255a957456ec80f445
parent9080a18fc554cea0858fae6692a7003c5f0365fc
drm/amd/pm: Update intermediate power state for SI

Update the current state as boot state during dpm initialization.
During the subsequent initialization, set_power_state gets called to
transition to the final power state. set_power_state refers to values
from the current state and without current state populated, it could
result in NULL pointer dereference.

For ex: on platforms where PCI speed change is supported through ACPI
ATCS method, the link speed of current state needs to be queried before
deciding on changing to final power state's link speed. The logic to query
ATCS-support was broken on certain platforms. The issue became visible
when broken ATCS-support logic got fixed with commit
f9b7f3703ff9 ("drm/amdgpu/acpi: make ATPX/ATCS structures global (v2)").

Bug:https://gitlab.freedesktop.org/drm/amd/-/issues/1698

Signed-off-by: Lijo Lazar <lijo.lazar@amd.com>
Reviewed-by: Hawking Zhang <Hawking.Zhang@amd.com>
Acked-by: Alex Deucher <alexander.deucher@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/pm/powerplay/si_dpm.c