* [PATCH v3] ASoC: mediatek: Add second I2S on mt8173-rt5650 machine driver
@ 2016-04-07 7:35 PC Liao
2016-04-07 9:50 ` Matthias Brugger
2016-04-18 11:36 ` PC Liao
0 siblings, 2 replies; 6+ messages in thread
From: PC Liao @ 2016-04-07 7:35 UTC (permalink / raw)
To: broonie, tiwai
Cc: srv_heupstream, linux-mediatek, s.hauer, linux-arm-kernel,
linux-kernel, alsa-devel, koro.chen, PC Liao
This patch adds second I2S connection to rt5650 codec for capture path on
mt8173-rt5650 machine driver.
Signed-off-by: PC Liao <pc.liao@mediatek.com>
---
Changes since v2:
Use sound-dai to determine the capture path.
---
.../devicetree/bindings/sound/mt8173-rt5650.txt | 6 +++
sound/soc/mediatek/mt8173-rt5650.c | 42 ++++++++++++++++++--
2 files changed, 44 insertions(+), 4 deletions(-)
diff --git a/Documentation/devicetree/bindings/sound/mt8173-rt5650.txt b/Documentation/devicetree/bindings/sound/mt8173-rt5650.txt
index fe5a5ef..4ed768e 100644
--- a/Documentation/devicetree/bindings/sound/mt8173-rt5650.txt
+++ b/Documentation/devicetree/bindings/sound/mt8173-rt5650.txt
@@ -5,11 +5,17 @@ Required properties:
- mediatek,audio-codec: the phandles of rt5650 codecs
- mediatek,platform: the phandle of MT8173 ASoC platform
+Optional properties:
+- sound-dai: audio codec dai on capture path
+ <&rt5650 0> : Default setting. Connect rt5650 I2S1 for capture. (dai_name = rt5645-aif1)
+ <&rt5650 1> : Connect rt5650 I2S2 for capture. (dai_name = rt5645-aif2)
+
Example:
sound {
compatible = "mediatek,mt8173-rt5650";
mediatek,audio-codec = <&rt5650>;
mediatek,platform = <&afe>;
+ sound-dai = <&rt5650 1>;
};
diff --git a/sound/soc/mediatek/mt8173-rt5650.c b/sound/soc/mediatek/mt8173-rt5650.c
index bb09bb1..9f56df9 100644
--- a/sound/soc/mediatek/mt8173-rt5650.c
+++ b/sound/soc/mediatek/mt8173-rt5650.c
@@ -85,12 +85,26 @@ static int mt8173_rt5650_init(struct snd_soc_pcm_runtime *runtime)
{
struct snd_soc_card *card = runtime->card;
struct snd_soc_codec *codec = runtime->codec_dais[0]->codec;
+ const char *codec_dai_capture = runtime->codec_dais[1]->name;
int ret;
rt5645_sel_asrc_clk_src(codec,
- RT5645_DA_STEREO_FILTER |
- RT5645_AD_STEREO_FILTER,
- RT5645_CLK_SEL_I2S1_ASRC);
+ RT5645_DA_STEREO_FILTER,
+ RT5645_CLK_SEL_I2S1_ASRC);
+
+ if (!strcmp(codec_dai_capture, "rt5645-aif1")) {
+ rt5645_sel_asrc_clk_src(codec,
+ RT5645_AD_STEREO_FILTER,
+ RT5645_CLK_SEL_I2S1_ASRC);
+ } else if (!strcmp(codec_dai_capture, "rt5645-aif2")) {
+ rt5645_sel_asrc_clk_src(codec,
+ RT5645_AD_STEREO_FILTER,
+ RT5645_CLK_SEL_I2S2_ASRC);
+ } else {
+ dev_err(card->dev, "Can't get the right codec dai\n");
+ return -EINVAL;
+ }
+
/* enable jack detection */
ret = snd_soc_card_jack_new(card, "Headset Jack",
SND_JACK_HEADPHONE | SND_JACK_MICROPHONE |
@@ -110,6 +124,11 @@ static int mt8173_rt5650_init(struct snd_soc_pcm_runtime *runtime)
static struct snd_soc_dai_link_component mt8173_rt5650_codecs[] = {
{
+ /* Playback */
+ .dai_name = "rt5645-aif1",
+ },
+ {
+ /* Capture */
.dai_name = "rt5645-aif1",
},
};
@@ -149,7 +168,7 @@ static struct snd_soc_dai_link mt8173_rt5650_dais[] = {
.cpu_dai_name = "I2S",
.no_pcm = 1,
.codecs = mt8173_rt5650_codecs,
- .num_codecs = 1,
+ .num_codecs = 2,
.init = mt8173_rt5650_init,
.dai_fmt = SND_SOC_DAIFMT_I2S | SND_SOC_DAIFMT_NB_NF |
SND_SOC_DAIFMT_CBS_CFS,
@@ -177,6 +196,7 @@ static int mt8173_rt5650_dev_probe(struct platform_device *pdev)
{
struct snd_soc_card *card = &mt8173_rt5650_card;
struct device_node *platform_node;
+ const char *codec_dai_capture;
int i, ret;
platform_node = of_parse_phandle(pdev->dev.of_node,
@@ -199,6 +219,20 @@ static int mt8173_rt5650_dev_probe(struct platform_device *pdev)
"Property 'audio-codec' missing or invalid\n");
return -EINVAL;
}
+ mt8173_rt5650_codecs[1].of_node = mt8173_rt5650_codecs[0].of_node;
+
+ if (device_property_present(&pdev->dev, "sound-dai")) {
+ ret = snd_soc_of_get_dai_name(pdev->dev.of_node,
+ &codec_dai_capture);
+ if (ret < 0) {
+ dev_err(&pdev->dev,
+ "%s snd_soc_of_get_dai_name fail %d\n",
+ __func__, ret);
+ return ret;
+ }
+ mt8173_rt5650_codecs[1].dai_name = codec_dai_capture;
+ }
+
card->dev = &pdev->dev;
platform_set_drvdata(pdev, card);
--
1.7.9.5
^ permalink raw reply related [flat|nested] 6+ messages in thread
* Re: [PATCH v3] ASoC: mediatek: Add second I2S on mt8173-rt5650 machine driver
2016-04-07 7:35 [PATCH v3] ASoC: mediatek: Add second I2S on mt8173-rt5650 machine driver PC Liao
@ 2016-04-07 9:50 ` Matthias Brugger
2016-04-07 10:03 ` PC Liao
2016-04-18 11:36 ` PC Liao
1 sibling, 1 reply; 6+ messages in thread
From: Matthias Brugger @ 2016-04-07 9:50 UTC (permalink / raw)
To: PC Liao, broonie, tiwai
Cc: alsa-devel, srv_heupstream, s.hauer, linux-kernel, koro.chen,
linux-mediatek, linux-arm-kernel
On 07/04/16 09:35, PC Liao wrote:
> This patch adds second I2S connection to rt5650 codec for capture path on
> mt8173-rt5650 machine driver.
>
> Signed-off-by: PC Liao <pc.liao@mediatek.com>
> ---
> Changes since v2:
> Use sound-dai to determine the capture path.
> ---
> .../devicetree/bindings/sound/mt8173-rt5650.txt | 6 +++
> sound/soc/mediatek/mt8173-rt5650.c | 42 ++++++++++++++++++--
> 2 files changed, 44 insertions(+), 4 deletions(-)
>
> diff --git a/Documentation/devicetree/bindings/sound/mt8173-rt5650.txt b/Documentation/devicetree/bindings/sound/mt8173-rt5650.txt
> index fe5a5ef..4ed768e 100644
> --- a/Documentation/devicetree/bindings/sound/mt8173-rt5650.txt
> +++ b/Documentation/devicetree/bindings/sound/mt8173-rt5650.txt
> @@ -5,11 +5,17 @@ Required properties:
> - mediatek,audio-codec: the phandles of rt5650 codecs
> - mediatek,platform: the phandle of MT8173 ASoC platform
>
> +Optional properties:
> +- sound-dai: audio codec dai on capture path
> + <&rt5650 0> : Default setting. Connect rt5650 I2S1 for capture. (dai_name = rt5645-aif1)
> + <&rt5650 1> : Connect rt5650 I2S2 for capture. (dai_name = rt5645-aif2)
> +
> Example:
>
> sound {
> compatible = "mediatek,mt8173-rt5650";
> mediatek,audio-codec = <&rt5650>;
> mediatek,platform = <&afe>;
> + sound-dai = <&rt5650 1>;
> };
>
> diff --git a/sound/soc/mediatek/mt8173-rt5650.c b/sound/soc/mediatek/mt8173-rt5650.c
> index bb09bb1..9f56df9 100644
> --- a/sound/soc/mediatek/mt8173-rt5650.c
> +++ b/sound/soc/mediatek/mt8173-rt5650.c
> @@ -85,12 +85,26 @@ static int mt8173_rt5650_init(struct snd_soc_pcm_runtime *runtime)
> {
> struct snd_soc_card *card = runtime->card;
> struct snd_soc_codec *codec = runtime->codec_dais[0]->codec;
> + const char *codec_dai_capture = runtime->codec_dais[1]->name;
> int ret;
>
> rt5645_sel_asrc_clk_src(codec,
> - RT5645_DA_STEREO_FILTER |
> - RT5645_AD_STEREO_FILTER,
> - RT5645_CLK_SEL_I2S1_ASRC);
> + RT5645_DA_STEREO_FILTER,
> + RT5645_CLK_SEL_I2S1_ASRC);
> +
> + if (!strcmp(codec_dai_capture, "rt5645-aif1")) {
> + rt5645_sel_asrc_clk_src(codec,
> + RT5645_AD_STEREO_FILTER,
> + RT5645_CLK_SEL_I2S1_ASRC);
> + } else if (!strcmp(codec_dai_capture, "rt5645-aif2")) {
> + rt5645_sel_asrc_clk_src(codec,
> + RT5645_AD_STEREO_FILTER,
> + RT5645_CLK_SEL_I2S2_ASRC);
> + } else {
> + dev_err(card->dev, "Can't get the right codec dai\n");
> + return -EINVAL;
For compatibility issues we should enable RT5645_CLK_SEL_I2S1_ASRC as
default. BTW in the old version you enabled DA and AD filter while in
the new version you just enable AD filter. What is the reason for that?
Regards,
Matthias
> + }
> +
> /* enable jack detection */
> ret = snd_soc_card_jack_new(card, "Headset Jack",
> SND_JACK_HEADPHONE | SND_JACK_MICROPHONE |
> @@ -110,6 +124,11 @@ static int mt8173_rt5650_init(struct snd_soc_pcm_runtime *runtime)
>
> static struct snd_soc_dai_link_component mt8173_rt5650_codecs[] = {
> {
> + /* Playback */
> + .dai_name = "rt5645-aif1",
> + },
> + {
> + /* Capture */
> .dai_name = "rt5645-aif1",
> },
> };
> @@ -149,7 +168,7 @@ static struct snd_soc_dai_link mt8173_rt5650_dais[] = {
> .cpu_dai_name = "I2S",
> .no_pcm = 1,
> .codecs = mt8173_rt5650_codecs,
> - .num_codecs = 1,
> + .num_codecs = 2,
> .init = mt8173_rt5650_init,
> .dai_fmt = SND_SOC_DAIFMT_I2S | SND_SOC_DAIFMT_NB_NF |
> SND_SOC_DAIFMT_CBS_CFS,
> @@ -177,6 +196,7 @@ static int mt8173_rt5650_dev_probe(struct platform_device *pdev)
> {
> struct snd_soc_card *card = &mt8173_rt5650_card;
> struct device_node *platform_node;
> + const char *codec_dai_capture;
> int i, ret;
>
> platform_node = of_parse_phandle(pdev->dev.of_node,
> @@ -199,6 +219,20 @@ static int mt8173_rt5650_dev_probe(struct platform_device *pdev)
> "Property 'audio-codec' missing or invalid\n");
> return -EINVAL;
> }
> + mt8173_rt5650_codecs[1].of_node = mt8173_rt5650_codecs[0].of_node;
> +
> + if (device_property_present(&pdev->dev, "sound-dai")) {
> + ret = snd_soc_of_get_dai_name(pdev->dev.of_node,
> + &codec_dai_capture);
> + if (ret < 0) {
> + dev_err(&pdev->dev,
> + "%s snd_soc_of_get_dai_name fail %d\n",
> + __func__, ret);
> + return ret;
> + }
> + mt8173_rt5650_codecs[1].dai_name = codec_dai_capture;
> + }
> +
> card->dev = &pdev->dev;
> platform_set_drvdata(pdev, card);
>
>
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: [PATCH v3] ASoC: mediatek: Add second I2S on mt8173-rt5650 machine driver
2016-04-07 9:50 ` Matthias Brugger
@ 2016-04-07 10:03 ` PC Liao
0 siblings, 0 replies; 6+ messages in thread
From: PC Liao @ 2016-04-07 10:03 UTC (permalink / raw)
To: Matthias Brugger
Cc: broonie, tiwai, alsa-devel, srv_heupstream, s.hauer,
linux-kernel, Koro Chen (陳思翰),
linux-mediatek, linux-arm-kernel
Hi Matthias,
On Thu, 2016-04-07 at 17:50 +0800, Matthias Brugger wrote:
>
> On 07/04/16 09:35, PC Liao wrote:
> > diff --git a/sound/soc/mediatek/mt8173-rt5650.c b/sound/soc/mediatek/mt8173-rt5650.c
> > index bb09bb1..9f56df9 100644
> > --- a/sound/soc/mediatek/mt8173-rt5650.c
> > +++ b/sound/soc/mediatek/mt8173-rt5650.c
> > @@ -85,12 +85,26 @@ static int mt8173_rt5650_init(struct snd_soc_pcm_runtime *runtime)
> > {
> > struct snd_soc_card *card = runtime->card;
> > struct snd_soc_codec *codec = runtime->codec_dais[0]->codec;
> > + const char *codec_dai_capture = runtime->codec_dais[1]->name;
> > int ret;
> >
> > rt5645_sel_asrc_clk_src(codec,
> > - RT5645_DA_STEREO_FILTER |
> > - RT5645_AD_STEREO_FILTER,
> > - RT5645_CLK_SEL_I2S1_ASRC);
> > + RT5645_DA_STEREO_FILTER,
> > + RT5645_CLK_SEL_I2S1_ASRC);
> > +
> > + if (!strcmp(codec_dai_capture, "rt5645-aif1")) {
> > + rt5645_sel_asrc_clk_src(codec,
> > + RT5645_AD_STEREO_FILTER,
> > + RT5645_CLK_SEL_I2S1_ASRC);
> > + } else if (!strcmp(codec_dai_capture, "rt5645-aif2")) {
> > + rt5645_sel_asrc_clk_src(codec,
> > + RT5645_AD_STEREO_FILTER,
> > + RT5645_CLK_SEL_I2S2_ASRC);
> > + } else {
> > + dev_err(card->dev, "Can't get the right codec dai\n");
> > + return -EINVAL;
>
> For compatibility issues we should enable RT5645_CLK_SEL_I2S1_ASRC as
> default. BTW in the old version you enabled DA and AD filter while in
> the new version you just enable AD filter. What is the reason for that?
>
> Regards,
> Matthias
Thanks for comment.
I separate rt5645_sel_asrc_clk_src function into two parts.
I have and enable DA filter for I2S1 first.
Then, I use codec_dai_capture to determine which I2S AD filter I need.
Thanks!
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: [PATCH v3] ASoC: mediatek: Add second I2S on mt8173-rt5650 machine driver
2016-04-07 7:35 [PATCH v3] ASoC: mediatek: Add second I2S on mt8173-rt5650 machine driver PC Liao
2016-04-07 9:50 ` Matthias Brugger
@ 2016-04-18 11:36 ` PC Liao
2016-04-18 12:03 ` Mark Brown
1 sibling, 1 reply; 6+ messages in thread
From: PC Liao @ 2016-04-18 11:36 UTC (permalink / raw)
To: broonie
Cc: tiwai, srv_heupstream, linux-mediatek, s.hauer, linux-arm-kernel,
linux-kernel, alsa-devel, Koro Chen (陳思翰)
Hi Mark,
On Thu, 2016-04-07 at 15:35 +0800, PC Liao wrote:
> This patch adds second I2S connection to rt5650 codec for capture path on
> mt8173-rt5650 machine driver.
>
> Signed-off-by: PC Liao <pc.liao@mediatek.com>
> ---
> Changes since v2:
> Use sound-dai to determine the capture path.
> ---
> .../devicetree/bindings/sound/mt8173-rt5650.txt | 6 +++
> sound/soc/mediatek/mt8173-rt5650.c | 42 ++++++++++++++++++--
> 2 files changed, 44 insertions(+), 4 deletions(-)
>
Could you please give some comments or suggestions?
Thanks!
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: [PATCH v3] ASoC: mediatek: Add second I2S on mt8173-rt5650 machine driver
2016-04-18 11:36 ` PC Liao
@ 2016-04-18 12:03 ` Mark Brown
2016-04-18 12:59 ` PC Liao
0 siblings, 1 reply; 6+ messages in thread
From: Mark Brown @ 2016-04-18 12:03 UTC (permalink / raw)
To: PC Liao
Cc: tiwai, srv_heupstream, linux-mediatek, s.hauer, linux-arm-kernel,
linux-kernel, alsa-devel, Koro Chen (陳思翰)
[-- Attachment #1: Type: text/plain, Size: 709 bytes --]
On Mon, Apr 18, 2016 at 07:36:20PM +0800, PC Liao wrote:
> Could you please give some comments or suggestions?
I don't have these patches. If you're getting review comments from
other people please address them, it's quite possible I saw them and
agreed with them.
Please don't send content free pings and please allow a reasonable time
for review. People get busy, go on holiday, attend conferences and so
on so unless there is some reason for urgency (like critical bug fixes)
please allow at least a couple of weeks for review. Sending content
free pings just adds to the mail volume (if they are seen at all) and if
something has gone wrong you'll have to resend the patches anyway.
[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 473 bytes --]
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: [PATCH v3] ASoC: mediatek: Add second I2S on mt8173-rt5650 machine driver
2016-04-18 12:03 ` Mark Brown
@ 2016-04-18 12:59 ` PC Liao
0 siblings, 0 replies; 6+ messages in thread
From: PC Liao @ 2016-04-18 12:59 UTC (permalink / raw)
To: Mark Brown
Cc: tiwai, srv_heupstream, linux-mediatek, s.hauer, linux-arm-kernel,
linux-kernel, alsa-devel, Koro Chen (陳思翰)
Hi Mark,
On Mon, 2016-04-18 at 20:03 +0800, Mark Brown wrote:
> On Mon, Apr 18, 2016 at 07:36:20PM +0800, PC Liao wrote:
>
> > Could you please give some comments or suggestions?
>
> I don't have these patches. If you're getting review comments from
> other people please address them, it's quite possible I saw them and
> agreed with them.
>
> Please don't send content free pings and please allow a reasonable time
> for review. People get busy, go on holiday, attend conferences and so
> on so unless there is some reason for urgency (like critical bug fixes)
> please allow at least a couple of weeks for review. Sending content
> free pings just adds to the mail volume (if they are seen at all) and if
> something has gone wrong you'll have to resend the patches anyway.
I am so sorry about that..........
I have sent v4.
Thanks for your review and help.
^ permalink raw reply [flat|nested] 6+ messages in thread
end of thread, other threads:[~2016-04-18 13:00 UTC | newest]
Thread overview: 6+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2016-04-07 7:35 [PATCH v3] ASoC: mediatek: Add second I2S on mt8173-rt5650 machine driver PC Liao
2016-04-07 9:50 ` Matthias Brugger
2016-04-07 10:03 ` PC Liao
2016-04-18 11:36 ` PC Liao
2016-04-18 12:03 ` Mark Brown
2016-04-18 12:59 ` PC Liao
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).