Received: by 2002:a05:6358:3188:b0:123:57c1:9b43 with SMTP id q8csp12572311rwd; Fri, 23 Jun 2023 07:54:02 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ5gaAFRJqFZGepNUI21O6s+BbLggsDLhymtlPpGOw+2x264RL8xgUsL81KRDgOVtJ5iLFBy X-Received: by 2002:a17:90a:3d0d:b0:259:b065:da4f with SMTP id h13-20020a17090a3d0d00b00259b065da4fmr20688340pjc.36.1687532041666; Fri, 23 Jun 2023 07:54:01 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1687532041; cv=none; d=google.com; s=arc-20160816; b=xwELYNTZCb6zvJZbQBWd6DDRGn253XX/iYAePHcWdjW8Q8l+dC9zDpT7Sah6iraQOS BH1IKoC0aRpneNA5wI7HAWA65oZZw6zIb7wU0iZX80VOcVBVEQ49OX0hdfgeW5CqmWRk TazfpL0OIWO/hrQA7XNwDNb4Js43a2zruPys/JYA0xrt9/RVLkh6SCRlomauieAOFTsE cTzVlu3Ux/CR+n6U6wHu55EwVh9gF5mFMEikKrlACSOCthKEpmaWqrQpNTprn3PUwJ/4 2Qz4wM76rimcRZ/3c59Yc70RSMwhttKoMyK7JbGzwpVzaOgdq9jvKf26Z1r3YgrShsla hX7A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=05lPHTw6kPfUUCzyOJSd2IE+Kgqn4YGRrjawMHpEUWk=; b=Yrta089Hs2tx+/Cdbe+FlTacXQy+I3soUTNRSu+dKTGGcRk4dBYhVzq/aKw9CUWr4C TTweaHvol/iCBL2zHPXF8bVR9c+Zee4C8EBoZnFEuGbIibz0LysGl5i+yeMOYDZuW10N H+gKx4HLJHUil1Hgzzut10of11ZXYD9ARCKGCcJf9Q9KuEGgQ9MZ5qIoLZsSoi9CcF1G jo/0B0J/+SGGgVadc1M5FQMhs7sgR66gaW59UabArV9XHniHBSPuFxjVklSvojyE7jZG F+qWTxJDwd8GVUWLrCmYbC0X6QJUAQbam+jUgb1Z0Ef2d00Ix816CFfN6Pwm9yCgxG9m h+Lg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass (test mode) header.i=@ideasonboard.com header.s=mail header.b=VbcvcnwV; 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 Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id o14-20020a17090a744e00b002476baf6b4bsi1138604pjk.149.2023.06.23.07.53.49; Fri, 23 Jun 2023 07:54:01 -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 (test mode) header.i=@ideasonboard.com header.s=mail header.b=VbcvcnwV; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231978AbjFWOnl (ORCPT + 99 others); Fri, 23 Jun 2023 10:43:41 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:39862 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231769AbjFWOni (ORCPT ); Fri, 23 Jun 2023 10:43:38 -0400 Received: from perceval.ideasonboard.com (perceval.ideasonboard.com [213.167.242.64]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id A88821BF2; Fri, 23 Jun 2023 07:43:15 -0700 (PDT) Received: from pendragon.ideasonboard.com (213-243-189-158.bb.dnainternet.fi [213.243.189.158]) by perceval.ideasonboard.com (Postfix) with ESMTPSA id 1E0DEBC; Fri, 23 Jun 2023 16:42:37 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=ideasonboard.com; s=mail; t=1687531357; bh=wdihR9kOfvIQ6G8MVle6NFFv5LJO2T8O0WCVNoKqb1c=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=VbcvcnwV642L1NkucKgXc8YtBoftMHpYjSn6AayKFnjm9KWOdNTZIwBoOh8YRg7Cr rItp4abJJNREMYeDz1RHehAffaXManymW8Mn/eeMPNizWKR+4GbM8yOIIl23orQKMW k9Emk67/9E9hMZ1YjHAAqDoJXQQ9lQpQL3d0DrS8= Date: Fri, 23 Jun 2023 17:43:12 +0300 From: Laurent Pinchart To: Geert Uytterhoeven Cc: Kieran Bingham , David Airlie , Daniel Vetter , Thomas Zimmermann , Magnus Damm , dri-devel@lists.freedesktop.org, linux-renesas-soc@vger.kernel.org, linux-kernel@vger.kernel.org, Rob Herring , Krzysztof Kozlowski , Conor Dooley , devicetree@vger.kernel.org Subject: Re: [PATCH 01/39] dt-bindings: display: Add Renesas SH-Mobile LCDC bindings Message-ID: <20230623144312.GE2112@pendragon.ideasonboard.com> References: <2259ff548f007afcb5a315a4c95c83a0ee4b7e03.1687423204.git.geert+renesas@glider.be> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline In-Reply-To: <2259ff548f007afcb5a315a4c95c83a0ee4b7e03.1687423204.git.geert+renesas@glider.be> X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,SPF_HELO_PASS,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: X-Mailing-List: linux-kernel@vger.kernel.org Hi Geert, Thank you for the patch. On Thu, Jun 22, 2023 at 11:21:13AM +0200, Geert Uytterhoeven wrote: > Add device tree bindings for the LCD Controller (LCDC) found in Renesas > SuperH SH-Mobile and ARM SH/R-Mobile SOCs. > > Based on a plain text prototype by Laurent Pinchart. > > Signed-off-by: Geert Uytterhoeven > Cc: Rob Herring > Cc: Krzysztof Kozlowski > Cc: Conor Dooley > Cc: devicetree@vger.kernel.org > --- > Changes compared to Laurent's original: > - Convert to json-schema, > - Rename compatible values from "renesas,lcdc-" to > "renesas,-lcdc", > - Add power-domains property, > - Add MIPI-DSI port on SH-Mobile AG5, > - Update example to reflect reality, > - Add to MAINTAINERS. > --- > .../display/renesas,shmobile-lcdc.yaml | 108 ++++++++++++++++++ > MAINTAINERS | 1 + > 2 files changed, 109 insertions(+) > create mode 100644 Documentation/devicetree/bindings/display/renesas,shmobile-lcdc.yaml > > diff --git a/Documentation/devicetree/bindings/display/renesas,shmobile-lcdc.yaml b/Documentation/devicetree/bindings/display/renesas,shmobile-lcdc.yaml > new file mode 100644 > index 0000000000000000..72a39fce7294d56d > --- /dev/null > +++ b/Documentation/devicetree/bindings/display/renesas,shmobile-lcdc.yaml > @@ -0,0 +1,108 @@ > +# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) > +%YAML 1.2 > +--- > +$id: http://devicetree.org/schemas/display/renesas,shmobile-lcdc.yaml# > +$schema: http://devicetree.org/meta-schemas/core.yaml# > + > +title: Renesas SH-Mobile LCD Controller (LCDC) > + > +maintainers: > + - Laurent Pinchart I'd be happy if you co-maintained this with me :-) Or even took ownership completely. > + > +properties: > + compatible: > + enum: > + - renesas,r8a7740-lcdc # R-Mobile A1 > + - renesas,sh73a0-lcdc # SH-Mobile AG5 > + > + reg: > + maxItems: 1 > + > + interrupts: > + maxItems: 1 > + > + clocks: > + minItems: 1 > + maxItems: 5 > + description: > + Only the functional clock is mandatory. > + Some of the optional clocks are model-dependent (e.g. "video" (a.k.a. > + "vou" or "dv_clk") is available on R-Mobile A1 only). > + > + clock-names: > + minItems: 1 > + maxItems: 5 > + items: > + enum: [ fck, media, lclk, hdmi, video ] Switching to per-item descriptions would allow documenting which clock applies to which SoC. Are enum items unique by default ? This would allow a combination of clocks that doesn't include the fck clock, that's not right. > + > + power-domains: > + maxItems: 1 > + > + ports: > + $ref: /schemas/graph.yaml#/properties/ports > + description: | > + The connections to the output video ports are modeled using the OF graph > + bindings specified in Documentation/devicetree/bindings/graph.txt. it's available in YAML form now. I'd just drop the "specified in ...". > + The number of ports and their assignment are model-dependent. > + Each port shall have a single endpoint. > + > + properties: > + port@0: > + $ref: /schemas/graph.yaml#/properties/port > + description: LCD port (R-Mobile A1 and SH-Mobile AG5) > + unevaluatedProperties: false > + > + port@1: > + $ref: /schemas/graph.yaml#/properties/port > + description: HDMI port (R-Mobile A1 LCDC1 and SH-Mobile AG5) > + unevaluatedProperties: false > + > + port@2: > + $ref: /schemas/graph.yaml#/properties/port > + description: MIPI-DSI port (SH-Mobile AG5) > + unevaluatedProperties: false Let's condition the ports on the compatible value to enable automatic validation. > + > + required: > + - port@0 Based on the above, port@1 is required too as it's present on all supported SoCs. Let's condition this on the compatible value too. > + > + unevaluatedProperties: false > + > +required: > + - compatible > + - reg > + - interrupts > + - clocks > + - clock-names > + - power-domains > + - ports > + > +additionalProperties: false > + > +examples: > + - | > + #include > + #include > + > + lcdc0: lcd-controller@fe940000 { > + compatible = "renesas,r8a7740-lcdc"; > + reg = <0xfe940000 0x4000>; > + interrupts = ; > + clocks = <&mstp1_clks R8A7740_CLK_LCDC0>, > + <&cpg_clocks R8A7740_CLK_M3>, <&lcdlclk0_clk>, > + <&vou_clk>; > + clock-names = "fck", "media", "lclk", "video"; > + power-domains = <&pd_a4lc>; > + status = "disabled"; > + > + ports { > + #address-cells = <1>; > + #size-cells = <0>; > + > + port@0 { > + reg = <0>; > + > + lcdc0_rgb: endpoint { > + }; > + }; > + }; > + }; > diff --git a/MAINTAINERS b/MAINTAINERS > index 83e9f4ac6bedaa9f..dc1935c196cb0e0b 100644 > --- a/MAINTAINERS > +++ b/MAINTAINERS > @@ -7023,6 +7023,7 @@ F: Documentation/devicetree/bindings/display/bridge/renesas,dsi-csi2-tx.yaml > F: Documentation/devicetree/bindings/display/bridge/renesas,dw-hdmi.yaml > F: Documentation/devicetree/bindings/display/bridge/renesas,lvds.yaml > F: Documentation/devicetree/bindings/display/renesas,du.yaml > +F: Documentation/devicetree/bindings/display/renesas,shmobile-lcdc.yaml > F: drivers/gpu/drm/renesas/ > F: include/linux/platform_data/shmob_drm.h > -- Regards, Laurent Pinchart