]> www.infradead.org Git - users/jedix/linux-maple.git/commitdiff
drm/amd/swsmu: allow asic to handle sensor type by itself
authorKevin Wang <kevin1.wang@amd.com>
Mon, 27 Jul 2020 01:08:22 +0000 (09:08 +0800)
committerAlex Deucher <alexander.deucher@amd.com>
Mon, 27 Jul 2020 20:23:06 +0000 (16:23 -0400)
1. allow asic to handle sensor type by itself.
2. if not, use smu common sensor to handle it.

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

index 3b427fa099fec42aebb203f7ab23abed59bd2e9d..55463e7a11e2af40bfc8c71bc8f3f5aec42433ce 100644 (file)
@@ -1948,6 +1948,10 @@ int smu_read_sensor(struct smu_context *smu,
 
        mutex_lock(&smu->mutex);
 
+       if (smu->ppt_funcs->read_sensor)
+               if (!smu->ppt_funcs->read_sensor(smu, sensor, data, size))
+                       goto unlock;
+
        switch (sensor) {
        case AMDGPU_PP_SENSOR_STABLE_PSTATE_SCLK:
                *((uint32_t *)data) = pstate_table->gfxclk_pstate.standard * 100;
@@ -1978,11 +1982,12 @@ int smu_read_sensor(struct smu_context *smu,
                *size = 4;
                break;
        default:
-               if (smu->ppt_funcs->read_sensor)
-                       ret = smu->ppt_funcs->read_sensor(smu, sensor, data, size);
+               *size = 0;
+               ret = -EOPNOTSUPP;
                break;
        }
 
+unlock:
        mutex_unlock(&smu->mutex);
 
        return ret;