[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <87bmqrosla.wl%kuninori.morimoto.gx@renesas.com>
Date: Thu, 18 May 2017 01:39:44 +0000
From: Kuninori Morimoto <kuninori.morimoto.gx@...esas.com>
To: Mark Brown <broonie@...nel.org>,
Archit Taneja <architt@...eaurora.org>
CC: Linux-ALSA <alsa-devel@...a-project.org>,
Simon <horms@...ge.net.au>, <linux-renesas-soc@...r.kernel.org>,
David Airlie <airlied@...ux.ie>,
Laurent Pinchart <laurent.pinchart+renesas@...asonboard.com>,
Russell King <rmk+kernel@...linux.org.uk>,
Jose Abreu <joabreu@...opsys.com>,
<dri-devel@...ts.freedesktop.org>, <linux-kernel@...r.kernel.org>
Subject: [PATCH 2/5] ASoC: simple-card-utils: support snd_soc_get_dai_id()
From: Kuninori Morimoto <kuninori.morimoto.gx@...esas.com>
ALSA SoC needs to know connected DAI ID for detecting.
It is not a big problem if device/driver was only for sound,
but getting DAI ID will be difficult if device includes both
Video/Sound, like HDMI.
To solve this issue, this patch adds new snd_soc_get_dai_id() and
its related .of_xlate_dai_id callback on component driver.
In below case, we can handle Sound port (= port@2) as ID = 0
if .of_xlate_dai_id has its support.
hdmi {
port@0 { /* VIDEO */ };
port@1 { /* VIDEO */ };
port@2 { /* SOUND */ };
};
Signed-off-by: Kuninori Morimoto <kuninori.morimoto.gx@...esas.com>
---
sound/soc/generic/simple-card-utils.c | 9 +++++++++
1 file changed, 9 insertions(+)
diff --git a/sound/soc/generic/simple-card-utils.c b/sound/soc/generic/simple-card-utils.c
index 5a3d51e..fe726e8 100644
--- a/sound/soc/generic/simple-card-utils.c
+++ b/sound/soc/generic/simple-card-utils.c
@@ -177,9 +177,18 @@ static int asoc_simple_card_get_dai_id(struct device_node *ep)
struct device_node *node;
struct device_node *endpoint;
int i, id;
+ int ret;
+
+ ret = snd_soc_get_dai_id(ep);
+ if (ret != -ENOTSUPP)
+ return ret;
node = of_graph_get_port_parent(ep);
+ /*
+ * Non HDMI sound case, counting port/endpoint on its DT
+ * is enough. Let's count it.
+ */
i = 0;
id = -1;
for_each_endpoint_of_node(node, endpoint) {
--
1.9.1
Powered by blists - more mailing lists