drm/amd/powerplay: fix fan speed show error (for hwmon pwm)
authorKevin Wang <kevin1.wang@amd.com>
Thu, 6 Jun 2019 09:12:34 +0000 (17:12 +0800)
committerAlex Deucher <alexander.deucher@amd.com>
Tue, 25 Jun 2019 18:25:48 +0000 (13:25 -0500)
the navi asic can't get current rpm by MSG_GetCurrentRpm,
it will cause show fan rpm error, use Metrics_t to replace it.

Signed-off-by: Kevin Wang <kevin1.wang@amd.com>
Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/powerplay/navi10_ppt.c

index 2d43e3dc79f6fae2ea7043b6d4ccff5d2d490bcd..953209b7c3eb5be5c036f2ea034466b012a5e9c7 100644 (file)
@@ -885,15 +885,33 @@ static bool navi10_is_dpm_running(struct smu_context *smu)
        return !!(feature_enabled & SMC_DPM_FEATURE);
 }
 
+static int navi10_get_fan_speed(struct smu_context *smu, uint16_t *value)
+{
+       SmuMetrics_t metrics = {0};
+       int ret = 0;
+
+       if (!value)
+               return -EINVAL;
+
+       ret = smu_update_table(smu, SMU_TABLE_SMU_METRICS,
+                              (void *)&metrics, false);
+       if (ret)
+               return ret;
+
+       *value = metrics.CurrFanSpeed;
+
+       return ret;
+}
+
 static int navi10_get_fan_speed_percent(struct smu_context *smu,
                                        uint32_t *speed)
 {
        int ret = 0;
        uint32_t percent = 0;
-       uint32_t current_rpm;
+       uint16_t current_rpm;
        PPTable_t *pptable = smu->smu_table.driver_pptable;
 
-       ret = smu_get_current_rpm(smu, &current_rpm);
+       ret = navi10_get_fan_speed(smu, &current_rpm);
        if (ret)
                return ret;