提交 b13aa109 编写于 作者: R Rex Zhu 提交者: Alex Deucher

drm/amdgpu: Use dpm_enabled as dpm state flag

driver will set dpm_enabled to true only when
module parameter amdgpu_dpm not equal to 0 and
smu hw initialize successfully.
Reviewed-by: NEvan Quan <evan.quan@amd.com>
Reviewed-by: NHuang Rui <ray.huang@amd.com>
Signed-off-by: NRex Zhu <Rex.Zhu@amd.com>
Signed-off-by: NAlex Deucher <alexander.deucher@amd.com>
上级 64f6db77
...@@ -428,7 +428,7 @@ static ssize_t amdgpu_debugfs_sensor_read(struct file *f, char __user *buf, ...@@ -428,7 +428,7 @@ static ssize_t amdgpu_debugfs_sensor_read(struct file *f, char __user *buf,
if (size & 3 || *pos & 0x3) if (size & 3 || *pos & 0x3)
return -EINVAL; return -EINVAL;
if (amdgpu_dpm == 0) if (!adev->pm.dpm_enabled)
return -EINVAL; return -EINVAL;
/* convert offset to sensor number */ /* convert offset to sensor number */
......
...@@ -704,7 +704,7 @@ static int amdgpu_info_ioctl(struct drm_device *dev, void *data, struct drm_file ...@@ -704,7 +704,7 @@ static int amdgpu_info_ioctl(struct drm_device *dev, void *data, struct drm_file
struct pp_gpu_power query = {0}; struct pp_gpu_power query = {0};
int query_size = sizeof(query); int query_size = sizeof(query);
if (amdgpu_dpm == 0) if (!adev->pm.dpm_enabled)
return -ENOENT; return -ENOENT;
switch (info->sensor_info.type) { switch (info->sensor_info.type) {
......
...@@ -6255,7 +6255,7 @@ static int ci_dpm_late_init(void *handle) ...@@ -6255,7 +6255,7 @@ static int ci_dpm_late_init(void *handle)
int ret; int ret;
struct amdgpu_device *adev = (struct amdgpu_device *)handle; struct amdgpu_device *adev = (struct amdgpu_device *)handle;
if (!amdgpu_dpm) if (!adev->pm.dpm_enabled)
return 0; return 0;
/* init the sysfs and debugfs files late */ /* init the sysfs and debugfs files late */
......
...@@ -2974,7 +2974,7 @@ static int kv_dpm_late_init(void *handle) ...@@ -2974,7 +2974,7 @@ static int kv_dpm_late_init(void *handle)
/* powerdown unused blocks for now */ /* powerdown unused blocks for now */
struct amdgpu_device *adev = (struct amdgpu_device *)handle; struct amdgpu_device *adev = (struct amdgpu_device *)handle;
if (!amdgpu_dpm) if (!adev->pm.dpm_enabled)
return 0; return 0;
kv_dpm_powergate_acp(adev, true); kv_dpm_powergate_acp(adev, true);
......
...@@ -7580,7 +7580,7 @@ static int si_dpm_late_init(void *handle) ...@@ -7580,7 +7580,7 @@ static int si_dpm_late_init(void *handle)
int ret; int ret;
struct amdgpu_device *adev = (struct amdgpu_device *)handle; struct amdgpu_device *adev = (struct amdgpu_device *)handle;
if (!amdgpu_dpm) if (!adev->pm.dpm_enabled)
return 0; return 0;
ret = si_set_temperature_range(adev); ret = si_set_temperature_range(adev);
......
...@@ -688,7 +688,7 @@ static int uvd_v4_2_set_powergating_state(void *handle, ...@@ -688,7 +688,7 @@ static int uvd_v4_2_set_powergating_state(void *handle,
if (state == AMD_PG_STATE_GATE) { if (state == AMD_PG_STATE_GATE) {
uvd_v4_2_stop(adev); uvd_v4_2_stop(adev);
if (adev->pg_flags & AMD_PG_SUPPORT_UVD && amdgpu_dpm == 0) { if (adev->pg_flags & AMD_PG_SUPPORT_UVD && !adev->pm.dpm_enabled) {
if (!(RREG32_SMC(ixCURRENT_PG_STATUS) & if (!(RREG32_SMC(ixCURRENT_PG_STATUS) &
CURRENT_PG_STATUS__UVD_PG_STATUS_MASK)) { CURRENT_PG_STATUS__UVD_PG_STATUS_MASK)) {
WREG32(mmUVD_PGFSM_CONFIG, (UVD_PGFSM_CONFIG__UVD_PGFSM_FSM_ADDR_MASK | WREG32(mmUVD_PGFSM_CONFIG, (UVD_PGFSM_CONFIG__UVD_PGFSM_FSM_ADDR_MASK |
...@@ -699,7 +699,7 @@ static int uvd_v4_2_set_powergating_state(void *handle, ...@@ -699,7 +699,7 @@ static int uvd_v4_2_set_powergating_state(void *handle,
} }
return 0; return 0;
} else { } else {
if (adev->pg_flags & AMD_PG_SUPPORT_UVD && amdgpu_dpm == 0) { if (adev->pg_flags & AMD_PG_SUPPORT_UVD && !adev->pm.dpm_enabled) {
if (RREG32_SMC(ixCURRENT_PG_STATUS) & if (RREG32_SMC(ixCURRENT_PG_STATUS) &
CURRENT_PG_STATUS__UVD_PG_STATUS_MASK) { CURRENT_PG_STATUS__UVD_PG_STATUS_MASK) {
WREG32(mmUVD_PGFSM_CONFIG, (UVD_PGFSM_CONFIG__UVD_PGFSM_FSM_ADDR_MASK | WREG32(mmUVD_PGFSM_CONFIG, (UVD_PGFSM_CONFIG__UVD_PGFSM_FSM_ADDR_MASK |
......
...@@ -211,7 +211,6 @@ int hwmgr_hw_init(struct pp_hwmgr *hwmgr) ...@@ -211,7 +211,6 @@ int hwmgr_hw_init(struct pp_hwmgr *hwmgr)
!hwmgr->pptable_func->pptable_init || !hwmgr->pptable_func->pptable_init ||
!hwmgr->hwmgr_func->backend_init) { !hwmgr->hwmgr_func->backend_init) {
hwmgr->pm_en = false; hwmgr->pm_en = false;
((struct amdgpu_device *)hwmgr->adev)->pm.dpm_enabled = false;
pr_info("dpm not supported \n"); pr_info("dpm not supported \n");
return 0; return 0;
} }
...@@ -240,6 +239,8 @@ int hwmgr_hw_init(struct pp_hwmgr *hwmgr) ...@@ -240,6 +239,8 @@ int hwmgr_hw_init(struct pp_hwmgr *hwmgr)
if (ret) if (ret)
goto err2; goto err2;
((struct amdgpu_device *)hwmgr->adev)->pm.dpm_enabled = true;
return 0; return 0;
err2: err2:
if (hwmgr->hwmgr_func->backend_fini) if (hwmgr->hwmgr_func->backend_fini)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册