From: Rob Herring <robh@kernel.org>
To: "Niklas Söderlund" <niklas.soderlund+renesas@ragnatech.se>
Cc: Kieran Bingham <kieran.bingham@ideasonboard.com>,
devicetree@vger.kernel.org, linux-media@vger.kernel.org,
linux-renesas-soc@vger.kernel.org,
Geert Uytterhoeven <geert+renesas@glider.be>,
Kieran Bingham <kieran.bingham+renesas@ideasonboard.com>
Subject: Re: [PATCH v3] dt-bindings: adv748x: Convert bindings to json-schema
Date: Wed, 27 Oct 2021 16:09:09 -0500 [thread overview]
Message-ID: <YXm/9cVkJnMqwktY@robh.at.kernel.org> (raw)
In-Reply-To: <20211019192044.782830-1-niklas.soderlund+renesas@ragnatech.se>
On Tue, Oct 19, 2021 at 09:20:44PM +0200, Niklas Söderlund wrote:
> Convert ADV748X analog video decoder documentation to json-schema.
>
> While converting the bindings extend it to enforce that all port@n nodes
> shall be encapsulated inside a ports node. This change does not have an
> effect on drivers parsing the ports@n nodes.
>
> Signed-off-by: Niklas Söderlund <niklas.soderlund+renesas@ragnatech.se>
> Reviewed-by: Geert Uytterhoeven <geert+renesas@glider.be>
> Reviewed-by: Kieran Bingham <kieran.bingham+renesas@ideasonboard.com>
> ---
> * Changes sinve v2
> - Add adv748x.yaml to MAINTAINERS.
> - Update commit message.
> - Add myself to under the maintainers section after talking with Kieran.
> - Split reg in examples in two lines to match reg-names.
>
> * Changes since v1
> - Update commit message to mention the added ports node.
>
> Hello,
>
> This conversion revealed a problem with the Renesas DTSI files for the
> adv7482 nodes. A fix for that have been submitted in a separate patch,
>
> [PATCH] arm64: dts: renesas: Add ports node to all adv7482 nodes
>
> Kind Regards,
> Niklas Söderlund
> ---
> .../devicetree/bindings/media/i2c/adv748x.txt | 116 ----------
> .../bindings/media/i2c/adv748x.yaml | 213 ++++++++++++++++++
> MAINTAINERS | 1 +
> 3 files changed, 214 insertions(+), 116 deletions(-)
> delete mode 100644 Documentation/devicetree/bindings/media/i2c/adv748x.txt
> create mode 100644 Documentation/devicetree/bindings/media/i2c/adv748x.yaml
>
> diff --git a/Documentation/devicetree/bindings/media/i2c/adv748x.txt b/Documentation/devicetree/bindings/media/i2c/adv748x.txt
> deleted file mode 100644
> index 4f91686e54a6b939..0000000000000000
> --- a/Documentation/devicetree/bindings/media/i2c/adv748x.txt
> +++ /dev/null
> @@ -1,116 +0,0 @@
> -* Analog Devices ADV748X video decoder with HDMI receiver
> -
> -The ADV7481 and ADV7482 are multi format video decoders with an integrated
> -HDMI receiver. They can output CSI-2 on two independent outputs TXA and TXB
> -from three input sources HDMI, analog and TTL.
> -
> -Required Properties:
> -
> - - compatible: Must contain one of the following
> - - "adi,adv7481" for the ADV7481
> - - "adi,adv7482" for the ADV7482
> -
> - - reg: I2C slave addresses
> - The ADV748x has up to twelve 256-byte maps that can be accessed via the
> - main I2C ports. Each map has it own I2C address and acts as a standard
> - slave device on the I2C bus. The main address is mandatory, others are
> - optional and remain at default values if not specified.
> -
> -Optional Properties:
> -
> - - interrupt-names: Should specify the interrupts as "intrq1", "intrq2" and/or
> - "intrq3". All interrupts are optional. The "intrq3" interrupt
> - is only available on the adv7481
> - - interrupts: Specify the interrupt lines for the ADV748x
> - - reg-names : Names of maps with programmable addresses.
> - It shall contain all maps needing a non-default address.
> - Possible map names are:
> - "main", "dpll", "cp", "hdmi", "edid", "repeater",
> - "infoframe", "cbus", "cec", "sdp", "txa", "txb"
> -
> -The device node must contain one 'port' child node per device input and output
> -port, in accordance with the video interface bindings defined in
> -Documentation/devicetree/bindings/media/video-interfaces.txt. The port nodes
> -are numbered as follows.
> -
> - Name Type Port
> - ---------------------------------------
> - AIN0 sink 0
> - AIN1 sink 1
> - AIN2 sink 2
> - AIN3 sink 3
> - AIN4 sink 4
> - AIN5 sink 5
> - AIN6 sink 6
> - AIN7 sink 7
> - HDMI sink 8
> - TTL sink 9
> - TXA source 10
> - TXB source 11
> -
> -The digital output port nodes, when present, shall contain at least one
> -endpoint. Each of those endpoints shall contain the data-lanes property as
> -described in video-interfaces.txt.
> -
> -Required source endpoint properties:
> - - data-lanes: an array of physical data lane indexes
> - The accepted value(s) for this property depends on which of the two
> - sources are described. For TXA 1, 2 or 4 data lanes can be described
> - while for TXB only 1 data lane is valid. See video-interfaces.txt
> - for detailed description.
> -
> -Ports are optional if they are not connected to anything at the hardware level.
> -
> -Example:
> -
> - video-receiver@70 {
> - compatible = "adi,adv7482";
> - reg = <0x70 0x71 0x72 0x73 0x74 0x75
> - 0x60 0x61 0x62 0x63 0x64 0x65>;
> - reg-names = "main", "dpll", "cp", "hdmi", "edid", "repeater",
> - "infoframe", "cbus", "cec", "sdp", "txa", "txb";
> -
> - #address-cells = <1>;
> - #size-cells = <0>;
> -
> - interrupt-parent = <&gpio6>;
> - interrupt-names = "intrq1", "intrq2";
> - interrupts = <30 IRQ_TYPE_LEVEL_LOW>,
> - <31 IRQ_TYPE_LEVEL_LOW>;
> -
> - port@7 {
> - reg = <7>;
> -
> - adv7482_ain7: endpoint {
> - remote-endpoint = <&cvbs_in>;
> - };
> - };
> -
> - port@8 {
> - reg = <8>;
> -
> - adv7482_hdmi: endpoint {
> - remote-endpoint = <&hdmi_in>;
> - };
> - };
> -
> - port@a {
> - reg = <10>;
> -
> - adv7482_txa: endpoint {
> - clock-lanes = <0>;
> - data-lanes = <1 2 3 4>;
> - remote-endpoint = <&csi40_in>;
> - };
> - };
> -
> - port@b {
> - reg = <11>;
> -
> - adv7482_txb: endpoint {
> - clock-lanes = <0>;
> - data-lanes = <1>;
> - remote-endpoint = <&csi20_in>;
> - };
> - };
> - };
> diff --git a/Documentation/devicetree/bindings/media/i2c/adv748x.yaml b/Documentation/devicetree/bindings/media/i2c/adv748x.yaml
> new file mode 100644
> index 0000000000000000..30c361766ba3023e
> --- /dev/null
> +++ b/Documentation/devicetree/bindings/media/i2c/adv748x.yaml
> @@ -0,0 +1,213 @@
> +# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
> +%YAML 1.2
> +---
> +$id: http://devicetree.org/schemas/media/i2c/adv748x.yaml#
> +$schema: http://devicetree.org/meta-schemas/core.yaml#
> +
> +title: Analog Devices ADV748X video decoder with HDMI receiver
> +
> +maintainers:
> + - Kieran Bingham <kieran.bingham@ideasonboard.com>
> + - Niklas Söderlund <niklas.soderlund@ragnatech.se>
> +
> +description:
> + The ADV7481 and ADV7482 are multi format video decoders with an integrated
> + HDMI receiver. They can output CSI-2 on two independent outputs TXA and TXB
> + from three input sources HDMI, analog and TTL.
> +
> +properties:
> + compatible:
> + items:
> + - enum:
> + - adi,adv7481
> + - adi,adv7482
> +
> + reg:
> + minItems: 1
> + maxItems: 12
> + description:
> + The ADV748x has up to twelve 256-byte maps that can be accessed via the
> + main I2C ports. Each map has it own I2C address and acts as a standard
> + slave device on the I2C bus. The main address is mandatory, others are
> + optional and remain at default values if not specified.
> +
> + reg-names:
> + minItems: 1
> + items:
> + - const: main
> + - enum: [ dpll, cp, hdmi, edid, repeater, infoframe, cbus, cec, sdp, txa, txb ]
> + - enum: [ dpll, cp, hdmi, edid, repeater, infoframe, cbus, cec, sdp, txa, txb ]
> + - enum: [ dpll, cp, hdmi, edid, repeater, infoframe, cbus, cec, sdp, txa, txb ]
> + - enum: [ dpll, cp, hdmi, edid, repeater, infoframe, cbus, cec, sdp, txa, txb ]
> + - enum: [ dpll, cp, hdmi, edid, repeater, infoframe, cbus, cec, sdp, txa, txb ]
> + - enum: [ dpll, cp, hdmi, edid, repeater, infoframe, cbus, cec, sdp, txa, txb ]
> + - enum: [ dpll, cp, hdmi, edid, repeater, infoframe, cbus, cec, sdp, txa, txb ]
> + - enum: [ dpll, cp, hdmi, edid, repeater, infoframe, cbus, cec, sdp, txa, txb ]
> + - enum: [ dpll, cp, hdmi, edid, repeater, infoframe, cbus, cec, sdp, txa, txb ]
> + - enum: [ dpll, cp, hdmi, edid, repeater, infoframe, cbus, cec, sdp, txa, txb ]
> + - enum: [ dpll, cp, hdmi, edid, repeater, infoframe, cbus, cec, sdp, txa, txb ]
> +
> + interrupts: true
> +
> + interrupt-names: true
> +
> + ports:
> + $ref: /schemas/graph.yaml#/properties/ports
> +
> + patternProperties:
> + "^port@[0-7]$":
> + $ref: /schemas/graph.yaml#/properties/port
> + description: Input port nodes for analog inputs AIN[0-7].
> +
> + properties:
> + port@8:
> + $ref: /schemas/graph.yaml#/properties/port
> + description: Input port node for HDMI.
> +
> + port@9:
> + $ref: /schemas/graph.yaml#/properties/port
> + description: Input port node for TTL.
> +
> + port@a:
> + $ref: /schemas/graph.yaml#/$defs/port-base
> + unevaluatedProperties: false
> + description:
> + Output port node, single endpoint describing the CSI-2 transmitter TXA.
> +
> + properties:
> + endpoint:
> + $ref: /schemas/media/video-interfaces.yaml#
> + unevaluatedProperties: false
> +
> + properties:
> + clock-lanes:
> + maxItems: 1
> +
> + data-lanes:
> + minItems: 1
> + maxItems: 4
> +
> + required:
> + - clock-lanes
> + - data-lanes
> +
> + port@b:
> + $ref: /schemas/graph.yaml#/$defs/port-base
> + unevaluatedProperties: false
> + description:
> + Output port node, single endpoint describing the CSI-2 transmitter TXB.
> +
> + properties:
> + endpoint:
> + $ref: /schemas/media/video-interfaces.yaml#
> + unevaluatedProperties: false
> +
> + properties:
> + clock-lanes:
> + maxItems: 1
> +
> + data-lanes:
> + maxItems: 1
> +
> + required:
> + - clock-lanes
> + - data-lanes
> +
> +allOf:
> + - if:
> + properties:
> + compatible:
> + contains:
> + const: adi,adv7481
> + then:
> + properties:
> + interrupts:
> + minItems: 1
> + maxItems: 3
> +
> + interrupt-names:
> + minItems: 1
> + items:
> + - enum: [ intrq1, intrq2, intrq3 ]
> + - enum: [ intrq1, intrq2, intrq3 ]
> + - enum: [ intrq1, intrq2, intrq3 ]
minItems: 1
maxItems: 3
items:
enum: [ intrq1, intrq2, intrq3 ]
> + else:
> + properties:
> + interrupts:
> + minItems: 1
> + maxItems: 2
> +
> + interrupt-names:
> + minItems: 1
> + items:
> + - enum: [ intrq1, intrq2 ]
> + - enum: [ intrq1, intrq2 ]
Similar here.
> +
> +additionalProperties: false
> +
> +required:
> + - compatible
> + - reg
> + - ports
> +
> +examples:
> + - |
> + #include <dt-bindings/interrupt-controller/irq.h>
> +
> + i2c {
> + #address-cells = <1>;
> + #size-cells = <0>;
> +
> + video-receiver@70 {
> + compatible = "adi,adv7482";
> + reg = <0x70 0x71 0x72 0x73 0x74 0x75
> + 0x60 0x61 0x62 0x63 0x64 0x65>;
> + reg-names = "main", "dpll", "cp", "hdmi", "edid", "repeater",
> + "infoframe", "cbus", "cec", "sdp", "txa", "txb";
> +
> + interrupt-parent = <&gpio6>;
> + interrupts = <30 IRQ_TYPE_LEVEL_LOW>, <31 IRQ_TYPE_LEVEL_LOW>;
> + interrupt-names = "intrq1", "intrq2";
> +
> + ports {
> + #address-cells = <1>;
> + #size-cells = <0>;
> +
> + port@7 {
> + reg = <7>;
> +
> + adv7482_ain7: endpoint {
> + remote-endpoint = <&cvbs_in>;
> + };
> + };
> +
> + port@8 {
> + reg = <8>;
> +
> + adv7482_hdmi: endpoint {
> + remote-endpoint = <&hdmi_in>;
> + };
> + };
> +
> + port@a {
> + reg = <10>;
> +
> + adv7482_txa: endpoint {
> + clock-lanes = <0>;
> + data-lanes = <1 2 3 4>;
> + remote-endpoint = <&csi40_in>;
> + };
> + };
> +
> + port@b {
> + reg = <11>;
> +
> + adv7482_txb: endpoint {
> + clock-lanes = <0>;
> + data-lanes = <1>;
> + remote-endpoint = <&csi20_in>;
> + };
> + };
> + };
> + };
> + };
> diff --git a/MAINTAINERS b/MAINTAINERS
> index ee91c5472bc1540a..6ea3e63cbc7f33c3 100644
> --- a/MAINTAINERS
> +++ b/MAINTAINERS
> @@ -1124,6 +1124,7 @@ M: Kieran Bingham <kieran.bingham@ideasonboard.com>
> L: linux-media@vger.kernel.org
> S: Maintained
> F: drivers/media/i2c/adv748x/*
> +F: Documentation/devicetree/bindings/media/i2c/adv748x.yaml
>
> ANALOG DEVICES INC ADV7511 DRIVER
> M: Hans Verkuil <hverkuil-cisco@xs4all.nl>
> --
> 2.33.1
>
>
prev parent reply other threads:[~2021-10-27 21:09 UTC|newest]
Thread overview: 2+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-10-19 19:20 [PATCH v3] dt-bindings: adv748x: Convert bindings to json-schema Niklas Söderlund
2021-10-27 21:09 ` Rob Herring [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=YXm/9cVkJnMqwktY@robh.at.kernel.org \
--to=robh@kernel.org \
--cc=devicetree@vger.kernel.org \
--cc=geert+renesas@glider.be \
--cc=kieran.bingham+renesas@ideasonboard.com \
--cc=kieran.bingham@ideasonboard.com \
--cc=linux-media@vger.kernel.org \
--cc=linux-renesas-soc@vger.kernel.org \
--cc=niklas.soderlund+renesas@ragnatech.se \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
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).