if (!clk_table || clk_type >= SMU_CLK_COUNT)
                return -EINVAL;
 
-       GET_DPM_CUR_FREQ(clk_table, clk_type, dpm_level, *freq);
+       switch (clk_type) {
+       case SMU_SOCCLK:
+               if (dpm_level >= NUM_SOCCLK_DPM_LEVELS)
+                       return -EINVAL;
+               *freq = clk_table->SocClocks[dpm_level].Freq;
+               break;
+       case SMU_MCLK:
+               if (dpm_level >= NUM_FCLK_DPM_LEVELS)
+                       return -EINVAL;
+               *freq = clk_table->FClocks[dpm_level].Freq;
+               break;
+       case SMU_DCEFCLK:
+               if (dpm_level >= NUM_DCFCLK_DPM_LEVELS)
+                       return -EINVAL;
+               *freq = clk_table->DcfClocks[dpm_level].Freq;
+               break;
+       case SMU_FCLK:
+               if (dpm_level >= NUM_FCLK_DPM_LEVELS)
+                       return -EINVAL;
+               *freq = clk_table->FClocks[dpm_level].Freq;
+               break;
+       default:
+               return -EINVAL;
+       }
+
+       return 0;
+}
+
+static int renoir_get_profiling_clk_mask(struct smu_context *smu,
+                                        enum amd_dpm_forced_level level,
+                                        uint32_t *sclk_mask,
+                                        uint32_t *mclk_mask,
+                                        uint32_t *soc_mask)
+{
+
+       if (level == AMD_DPM_FORCED_LEVEL_PROFILE_MIN_SCLK) {
+               if (sclk_mask)
+                       *sclk_mask = 0;
+       } else if (level == AMD_DPM_FORCED_LEVEL_PROFILE_MIN_MCLK) {
+               if (mclk_mask)
+                       *mclk_mask = 0;
+       } else if (level == AMD_DPM_FORCED_LEVEL_PROFILE_PEAK) {
+               if(sclk_mask)
+                       /* The sclk as gfxclk and has three level about max/min/current */
+                       *sclk_mask = 3 - 1;
+
+               if(mclk_mask)
+                       *mclk_mask = NUM_MEMCLK_DPM_LEVELS - 1;
+
+               if(soc_mask)
+                       *soc_mask = NUM_SOCCLK_DPM_LEVELS - 1;
+       }
 
        return 0;
 }
 
