Message ID | 20230421124122.324820-2-herve.codina@bootlin.com |
---|---|
State | New |
Headers |
Return-Path: <linux-kernel-owner@vger.kernel.org> Delivered-To: ouuuleilei@gmail.com Received: by 2002:a59:b0ea:0:b0:3b6:4342:cba0 with SMTP id b10csp1038608vqo; Fri, 21 Apr 2023 05:46:57 -0700 (PDT) X-Google-Smtp-Source: AKy350ZxdtIv/Hg4UQ8f3R9Tv/uat7BED2kEbRBLVK/RN3tdkktNYmuxFzt2nmg7rLkBEBUyuIkG X-Received: by 2002:a05:6a00:1582:b0:63d:3ddb:5f3f with SMTP id u2-20020a056a00158200b0063d3ddb5f3fmr6947085pfk.0.1682081217209; Fri, 21 Apr 2023 05:46:57 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1682081217; cv=none; d=google.com; s=arc-20160816; b=XAfzN3sDnh8BSgROAPS9nAeiTNjvWIB4X0vDN2pRFIZzrOIvUfZAwpkkzIYoJW8O1v ZiL290UmlWiqqwUfFEqwRT4uSZFKcVVceeBIm+Ei1dqpysOpJTeCVjLEcsDS+CjgQ3IK NZsDw+Z6CW61LePnauQ4/PMiccuqPlMycHRtmMhbCP8lk0aUdSUt/bSrmgdymI3Y1BUB tCW10tiKMxXwOl4JTDqfUkF/FGGLhWmy6L1WBEfCDsvFpyB15TEUc3dWupCJImSPKVuI jDU+YkPJJX7WLTg9PWrWR+qb7MEEBQxhWFEysxfPkb5/VEoRysxam30o0GOJd2FL9fuP 9XeA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=eNsCq0s00cdcExGMd2Rls3HSwLDqQCPjKQ7JzV6nFDI=; b=wki0TtI3HiJbINScqPx2cYP9F1fVtbuDDKK+H+snGcpu04NeFXpRuDtIbAnlgApq+o 0EfXEr+AM6aDyVgVwmMNsR6L9b7DI5lw0zU5L/XqMIYs8gqXPsx6NIKN1yOsF9R/7cbT HmuRFRBVblOJW8mh8P6/KY+QYV/rtcEVOek8PwNi8e6XJceEhEs8zrbzl7NsJdfIE5WW pkYTZMw+3BED/pZZ09J9Nu9NcV/PdY8mYJI19EWLFu+LVzeYTZ5X3gID1u4BZZ+wsOcx G70qUNo5A8w0yqSDjxvQck2BngmLLj1ZIpe30U7XJ+ncbZiU4Y97XLnejMf4uLpiS7As ejdQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@bootlin.com header.s=gm1 header.b=QClt+BCD; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=bootlin.com Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id m127-20020a625885000000b0063b652ff9cdsi3075520pfb.404.2023.04.21.05.46.44; Fri, 21 Apr 2023 05:46:57 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@bootlin.com header.s=gm1 header.b=QClt+BCD; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=bootlin.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229575AbjDUMmZ (ORCPT <rfc822;cjcooper78@gmail.com> + 99 others); Fri, 21 Apr 2023 08:42:25 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:44908 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231921AbjDUMmW (ORCPT <rfc822;linux-kernel@vger.kernel.org>); Fri, 21 Apr 2023 08:42:22 -0400 Received: from relay2-d.mail.gandi.net (relay2-d.mail.gandi.net [IPv6:2001:4b98:dc4:8::222]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id CDA4C10240; Fri, 21 Apr 2023 05:41:47 -0700 (PDT) Received: (Authenticated sender: herve.codina@bootlin.com) by mail.gandi.net (Postfix) with ESMTPA id AE9A740007; Fri, 21 Apr 2023 12:41:43 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=bootlin.com; s=gm1; t=1682080904; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=eNsCq0s00cdcExGMd2Rls3HSwLDqQCPjKQ7JzV6nFDI=; b=QClt+BCDWwhb08qssJkO5Mnz+mTsc0qr/vnqlDJjJEEnPe741wrKNRdxSsaP97cjKQTq8k V/t7Ho58TgZ/3/rfOvyfx2K2zkrC2idEVmE770AjuXb762FnlLP9MAkTTviN5KZagfNwAN oK/4u1tuS1uddfmahTeg3M9d4IGuyEO6ORp5N2H3V+c/xyAAJAakmemGJQWLKhzwP5Nj2A r0/rkKgSUcWd9noVnD5iPj5ExEAS+Obu6XGQxQyMI2zzCgglewV1/4fBWnR8hpL4Sfb89t 8QMtFhBIq0TcfacVoQzq9qX3RRkxehIi/xuD2p8Anq0GkyVxQaCQhDSjBum9iw== From: Herve Codina <herve.codina@bootlin.com> To: Herve Codina <herve.codina@bootlin.com>, Liam Girdwood <lgirdwood@gmail.com>, Mark Brown <broonie@kernel.org>, Rob Herring <robh+dt@kernel.org>, Krzysztof Kozlowski <krzysztof.kozlowski+dt@linaro.org>, Jonathan Cameron <jic23@kernel.org>, Lars-Peter Clausen <lars@metafoo.de>, Jaroslav Kysela <perex@perex.cz>, Takashi Iwai <tiwai@suse.com> Cc: alsa-devel@alsa-project.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, linux-iio@vger.kernel.org, Christophe Leroy <christophe.leroy@csgroup.eu>, Thomas Petazzoni <thomas.petazzoni@bootlin.com> Subject: [PATCH 1/4] dt-bindings: sound: Add simple-iio-aux Date: Fri, 21 Apr 2023 14:41:19 +0200 Message-Id: <20230421124122.324820-2-herve.codina@bootlin.com> X-Mailer: git-send-email 2.39.2 In-Reply-To: <20230421124122.324820-1-herve.codina@bootlin.com> References: <20230421124122.324820-1-herve.codina@bootlin.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-2.8 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_LOW,SPF_HELO_NONE, SPF_PASS,T_SCC_BODY_TEXT_LINE,URIBL_BLOCKED autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: <linux-kernel.vger.kernel.org> X-Mailing-List: linux-kernel@vger.kernel.org X-getmail-retrieved-from-mailbox: =?utf-8?q?INBOX?= X-GMAIL-THRID: =?utf-8?q?1763789994567689631?= X-GMAIL-MSGID: =?utf-8?q?1763789994567689631?= |
Series |
Add support for IIO devices in ASoC
|
|
Commit Message
Herve Codina
April 21, 2023, 12:41 p.m. UTC
Industrial I/O devices can be present in the audio path.
These devices needs to be viewed as audio components in order to be
fully integrated in the audio path.
simple-iio-aux allows to consider these Industrial I/O devices as
auxliary audio devices.
Signed-off-by: Herve Codina <herve.codina@bootlin.com>
---
.../bindings/sound/simple-iio-aux.yaml | 65 +++++++++++++++++++
1 file changed, 65 insertions(+)
create mode 100644 Documentation/devicetree/bindings/sound/simple-iio-aux.yaml
Comments
On Fri, Apr 21, 2023 at 02:41:19PM +0200, Herve Codina wrote: > Industrial I/O devices can be present in the audio path. > These devices needs to be viewed as audio components in order to be > fully integrated in the audio path. > > simple-iio-aux allows to consider these Industrial I/O devices as > auxliary audio devices. What makes it simple? Any binding called simple or generic is a trigger for me. Best to avoid those terms. :) Examples of devices would be useful here. > > Signed-off-by: Herve Codina <herve.codina@bootlin.com> > --- > .../bindings/sound/simple-iio-aux.yaml | 65 +++++++++++++++++++ > 1 file changed, 65 insertions(+) > create mode 100644 Documentation/devicetree/bindings/sound/simple-iio-aux.yaml > > diff --git a/Documentation/devicetree/bindings/sound/simple-iio-aux.yaml b/Documentation/devicetree/bindings/sound/simple-iio-aux.yaml > new file mode 100644 > index 000000000000..fab128fce4fc > --- /dev/null > +++ b/Documentation/devicetree/bindings/sound/simple-iio-aux.yaml > @@ -0,0 +1,65 @@ > +# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) > +%YAML 1.2 > +--- > +$id: http://devicetree.org/schemas/sound/simple-iio-aux.yaml# > +$schema: http://devicetree.org/meta-schemas/core.yaml# > + > +title: Simple IIO auxiliary > + > +maintainers: > + - Herve Codina <herve.codina@bootlin.com> > + > +description: | Don't need '|' > + Auxiliary device based on Industrial I/O device channels > + > +allOf: > + - $ref: /schemas/iio/iio-consumer.yaml You don't need to reference consumer schemas. > + - $ref: dai-common.yaml# > + > +properties: > + compatible: > + const: simple-iio-aux > + > + io-channels: > + description: > + Industrial I/O device channels used > + > + io-channel-names: > + description: > + Industrial I/O channel names related to io-channels. > + These names are used to provides sound controls, widgets and routes names. > + > + invert: Property names should globally only have 1 type definition. This is generic enough I'd be concerned that's not the case. > + $ref: /schemas/types.yaml#/definitions/uint32-array > + description: | > + A list of 0/1 flags defining whether or not the related channel is > + inverted > + items: > + enum: [0, 1] > + default: 0 > + description: | > + Invert the sound control value compared to the IIO channel raw value. > + - 1: The related sound control value is inverted meaning that the > + minimum sound control value correspond to the maximum IIO channel > + raw value and the maximum sound control value correspond to the > + minimum IIO channel raw value. > + - 0: The related sound control value is not inverted meaning that the > + minimum (resp maximum) sound control value correspond to the > + minimum (resp maximum) IIO channel raw value. > + > +required: > + - compatible > + - io-channels > + - io-channel-names > + > +unevaluatedProperties: false > + > +examples: > + - | > + aux { > + compatible = "simple-iio-aux"; > + io-channels = <&iio 0>, <&iio 1>, <&iio 2>, <&iio 3>; > + io-channel-names = "CH0", "CH1", "CH2", "CH3"; Not really useful names. Do you have a real example? > + /* Invert CH1 and CH2 */ > + invert = <0 1 1>; IMO, invert should be same length as io-channels. > + }; How do support multiple instances? Say you have 2 sound cards (or 1 sound card with multiple audio paths) each with different sets of IIO channels associated with it. You'd need a link to each 'aux' node. Why not just add io-channels to the sound card nodes directly? That's already just a virtual, top-level container node grouping all the components. I don't see why we need another virtual node grouping a subset of them. Rob
On Tue, Apr 25, 2023 at 12:30:29PM -0500, Rob Herring wrote: > On Fri, Apr 21, 2023 at 02:41:19PM +0200, Herve Codina wrote: > > + aux { > > + compatible = "simple-iio-aux"; > > + io-channels = <&iio 0>, <&iio 1>, <&iio 2>, <&iio 3>; > > + io-channel-names = "CH0", "CH1", "CH2", "CH3"; > Not really useful names. Do you have a real example? I fear those might be real names for channels on an IIO device...
Hi Rob, On Tue, 25 Apr 2023 12:30:29 -0500 Rob Herring <robh@kernel.org> wrote: > On Fri, Apr 21, 2023 at 02:41:19PM +0200, Herve Codina wrote: > > Industrial I/O devices can be present in the audio path. > > These devices needs to be viewed as audio components in order to be > > fully integrated in the audio path. > > > > simple-iio-aux allows to consider these Industrial I/O devices as > > auxliary audio devices. > > What makes it simple? Any binding called simple or generic is a trigger > for me. Best to avoid those terms. :) I choose simple-iio-aux because some simple-* already exists. For instance simple-audio-amplifier or simple-audio-mux. Do you prefer audio-iio-aux ? Let me know if I should change. > > Examples of devices would be useful here. > > > > > Signed-off-by: Herve Codina <herve.codina@bootlin.com> > > --- > > .../bindings/sound/simple-iio-aux.yaml | 65 +++++++++++++++++++ > > 1 file changed, 65 insertions(+) > > create mode 100644 Documentation/devicetree/bindings/sound/simple-iio-aux.yaml > > > > diff --git a/Documentation/devicetree/bindings/sound/simple-iio-aux.yaml b/Documentation/devicetree/bindings/sound/simple-iio-aux.yaml > > new file mode 100644 > > index 000000000000..fab128fce4fc > > --- /dev/null > > +++ b/Documentation/devicetree/bindings/sound/simple-iio-aux.yaml > > @@ -0,0 +1,65 @@ > > +# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) > > +%YAML 1.2 > > +--- > > +$id: http://devicetree.org/schemas/sound/simple-iio-aux.yaml# > > +$schema: http://devicetree.org/meta-schemas/core.yaml# > > + > > +title: Simple IIO auxiliary > > + > > +maintainers: > > + - Herve Codina <herve.codina@bootlin.com> > > + > > +description: | > > Don't need '|' Will be fixed. > > > + Auxiliary device based on Industrial I/O device channels > > + > > +allOf: > > + - $ref: /schemas/iio/iio-consumer.yaml > > You don't need to reference consumer schemas. Right, will be removed. > > > + - $ref: dai-common.yaml# > > + > > +properties: > > + compatible: > > + const: simple-iio-aux > > + > > + io-channels: > > + description: > > + Industrial I/O device channels used > > + > > + io-channel-names: > > + description: > > + Industrial I/O channel names related to io-channels. > > + These names are used to provides sound controls, widgets and routes names. > > + > > + invert: > > Property names should globally only have 1 type definition. This is > generic enough I'd be concerned that's not the case. What do you mean ? > > > + $ref: /schemas/types.yaml#/definitions/uint32-array > > + description: | > > + A list of 0/1 flags defining whether or not the related channel is > > + inverted > > + items: > > + enum: [0, 1] > > + default: 0 > > + description: | > > + Invert the sound control value compared to the IIO channel raw value. > > + - 1: The related sound control value is inverted meaning that the > > + minimum sound control value correspond to the maximum IIO channel > > + raw value and the maximum sound control value correspond to the > > + minimum IIO channel raw value. > > + - 0: The related sound control value is not inverted meaning that the > > + minimum (resp maximum) sound control value correspond to the > > + minimum (resp maximum) IIO channel raw value. > > + > > +required: > > + - compatible > > + - io-channels > > + - io-channel-names > > + > > +unevaluatedProperties: false > > + > > +examples: > > + - | > > + aux { > > + compatible = "simple-iio-aux"; > > + io-channels = <&iio 0>, <&iio 1>, <&iio 2>, <&iio 3>; > > + io-channel-names = "CH0", "CH1", "CH2", "CH3"; > > Not really useful names. Do you have a real example? As Mark said, for IIO channel, using CHx makes sense. See below, I provide a full example. > > > + /* Invert CH1 and CH2 */ > > + invert = <0 1 1>; > > IMO, invert should be same length as io-channels. I will update. Related to this topic, when I wrote this binding, I wanted to add some rules/constraints in order to: - Have this property optional - If present, force to have as many items in the invert array as the number of items present in the io-channels array. I never succeed in writing the constraint for the invert property. It should be possible (it is done for some 'foo' 'foo-names' pair such as clocks). Can you tell me if possible in my case and give me some pointers ? > > > + }; > > How do support multiple instances? Say you have 2 sound cards (or 1 > sound card with multiple audio paths) each with different sets of IIO > channels associated with it. You'd need a link to each 'aux' node. Why > not just add io-channels to the sound card nodes directly? That's > already just a virtual, top-level container node grouping all the > components. I don't see why we need another virtual node grouping a > subset of them. I don't see what you mean. I use a simple-audio-card and here is a full example using several instances: spi { #address-cells = <1>; #size-cells = <0>; /* potentiometers present in an input amplifier design */ pot_in: potentiometer@0 { compatible = "foo,xxx"; reg = <0>; #io-channel-cells = <1>; }; /* potentiometers present in an output amplifier design */ pot_out: potentiometer@1 { compatible = "foo,xxx"; reg = <1>; #io-channel-cells = <1>; }; /* A codec */ codec: codec@2 { compatible = "bar,yyy"; reg = <2>; sound-name-prefix = "CODEC"; }; }; amp_out: aux-out { compatible = "simple-iio-aux"; io-channels = <&pot_out 0>, <&pot_out 1>, io-channel-names = "CH0", "CH1"; invert = <1 1>; sound-name-prefix = "AMP_OUT"; }; amp_in: aux-in { compatible = "simple-iio-aux"; io-channels = <&pot_in 0>, <&pot_in 1>; io-channel-names = "CH0", "CH1"; sound-name-prefix = "AMP_IN"; }; sound { compatible = "simple-audio-card"; #address-cells = <1>; #size-cells = <0>; simple-audio-card,name = "My Sound Card"; simple-audio-card,aux-devs = <&_in>, <&_out>; simple-audio-card,routing = "CODEC IN0", "AMP_IN CH0 OUT", "CODEC IN1", "AMP_IN CH1 OUT", "AMP_OUT CH0 IN", "CODEC OUT0", "AMP_OUT CH1 IN", "CODEC OUT1", simple-audio-card,dai-link@0 { ... }; }; Best regards, Hervé
On 26/04/2023 09:36, Herve Codina wrote: > Hi Rob, > > On Tue, 25 Apr 2023 12:30:29 -0500 > Rob Herring <robh@kernel.org> wrote: > >> On Fri, Apr 21, 2023 at 02:41:19PM +0200, Herve Codina wrote: >>> Industrial I/O devices can be present in the audio path. >>> These devices needs to be viewed as audio components in order to be >>> fully integrated in the audio path. >>> >>> simple-iio-aux allows to consider these Industrial I/O devices as >>> auxliary audio devices. >> >> What makes it simple? Any binding called simple or generic is a trigger >> for me. Best to avoid those terms. :) > > I choose simple-iio-aux because some simple-* already exists. > For instance simple-audio-amplifier or simple-audio-mux. > > Do you prefer audio-iio-aux ? > Let me know if I should change. It means that often what people call "simple" and "generic" works only for their specific case, because it is not really simple and generic. After some time the "simple" and "generic" becomes "complicated" and "huge". Conclusion: sometimes simple and generic bindings are bad idea and you should have something specific. Your description in the binding also does not help to match it to specific, real device. Provide the examples, as Rob asked. ... >>> + io-channels: >>> + description: >>> + Industrial I/O device channels used >>> + >>> + io-channel-names: >>> + description: >>> + Industrial I/O channel names related to io-channels. >>> + These names are used to provides sound controls, widgets and routes names. >>> + >>> + invert: >> >> Property names should globally only have 1 type definition. This is >> generic enough I'd be concerned that's not the case. > > What do you mean ? It is quite likely this will interfere with other properties having the same name but different type/definition. If you want to keep it named generic, then please investigate how this would affect any other bindings. So easier is to make it not that generic, some more specific name. > >> >>> + $ref: /schemas/types.yaml#/definitions/uint32-array >>> + description: | >>> + A list of 0/1 flags defining whether or not the related channel is >>> + inverted >>> + items: >>> + enum: [0, 1] >>> + default: 0 >>> + description: | >>> + Invert the sound control value compared to the IIO channel raw value. >>> + - 1: The related sound control value is inverted meaning that the >>> + minimum sound control value correspond to the maximum IIO channel >>> + raw value and the maximum sound control value correspond to the >>> + minimum IIO channel raw value. >>> + - 0: The related sound control value is not inverted meaning that the >>> + minimum (resp maximum) sound control value correspond to the >>> + minimum (resp maximum) IIO channel raw value. >>> + >>> +required: >>> + - compatible >>> + - io-channels >>> + - io-channel-names >>> + >>> +unevaluatedProperties: false >>> + >>> +examples: >>> + - | >>> + aux { >>> + compatible = "simple-iio-aux"; >>> + io-channels = <&iio 0>, <&iio 1>, <&iio 2>, <&iio 3>; >>> + io-channel-names = "CH0", "CH1", "CH2", "CH3"; >> >> Not really useful names. Do you have a real example? > > As Mark said, for IIO channel, using CHx makes sense. > See below, I provide a full example. > >> >>> + /* Invert CH1 and CH2 */ >>> + invert = <0 1 1>; >> >> IMO, invert should be same length as io-channels. > > I will update. > > Related to this topic, when I wrote this binding, I wanted to add some > rules/constraints in order to: > - Have this property optional > - If present, force to have as many items in the invert array as the > number of items present in the io-channels array. > > I never succeed in writing the constraint for the invert property. > It should be possible (it is done for some 'foo' 'foo-names' pair such > as clocks). > Can you tell me if possible in my case and give me some pointers ? > >> >>> + }; >> >> How do support multiple instances? Say you have 2 sound cards (or 1 >> sound card with multiple audio paths) each with different sets of IIO >> channels associated with it. You'd need a link to each 'aux' node. Why >> not just add io-channels to the sound card nodes directly? That's >> already just a virtual, top-level container node grouping all the >> components. I don't see why we need another virtual node grouping a >> subset of them. > > I don't see what you mean. > I use a simple-audio-card and here is a full example using several > instances: Just like Rob said: "You'd need a link to each 'aux' node" and you did it... So now the rest of Rob's answer: "Why not just add io-channels to the sound card nodes directly? That's already just a virtual, top-level container node grouping all the components. I don't see why we need another virtual node grouping a subset of them." Why do you need another node if it is not really representing a real, separate device? Best regards, Krzysztof
On Tue, May 02, 2023 at 09:26:32AM +0200, Krzysztof Kozlowski wrote: > On 26/04/2023 09:36, Herve Codina wrote: > > Rob Herring <robh@kernel.org> wrote: > >> On Fri, Apr 21, 2023 at 02:41:19PM +0200, Herve Codina wrote: > >>> simple-iio-aux allows to consider these Industrial I/O devices as > >>> auxliary audio devices. > >> What makes it simple? Any binding called simple or generic is a trigger > >> for me. Best to avoid those terms. :) > > I choose simple-iio-aux because some simple-* already exists. > > For instance simple-audio-amplifier or simple-audio-mux. > > Do you prefer audio-iio-aux ? > > Let me know if I should change. > It means that often what people call "simple" and "generic" works only > for their specific case, because it is not really simple and generic. > After some time the "simple" and "generic" becomes "complicated" and > "huge". Conclusion: sometimes simple and generic bindings are bad idea > and you should have something specific. > Your description in the binding also does not help to match it to > specific, real device. Provide the examples, as Rob asked. I don't understand what you are looking for here. IIO is a subsystem which represents generic DACs and ADCs (along with other I/O things). Audio devices also have DACs and ADCs, somewhat specialised for use in audio but more limited by specs and interfaces than by anything fundamental. The goal here is to map DACs and ADCs described as IIO for use in an audio context. ADCs are devices that convert analog signals into digital values, DACs are devices that convert digital values into analog signals. > >> How do support multiple instances? Say you have 2 sound cards (or 1 > >> sound card with multiple audio paths) each with different sets of IIO > >> channels associated with it. You'd need a link to each 'aux' node. Why > >> not just add io-channels to the sound card nodes directly? That's > >> already just a virtual, top-level container node grouping all the > >> components. I don't see why we need another virtual node grouping a > >> subset of them. > > I don't see what you mean. > > I use a simple-audio-card and here is a full example using several > > instances: > Just like Rob said: "You'd need a link to each 'aux' node" > and you did it... > So now the rest of Rob's answer: > "Why not just add io-channels to the sound card nodes directly? That's > already just a virtual, top-level container node grouping all the > components. I don't see why we need another virtual node grouping a > subset of them." > Why do you need another node if it is not really representing a real, > separate device? If nothing else I would expect it to be useful from a comprehensibility point of view to bundle multiple IIO devices into a single multi-channel audio stream, an individual IIO device is likely to only present a single channel of data but it is common to group multiple channels of audio data.
Hi Rob, Krzysztof, Mark, On Thu, 4 May 2023 13:22:35 +0900 Mark Brown <broonie@kernel.org> wrote: > On Tue, May 02, 2023 at 09:26:32AM +0200, Krzysztof Kozlowski wrote: > > On 26/04/2023 09:36, Herve Codina wrote: > > > Rob Herring <robh@kernel.org> wrote: > > >> On Fri, Apr 21, 2023 at 02:41:19PM +0200, Herve Codina wrote: > > > >>> simple-iio-aux allows to consider these Industrial I/O devices as > > >>> auxliary audio devices. > > > >> What makes it simple? Any binding called simple or generic is a trigger > > >> for me. Best to avoid those terms. :) > > > > I choose simple-iio-aux because some simple-* already exists. > > > For instance simple-audio-amplifier or simple-audio-mux. > > > > Do you prefer audio-iio-aux ? > > > Let me know if I should change. > > > It means that often what people call "simple" and "generic" works only > > for their specific case, because it is not really simple and generic. > > After some time the "simple" and "generic" becomes "complicated" and > > "huge". Conclusion: sometimes simple and generic bindings are bad idea > > and you should have something specific. > > > Your description in the binding also does not help to match it to > > specific, real device. Provide the examples, as Rob asked. > > I don't understand what you are looking for here. IIO is a subsystem > which represents generic DACs and ADCs (along with other I/O things). > Audio devices also have DACs and ADCs, somewhat specialised for use in > audio but more limited by specs and interfaces than by anything > fundamental. The goal here is to map DACs and ADCs described as IIO for > use in an audio context. > > ADCs are devices that convert analog signals into digital values, DACs > are devices that convert digital values into analog signals. > > > >> How do support multiple instances? Say you have 2 sound cards (or 1 > > >> sound card with multiple audio paths) each with different sets of IIO > > >> channels associated with it. You'd need a link to each 'aux' node. Why > > >> not just add io-channels to the sound card nodes directly? That's > > >> already just a virtual, top-level container node grouping all the > > >> components. I don't see why we need another virtual node grouping a > > >> subset of them. > > > > I don't see what you mean. > > > I use a simple-audio-card and here is a full example using several > > > instances: > > > Just like Rob said: "You'd need a link to each 'aux' node" > > > and you did it... > > > So now the rest of Rob's answer: > > > "Why not just add io-channels to the sound card nodes directly? That's > > already just a virtual, top-level container node grouping all the > > components. I don't see why we need another virtual node grouping a > > subset of them." > > > Why do you need another node if it is not really representing a real, > > separate device? > > If nothing else I would expect it to be useful from a comprehensibility > point of view to bundle multiple IIO devices into a single multi-channel > audio stream, an individual IIO device is likely to only present a > single channel of data but it is common to group multiple channels of > audio data. I cannot simply add io-channels to the sound card directly. I need a node to set at least the sound-name-prefix property. Further more having a node and a related compatible string can be easier to maintain and add future evolution related to these "virtual" devices. As some subnodes are already defined for a sound card node, I propose to group these "virtual" audio devices node in a specific bundle node. This lead to the following example: ---- 8< ---- spi { #address-cells = <1>; #size-cells = <0>; /* potentiometers present in an input amplifier design */ pot_in: potentiometer@0 { compatible = "foo,xxx"; reg = <0>; #io-channel-cells = <1>; }; /* potentiometers present in an output amplifier design */ pot_out: potentiometer@1 { compatible = "foo,xxx"; reg = <1>; #io-channel-cells = <1>; }; /* A codec */ codec: codec@2 { compatible = "bar,yyy"; reg = <2>; sound-name-prefix = "CODEC"; }; }; sound { compatible = "simple-audio-card"; #address-cells = <1>; #size-cells = <0>; simple-audio-card,name = "My Sound Card"; simple-audio-card,aux-devs = <&_in>, <&_out>; simple-audio-card,routing = "CODEC IN0", "AMP_IN CH0 OUT", "CODEC IN1", "AMP_IN CH1 OUT", "AMP_OUT CH0 IN", "CODEC OUT0", "AMP_OUT CH1 IN", "CODEC OUT1"; simple-audio-card,dai-link@0 { ... }; ... /* A bundle for the additional devices */ simple-audio-card,additional-devs { amp_out: aux-out { compatible = "audio-iio-aux"; /* Instead of "simple-iio-aux */ io-channels = <&pot_out 0>, <&pot_out 1>, io-channel-names = "CH0", "CH1"; snd-control-invert-range = <1 1>; /* Old 'invert' renamed */ sound-name-prefix = "AMP_OUT"; }; amp_in: aux-in { compatible = "audio-iio-aux"; io-channels = <&pot_in 0>, <&pot_in 1>; io-channel-names = "CH0", "CH1"; sound-name-prefix = "AMP_IN"; }; }; }; ---- 8< ---- What do you think about this new binding ? Best regards, Hervé
diff --git a/Documentation/devicetree/bindings/sound/simple-iio-aux.yaml b/Documentation/devicetree/bindings/sound/simple-iio-aux.yaml new file mode 100644 index 000000000000..fab128fce4fc --- /dev/null +++ b/Documentation/devicetree/bindings/sound/simple-iio-aux.yaml @@ -0,0 +1,65 @@ +# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) +%YAML 1.2 +--- +$id: http://devicetree.org/schemas/sound/simple-iio-aux.yaml# +$schema: http://devicetree.org/meta-schemas/core.yaml# + +title: Simple IIO auxiliary + +maintainers: + - Herve Codina <herve.codina@bootlin.com> + +description: | + Auxiliary device based on Industrial I/O device channels + +allOf: + - $ref: /schemas/iio/iio-consumer.yaml + - $ref: dai-common.yaml# + +properties: + compatible: + const: simple-iio-aux + + io-channels: + description: + Industrial I/O device channels used + + io-channel-names: + description: + Industrial I/O channel names related to io-channels. + These names are used to provides sound controls, widgets and routes names. + + invert: + $ref: /schemas/types.yaml#/definitions/uint32-array + description: | + A list of 0/1 flags defining whether or not the related channel is + inverted + items: + enum: [0, 1] + default: 0 + description: | + Invert the sound control value compared to the IIO channel raw value. + - 1: The related sound control value is inverted meaning that the + minimum sound control value correspond to the maximum IIO channel + raw value and the maximum sound control value correspond to the + minimum IIO channel raw value. + - 0: The related sound control value is not inverted meaning that the + minimum (resp maximum) sound control value correspond to the + minimum (resp maximum) IIO channel raw value. + +required: + - compatible + - io-channels + - io-channel-names + +unevaluatedProperties: false + +examples: + - | + aux { + compatible = "simple-iio-aux"; + io-channels = <&iio 0>, <&iio 1>, <&iio 2>, <&iio 3>; + io-channel-names = "CH0", "CH1", "CH2", "CH3"; + /* Invert CH1 and CH2 */ + invert = <0 1 1>; + };