aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKuninori Morimoto <kuninori.morimoto.gx@renesas.com>2016-01-20 20:59:12 -0500
committerMark Brown <broonie@kernel.org>2016-01-22 12:12:25 -0500
commitd0658b31c712327e04ddc2621742144de5562962 (patch)
tree39d27d14e0ed523272381491bc6ec4bc3b72f383
parentbd9a603fe78fa838a9c884b1e67749120a45508c (diff)
ASoC: rsnd: ctu: add rsnd_ctu_halt()
Based on datasheet process Signed-off-by: Kuninori Morimoto <kuninori.morimoto.gx@renesas.com> Signed-off-by: Mark Brown <broonie@kernel.org>
-rw-r--r--sound/soc/sh/rcar/ctu.c8
1 files changed, 8 insertions, 0 deletions
diff --git a/sound/soc/sh/rcar/ctu.c b/sound/soc/sh/rcar/ctu.c
index 0dc451803eb6..7b482f36cb63 100644
--- a/sound/soc/sh/rcar/ctu.c
+++ b/sound/soc/sh/rcar/ctu.c
@@ -31,6 +31,12 @@ static void rsnd_ctu_activation(struct rsnd_mod *mod)
31 rsnd_mod_write(mod, CTU_SWRSR, 1); 31 rsnd_mod_write(mod, CTU_SWRSR, 1);
32} 32}
33 33
34static void rsnd_ctu_halt(struct rsnd_mod *mod)
35{
36 rsnd_mod_write(mod, CTU_CTUIR, 1);
37 rsnd_mod_write(mod, CTU_SWRSR, 0);
38}
39
34#define rsnd_ctu_initialize_lock(mod) __rsnd_ctu_initialize_lock(mod, 1) 40#define rsnd_ctu_initialize_lock(mod) __rsnd_ctu_initialize_lock(mod, 1)
35#define rsnd_ctu_initialize_unlock(mod) __rsnd_ctu_initialize_lock(mod, 0) 41#define rsnd_ctu_initialize_unlock(mod) __rsnd_ctu_initialize_lock(mod, 0)
36static void __rsnd_ctu_initialize_lock(struct rsnd_mod *mod, u32 enable) 42static void __rsnd_ctu_initialize_lock(struct rsnd_mod *mod, u32 enable)
@@ -66,6 +72,8 @@ static int rsnd_ctu_quit(struct rsnd_mod *mod,
66 struct rsnd_dai_stream *io, 72 struct rsnd_dai_stream *io,
67 struct rsnd_priv *priv) 73 struct rsnd_priv *priv)
68{ 74{
75 rsnd_ctu_halt(mod);
76
69 rsnd_mod_power_off(mod); 77 rsnd_mod_power_off(mod);
70 78
71 return 0; 79 return 0;