return ret;
 }
 
-static const struct smu_temperature_range arcturus_thermal_policy[] =
-{
-       {-273150,  99000, 99000, -273150, 99000, 99000, -273150, 99000, 99000},
-       { 120000, 120000, 120000, 120000, 120000, 120000, 120000, 120000, 120000},
-};
-
 static int arcturus_get_thermal_temperature_range(struct smu_context *smu,
                                                struct smu_temperature_range *range)
 {
-
        PPTable_t *pptable = smu->smu_table.driver_pptable;
 
        if (!range)
                return -EINVAL;
 
-       memcpy(range, &arcturus_thermal_policy[0], sizeof(struct smu_temperature_range));
-
        range->max = pptable->TedgeLimit *
                SMU_TEMPERATURE_UNITS_PER_CENTIGRADES;
        range->edge_emergency_max = (pptable->TedgeLimit + CTF_OFFSET_EDGE) *
        range->mem_emergency_max = (pptable->TmemLimit + CTF_OFFSET_HBM)*
                SMU_TEMPERATURE_UNITS_PER_CENTIGRADES;
 
-
        return 0;
 }
 
 
 #define WORKLOAD_MAP(profile, workload) \
        [profile] = {1, (workload)}
 
+static const struct smu_temperature_range smu11_thermal_policy[] =
+{
+       {-273150,  99000, 99000, -273150, 99000, 99000, -273150, 99000, 99000},
+       { 120000, 120000, 120000, 120000, 120000, 120000, 120000, 120000, 120000},
+};
+
 struct smu_11_0_cmn2aisc_mapping {
        int     valid_mapping;
        int     map_to;
 
        if (!range || !powerplay_table)
                return -EINVAL;
 
-       /* The unit is temperature */
-       range->min = 0;
-       range->max = powerplay_table->software_shutdown_temp;
+       range->max = powerplay_table->software_shutdown_temp *
+               SMU_TEMPERATURE_UNITS_PER_CENTIGRADES;
 
        return 0;
 }
 
 }
 
 static int smu_v11_0_set_thermal_range(struct smu_context *smu,
-                                      struct smu_temperature_range *range)
+                                      struct smu_temperature_range range)
 {
        struct amdgpu_device *adev = smu->adev;
        int low = SMU_THERMAL_MINIMUM_ALERT_TEMP;
        int high = SMU_THERMAL_MAXIMUM_ALERT_TEMP;
        uint32_t val;
 
-       if (!range)
-               return -EINVAL;
-
-       if (low < range->min)
-               low = range->min;
-       if (high > range->max)
-               high = range->max;
-
-       low = max(SMU_THERMAL_MINIMUM_ALERT_TEMP, range->min);
-       high = min(SMU_THERMAL_MAXIMUM_ALERT_TEMP, range->max);
+       low = max(SMU_THERMAL_MINIMUM_ALERT_TEMP,
+                       range.min / SMU_TEMPERATURE_UNITS_PER_CENTIGRADES);
+       high = min(SMU_THERMAL_MAXIMUM_ALERT_TEMP,
+                       range.max / SMU_TEMPERATURE_UNITS_PER_CENTIGRADES);
 
        if (low > high)
                return -EINVAL;
 static int smu_v11_0_start_thermal_control(struct smu_context *smu)
 {
        int ret = 0;
-       struct smu_temperature_range range = {
-               TEMP_RANGE_MIN,
-               TEMP_RANGE_MAX,
-               TEMP_RANGE_MAX,
-               TEMP_RANGE_MIN,
-               TEMP_RANGE_MAX,
-               TEMP_RANGE_MAX,
-               TEMP_RANGE_MIN,
-               TEMP_RANGE_MAX,
-               TEMP_RANGE_MAX};
+       struct smu_temperature_range range;
        struct amdgpu_device *adev = smu->adev;
 
        if (!smu->pm_enabled)
                return ret;
 
+       memcpy(&range, &smu11_thermal_policy[0], sizeof(struct smu_temperature_range));
+
        ret = smu_get_thermal_temperature_range(smu, &range);
        if (ret)
                return ret;
 
        if (smu->smu_table.thermal_controller_type) {
-               ret = smu_v11_0_set_thermal_range(smu, &range);
+               ret = smu_v11_0_set_thermal_range(smu, range);
                if (ret)
                        return ret;
 
                        return ret;
        }
 
-       adev->pm.dpm.thermal.min_temp = range.min * SMU_TEMPERATURE_UNITS_PER_CENTIGRADES;
-       adev->pm.dpm.thermal.max_temp = range.max * SMU_TEMPERATURE_UNITS_PER_CENTIGRADES;
-       adev->pm.dpm.thermal.max_edge_emergency_temp = range.edge_emergency_max * SMU_TEMPERATURE_UNITS_PER_CENTIGRADES;
-       adev->pm.dpm.thermal.min_hotspot_temp = range.hotspot_min * SMU_TEMPERATURE_UNITS_PER_CENTIGRADES;
-       adev->pm.dpm.thermal.max_hotspot_crit_temp = range.hotspot_crit_max * SMU_TEMPERATURE_UNITS_PER_CENTIGRADES;
-       adev->pm.dpm.thermal.max_hotspot_emergency_temp = range.hotspot_emergency_max * SMU_TEMPERATURE_UNITS_PER_CENTIGRADES;
-       adev->pm.dpm.thermal.min_mem_temp = range.mem_min * SMU_TEMPERATURE_UNITS_PER_CENTIGRADES;
-       adev->pm.dpm.thermal.max_mem_crit_temp = range.mem_crit_max * SMU_TEMPERATURE_UNITS_PER_CENTIGRADES;
-       adev->pm.dpm.thermal.max_mem_emergency_temp = range.mem_emergency_max * SMU_TEMPERATURE_UNITS_PER_CENTIGRADES;
-       adev->pm.dpm.thermal.min_temp = range.min * SMU_TEMPERATURE_UNITS_PER_CENTIGRADES;
-       adev->pm.dpm.thermal.max_temp = range.max * SMU_TEMPERATURE_UNITS_PER_CENTIGRADES;
+       adev->pm.dpm.thermal.min_temp = range.min;
+       adev->pm.dpm.thermal.max_temp = range.max;
+       adev->pm.dpm.thermal.max_edge_emergency_temp = range.edge_emergency_max;
+       adev->pm.dpm.thermal.min_hotspot_temp = range.hotspot_min;
+       adev->pm.dpm.thermal.max_hotspot_crit_temp = range.hotspot_crit_max;
+       adev->pm.dpm.thermal.max_hotspot_emergency_temp = range.hotspot_emergency_max;
+       adev->pm.dpm.thermal.min_mem_temp = range.mem_min;
+       adev->pm.dpm.thermal.max_mem_crit_temp = range.mem_crit_max;
+       adev->pm.dpm.thermal.max_mem_emergency_temp = range.mem_emergency_max;
 
        return ret;
 }
 
        if (!range || !powerplay_table)
                return -EINVAL;
 
-       /* The unit is temperature */
-       range->min = 0;
-       range->max = powerplay_table->usSoftwareShutdownTemp;
-       range->edge_emergency_max = (pptable->TedgeLimit + CTF_OFFSET_EDGE);
-       range->hotspot_crit_max = pptable->ThotspotLimit;
-       range->hotspot_emergency_max = (pptable->ThotspotLimit + CTF_OFFSET_HOTSPOT);
-       range->mem_crit_max = pptable->ThbmLimit;
-       range->mem_emergency_max = (pptable->ThbmLimit + CTF_OFFSET_HBM);
+       range->max = powerplay_table->usSoftwareShutdownTemp *
+               SMU_TEMPERATURE_UNITS_PER_CENTIGRADES;
+       range->edge_emergency_max = (pptable->TedgeLimit + CTF_OFFSET_EDGE) *
+               SMU_TEMPERATURE_UNITS_PER_CENTIGRADES;
+       range->hotspot_crit_max = pptable->ThotspotLimit *
+               SMU_TEMPERATURE_UNITS_PER_CENTIGRADES;
+       range->hotspot_emergency_max = (pptable->ThotspotLimit + CTF_OFFSET_HOTSPOT) *
+               SMU_TEMPERATURE_UNITS_PER_CENTIGRADES;
+       range->mem_crit_max = pptable->ThbmLimit *
+               SMU_TEMPERATURE_UNITS_PER_CENTIGRADES;
+       range->mem_emergency_max = (pptable->ThbmLimit + CTF_OFFSET_HBM) *
+               SMU_TEMPERATURE_UNITS_PER_CENTIGRADES;
 
 
        return 0;