OSDN Git Service

drm/amd/powerplay: get raven current sclk and mclk (v2)
authorEvan Quan <evan.quan@amd.com>
Tue, 26 Sep 2017 03:49:28 +0000 (11:49 +0800)
committerAlex Deucher <alexander.deucher@amd.com>
Fri, 6 Oct 2017 21:43:42 +0000 (17:43 -0400)
v2: squash in rebase fix (Tom)

Signed-off-by: Evan Quan <evan.quan@amd.com>
Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
Reviewed-by: Junwei Zhang <Jerry.Zhang@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/powerplay/hwmgr/rv_hwmgr.c

index 1ba69d6..a0c36f2 100644 (file)
@@ -850,13 +850,37 @@ static int rv_thermal_get_temperature(struct pp_hwmgr *hwmgr)
 static int rv_read_sensor(struct pp_hwmgr *hwmgr, int idx,
                          void *value, int *size)
 {
+       uint32_t sclk, mclk;
+       int ret = 0;
+
        switch (idx) {
+       case AMDGPU_PP_SENSOR_GFX_SCLK:
+               ret = smum_send_msg_to_smc(hwmgr, PPSMC_MSG_GetGfxclkFrequency);
+               if (!ret) {
+                       rv_read_arg_from_smc(hwmgr, &sclk);
+                       /* in units of 10KHZ */
+                       *((uint32_t *)value) = sclk * 100;
+                       *size = 4;
+               }
+               break;
+       case AMDGPU_PP_SENSOR_GFX_MCLK:
+               ret = smum_send_msg_to_smc(hwmgr, PPSMC_MSG_GetFclkFrequency);
+               if (!ret) {
+                       rv_read_arg_from_smc(hwmgr, &mclk);
+                       /* in units of 10KHZ */
+                       *((uint32_t *)value) = mclk * 100;
+                       *size = 4;
+               }
+               break;
        case AMDGPU_PP_SENSOR_GPU_TEMP:
                *((uint32_t *)value) = rv_thermal_get_temperature(hwmgr);
-               return 0;
+               break;
        default:
-               return -EINVAL;
+               ret = -EINVAL;
+               break;
        }
+
+       return ret;
 }
 
 static const struct pp_hwmgr_func rv_hwmgr_funcs = {