提交 7b32dd0b 编写于 作者: S Sathishkumar S 提交者: Alex Deucher

drm/amd/pm: support ss metrics read on renoir

add support to read smart shift apu and dgpu power share
on renoir.
Signed-off-by: NSathishkumar S <sathishkumar.sundararaju@amd.com>
Reviewed-by: NLijo Lazar <lijo.lazar@amd.com>
Signed-off-by: NAlex Deucher <alexander.deucher@amd.com>
上级 3be4dca1
...@@ -1180,6 +1180,28 @@ static int renoir_get_smu_metrics_data(struct smu_context *smu, ...@@ -1180,6 +1180,28 @@ static int renoir_get_smu_metrics_data(struct smu_context *smu,
case METRICS_VOLTAGE_VDDSOC: case METRICS_VOLTAGE_VDDSOC:
*value = metrics->Voltage[1]; *value = metrics->Voltage[1];
break; break;
case METRICS_SS_APU_SHARE:
/* return the percentage of APU power with respect to APU's power limit.
* percentage is reported, this isn't boost value. Smartshift power
* boost/shift is only when the percentage is more than 100.
*/
if (metrics->StapmOriginalLimit > 0)
*value = (metrics->ApuPower * 100) / metrics->StapmOriginalLimit;
else
*value = 0;
break;
case METRICS_SS_DGPU_SHARE:
/* return the percentage of dGPU power with respect to dGPU's power limit.
* percentage is reported, this isn't boost value. Smartshift power
* boost/shift is only when the percentage is more than 100.
*/
if ((metrics->dGpuPower > 0) &&
(metrics->StapmCurrentLimit > metrics->StapmOriginalLimit))
*value = (metrics->dGpuPower * 100) /
(metrics->StapmCurrentLimit - metrics->StapmOriginalLimit);
else
*value = 0;
break;
default: default:
*value = UINT_MAX; *value = UINT_MAX;
break; break;
...@@ -1251,6 +1273,18 @@ static int renoir_read_sensor(struct smu_context *smu, ...@@ -1251,6 +1273,18 @@ static int renoir_read_sensor(struct smu_context *smu,
(uint32_t *)data); (uint32_t *)data);
*size = 4; *size = 4;
break; break;
case AMDGPU_PP_SENSOR_SS_APU_SHARE:
ret = renoir_get_smu_metrics_data(smu,
METRICS_SS_APU_SHARE,
(uint32_t *)data);
*size = 4;
break;
case AMDGPU_PP_SENSOR_SS_DGPU_SHARE:
ret = renoir_get_smu_metrics_data(smu,
METRICS_SS_DGPU_SHARE,
(uint32_t *)data);
*size = 4;
break;
default: default:
ret = -EOPNOTSUPP; ret = -EOPNOTSUPP;
break; break;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册