aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorStephen Warren <swarren@nvidia.com>2011-04-18 22:58:11 -0400
committerMark Brown <broonie@opensource.wolfsonmicro.com>2011-04-20 09:00:35 -0400
commit97945c46a23de5f9dfedf1b4a33e51d074df9a9c (patch)
treef86addbfd71162f59ca1af16fc5bacefc51bfd5c
parentdad31ec133adb20c8fd10bfd9379da3f08b8721e (diff)
ASoC: WM8903: Implement DMIC support
In addition to the currently supported analog capture path, the WM8903 also supports digital mics. The analog and digital capture paths are exclusive; a mux is present to select the capture source. Logically, the mux exists to select the decimator's input, from either the ADC or DMIC block outputs. However, the ADC power domain also includes the DMIC interface. Consequently, this change represents the mux as existing immediately before the ADC, and selecting between the Input PGA and DMIC block outputs. An alternative might be to represent the mux in its correct location, and associate the ADC power enable controls with both the real ADC, and a fake ADC for the DMIC? Signed-off-by: Stephen Warren <swarren@nvidia.com> Acked-by: Liam Girdwood <lrg@ti.com> Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
-rw-r--r--sound/soc/codecs/wm8903.c23
1 files changed, 21 insertions, 2 deletions
diff --git a/sound/soc/codecs/wm8903.c b/sound/soc/codecs/wm8903.c
index d53f206d6410..f3cab8491431 100644
--- a/sound/soc/codecs/wm8903.c
+++ b/sound/soc/codecs/wm8903.c
@@ -634,6 +634,13 @@ static const struct soc_enum lsidetone_enum =
634static const struct soc_enum rsidetone_enum = 634static const struct soc_enum rsidetone_enum =
635 SOC_ENUM_SINGLE(WM8903_DAC_DIGITAL_0, 0, 3, sidetone_text); 635 SOC_ENUM_SINGLE(WM8903_DAC_DIGITAL_0, 0, 3, sidetone_text);
636 636
637static const char *adcinput_text[] = {
638 "ADC", "DMIC"
639};
640
641static const struct soc_enum adcinput_enum =
642 SOC_ENUM_SINGLE(WM8903_CLOCK_RATE_TEST_4, 9, 2, adcinput_text);
643
637static const char *aif_text[] = { 644static const char *aif_text[] = {
638 "Left", "Right" 645 "Left", "Right"
639}; 646};
@@ -767,6 +774,9 @@ static const struct snd_kcontrol_new lsidetone_mux =
767static const struct snd_kcontrol_new rsidetone_mux = 774static const struct snd_kcontrol_new rsidetone_mux =
768 SOC_DAPM_ENUM("DACR Sidetone Mux", rsidetone_enum); 775 SOC_DAPM_ENUM("DACR Sidetone Mux", rsidetone_enum);
769 776
777static const struct snd_kcontrol_new adcinput_mux =
778 SOC_DAPM_ENUM("ADC Input", adcinput_enum);
779
770static const struct snd_kcontrol_new lcapture_mux = 780static const struct snd_kcontrol_new lcapture_mux =
771 SOC_DAPM_ENUM("Left Capture Mux", lcapture_enum); 781 SOC_DAPM_ENUM("Left Capture Mux", lcapture_enum);
772 782
@@ -817,6 +827,7 @@ SND_SOC_DAPM_INPUT("IN2L"),
817SND_SOC_DAPM_INPUT("IN2R"), 827SND_SOC_DAPM_INPUT("IN2R"),
818SND_SOC_DAPM_INPUT("IN3L"), 828SND_SOC_DAPM_INPUT("IN3L"),
819SND_SOC_DAPM_INPUT("IN3R"), 829SND_SOC_DAPM_INPUT("IN3R"),
830SND_SOC_DAPM_INPUT("DMICDAT"),
820 831
821SND_SOC_DAPM_OUTPUT("HPOUTL"), 832SND_SOC_DAPM_OUTPUT("HPOUTL"),
822SND_SOC_DAPM_OUTPUT("HPOUTR"), 833SND_SOC_DAPM_OUTPUT("HPOUTR"),
@@ -842,6 +853,9 @@ SND_SOC_DAPM_MUX("Right Input Mode Mux", SND_SOC_NOPM, 0, 0, &rinput_mode_mux),
842SND_SOC_DAPM_PGA("Left Input PGA", WM8903_POWER_MANAGEMENT_0, 1, 0, NULL, 0), 853SND_SOC_DAPM_PGA("Left Input PGA", WM8903_POWER_MANAGEMENT_0, 1, 0, NULL, 0),
843SND_SOC_DAPM_PGA("Right Input PGA", WM8903_POWER_MANAGEMENT_0, 0, 0, NULL, 0), 854SND_SOC_DAPM_PGA("Right Input PGA", WM8903_POWER_MANAGEMENT_0, 0, 0, NULL, 0),
844 855
856SND_SOC_DAPM_MUX("Left ADC Input", SND_SOC_NOPM, 0, 0, &adcinput_mux),
857SND_SOC_DAPM_MUX("Right ADC Input", SND_SOC_NOPM, 0, 0, &adcinput_mux),
858
845SND_SOC_DAPM_ADC("ADCL", NULL, WM8903_POWER_MANAGEMENT_6, 1, 0), 859SND_SOC_DAPM_ADC("ADCL", NULL, WM8903_POWER_MANAGEMENT_6, 1, 0),
846SND_SOC_DAPM_ADC("ADCR", NULL, WM8903_POWER_MANAGEMENT_6, 0, 0), 860SND_SOC_DAPM_ADC("ADCR", NULL, WM8903_POWER_MANAGEMENT_6, 0, 0),
847 861
@@ -979,6 +993,11 @@ static const struct snd_soc_dapm_route wm8903_intercon[] = {
979 { "Left Input PGA", NULL, "Left Input Mode Mux" }, 993 { "Left Input PGA", NULL, "Left Input Mode Mux" },
980 { "Right Input PGA", NULL, "Right Input Mode Mux" }, 994 { "Right Input PGA", NULL, "Right Input Mode Mux" },
981 995
996 { "Left ADC Input", "ADC", "Left Input PGA" },
997 { "Left ADC Input", "DMIC", "DMICDAT" },
998 { "Right ADC Input", "ADC", "Right Input PGA" },
999 { "Right ADC Input", "DMIC", "DMICDAT" },
1000
982 { "Left Capture Mux", "Left", "ADCL" }, 1001 { "Left Capture Mux", "Left", "ADCL" },
983 { "Left Capture Mux", "Right", "ADCR" }, 1002 { "Left Capture Mux", "Right", "ADCR" },
984 1003
@@ -988,9 +1007,9 @@ static const struct snd_soc_dapm_route wm8903_intercon[] = {
988 { "AIFTXL", NULL, "Left Capture Mux" }, 1007 { "AIFTXL", NULL, "Left Capture Mux" },
989 { "AIFTXR", NULL, "Right Capture Mux" }, 1008 { "AIFTXR", NULL, "Right Capture Mux" },
990 1009
991 { "ADCL", NULL, "Left Input PGA" }, 1010 { "ADCL", NULL, "Left ADC Input" },
992 { "ADCL", NULL, "CLK_DSP" }, 1011 { "ADCL", NULL, "CLK_DSP" },
993 { "ADCR", NULL, "Right Input PGA" }, 1012 { "ADCR", NULL, "Right ADC Input" },
994 { "ADCR", NULL, "CLK_DSP" }, 1013 { "ADCR", NULL, "CLK_DSP" },
995 1014
996 { "Left Playback Mux", "Left", "AIFRXL" }, 1015 { "Left Playback Mux", "Left", "AIFRXL" },