opts_dp->lanes = ctrl->link->link_params.num_lanes;
        opts_dp->link_rate = ctrl->link->link_params.rate / 100;
        opts_dp->ssc = drm_dp_max_downspread(dpcd);
-       dp_ctrl_set_clock_rate(ctrl, DP_CTRL_PM, "ctrl_link",
-                                       ctrl->link->link_params.rate * 1000);
 
        phy_configure(phy, &dp_io->phy_opts);
        phy_power_on(phy);
 
+       dev_pm_opp_set_rate(ctrl->dev, ctrl->link->link_params.rate * 1000);
        ret = dp_power_clk_enable(ctrl->power, DP_CTRL_PM, true);
        if (ret)
                DRM_ERROR("Unable to start link clocks. ret=%d\n", ret);
         * link clock might have been adjusted as part of the
         * link maintenance.
         */
+       dev_pm_opp_set_rate(ctrl->dev, 0);
        ret = dp_power_clk_enable(ctrl->power, DP_CTRL_PM, false);
        if (ret) {
                DRM_ERROR("Failed to disable clocks. ret=%d\n", ret);
 
        dp_catalog_ctrl_reset(ctrl->catalog);
 
+       dev_pm_opp_set_rate(ctrl->dev, 0);
        ret = dp_power_clk_enable(ctrl->power, DP_CTRL_PM, false);
        if (ret) {
                DRM_ERROR("Failed to disable link clocks. ret=%d\n", ret);
                }
        }
 
+       dev_pm_opp_set_rate(ctrl->dev, 0);
        ret = dp_power_clk_enable(ctrl->power, DP_CTRL_PM, false);
        if (ret) {
                DRM_ERROR("Failed to disable link clocks. ret=%d\n", ret);
        if (ret)
                DRM_ERROR("Failed to disable pixel clocks. ret=%d\n", ret);
 
+       dev_pm_opp_set_rate(ctrl->dev, 0);
        ret = dp_power_clk_enable(ctrl->power, DP_CTRL_PM, false);
        if (ret) {
                DRM_ERROR("Failed to disable link clocks. ret=%d\n", ret);
 
        return 0;
 }
 
-static int dp_power_clk_set_link_rate(struct dp_power_private *power,
-                       struct dss_clk *clk_arry, int num_clk, int enable)
-{
-       u32 rate;
-       int i, rc = 0;
-
-       for (i = 0; i < num_clk; i++) {
-               if (clk_arry[i].clk) {
-                       if (clk_arry[i].type == DSS_CLK_PCLK) {
-                               if (enable)
-                                       rate = clk_arry[i].rate;
-                               else
-                                       rate = 0;
-
-                               rc = dev_pm_opp_set_rate(power->dev, rate);
-                               if (rc)
-                                       break;
-                       }
-
-               }
-       }
-       return rc;
-}
-
 static int dp_power_clk_set_rate(struct dp_power_private *power,
                enum dp_pm_type module, bool enable)
 {
        int rc = 0;
        struct dss_module_power *mp = &power->parser->mp[module];
 
-       if (module == DP_CTRL_PM) {
-               rc = dp_power_clk_set_link_rate(power, mp->clk_config, mp->num_clk, enable);
-               if (rc) {
-                       DRM_ERROR("failed to set link clks rate\n");
-                       return rc;
-               }
-       } else {
-
+       if (module != DP_CTRL_PM) {
                if (enable) {
                        rc = msm_dss_clk_set_rate(mp->clk_config, mp->num_clk);
                        if (rc) {