+static int renoir_get_dpm_ultimate_freq(struct smu_context *smu,
+                                       enum smu_clk_type clk_type,
+                                       uint32_t *min,
+                                       uint32_t *max)
+{
+       int ret = 0;
+       uint32_t mclk_mask, soc_mask;
+       uint32_t clock_limit;
+
+       if (!smu_clk_dpm_is_enabled(smu, clk_type)) {
+               switch (clk_type) {
+               case SMU_MCLK:
+               case SMU_UCLK:
+                       clock_limit = smu->smu_table.boot_values.uclk;
+                       break;
+               case SMU_GFXCLK:
+               case SMU_SCLK:
+                       clock_limit = smu->smu_table.boot_values.gfxclk;
+                       break;
+               case SMU_SOCCLK:
+                       clock_limit = smu->smu_table.boot_values.socclk;
+                       break;
+               default:
+                       clock_limit = 0;
+                       break;
+               }
+
+               /* clock in Mhz unit */
+               if (min)
+                       *min = clock_limit / 100;
+               if (max)
+                       *max = clock_limit / 100;
+
+               return 0;
+       }
+
+       if (max) {
+               ret = renoir_get_profiling_clk_mask(smu,
+                                                   AMD_DPM_FORCED_LEVEL_PROFILE_PEAK,
+                                                   NULL,
+                                                   &mclk_mask,
+                                                   &soc_mask);
+               if (ret)
+                       goto failed;
+
+               switch (clk_type) {
+               case SMU_GFXCLK:
+               case SMU_SCLK:
+                       ret = smu_send_smc_msg(smu, SMU_MSG_GetMaxGfxclkFrequency, max);
+                       if (ret) {
+                               dev_err(smu->adev->dev, "Attempt to get max GX frequency from SMC Failed !\n");
+                               goto failed;
+                       }
+                       break;
+               case SMU_UCLK:
+               case SMU_FCLK:
+               case SMU_MCLK:
+                       ret = renoir_get_dpm_clk_limited(smu, clk_type, mclk_mask, max);
+                       if (ret)
+                               goto failed;
+                       break;
+               case SMU_SOCCLK:
+                       ret = renoir_get_dpm_clk_limited(smu, clk_type, soc_mask, max);
+                       if (ret)
+                               goto failed;
+                       break;
+               default:
+                       ret = -EINVAL;
+                       goto failed;
+               }
+       }
+
+       if (min) {
+               switch (clk_type) {
+               case SMU_GFXCLK:
+               case SMU_SCLK:
+                       ret = smu_send_smc_msg(smu, SMU_MSG_GetMinGfxclkFrequency, min);
+                       if (ret) {
+                               dev_err(smu->adev->dev, "Attempt to get min GX frequency from SMC Failed !\n");
+                               goto failed;
+                       }
+                       break;
+               case SMU_UCLK:
+               case SMU_FCLK:
+               case SMU_MCLK:
+                       ret = renoir_get_dpm_clk_limited(smu, clk_type, 0, min);
+                       if (ret)
+                               goto failed;
+                       break;
+               case SMU_SOCCLK:
+                       ret = renoir_get_dpm_clk_limited(smu, clk_type, 0, min);
+                       if (ret)
+                               goto failed;
+                       break;
+               default:
+                       ret = -EINVAL;
+                       goto failed;
+               }
+       }
+failed:
+       return ret;
+}
+
 static int renoir_print_clk_levels(struct smu_context *smu,
                        enum smu_clk_type clk_type, char *buf)
 {
        int i, size = 0, ret = 0;
        uint32_t cur_value = 0, value = 0, count = 0, min = 0, max = 0;
-       DpmClocks_t *clk_table = smu->smu_table.clocks_table;
        SmuMetrics_t metrics;
        bool cur_value_match_level = false;
 
-       if (!clk_table || clk_type >= SMU_CLK_COUNT)
-               return -EINVAL;
-
        memset(&metrics, 0, sizeof(metrics));
 
        ret = renoir_get_metrics_table(smu, &metrics);
        case SMU_SCLK:
                /* retirve table returned paramters unit is MHz */
                cur_value = metrics.ClockFrequency[CLOCK_GFXCLK];
-               ret = smu_v12_0_get_dpm_ultimate_freq(smu, SMU_GFXCLK, &min, &max);
+               ret = renoir_get_dpm_ultimate_freq(smu, SMU_GFXCLK, &min, &max);
                if (!ret) {
                        /* driver only know min/max gfx_clk, Add level 1 for all other gfx clks */
                        if (cur_value  == max)
        }
 
        for (i = 0; i < count; i++) {
-               GET_DPM_CUR_FREQ(clk_table, clk_type, i, value);
+               ret = renoir_get_dpm_clk_limited(smu, clk_type, i, &value);
+               if (ret)
+                       return ret;
                if (!value)
                        continue;
                size += sprintf(buf + size, "%d: %uMhz %s\n", i, value,
 
        for (i = 0; i < ARRAY_SIZE(clks); i++) {
                clk_type = clks[i];
-               ret = smu_v12_0_get_dpm_ultimate_freq(smu, clk_type, &min_freq, &max_freq);
+               ret = renoir_get_dpm_ultimate_freq(smu, clk_type, &min_freq, &max_freq);
                if (ret)
                        return ret;
 
 
                clk_type = clk_feature_map[i].clk_type;
 
-               ret = smu_v12_0_get_dpm_ultimate_freq(smu, clk_type, &min_freq, &max_freq);
+               ret = renoir_get_dpm_ultimate_freq(smu, clk_type, &min_freq, &max_freq);
                if (ret)
                        return ret;
 
        return pplib_workload;
 }
 
-static int renoir_get_profiling_clk_mask(struct smu_context *smu,
-                                        enum amd_dpm_forced_level level,
-                                        uint32_t *sclk_mask,
-                                        uint32_t *mclk_mask,
-                                        uint32_t *soc_mask)
-{
-
-       if (level == AMD_DPM_FORCED_LEVEL_PROFILE_MIN_SCLK) {
-               if (sclk_mask)
-                       *sclk_mask = 0;
-       } else if (level == AMD_DPM_FORCED_LEVEL_PROFILE_MIN_MCLK) {
-               if (mclk_mask)
-                       *mclk_mask = 0;
-       } else if (level == AMD_DPM_FORCED_LEVEL_PROFILE_PEAK) {
-               if(sclk_mask)
-                       /* The sclk as gfxclk and has three level about max/min/current */
-                       *sclk_mask = 3 - 1;
-
-               if(mclk_mask)
-                       *mclk_mask = NUM_MEMCLK_DPM_LEVELS - 1;
-
-               if(soc_mask)
-                       *soc_mask = NUM_SOCCLK_DPM_LEVELS - 1;
-       }
-
-       return 0;
-}
 
 /**
  * This interface get dpm clock table for dc
 
        int ret = 0 ;
        uint32_t soft_min_level = 0, soft_max_level = 0, min_freq = 0, max_freq = 0;
-       DpmClocks_t *clk_table = smu->smu_table.clocks_table;
 
        soft_min_level = mask ? (ffs(mask) - 1) : 0;
        soft_max_level = mask ? (fls(mask) - 1) : 0;
                        return -EINVAL;
                }
 
-               ret = smu_v12_0_get_dpm_ultimate_freq(smu, SMU_GFXCLK, &min_freq, &max_freq);
+               ret = renoir_get_dpm_ultimate_freq(smu, SMU_GFXCLK, &min_freq, &max_freq);
                if (ret)
                        return ret;
                ret = smu_send_smc_msg_with_param(smu, SMU_MSG_SetSoftMaxGfxClk,
                        return ret;
                break;
        case SMU_SOCCLK:
-               GET_DPM_CUR_FREQ(clk_table, clk_type, soft_min_level, min_freq);
-               GET_DPM_CUR_FREQ(clk_table, clk_type, soft_max_level, max_freq);
+               ret = renoir_get_dpm_clk_limited(smu, clk_type, soft_min_level, &min_freq);
+               if (ret)
+                       return ret;
+               ret = renoir_get_dpm_clk_limited(smu, clk_type, soft_max_level, &max_freq);
+               if (ret)
+                       return ret;
                ret = smu_send_smc_msg_with_param(smu, SMU_MSG_SetSoftMaxSocclkByFreq, max_freq, NULL);
                if (ret)
                        return ret;
                break;
        case SMU_MCLK:
        case SMU_FCLK:
-               GET_DPM_CUR_FREQ(clk_table, clk_type, soft_min_level, min_freq);
-               GET_DPM_CUR_FREQ(clk_table, clk_type, soft_max_level, max_freq);
+               ret = renoir_get_dpm_clk_limited(smu, clk_type, soft_min_level, &min_freq);
+               if (ret)
+                       return ret;
+               ret = renoir_get_dpm_clk_limited(smu, clk_type, soft_max_level, &max_freq);
+               if (ret)
+                       return ret;
                ret = smu_send_smc_msg_with_param(smu, SMU_MSG_SetSoftMaxFclkByFreq, max_freq, NULL);
                if (ret)
                        return ret;
        int ret = 0;
        uint32_t sclk_freq = 0, uclk_freq = 0;
 
-       ret = smu_v12_0_get_dpm_ultimate_freq(smu, SMU_SCLK, NULL, &sclk_freq);
+       ret = renoir_get_dpm_ultimate_freq(smu, SMU_SCLK, NULL, &sclk_freq);
        if (ret)
                return ret;
 
        if (ret)
                return ret;
 
-       ret = smu_v12_0_get_dpm_ultimate_freq(smu, SMU_UCLK, NULL, &uclk_freq);
+       ret = renoir_get_dpm_ultimate_freq(smu, SMU_UCLK, NULL, &uclk_freq);
        if (ret)
                return ret;
 
        .fini_smc_tables = smu_v12_0_fini_smc_tables,
        .set_default_dpm_table = smu_v12_0_set_default_dpm_tables,
        .get_enabled_mask = smu_v12_0_get_enabled_mask,
-       .get_dpm_ultimate_freq = smu_v12_0_get_dpm_ultimate_freq,
+       .get_dpm_ultimate_freq = renoir_get_dpm_ultimate_freq,
        .mode2_reset = smu_v12_0_mode2_reset,
        .set_soft_freq_limited_range = smu_v12_0_set_soft_freq_limited_range,
        .set_driver_table_location = smu_v12_0_set_driver_table_location,
 
        return ret;
 }
 
-int smu_v12_0_get_dpm_ultimate_freq(struct smu_context *smu, enum smu_clk_type clk_type,
-                                                uint32_t *min, uint32_t *max)
-{
-       int ret = 0;
-       uint32_t mclk_mask, soc_mask;
-       uint32_t clock_limit;
-
-       if (!smu_clk_dpm_is_enabled(smu, clk_type)) {
-               switch (clk_type) {
-               case SMU_MCLK:
-               case SMU_UCLK:
-                       clock_limit = smu->smu_table.boot_values.uclk;
-                       break;
-               case SMU_GFXCLK:
-               case SMU_SCLK:
-                       clock_limit = smu->smu_table.boot_values.gfxclk;
-                       break;
-               case SMU_SOCCLK:
-                       clock_limit = smu->smu_table.boot_values.socclk;
-                       break;
-               default:
-                       clock_limit = 0;
-                       break;
-               }
-
-               /* clock in Mhz unit */
-               if (min)
-                       *min = clock_limit / 100;
-               if (max)
-                       *max = clock_limit / 100;
-
-               return 0;
-       }
-
-       if (max) {
-               ret = smu_get_profiling_clk_mask(smu, AMD_DPM_FORCED_LEVEL_PROFILE_PEAK,
-                                                NULL,
-                                                &mclk_mask,
-                                                &soc_mask);
-               if (ret)
-                       goto failed;
-
-               switch (clk_type) {
-               case SMU_GFXCLK:
-               case SMU_SCLK:
-                       ret = smu_send_smc_msg(smu, SMU_MSG_GetMaxGfxclkFrequency, max);
-                       if (ret) {
-                               dev_err(smu->adev->dev, "Attempt to get max GX frequency from SMC Failed !\n");
-                               goto failed;
-                       }
-                       break;
-               case SMU_UCLK:
-               case SMU_FCLK:
-               case SMU_MCLK:
-                       ret = smu_get_dpm_clk_limited(smu, clk_type, mclk_mask, max);
-                       if (ret)
-                               goto failed;
-                       break;
-               case SMU_SOCCLK:
-                       ret = smu_get_dpm_clk_limited(smu, clk_type, soc_mask, max);
-                       if (ret)
-                               goto failed;
-                       break;
-               default:
-                       ret = -EINVAL;
-                       goto failed;
-               }
-       }
-
-       if (min) {
-               switch (clk_type) {
-               case SMU_GFXCLK:
-               case SMU_SCLK:
-                       ret = smu_send_smc_msg(smu, SMU_MSG_GetMinGfxclkFrequency, min);
-                       if (ret) {
-                               dev_err(smu->adev->dev, "Attempt to get min GX frequency from SMC Failed !\n");
-                               goto failed;
-                       }
-                       break;
-               case SMU_UCLK:
-               case SMU_FCLK:
-               case SMU_MCLK:
-                       ret = smu_get_dpm_clk_limited(smu, clk_type, 0, min);
-                       if (ret)
-                               goto failed;
-                       break;
-               case SMU_SOCCLK:
-                       ret = smu_get_dpm_clk_limited(smu, clk_type, 0, min);
-                       if (ret)
-                               goto failed;
-                       break;
-               default:
-                       ret = -EINVAL;
-                       goto failed;
-               }
-       }
-failed:
-       return ret;
-}
-
 int smu_v12_0_mode2_reset(struct smu_context *smu){
        return smu_v12_0_send_msg_with_param(smu, SMU_MSG_GfxDeviceDriverReset, SMU_RESET_MODE_2, NULL);
 }