summaryrefslogtreecommitdiffstats
path: root/sound/soc/codecs/pcm1792a.c
diff options
context:
space:
mode:
authorMark Brown <broonie@linaro.org>2013-08-13 19:30:00 +0200
committerMark Brown <broonie@linaro.org>2013-08-15 12:33:15 +0200
commite7a5cb4223c86df522a97e21742aeef153db4ebb (patch)
tree51746ec45bca5773dd29fdfddfad9e2eb28039be /sound/soc/codecs/pcm1792a.c
parentASoC: pcm1792a: Remove empty capture DAI stub (diff)
downloadlinux-e7a5cb4223c86df522a97e21742aeef153db4ebb.tar.xz
linux-e7a5cb4223c86df522a97e21742aeef153db4ebb.zip
ASoC: pcm1792a: Add DAPM support
Provide DAPM for the device, ensuring operation with DAPM required by the core and making it easier to hook up external hardware to it. Signed-off-by: Mark Brown <broonie@linaro.org>
Diffstat (limited to 'sound/soc/codecs/pcm1792a.c')
-rw-r--r--sound/soc/codecs/pcm1792a.c18
1 files changed, 18 insertions, 0 deletions
diff --git a/sound/soc/codecs/pcm1792a.c b/sound/soc/codecs/pcm1792a.c
index c57d3a5665c5..2a8eccf64c76 100644
--- a/sound/soc/codecs/pcm1792a.c
+++ b/sound/soc/codecs/pcm1792a.c
@@ -154,6 +154,20 @@ static const struct snd_kcontrol_new pcm1792a_controls[] = {
pcm1792a_dac_tlv),
};
+static const struct snd_soc_dapm_widget pcm1792a_dapm_widgets[] = {
+SND_SOC_DAPM_OUTPUT("IOUTL+"),
+SND_SOC_DAPM_OUTPUT("IOUTL-"),
+SND_SOC_DAPM_OUTPUT("IOUTR+"),
+SND_SOC_DAPM_OUTPUT("IOUTR-"),
+};
+
+static const struct snd_soc_dapm_route pcm1792a_dapm_routes[] = {
+ { "IOUTL+", NULL, "Playback" },
+ { "IOUTL-", NULL, "Playback" },
+ { "IOUTR+", NULL, "Playback" },
+ { "IOUTR-", NULL, "Playback" },
+};
+
static struct snd_soc_dai_driver pcm1792a_dai = {
.name = "pcm1792a-hifi",
.playback = {
@@ -184,6 +198,10 @@ static const struct regmap_config pcm1792a_regmap = {
static struct snd_soc_codec_driver soc_codec_dev_pcm1792a = {
.controls = pcm1792a_controls,
.num_controls = ARRAY_SIZE(pcm1792a_controls),
+ .dapm_widgets = pcm1792a_dapm_widgets,
+ .num_dapm_widgets = ARRAY_SIZE(pcm1792a_dapm_widgets),
+ .dapm_routes = pcm1792a_dapm_routes,
+ .num_dapm_routes = ARRAY_SIZE(pcm1792a_dapm_routes),
};
static int pcm1792a_spi_probe(struct spi_device *spi)