From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753256AbdIEVNs (ORCPT ); Tue, 5 Sep 2017 17:13:48 -0400 Received: from mail-out.m-online.net ([212.18.0.10]:36683 "EHLO mail-out.m-online.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752312AbdIEVNq (ORCPT ); Tue, 5 Sep 2017 17:13:46 -0400 X-Auth-Info: OChJWvDaI6b0kxRC83xwcvOau0QZd6niTE+Cb+mnEvI= Subject: Re: [PATCH] sound: soc: fsl: Do not set DAI sysclk when it is equal to system freq To: Nicolin Chen , Fabio Estevam Cc: Timur Tabi , Xiubo Li , Liam Girdwood , Mark Brown , Jaroslav Kysela , Takashi Iwai , "festevam@gmail.com" , "alsa-devel@alsa-project.org" , "linuxppc-dev@lists.ozlabs.org" , "linux-kernel@vger.kernel.org" References: <1504436701-20700-1-git-send-email-lukma@denx.de> <07e54d28-3bbc-aad2-146b-30867c0bc337@denx.de> <20170905052031.GB2774@Asurada-CZ80> <819784e1-910b-6833-997a-2097e147bd0c@denx.de> <20170905181108.GB23906@Asurada-Nvidia> From: =?UTF-8?Q?=c5=81ukasz_Majewski?= Organization: DENX Message-ID: Date: Tue, 5 Sep 2017 23:13:40 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.2.1 MIME-Version: 1.0 In-Reply-To: <20170905181108.GB23906@Asurada-Nvidia> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Nicolin, > On Tue, Sep 05, 2017 at 10:35:34AM +0200, Ɓukasz Majewski wrote: > >>> And apparently, we shouldn't set bitclk to 66MHz either. Can >>> you help to find where this 66MHz comes from? > >> 2. int asoc_simple_card_init_dai() @ simple-card-utils.c > > Oh, I just searched in the simple-card.c but missed this file. > >> In this function (point 2.) the >> simple_dai->sysclk is set and: >> snd_soc_dai_set_sysclk(dai, 0, simple_dai->sysclk, 0) >> which sets frequency to 66 MHz [*]. >> >> The asoc_simple_card_init_dai() is called in >> asoc_simple_card_dai_init() @ simple-card.c >> which is assigned to dai_link->init >> dai_link->init = asoc_simple_card_dai_init; @ simple_card.c >> >> And the sysclk itself is defined at: >> ------------------------------------- >> dai_props->codec_dai->sysclk, which is used at:a > > Why codec_dai? Why not dai_props->cpu_dai->sysclk since we are talking > about SSI? This is how the simple-card (simple-sound-card) is written. > >> asoc_simple_card_startup(), asoc_simple_card_shutdown() and others >> functions at simple-card.c >> It is setup at: >> asoc_simple_card_parse_clk() @ simple-card-utils.c from macro: >> #define asoc_simple_card_parse_clk_cpu() >> And the problem is: >> ------------------- >> >> At the >> asoc_simple_card_parse_clk() >> we finally go to dts node: >> /soc/aips-bus@02100000/i2c@021a0000/tfa9879@6C > > This tfa9879 should be the CODEC right? Yes. The tfa9879 is a codec (very simple -> I2S + I2C, mono). They key point here is the asoc_simple_card_parse_clk() function from simple-card-utils.c Please look how the clock is assigned; It first checks for cpu clock, then for "system-clock-frequency" DTS node and _finally_ looks for another "child" clock [1], which is the codec attached to I2C. And from there it takes the 66 MHz CLK: /soc/aips-bus@02100000/i2c@021a0000/tfa9879@6C > >> which has clock from I2C (66 MHz). > > You mean I2C scl or I2S sclk? I2C scl. > > ----------------------------------------------------------------- > > But anyway, I feel very confused here as you have 66MHz clock rate > (regardless of it purpose) for a codec dai but it's been passed to > a cpu dai (SSI). Please look into asoc_simple_card_parse_clk(). My DTS [1] (it is different than other in-tree supported codecs - at least I did not find similar setup in DTSes): sound { compatible = "simple-audio-card"; label = "tfa9879-mono"; simple-audio-card,dai-link { /* DAC */ format = "i2s"; bitclock-master = <&dailink_master>; frame-master = <&dailink_master>; dailink_master: cpu { sound-dai = <&ssi2>; }; codec { sound-dai = <&codec>; }; }; }; &i2c1 { clock-frequency = <400000>; pinctrl-names = "default"; pinctrl-0 = <&pinctrl_i2c1>; status = "okay"; codec: tfa9879@6C { #sound-dai-cells = <0>; compatible = "tfa9879"; reg = <0x6C>; }; }; &ssi2 { fsl,mode = "i2s-master"; status = "okay"; }; the ssi2 node is defined in imx6qdl.dtsi file (no changes). The SOC is IMX6Q. The TFA9879 is a slave for I2S transmission. > >> [*] - I could workaround this problem by setting: >> >> system-clock-frequency = <0> in >> >> dailink_master: cpu { >> sound-dai = <&ssi2>; >> }; >> >> but this is IMHO even worse hack.... than this patch. > > I haven't used simple-card for a while so I forgot how to define > its DT bindings specifically. But you should assign ssi2 as the > CPU dai and assign tfa9879 as a CODEC dai. > -- Best regards, Lukasz Majewski -- DENX Software Engineering GmbH, Managing Director: Wolfgang Denk HRB 165235 Munich, Office: Kirchenstr.5, D-82194 Groebenzell, Germany Phone: (+49)-8142-66989-10 Fax: (+49)-8142-66989-80 Email: wd@denx.de From mboxrd@z Thu Jan 1 00:00:00 1970 From: =?UTF-8?Q?=c5=81ukasz_Majewski?= Subject: Re: [PATCH] sound: soc: fsl: Do not set DAI sysclk when it is equal to system freq Date: Tue, 5 Sep 2017 23:13:40 +0200 Message-ID: References: <1504436701-20700-1-git-send-email-lukma@denx.de> <07e54d28-3bbc-aad2-146b-30867c0bc337@denx.de> <20170905052031.GB2774@Asurada-CZ80> <819784e1-910b-6833-997a-2097e147bd0c@denx.de> <20170905181108.GB23906@Asurada-Nvidia> Mime-Version: 1.0 Content-Type: text/plain; charset="utf-8"; Format="flowed" Content-Transfer-Encoding: base64 Return-path: Received: from mail-out.m-online.net (mail-out.m-online.net [212.18.0.10]) by alsa0.perex.cz (Postfix) with ESMTP id A087E267236 for ; Tue, 5 Sep 2017 23:13:45 +0200 (CEST) In-Reply-To: <20170905181108.GB23906@Asurada-Nvidia> Content-Language: en-US List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: alsa-devel-bounces@alsa-project.org Sender: alsa-devel-bounces@alsa-project.org To: Nicolin Chen , Fabio Estevam Cc: "alsa-devel@alsa-project.org" , Timur Tabi , Xiubo Li , "linuxppc-dev@lists.ozlabs.org" , Takashi Iwai , Liam Girdwood , Mark Brown , "festevam@gmail.com" , "linux-kernel@vger.kernel.org" List-Id: alsa-devel@alsa-project.org SGkgTmljb2xpbiwKCj4gT24gVHVlLCBTZXAgMDUsIDIwMTcgYXQgMTA6MzU6MzRBTSArMDIwMCwg xYF1a2FzeiBNYWpld3NraSB3cm90ZToKPiAKPj4+IEFuZCBhcHBhcmVudGx5LCB3ZSBzaG91bGRu J3Qgc2V0IGJpdGNsayB0byA2Nk1IeiBlaXRoZXIuIENhbgo+Pj4geW91IGhlbHAgdG8gZmluZCB3 aGVyZSB0aGlzIDY2TUh6IGNvbWVzIGZyb20/Cj4gCj4+IDIuIGludCBhc29jX3NpbXBsZV9jYXJk X2luaXRfZGFpKCkgQCBzaW1wbGUtY2FyZC11dGlscy5jCj4gCj4gT2gsIEkganVzdCBzZWFyY2hl ZCBpbiB0aGUgc2ltcGxlLWNhcmQuYyBidXQgbWlzc2VkIHRoaXMgZmlsZS4KPiAKPj4gSW4gdGhp cyBmdW5jdGlvbiAocG9pbnQgMi4pIHRoZQo+PiBzaW1wbGVfZGFpLT5zeXNjbGsgaXMgc2V0IGFu ZDoKPj4gc25kX3NvY19kYWlfc2V0X3N5c2NsayhkYWksIDAsIHNpbXBsZV9kYWktPnN5c2Nsaywg MCkKPj4gd2hpY2ggc2V0cyBmcmVxdWVuY3kgdG8gNjYgTUh6IFsqXS4KPj4KPj4gVGhlIGFzb2Nf c2ltcGxlX2NhcmRfaW5pdF9kYWkoKSBpcyBjYWxsZWQgaW4KPj4gYXNvY19zaW1wbGVfY2FyZF9k YWlfaW5pdCgpIEAgc2ltcGxlLWNhcmQuYwo+PiB3aGljaCBpcyBhc3NpZ25lZCB0byBkYWlfbGlu ay0+aW5pdAo+PiBkYWlfbGluay0+aW5pdAkJPSBhc29jX3NpbXBsZV9jYXJkX2RhaV9pbml0OyBA IHNpbXBsZV9jYXJkLmMKPj4KPj4gQW5kIHRoZSBzeXNjbGsgaXRzZWxmIGlzIGRlZmluZWQgYXQ6 Cj4+IC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KPj4gZGFpX3Byb3BzLT5j b2RlY19kYWktPnN5c2Nsaywgd2hpY2ggaXMgdXNlZCBhdDphCj4gCj4gV2h5IGNvZGVjX2RhaT8g V2h5IG5vdCBkYWlfcHJvcHMtPmNwdV9kYWktPnN5c2NsayBzaW5jZSB3ZSBhcmUgdGFsa2luZwo+ IGFib3V0IFNTST8KClRoaXMgaXMgaG93IHRoZSBzaW1wbGUtY2FyZCAoc2ltcGxlLXNvdW5kLWNh cmQpIGlzIHdyaXR0ZW4uCgo+IAo+PiBhc29jX3NpbXBsZV9jYXJkX3N0YXJ0dXAoKSwgYXNvY19z aW1wbGVfY2FyZF9zaHV0ZG93bigpIGFuZCBvdGhlcnMKPj4gZnVuY3Rpb25zIGF0IHNpbXBsZS1j YXJkLmMKPj4gSXQgaXMgc2V0dXAgYXQ6Cj4+IGFzb2Nfc2ltcGxlX2NhcmRfcGFyc2VfY2xrKCkg QCBzaW1wbGUtY2FyZC11dGlscy5jIGZyb20gbWFjcm86Cj4+ICNkZWZpbmUgYXNvY19zaW1wbGVf Y2FyZF9wYXJzZV9jbGtfY3B1KCkKPj4gQW5kIHRoZSBwcm9ibGVtIGlzOgo+PiAtLS0tLS0tLS0t LS0tLS0tLS0tCj4+Cj4+IEF0IHRoZQo+PiBhc29jX3NpbXBsZV9jYXJkX3BhcnNlX2NsaygpCj4+ IHdlIGZpbmFsbHkgZ28gdG8gZHRzIG5vZGU6Cj4+IC9zb2MvYWlwcy1idXNAMDIxMDAwMDAvaTJj QDAyMWEwMDAwL3RmYTk4NzlANkMKPiAKPiBUaGlzIHRmYTk4Nzkgc2hvdWxkIGJlIHRoZSBDT0RF QyByaWdodD8KClllcy4gVGhlIHRmYTk4NzkgaXMgYSBjb2RlYyAodmVyeSBzaW1wbGUgLT4gSTJT ICsgSTJDLCBtb25vKS4KClRoZXkga2V5IHBvaW50IGhlcmUgaXMgdGhlIGFzb2Nfc2ltcGxlX2Nh cmRfcGFyc2VfY2xrKCkgZnVuY3Rpb24gZnJvbSAKc2ltcGxlLWNhcmQtdXRpbHMuYwoKUGxlYXNl IGxvb2sgaG93IHRoZSBjbG9jayBpcyBhc3NpZ25lZDsgSXQgZmlyc3QgY2hlY2tzIGZvciBjcHUg Y2xvY2ssIAp0aGVuIGZvciAic3lzdGVtLWNsb2NrLWZyZXF1ZW5jeSIgRFRTIG5vZGUgYW5kIF9m aW5hbGx5XyBsb29rcyBmb3IgCmFub3RoZXIgImNoaWxkIiBjbG9jayBbMV0sIHdoaWNoIGlzIHRo ZSBjb2RlYyBhdHRhY2hlZCB0byBJMkMuCgpBbmQgZnJvbSB0aGVyZSBpdCB0YWtlcyB0aGUgNjYg TUh6IENMSzoKL3NvYy9haXBzLWJ1c0AwMjEwMDAwMC9pMmNAMDIxYTAwMDAvdGZhOTg3OUA2QwoK Cgo+IAo+PiB3aGljaCBoYXMgY2xvY2sgZnJvbSBJMkMgKDY2IE1IeikuCj4gCj4gWW91IG1lYW4g STJDIHNjbCBvciBJMlMgc2Nsaz8KCkkyQyBzY2wuCgo+IAo+IC0tLS0tLS0tLS0tLS0tLS0tLS0t LS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCj4gCj4gQnV0IGFu eXdheSwgSSBmZWVsIHZlcnkgY29uZnVzZWQgaGVyZSBhcyB5b3UgaGF2ZSA2Nk1IeiBjbG9jayBy YXRlCj4gKHJlZ2FyZGxlc3Mgb2YgaXQgcHVycG9zZSkgZm9yIGEgY29kZWMgZGFpIGJ1dCBpdCdz IGJlZW4gcGFzc2VkIHRvCj4gYSBjcHUgZGFpIChTU0kpLgoKUGxlYXNlIGxvb2sgaW50byBhc29j X3NpbXBsZV9jYXJkX3BhcnNlX2NsaygpLgoKCk15IERUUyBbMV0gKGl0IGlzIGRpZmZlcmVudCB0 aGFuIG90aGVyIGluLXRyZWUgc3VwcG9ydGVkIGNvZGVjcyAtIGF0IApsZWFzdCBJIGRpZCBub3Qg ZmluZCBzaW1pbGFyIHNldHVwIGluIERUU2VzKToKCglzb3VuZCB7CgkJY29tcGF0aWJsZSA9ICJz aW1wbGUtYXVkaW8tY2FyZCI7CgkJbGFiZWwgPSAidGZhOTg3OS1tb25vIjsKCgkJc2ltcGxlLWF1 ZGlvLWNhcmQsZGFpLWxpbmsgewoJCQkvKiBEQUMgKi8KCQkJZm9ybWF0ID0gImkycyI7CgkJCWJp dGNsb2NrLW1hc3RlciA9IDwmZGFpbGlua19tYXN0ZXI+OwoJCQlmcmFtZS1tYXN0ZXIgPSA8JmRh aWxpbmtfbWFzdGVyPjsKCgkJCWRhaWxpbmtfbWFzdGVyOiBjcHUgewoJCQkgICAgc291bmQtZGFp ID0gPCZzc2kyPjsKCQkJfTsKCQkJY29kZWMgewoJCQkgICAgc291bmQtZGFpID0gPCZjb2RlYz47 CgkJCX07CgkJfTsKCX07CgoKJmkyYzEgewoJY2xvY2stZnJlcXVlbmN5ID0gPDQwMDAwMD47Cglw aW5jdHJsLW5hbWVzID0gImRlZmF1bHQiOwoJcGluY3RybC0wID0gPCZwaW5jdHJsX2kyYzE+OwoJ c3RhdHVzID0gIm9rYXkiOwoKCWNvZGVjOiB0ZmE5ODc5QDZDIHsKCQkjc291bmQtZGFpLWNlbGxz ID0gPDA+OwoJCWNvbXBhdGlibGUgPSAidGZhOTg3OSI7CgkJcmVnID0gPDB4NkM+OwoJfTsKfTsK CiZzc2kyIHsKCWZzbCxtb2RlID0gImkycy1tYXN0ZXIiOwoJc3RhdHVzID0gIm9rYXkiOwp9OwoK dGhlIHNzaTIgbm9kZSBpcyBkZWZpbmVkIGluIGlteDZxZGwuZHRzaSBmaWxlIChubyBjaGFuZ2Vz KS4KClRoZSBTT0MgaXMgSU1YNlEuCgpUaGUgVEZBOTg3OSBpcyBhIHNsYXZlIGZvciBJMlMgdHJh bnNtaXNzaW9uLgoKCj4gCj4+IFsqXSAtIEkgY291bGQgd29ya2Fyb3VuZCB0aGlzIHByb2JsZW0g Ynkgc2V0dGluZzoKPj4KPj4gc3lzdGVtLWNsb2NrLWZyZXF1ZW5jeSA9IDwwPiBpbgo+Pgo+PiAJ CQlkYWlsaW5rX21hc3RlcjogY3B1IHsKPj4gCQkJICAgIHNvdW5kLWRhaSA9IDwmc3NpMj47Cj4+ IAkJCX07Cj4+Cj4+IGJ1dCB0aGlzIGlzIElNSE8gZXZlbiB3b3JzZSBoYWNrLi4uLiB0aGFuIHRo aXMgcGF0Y2guCj4gCj4gSSBoYXZlbid0IHVzZWQgc2ltcGxlLWNhcmQgZm9yIGEgd2hpbGUgc28g SSBmb3Jnb3QgaG93IHRvIGRlZmluZQo+IGl0cyBEVCBiaW5kaW5ncyBzcGVjaWZpY2FsbHkuIEJ1 dCB5b3Ugc2hvdWxkIGFzc2lnbiBzc2kyIGFzIHRoZQo+IENQVSBkYWkgYW5kIGFzc2lnbiB0ZmE5 ODc5IGFzIGEgQ09ERUMgZGFpLgo+IAoKCi0tIApCZXN0IHJlZ2FyZHMsCgpMdWthc3ogTWFqZXdz a2kKCi0tCgpERU5YIFNvZnR3YXJlIEVuZ2luZWVyaW5nIEdtYkgsICAgICAgTWFuYWdpbmcgRGly ZWN0b3I6IFdvbGZnYW5nIERlbmsKSFJCIDE2NTIzNSBNdW5pY2gsIE9mZmljZTogS2lyY2hlbnN0 ci41LCBELTgyMTk0IEdyb2ViZW56ZWxsLCBHZXJtYW55ClBob25lOiAoKzQ5KS04MTQyLTY2OTg5 LTEwIEZheDogKCs0OSktODE0Mi02Njk4OS04MCBFbWFpbDogd2RAZGVueC5kZQpfX19fX19fX19f X19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fXwpBbHNhLWRldmVsIG1haWxpbmcg bGlzdApBbHNhLWRldmVsQGFsc2EtcHJvamVjdC5vcmcKaHR0cDovL21haWxtYW4uYWxzYS1wcm9q ZWN0Lm9yZy9tYWlsbWFuL2xpc3RpbmZvL2Fsc2EtZGV2ZWwK