summaryrefslogtreecommitdiffstats
path: root/sound/soc/codecs/pcm3008.c
diff options
context:
space:
mode:
authorMark Brown <broonie@linaro.org>2013-08-15 13:01:40 +0200
committerMark Brown <broonie@linaro.org>2013-08-18 17:40:00 +0200
commitfaaf36f21642a140715b7d6cf897ab4f4f5a924d (patch)
tree1a6bedf64aa7bce9cbdd4f161c0773cba2ecad29 /sound/soc/codecs/pcm3008.c
parentASoC: pcm3008: Use gpio_set_value_cansleep() (diff)
downloadlinux-faaf36f21642a140715b7d6cf897ab4f4f5a924d.tar.xz
linux-faaf36f21642a140715b7d6cf897ab4f4f5a924d.zip
ASoC: pcm3008: Add DAPM support
Make it possible to connect external devices to the CODEC and ensure continued operation with non-DAPM support removed from the core. Signed-off-by: Mark Brown <broonie@linaro.org>
Diffstat (limited to 'sound/soc/codecs/pcm3008.c')
-rw-r--r--sound/soc/codecs/pcm3008.c20
1 files changed, 20 insertions, 0 deletions
diff --git a/sound/soc/codecs/pcm3008.c b/sound/soc/codecs/pcm3008.c
index 8b9b378bc0a7..19f5028354f6 100644
--- a/sound/soc/codecs/pcm3008.c
+++ b/sound/soc/codecs/pcm3008.c
@@ -28,6 +28,22 @@
#include "pcm3008.h"
+static const struct snd_soc_dapm_widget pcm3008_dapm_widgets[] = {
+SND_SOC_DAPM_INPUT("VINL"),
+SND_SOC_DAPM_INPUT("VINR"),
+
+SND_SOC_DAPM_OUTPUT("VOUTL"),
+SND_SOC_DAPM_OUTPUT("VOUTR"),
+};
+
+static const struct snd_soc_dapm_route pcm3008_dapm_routes[] = {
+ { "PCM3008 Capture", NULL, "VINL" },
+ { "PCM3008 Capture", NULL, "VINR" },
+
+ { "VOUTL", NULL, "PCM3008 Playback" },
+ { "VOUTR", NULL, "PCM3008 Playback" },
+};
+
#define PCM3008_RATES (SNDRV_PCM_RATE_32000 | SNDRV_PCM_RATE_44100 | \
SNDRV_PCM_RATE_48000)
@@ -77,6 +93,10 @@ static int pcm3008_soc_resume(struct snd_soc_codec *codec)
static struct snd_soc_codec_driver soc_codec_dev_pcm3008 = {
.suspend = pcm3008_soc_suspend,
.resume = pcm3008_soc_resume,
+ .dapm_widgets = pcm3008_dapm_widgets,
+ .num_dapm_widgets = ARRAY_SIZE(pcm3008_dapm_widgets),
+ .dapm_routes = pcm3008_dapm_routes,
+ .num_dapm_routes = ARRAY_SIZE(pcm3008_dapm_routes),
};
static int pcm3008_codec_probe(struct platform_device *pdev)