aboutsummaryrefslogtreecommitdiffstats
path: root/sound/soc/codecs/twl6040.c
diff options
context:
space:
mode:
authorPeter Ujfalusi <peter.ujfalusi@ti.com>2011-10-12 07:46:02 -0400
committerMark Brown <broonie@opensource.wolfsonmicro.com>2011-10-12 08:11:54 -0400
commit33b6816ca3a4027a1b5444c83c1c24c0b1991262 (patch)
treec14a30ad5b0d70023887f6de96889678409b8c2b /sound/soc/codecs/twl6040.c
parent67c341302f5a401a405be758250bada39746c96b (diff)
ASoC: twl6040: Workaround for headset DC offset caused pop noise
Both Headset DAC need to be turned on/off at the same time before any of the output drivers are enabled (HS Left/Right, Earpiece). Move the HS DAC enable code to sequenced DAPM_SUPPLY, and attach it to the DACs. Signed-off-by: Peter Ujfalusi <peter.ujfalusi@ti.com> Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
Diffstat (limited to 'sound/soc/codecs/twl6040.c')
-rw-r--r--sound/soc/codecs/twl6040.c36
1 files changed, 28 insertions, 8 deletions
diff --git a/sound/soc/codecs/twl6040.c b/sound/soc/codecs/twl6040.c
index 864849838f4d..636923051ad3 100644
--- a/sound/soc/codecs/twl6040.c
+++ b/sound/soc/codecs/twl6040.c
@@ -654,6 +654,26 @@ static int headset_power_mode(struct snd_soc_codec *codec, int high_perf)
654static int twl6040_hs_dac_event(struct snd_soc_dapm_widget *w, 654static int twl6040_hs_dac_event(struct snd_soc_dapm_widget *w,
655 struct snd_kcontrol *kcontrol, int event) 655 struct snd_kcontrol *kcontrol, int event)
656{ 656{
657 struct snd_soc_codec *codec = w->codec;
658 u8 hslctl, hsrctl;
659
660 /*
661 * Workaround for Headset DC offset caused pop noise:
662 * Both HS DAC need to be turned on (before the HS driver) and off at
663 * the same time.
664 */
665 hslctl = twl6040_read_reg_cache(codec, TWL6040_REG_HSLCTL);
666 hsrctl = twl6040_read_reg_cache(codec, TWL6040_REG_HSRCTL);
667 if (SND_SOC_DAPM_EVENT_ON(event)) {
668 hslctl |= TWL6040_HSDACENA;
669 hsrctl |= TWL6040_HSDACENA;
670 } else {
671 hslctl &= ~TWL6040_HSDACENA;
672 hsrctl &= ~TWL6040_HSDACENA;
673 }
674 twl6040_write(codec, TWL6040_REG_HSLCTL, hslctl);
675 twl6040_write(codec, TWL6040_REG_HSRCTL, hsrctl);
676
657 msleep(1); 677 msleep(1);
658 return 0; 678 return 0;
659} 679}
@@ -1103,14 +1123,8 @@ static const struct snd_soc_dapm_widget twl6040_dapm_widgets[] = {
1103 TWL6040_REG_DMICBCTL, 4, 0), 1123 TWL6040_REG_DMICBCTL, 4, 0),
1104 1124
1105 /* DACs */ 1125 /* DACs */
1106 SND_SOC_DAPM_DAC_E("HSDAC Left", "Headset Playback", 1126 SND_SOC_DAPM_DAC("HSDAC Left", "Headset Playback", SND_SOC_NOPM, 0, 0),
1107 TWL6040_REG_HSLCTL, 0, 0, 1127 SND_SOC_DAPM_DAC("HSDAC Right", "Headset Playback", SND_SOC_NOPM, 0, 0),
1108 twl6040_hs_dac_event,
1109 SND_SOC_DAPM_POST_PMU | SND_SOC_DAPM_POST_PMD),
1110 SND_SOC_DAPM_DAC_E("HSDAC Right", "Headset Playback",
1111 TWL6040_REG_HSRCTL, 0, 0,
1112 twl6040_hs_dac_event,
1113 SND_SOC_DAPM_POST_PMU | SND_SOC_DAPM_POST_PMD),
1114 SND_SOC_DAPM_DAC_E("HFDAC Left", "Handsfree Playback", 1128 SND_SOC_DAPM_DAC_E("HFDAC Left", "Handsfree Playback",
1115 TWL6040_REG_HFLCTL, 0, 0, 1129 TWL6040_REG_HFLCTL, 0, 0,
1116 twl6040_power_mode_event, 1130 twl6040_power_mode_event,
@@ -1175,6 +1189,9 @@ static const struct snd_soc_dapm_widget twl6040_dapm_widgets[] = {
1175 NULL, 0), 1189 NULL, 0),
1176 SND_SOC_DAPM_SUPPLY("Vibra Right Control", TWL6040_REG_VIBCTLR, 2, 0, 1190 SND_SOC_DAPM_SUPPLY("Vibra Right Control", TWL6040_REG_VIBCTLR, 2, 0,
1177 NULL, 0), 1191 NULL, 0),
1192 SND_SOC_DAPM_SUPPLY_S("HSDAC Power", 1, SND_SOC_NOPM, 0, 0,
1193 twl6040_hs_dac_event,
1194 SND_SOC_DAPM_POST_PMU | SND_SOC_DAPM_POST_PMD),
1178 1195
1179 /* Analog playback PGAs */ 1196 /* Analog playback PGAs */
1180 SND_SOC_DAPM_PGA("HF Left PGA", 1197 SND_SOC_DAPM_PGA("HF Left PGA",
@@ -1204,6 +1221,9 @@ static const struct snd_soc_dapm_route intercon[] = {
1204 {"AFMAmpL", NULL, "AFML"}, 1221 {"AFMAmpL", NULL, "AFML"},
1205 {"AFMAmpR", NULL, "AFMR"}, 1222 {"AFMAmpR", NULL, "AFMR"},
1206 1223
1224 {"HSDAC Left", NULL, "HSDAC Power"},
1225 {"HSDAC Right", NULL, "HSDAC Power"},
1226
1207 {"Headset Left Playback", "HS DAC", "HSDAC Left"}, 1227 {"Headset Left Playback", "HS DAC", "HSDAC Left"},
1208 {"Headset Left Playback", "Line-In amp", "AFMAmpL"}, 1228 {"Headset Left Playback", "Line-In amp", "AFMAmpL"},
1209 1229