aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSrinivas Kandagatla <srinivas.kandagatla@linaro.org>2021-10-18 14:33:54 +0100
committerSrinivas Kandagatla <srinivas.kandagatla@linaro.org>2021-12-13 13:52:56 +0000
commite7da0ac1ae2a864e1545a4a8f352772aac319c0e (patch)
treeb53ad6990c8eeb38cdc9b2b0a4c4975563627265
parent8714e5a4704d755bfe579a02e196aa68b0d05631 (diff)
ASoC: codecs: va-macro: add runtime pm support
Signed-off-by: Srinivas Kandagatla <srinivas.kandagatla@linaro.org>
-rw-r--r--sound/soc/codecs/lpass-va-macro.c38
1 files changed, 37 insertions, 1 deletions
diff --git a/sound/soc/codecs/lpass-va-macro.c b/sound/soc/codecs/lpass-va-macro.c
index 11147e35689b..4a9142ebd279 100644
--- a/sound/soc/codecs/lpass-va-macro.c
+++ b/sound/soc/codecs/lpass-va-macro.c
@@ -9,6 +9,7 @@
#include <linux/of_clk.h>
#include <linux/of_platform.h>
#include <linux/platform_device.h>
+#include <linux/pm_runtime.h>
#include <linux/regmap.h>
#include <linux/regulator/consumer.h>
#include <sound/soc.h>
@@ -1426,7 +1427,7 @@ static int va_macro_probe(struct platform_device *pdev)
}
/* mclk rate */
- clk_set_rate(va->clks[1].clk, VA_MACRO_MCLK_FREQ);
+ clk_set_rate(va->clks[1].clk, 2 * VA_MACRO_MCLK_FREQ);
ret = clk_bulk_prepare_enable(VA_NUM_CLKS_MAX, va->clks);
if (ret)
return ret;
@@ -1454,6 +1455,12 @@ static int va_macro_probe(struct platform_device *pdev)
if (ret)
goto err;
+ pm_runtime_set_autosuspend_delay(dev, 3000);
+ pm_runtime_use_autosuspend(dev);
+ pm_runtime_mark_last_busy(dev);
+ pm_runtime_set_active(dev);
+ pm_runtime_enable(dev);
+
return ret;
err:
@@ -1471,6 +1478,34 @@ static int va_macro_remove(struct platform_device *pdev)
return 0;
}
+static int __maybe_unused va_macro_runtime_suspend(struct device *dev)
+{
+ struct va_macro *va = dev_get_drvdata(dev);
+
+ regcache_cache_only(va->regmap, true);
+ regcache_mark_dirty(va->regmap);
+
+ clk_disable_unprepare(va->clks[2].clk);
+
+ return 0;
+}
+
+static int __maybe_unused va_macro_runtime_resume(struct device *dev)
+{
+ struct va_macro *va = dev_get_drvdata(dev);
+
+ clk_prepare_enable(va->clks[2].clk);
+
+ regcache_cache_only(va->regmap, false);
+ regcache_sync(va->regmap);
+ return 0;
+}
+
+
+static const struct dev_pm_ops va_macro_pm_ops = {
+ SET_RUNTIME_PM_OPS(va_macro_runtime_suspend, va_macro_runtime_resume, NULL)
+};
+
static const struct of_device_id va_macro_dt_match[] = {
{ .compatible = "qcom,sc7280-lpass-va-macro" },
{ .compatible = "qcom,sm8250-lpass-va-macro" },
@@ -1483,6 +1518,7 @@ static struct platform_driver va_macro_driver = {
.name = "va_macro",
.of_match_table = va_macro_dt_match,
.suppress_bind_attrs = true,
+ .pm = &va_macro_pm_ops,
},
.probe = va_macro_probe,
.remove = va_macro_remove,