提交 c122f27e 编写于 作者: M Murali Karicheri 提交者: Rafael J. Wysocki

base: power - use clk_prepare_enable and clk_prepare_disable

When PM runtime is enabled in DaVinci and the machine migrates to
common clk framework, the clk_enable() gets called without
clk_prepare(). This patch is to fix this issue so that PM run
time can inter work with common clk framework.
Signed-off-by: NMurali Karicheri <m-karicheri2@ti.com>
Signed-off-by: NRafael J. Wysocki <rafael.j.wysocki@intel.com>
上级 77b67063
...@@ -99,7 +99,7 @@ static void __pm_clk_remove(struct pm_clock_entry *ce) ...@@ -99,7 +99,7 @@ static void __pm_clk_remove(struct pm_clock_entry *ce)
if (ce->status < PCE_STATUS_ERROR) { if (ce->status < PCE_STATUS_ERROR) {
if (ce->status == PCE_STATUS_ENABLED) if (ce->status == PCE_STATUS_ENABLED)
clk_disable(ce->clk); clk_disable_unprepare(ce->clk);
if (ce->status >= PCE_STATUS_ACQUIRED) if (ce->status >= PCE_STATUS_ACQUIRED)
clk_put(ce->clk); clk_put(ce->clk);
...@@ -396,7 +396,7 @@ static void enable_clock(struct device *dev, const char *con_id) ...@@ -396,7 +396,7 @@ static void enable_clock(struct device *dev, const char *con_id)
clk = clk_get(dev, con_id); clk = clk_get(dev, con_id);
if (!IS_ERR(clk)) { if (!IS_ERR(clk)) {
clk_enable(clk); clk_prepare_enable(clk);
clk_put(clk); clk_put(clk);
dev_info(dev, "Runtime PM disabled, clock forced on.\n"); dev_info(dev, "Runtime PM disabled, clock forced on.\n");
} }
...@@ -413,7 +413,7 @@ static void disable_clock(struct device *dev, const char *con_id) ...@@ -413,7 +413,7 @@ static void disable_clock(struct device *dev, const char *con_id)
clk = clk_get(dev, con_id); clk = clk_get(dev, con_id);
if (!IS_ERR(clk)) { if (!IS_ERR(clk)) {
clk_disable(clk); clk_disable_unprepare(clk);
clk_put(clk); clk_put(clk);
dev_info(dev, "Runtime PM disabled, clock forced off.\n"); dev_info(dev, "Runtime PM disabled, clock forced off.\n");
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册