aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAdam Thomson <Adam.Thomson.Opensource@diasemi.com>2016-05-10 11:11:04 -0400
committerMark Brown <broonie@kernel.org>2016-05-10 14:24:16 -0400
commita0d5caeaebfd00853efa0080afc850e10be7b39a (patch)
tree499963aa6cd5b74096d16b4ea4f9bece30f07f03
parentf55532a0c0b8bb6148f4e07853b876ef73bc69ca (diff)
ASoC: da7213: Add DAI DAPM event to control DAI clocks
Currently, when Codec is I2S master DAI clocks are continuously generated even if all audio streams have stopped. To improve efficiency, control of the DAI clocks for master mode have been moved to a DAPM widget event so they're only enabled as required. Signed-off-by: Adam Thomson <Adam.Thomson.Opensource@diasemi.com> Signed-off-by: Mark Brown <broonie@kernel.org>
-rw-r--r--sound/soc/codecs/da7213.c35
-rw-r--r--sound/soc/codecs/da7213.h2
2 files changed, 32 insertions, 5 deletions
diff --git a/sound/soc/codecs/da7213.c b/sound/soc/codecs/da7213.c
index 7278f93460c1..701bd6204747 100644
--- a/sound/soc/codecs/da7213.c
+++ b/sound/soc/codecs/da7213.c
@@ -726,6 +726,36 @@ static const struct snd_kcontrol_new da7213_dapm_mixoutr_controls[] = {
726 726
727 727
728/* 728/*
729 * DAPM Events
730 */
731
732static int da7213_dai_event(struct snd_soc_dapm_widget *w,
733 struct snd_kcontrol *kcontrol, int event)
734{
735 struct snd_soc_codec *codec = snd_soc_dapm_to_codec(w->dapm);
736 struct da7213_priv *da7213 = snd_soc_codec_get_drvdata(codec);
737
738 switch (event) {
739 case SND_SOC_DAPM_PRE_PMU:
740 /* Enable DAI clks for master mode */
741 if (da7213->master)
742 snd_soc_update_bits(codec, DA7213_DAI_CLK_MODE,
743 DA7213_DAI_CLK_EN_MASK,
744 DA7213_DAI_CLK_EN_MASK);
745 return 0;
746 case SND_SOC_DAPM_POST_PMD:
747 /* Disable DAI clks if in master mode */
748 if (da7213->master)
749 snd_soc_update_bits(codec, DA7213_DAI_CLK_MODE,
750 DA7213_DAI_CLK_EN_MASK, 0);
751 return 0;
752 default:
753 return -EINVAL;
754 }
755}
756
757
758/*
729 * DAPM widgets 759 * DAPM widgets
730 */ 760 */
731 761
@@ -736,7 +766,8 @@ static const struct snd_soc_dapm_widget da7213_dapm_widgets[] = {
736 766
737 /* Use a supply here as this controls both input & output DAIs */ 767 /* Use a supply here as this controls both input & output DAIs */
738 SND_SOC_DAPM_SUPPLY("DAI", DA7213_DAI_CTRL, DA7213_DAI_EN_SHIFT, 768 SND_SOC_DAPM_SUPPLY("DAI", DA7213_DAI_CTRL, DA7213_DAI_EN_SHIFT,
739 DA7213_NO_INVERT, NULL, 0), 769 DA7213_NO_INVERT, da7213_dai_event,
770 SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
740 771
741 /* 772 /*
742 * Input 773 * Input
@@ -1143,11 +1174,9 @@ static int da7213_set_dai_fmt(struct snd_soc_dai *codec_dai, unsigned int fmt)
1143 /* Set master/slave mode */ 1174 /* Set master/slave mode */
1144 switch (fmt & SND_SOC_DAIFMT_MASTER_MASK) { 1175 switch (fmt & SND_SOC_DAIFMT_MASTER_MASK) {
1145 case SND_SOC_DAIFMT_CBM_CFM: 1176 case SND_SOC_DAIFMT_CBM_CFM:
1146 dai_clk_mode |= DA7213_DAI_CLK_EN_MASTER_MODE;
1147 da7213->master = true; 1177 da7213->master = true;
1148 break; 1178 break;
1149 case SND_SOC_DAIFMT_CBS_CFS: 1179 case SND_SOC_DAIFMT_CBS_CFS:
1150 dai_clk_mode |= DA7213_DAI_CLK_EN_SLAVE_MODE;
1151 da7213->master = false; 1180 da7213->master = false;
1152 break; 1181 break;
1153 default: 1182 default:
diff --git a/sound/soc/codecs/da7213.h b/sound/soc/codecs/da7213.h
index 030fd691b076..5de5c2997e0c 100644
--- a/sound/soc/codecs/da7213.h
+++ b/sound/soc/codecs/da7213.h
@@ -178,8 +178,6 @@
178#define DA7213_DAI_BCLKS_PER_WCLK_MASK (0x3 << 0) 178#define DA7213_DAI_BCLKS_PER_WCLK_MASK (0x3 << 0)
179#define DA7213_DAI_CLK_POL_INV (0x1 << 2) 179#define DA7213_DAI_CLK_POL_INV (0x1 << 2)
180#define DA7213_DAI_WCLK_POL_INV (0x1 << 3) 180#define DA7213_DAI_WCLK_POL_INV (0x1 << 3)
181#define DA7213_DAI_CLK_EN_SLAVE_MODE (0x0 << 7)
182#define DA7213_DAI_CLK_EN_MASTER_MODE (0x1 << 7)
183#define DA7213_DAI_CLK_EN_MASK (0x1 << 7) 181#define DA7213_DAI_CLK_EN_MASK (0x1 << 7)
184 182
185/* DA7213_DAI_CTRL = 0x29 */ 183/* DA7213_DAI_CTRL = 0x29 */