Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp247572pxf; Thu, 11 Mar 2021 03:01:11 -0800 (PST) X-Google-Smtp-Source: ABdhPJzD8AcwCLuaviomX/zKQna2ssDLhSv4pA3X3C/rs7N9cvy5pYoZ5dVPc3BqYFkWLTCnGki0 X-Received: by 2002:a17:906:85b:: with SMTP id f27mr2562311ejd.414.1615460471650; Thu, 11 Mar 2021 03:01:11 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1615460471; cv=none; d=google.com; s=arc-20160816; b=RTTYSygNuF+mKoR3mw7B0KcswTlpE/vzC37s64yR0NGt57+Tit8FveJTz2pfjfKABp MgIo74buHekS7hP6z70kxfJOyVjFIGo1weEJPRSmsgWts/WcXzFZJ2XVk8+jafZkRnmn 5+JiKKyYgTgEQEIRAP4ihsoKb8GsaWEGCIg4GyrspVC0z1ABdRAe0g9ILzy568n7No0W DR6fdgI3ZZEM0E5N4XAwzgA72pLTIL9uQWPH3LfSi6Y9OxhLuM1qgPEk+wPmu6jRxYPj G+jg6OkwsgPzhRWv3FIoDq8HDHpG5GSUDoJIUyeRa0vRVXxzck2p++PgNinkUvVk0kTB f2Mw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:subject:message-id:date:from:in-reply-to :references:mime-version:dkim-signature; bh=3UiH+kUE+AB5h+QM3HtJZhWpgi2YQCcTnzrYrkv0thQ=; b=sGFT1qraT2HCLiPsiP2UTmNI40BcrHPVO7dWbpcd4nEgDvsAdZU3pA/q5dQdn19/Yl P1hteSF5hg5daJmGzvmtbsV8KDI0dAoQEjWLC17smYzIABGu1C1QykZjlR0PKNaSAN+N fOAky9RGv4wwNoMvMfAKdE5DUYCabUyRB17yi7chWrGkA/9XYPxa0XVsZY13RZvNsH47 JIibFQyHeokIYIbZ6YL2ktE6y2WEyn5Ie3vF7y8bl5oP4fC0YwTjDpto5NT3+wg3YREd Z4U0hZjXTZEXcufwWwL7gxi+LMD1eJXy/16saWBLEklc+ClywFd/2Q3fACBxK/dFuFyy vXYw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=CNiSwaWS; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id cw18si1535625edb.142.2021.03.11.03.00.48; Thu, 11 Mar 2021 03:01:11 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=CNiSwaWS; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232416AbhCKK7N (ORCPT + 99 others); Thu, 11 Mar 2021 05:59:13 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:42284 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232471AbhCKK6y (ORCPT ); Thu, 11 Mar 2021 05:58:54 -0500 Received: from mail-qk1-x736.google.com (mail-qk1-x736.google.com [IPv6:2607:f8b0:4864:20::736]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 4A7AAC061574; Thu, 11 Mar 2021 02:58:54 -0800 (PST) Received: by mail-qk1-x736.google.com with SMTP id f124so20088410qkj.5; Thu, 11 Mar 2021 02:58:54 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=3UiH+kUE+AB5h+QM3HtJZhWpgi2YQCcTnzrYrkv0thQ=; b=CNiSwaWS5Le1oZOW3/IlTMc86hDM8oGd/z9Mu8/Y7NzcHshvFyki/EPYDtukE9mMwk 2nJP4YLekvXzZOyjYiiwD7sRtWIoWiUQqJo9Ma5/6uLftQXQzn25Tv8DsR+7siFdjozF 44D84jlB0d9hF9F53+DHHOsVqBJskxr6ZGXCZqmCWHPbjPd876ymHd8CcjX3kldN3LAK d6bP5fvaHztHMR37LDG5MAZ/At4tz+QFJNOCWRR8oHlJ0pe3XlZE5wE5PjeZuFVAMA8S MoU1XZcAMi8YUKX5zMgkzsIGq5vmS3A/paXvynY0mobidIf+axslWfRimcaA/eQelLGy um7Q== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=3UiH+kUE+AB5h+QM3HtJZhWpgi2YQCcTnzrYrkv0thQ=; b=AGGxvlQn4HunftJvZxKNfEVXvHXeKwUaza7aUPRfLW3xFhSXQOUBbqBvN3ryXM3RPB iQCzbuK8bDR3QqNx1qaS9qO59MtySQ2qnFNcxuuxrE4bplALnjkTkuhUuGM7WQOR6EFu 6JKCEwVr/iAoPykvmvbECN4S6wJGlGLOG7njEZDaUA/ZnLzdCmB22ICr/uuTbS9xeJQm X40LFynOlojcQB+Jz11Td9qdVQkKEK9v2Q4Vqcr5eVoqmi+8M3JmIAkgUWP0yY7W5sm3 gfAsEfbh5/egJSjy6v/+lJse25mkI1uWjCA+Qchxwsxh3YrtsIKi4mv84/1J4qZ6MjhR Pqpg== X-Gm-Message-State: AOAM533E/eAPNHNZdUT7MEMByg52joaVx/NMfeN+h9csNrltArh/uoRz SCNlN+YjbfsEm634Jam1u7+VJH28F5i9qvQwBTQ= X-Received: by 2002:a05:620a:718:: with SMTP id 24mr6897580qkc.121.1615460333507; Thu, 11 Mar 2021 02:58:53 -0800 (PST) MIME-Version: 1.0 References: <1615209750-2357-1-git-send-email-shengjiu.wang@nxp.com> <1615209750-2357-4-git-send-email-shengjiu.wang@nxp.com> <20210310024834.GA1623179@robh.at.kernel.org> In-Reply-To: From: Shengjiu Wang Date: Thu, 11 Mar 2021 18:58:42 +0800 Message-ID: Subject: Re: [PATCH v4 3/6] ASoC: dt-bindings: fsl_rpmsg: Add binding doc for rpmsg cpu dai driver To: Rob Herring Cc: Shengjiu Wang , "open list:OPEN FIRMWARE AND FLATTENED DEVICE TREE BINDINGS" , Linux-ALSA , Timur Tabi , Liam Girdwood , linuxppc-dev , Xiubo Li , linux-kernel , Takashi Iwai , Nicolin Chen , Mark Brown , Fabio Estevam Content-Type: text/plain; charset="UTF-8" Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Rob On Thu, Mar 11, 2021 at 5:12 AM Rob Herring wrote: > > On Wed, Mar 10, 2021 at 6:33 AM Shengjiu Wang wrote: > > > > Hi Rob > > > > On Wed, Mar 10, 2021 at 10:49 AM Rob Herring wrote: > > > > > > On Mon, Mar 08, 2021 at 09:22:27PM +0800, Shengjiu Wang wrote: > > > > fsl_rpmsg cpu dai driver is driver for rpmsg audio, which is mainly used > > > > > > Bindings describe h/w blocks, not drivers. > > > > I will modify the descriptions. but here it is a virtual device. the > > mapping in real h/w is cortex M core, Cortex M core controls the SAI, > > DMA interface. What we see from Linux side is a audio service > > through rpmsg channel. > > It's describing the h/w from the view of the OS. It's not important > that it's a Cortex-M, but how you interface to it whether that's > shared registers, mailbox, etc. And it's what resources the block uses > that the OS controls. ok. > > > > > for getting the user's configuration from device tree and configure the > > > > clocks which is used by Cortex-M core. So in this document define the > > > > needed property. > > > > > > > > Signed-off-by: Shengjiu Wang > > > > --- > > > > .../devicetree/bindings/sound/fsl,rpmsg.yaml | 118 ++++++++++++++++++ > > > > 1 file changed, 118 insertions(+) > > > > create mode 100644 Documentation/devicetree/bindings/sound/fsl,rpmsg.yaml > > > > > > > > diff --git a/Documentation/devicetree/bindings/sound/fsl,rpmsg.yaml b/Documentation/devicetree/bindings/sound/fsl,rpmsg.yaml > > > > new file mode 100644 > > > > index 000000000000..5731c1fbc0a6 > > > > --- /dev/null > > > > +++ b/Documentation/devicetree/bindings/sound/fsl,rpmsg.yaml > > > > @@ -0,0 +1,118 @@ > > > > +# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) > > > > +%YAML 1.2 > > > > +--- > > > > +$id: http://devicetree.org/schemas/sound/fsl,rpmsg.yaml# > > > > +$schema: http://devicetree.org/meta-schemas/core.yaml# > > > > + > > > > +title: NXP Audio RPMSG CPU DAI Controller > > > > + > > > > +maintainers: > > > > + - Shengjiu Wang > > > > + > > > > +description: | > > > > + fsl_rpmsg cpu dai driver is virtual driver for rpmsg audio, which doesn't > > > > + touch hardware. It is mainly used for getting the user's configuration > > > > + from device tree and configure the clocks which is used by Cortex-M core. > > > > + So in this document define the needed property. > > > > + > > > > +properties: > > > > + compatible: > > > > + enum: > > > > + - fsl,imx7ulp-rpmsg > > > > + - fsl,imx8mn-rpmsg > > > > + - fsl,imx8mm-rpmsg > > > > + - fsl,imx8mp-rpmsg > > > > + > > > > + model: > > > > + $ref: /schemas/types.yaml#/definitions/string > > > > + description: User specified audio sound card name > > > > + > > > > + clocks: > > > > + items: > > > > + - description: Peripheral clock for register access > > > > + - description: Master clock > > > > + - description: DMA clock for DMA register access > > > > + - description: Parent clock for multiple of 8kHz sample rates > > > > + - description: Parent clock for multiple of 11kHz sample rates > > > > + minItems: 5 > > > > > > If this doesn't touch hardware, what are these clocks for? > > > > When the cortex-M core support audio service, these clock > > needed prepared & enabled by ALSA driver. > > > > > > > > You don't need 'minItems' unless it's less than the number of 'items'. > > > > Ok, I will remove this minItems. > > > > > > > > > + > > > > + clock-names: > > > > + items: > > > > + - const: ipg > > > > + - const: mclk > > > > + - const: dma > > > > + - const: pll8k > > > > + - const: pll11k > > > > + minItems: 5 > > > > + > > > > + power-domains: > > > > + maxItems: 1 > > > > + > > > > + fsl,audioindex: > > > > + $ref: /schemas/types.yaml#/definitions/uint32 > > > > + enum: [0, 1] > > > > + default: 0 > > > > + description: Instance index for sound card in > > > > + M core side, which share one rpmsg > > > > + channel. > > > > > > We don't do indexes in DT. What's this numbering tied to? > > > > I will remove it. it is not necessary > > > > > > > > > + > > > > + fsl,version: > > > > > > version of what? > > > > > > This seems odd at best. > > > > > > > I will remove it. it is not necessary > > > > > > + $ref: /schemas/types.yaml#/definitions/uint32 > > > > + enum: [1, 2] > > > > > > You're going to update this with every new firmware version? > > > > > > > + default: 2 > > > > + description: The version of M core image, which is > > > > + to make driver compatible with different image. > > > > + > > > > + fsl,buffer-size: > > > > + $ref: /schemas/types.yaml#/definitions/uint32 > > > > + description: pre allocate dma buffer size > > > > > > How can you have DMA, this doesn't touch h/w? > > > > The DMA is handled by M core image for sound playback > > and capture. we need to allocated buffer in Linux side. > > here just make the buffer size to be configurable. > > Do we set audio buffer sizes for other audio devices in DT? If not, > why is this special? If so, why is it not common. No. I will move it to driver. > > > > > + fsl,enable-lpa: > > > > + $ref: /schemas/types.yaml#/definitions/flag > > > > + description: enable low power audio path. > > > > + > > > > + fsl,rpmsg-out: > > > > + $ref: /schemas/types.yaml#/definitions/flag > > > > + description: | > > > > + This is a boolean property. If present, the transmitting function > > > > + will be enabled. > > > > + > > > > + fsl,rpmsg-in: > > > > + $ref: /schemas/types.yaml#/definitions/flag > > > > + description: | > > > > + This is a boolean property. If present, the receiving function > > > > + will be enabled. > > > > + > > > > + fsl,codec-type: > > > > + $ref: /schemas/types.yaml#/definitions/uint32 > > > > + enum: [0, 1, 2] > > > > + default: 0 > > > > + description: Sometimes the codec is registered by > > > > + driver not by the device tree, this items > > > > + can be used to distinguish codecs. > > > > > > How does one decide what value to use? > > > > I will add more description: > > 0: dummy codec > > 1: WM8960 codec > > 2: AK4497 codec > > I assume the last 2 cases have nodes in DT (pointed to by > 'audio-codec'), so this is redundant. Ok, will remove it. > > > > > + > > > > + audio-codec: > > > > + $ref: /schemas/types.yaml#/definitions/phandle > > > > + description: The phandle of the audio codec > > > > > > The codec is controlled from the Linux side? > > > > yes. > > > > > > > > > + > > > > + memory-region: > > > > + $ref: /schemas/types.yaml#/definitions/phandle > > > > + description: phandle to the reserved memory nodes > > > > + > > > > +required: > > > > + - compatible > > > > + - fsl,audioindex > > > > + - fsl,version > > > > + - fsl,buffer-size > > > > + > > > > +additionalProperties: false > > > > + > > > > +examples: > > > > + - | > > > > + rpmsg_audio: rpmsg_audio { > > > > + compatible = "fsl,imx8mn-rpmsg"; > > > > + fsl,audioindex = <0> ; > > > > + fsl,version = <2>; > > > > + fsl,buffer-size = <0x6000000>; > > > > + fsl,enable-lpa; > > > > > > How does this work? Don't you need somewhere to put the 'rpmsg' data? > > > > The rpmsg data is not handled in this "rpmsg_audio" device, it is just to > > prepare the resource for rpmsg audio function, the clock, the memory > > the power... > > > > The rpmsg data is handled in imx-pcm-rpmsg.c and imx-audio-rpmsg.c > > These devices is registered by imx remoteproc driver. > > Then what is 'memory-region' for? You need that, a mailbox, or ??? > somewhere in DT. > The M core can't access all the DDR memory space on some platform, so use 'memory-region' reserve a specific memory for dma buffer which M core can access. best regards wang shengjiu