Received: by 2002:a05:7412:40d:b0:e2:908c:2ebd with SMTP id 13csp278564rdf; Tue, 21 Nov 2023 02:27:23 -0800 (PST) X-Google-Smtp-Source: AGHT+IFD2z3Y4yd6mXVt1xGop+TMLynllxUz4Dsxz8ptd4OS3nXtYji+9t9iEQ/3cTXHOiM5auU1 X-Received: by 2002:a9d:6757:0:b0:6d6:4fed:a21a with SMTP id w23-20020a9d6757000000b006d64feda21amr10442290otm.6.1700562443647; Tue, 21 Nov 2023 02:27:23 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1700562443; cv=none; d=google.com; s=arc-20160816; b=MXqi5hUX9gn7KtjyBrizLEBUW87V3mvqifdjCAFQIIkTSS4i8RASjzuzyig67/ehNi eWJT0Xg9p5IghfcEml+3MTth05MVqDJpQYoRQp0MZRvzo4nWGnXU4wxQomj3/R2Z6mGp 9wNSq5LSsq890fFC7YnJixlrsBhiU1lYKTRbfqqTcCmZDSPz3w6guKI2w9UXHbU53cl/ RrBMY5zTyR/f2eNa00c5mYmwtS2BzLKrGJgpbzkDjlPzzV0QzJbsQQaupMejJ+rfbU13 Xid85OjqvWrix3Ox7LpgfGlR+P5T2sA5KGkv0ZX/ByKjkb+MBrwfgrw9oyh8o3/WKLY0 Ps2g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to :content-language:from:references:cc:to:subject:user-agent :mime-version:date:message-id:dkim-signature; bh=11dYioFRQNzUxWIkK/ikbWEMirVUv1PvQWDOGO4JBMM=; fh=il1jr1oqO0FNrwvkr6XT24z4d3M1tDLsYQoZPx+BXZg=; b=pq+6AmJZUOGpLA/K/9FvcJPViwFBOBndAgMV/hf+lneR594zlZPLbSrVPIrspdik/J +B+K+zE/KF8URDHanbr5gGUBXCQ7AFMNbNcFivproOfp3RVvEOJPo/VUljTsUN5PXjA6 /8Y/VtZhi4mC6bxCkMh0L1cHZ/xlOf59ZmvtQCBSRqa/vN3xuhFP1TuFFV0c2xdJjPwY jRnT8dYBD3x7Um+nFVv1GUFyZic2Ox0F4UpJybyX1ernEmo5kXPI101AtZWyujsUceD2 LL0jH+rGamBmxXfvLJW/fn06ZoaCOVwMSqr1d11TsnlM199n4sS2bnSDXpjUi7jMbR7R RcFw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@collabora.com header.s=mail header.b=WrcKpvdV; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:8 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=collabora.com Return-Path: Received: from fry.vger.email (fry.vger.email. [2620:137:e000::3:8]) by mx.google.com with ESMTPS id z15-20020a634c0f000000b005bd9fc46b76si9972645pga.302.2023.11.21.02.27.23 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 21 Nov 2023 02:27:23 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:8 as permitted sender) client-ip=2620:137:e000::3:8; Authentication-Results: mx.google.com; dkim=pass header.i=@collabora.com header.s=mail header.b=WrcKpvdV; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:8 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=collabora.com Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by fry.vger.email (Postfix) with ESMTP id 9A6DD807933C; Tue, 21 Nov 2023 02:25:37 -0800 (PST) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.11 at fry.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231923AbjKUKZS (ORCPT + 99 others); Tue, 21 Nov 2023 05:25:18 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:55422 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230304AbjKUKZQ (ORCPT ); Tue, 21 Nov 2023 05:25:16 -0500 Received: from madras.collabora.co.uk (madras.collabora.co.uk [46.235.227.172]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 62CB9E8; Tue, 21 Nov 2023 02:25:11 -0800 (PST) Received: from [100.107.97.3] (cola.collaboradmins.com [195.201.22.229]) (using TLSv1.3 with cipher TLS_AES_128_GCM_SHA256 (128/128 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits) server-digest SHA256) (No client certificate requested) (Authenticated sender: kholk11) by madras.collabora.co.uk (Postfix) with ESMTPSA id 4D2AB66072F1; Tue, 21 Nov 2023 10:25:08 +0000 (GMT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=collabora.com; s=mail; t=1700562309; bh=xTDhw6B0torqkaxxO598WkuvO21AtWGiswLnga/6zdw=; h=Date:Subject:To:Cc:References:From:In-Reply-To:From; b=WrcKpvdVBH/n5k5OgsCeo8xOMDk8RIGxlRxe3NurIBFzCktrdr9D0jHmLSLYqoPD8 1n0t/46YZw3z/j2hdIodpPo7n/pEoDNi6rWtNIWgEFG/eeZyk23AFE26M/oHyGlEXt am4BYfbfibdkv/pTSpuPiPYrvLydTv53JXxtTQGktdxpQm/Dv1oxRBTCPSCpDZX1WK CxCAROV+vBHAYaysnfp20LNugcx0Ta+gvlrjP4UdxXzd+LtJeoopGYJDP+889o29yR gJCLA5EJczarAQTH4PdHhzuVo6iyUiMQFtUamu2TUXpOTjcXGgDacTZwCkg4GYEaEN BIAX7PykJsh4A== Message-ID: <947c4a52-6688-46ef-9e37-087164971da5@collabora.com> Date: Tue, 21 Nov 2023 11:25:05 +0100 MIME-Version: 1.0 User-Agent: Mozilla Thunderbird Subject: Re: [PATCH v2] docs: dt-bindings: add DTS Coding Style document To: Krzysztof Kozlowski , Rob Herring , Krzysztof Kozlowski , Conor Dooley , Matthias Brugger , devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-mediatek@lists.infradead.org Cc: Andrew Davis , Arnd Bergmann , Bjorn Andersson , Geert Uytterhoeven , Heiko Stuebner , Konrad Dybcio , Michal Simek , Neil Armstrong , Nishanth Menon , Olof Johansson , linux-rockchip@lists.infradead.org, linux-samsung-soc@vger.kernel.org, linux-amlogic@lists.infradead.org, linux-arm-msm@vger.kernel.org References: <20231120084044.23838-1-krzysztof.kozlowski@linaro.org> <92cf3bcc-18e7-40ba-a082-1b8b6bea0dee@collabora.com> From: AngeloGioacchino Del Regno Content-Language: en-US In-Reply-To: Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-0.9 required=5.0 tests=DKIM_SIGNED,DKIM_VALID, DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on fry.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (fry.vger.email [0.0.0.0]); Tue, 21 Nov 2023 02:25:37 -0800 (PST) Il 20/11/23 15:57, Krzysztof Kozlowski ha scritto: > On 20/11/2023 12:43, AngeloGioacchino Del Regno wrote: >> Il 20/11/23 09:40, Krzysztof Kozlowski ha scritto: >>> Document preferred coding style for Devicetree sources (DTS and DTSI), >>> to bring consistency among all (sub)architectures and ease in reviews. >>> >>> Cc: Andrew Davis >>> Cc: AngeloGioacchino Del Regno >>> Cc: Arnd Bergmann >>> Cc: Bjorn Andersson >>> Cc: Geert Uytterhoeven >>> Cc: Heiko Stuebner >>> Cc: Konrad Dybcio >>> Cc: Matthias Brugger >>> Cc: Michal Simek >>> Cc: Neil Armstrong >>> Cc: Nishanth Menon >>> Cc: Olof Johansson >>> Signed-off-by: Krzysztof Kozlowski >>> >>> --- >>> >>> Merging idea: Rob/DT bindings >>> >>> Changes in v2 >>> ============= >>> 1. Hopefully incorporate entire feedback from comments: >>> a. Fix \ { => / { (Rob) >>> b. Name: dts-coding-style (Rob) >>> c. Exceptions for ordering nodes by name for Renesas and pinctrl (Geert, >>> Konrad) >>> d. Ordering properties by common/vendor (Rob) >>> e. Array entries in <> (Rob) >>> >>> 2. New chapter: Organizing DTSI and DTS >>> >>> 3. Several grammar fixes (missing articles) >>> >>> Cc: linux-rockchip@lists.infradead.org >>> Cc: linux-mediatek@lists.infradead.org >>> Cc: linux-samsung-soc@vger.kernel.org >>> Cc: linux-amlogic@lists.infradead.org >>> Cc: linux-arm-kernel@lists.infradead.org >>> Cc: linux-arm-msm@vger.kernel.org >>> --- >>> .../devicetree/bindings/dts-coding-style.rst | 163 ++++++++++++++++++ >>> Documentation/devicetree/bindings/index.rst | 1 + >>> 2 files changed, 164 insertions(+) >>> create mode 100644 Documentation/devicetree/bindings/dts-coding-style.rst >>> >>> diff --git a/Documentation/devicetree/bindings/dts-coding-style.rst b/Documentation/devicetree/bindings/dts-coding-style.rst >>> new file mode 100644 >>> index 000000000000..cc7e3b4d1b92 >>> --- /dev/null >>> +++ b/Documentation/devicetree/bindings/dts-coding-style.rst >>> @@ -0,0 +1,163 @@ >>> +.. SPDX-License-Identifier: GPL-2.0 >>> +.. _dtscodingstyle: >>> + >>> +===================================== >>> +Devicetree Sources (DTS) Coding Style >>> +===================================== >>> + >>> +When writing Devicetree Sources (DTS) please observe below guidelines. They >>> +should be considered complementary to any rules expressed already in Devicetree >>> +Specification and dtc compiler (including W=1 and W=2 builds). >>> + >>> +Individual architectures and sub-architectures can add additional rules, making >>> +the style stricter. >>> + >>> +Naming and Valid Characters >>> +--------------------------- >>> + >>> +1. Node and property names are allowed to use only: >>> + >>> + * lowercase characters: [a-z] >>> + * digits: [0-9] >>> + * dash: - >>> + >>> +2. Labels are allowed to use only: >>> + >>> + * lowercase characters: [a-z] >>> + * digits: [0-9] >>> + * underscore: _ >>> + >>> +3. Unit addresses should use lowercase hex, without leading zeros (padding). >> >> This is imperative, so: s/should/shall/g > > Sure, fine. > >> >>> + >>> +4. Hex values in properties, e.g. "reg", should use lowercase hex. The address >>> + part can be padded with leading zeros. >>> + >> >> Same here, I'd say.... :-) >> >>> +Example:: >>> + >>> + gpi_dma2: dma-controller@800000 { >>> + compatible = "qcom,sm8550-gpi-dma", "qcom,sm6350-gpi-dma"; >>> + reg = <0x0 0x00800000 0x0 0x60000>; >>> + } >>> + >>> +Order of Nodes >>> +-------------- >>> + >>> +1. Nodes within any bus, thus using unit addresses for children, shall be >>> + ordered incrementally by unit address. >>> + Alternatively for some sub-architectures, nodes of the same type can be >>> + grouped together (e.g. all I2C controllers one after another even if this >>> + breaks unit address ordering). >>> + >>> +2. Nodes without unit addresses should be ordered alpha-numerically by the node >>> + name. For a few types of nodes, they can be ordered by the main property >>> + (e.g. pin configuration states ordered by value of "pins" property). >>> + >>> +3. When extending nodes in the board DTS via &label, the entries should be >>> + ordered alpha-numerically. >>> + >>> +Example:: >>> + >> >> Hmm, comments! >> >>> + // SoC DTSI >> >> ....speaking of commenting, should we at least suggest to use C-style comments? >> >> /* SoC DTSI */ > > I can switch it to C-style in the example, but we are going with Linux > Coding Style which soon will allow // judging by Linus' statements. > Right. That wasn't a strong opinion anyway, so it's totally okay as well. >> >>> + >>> + / { >>> + cpus { >>> + // ... >>> + }; >>> + >>> + psci { >>> + // ... >>> + }; >>> + >>> + soc@ { >>> + dma: dma-controller@10000 { >>> + // ... >>> + }; >>> + >>> + clk: clock-controller@80000 { >>> + // ... >>> + }; >>> + }; >>> + }; >>> + >>> + // Board DTS >>> + >>> + &clk { >>> + // ... >>> + }; >>> + >>> + &dma { >>> + // ... >>> + }; >>> + >>> + >>> +Order of Properties in Device Node >>> +---------------------------------- >>> + >>> +Following order of properties in device nodes is preferred: >>> + >>> +1. compatible >>> +2. reg >>> +3. ranges >>> +4. Standard/common properties (defined by common bindings, e.g. without >>> + vendor-prefixes) >>> +5. Vendor-specific properties >>> +6. status (if applicable) >>> +7. Child nodes, where each node is preceded with a blank line >>> + >>> +The "status" property is by default "okay", thus it can be omitted. >>> + >>> +Example:: >>> + >>> + // SoC DTSI >>> + >>> + usb_1_hsphy: phy@88e3000 { >>> + compatible = "qcom,sm8550-snps-eusb2-phy"; >>> + reg = <0x0 0x088e3000 0x0 0x154>; >>> + #phy-cells = <0>; >>> + resets = <&gcc GCC_QUSB2PHY_PRIM_BCR>; >>> + status = "disabled"; >>> + }; >> >> Since this describes vendor-specific properties and vendor prefixes as well >> as standard properties, I think it would be clearer if we use something more >> complex that actually contains those as an example. >> >> There's a few. One is MediaTek: >> >> vdo1_rdma0: dma-controller@1c104000 { >> compatible = "mediatek,mt8195-vdo1-rdma"; >> reg = <0 0x1c104000 0 0x1000>; >> #dma-cells = <1>; >> clocks = <&vdosys1 CLK_VDO1_MDP_RDMA0>; >> interrupts = ; >> iommus = <&iommu_vdo M4U_PORT_L2_MDP_RDMA0>; >> power-domains = <&spm MT8195_POWER_DOMAIN_VDOSYS1>; >> mediatek,gce-client-reg = <&gce0 SUBSYS_1c10XXXX 0x4000 0x1000>; >> }; >> >> ...or other one can be nVidia: >> >> mipi: mipi@700e3000 { >> compatible = "nvidia,tegra210-mipi"; >> reg = <0x0 0x700e3000 0x0 0x100>; >> clocks = <&tegra_car TEGRA210_CLK_MIPI_CAL>; >> clock-names = "mipi-cal"; >> power-domains = <&pd_sor>; >> #nvidia,mipi-calibrate-cells = <1>; >> }; >> >> ...or we could make an example out of fantasy, which could work even better >> as far as describing goes. >> >> /* SoC DTSI */ >> >> device_node: device-class@6789abc { >> compatible = "vendor,device"; > > Yep. I'll use this, unless checkpatch complains about undocumented > compatible. :) This allows to show the child node. > If checkpatch complains about undocumented compatible, could we perhaps use one that does actually exist, while still retaining the actual mockup examples? I understand the eventual concern about somewhat wrongly documenting said device, but it's also true that this is documentation about something else that is not related to a specific device (so perhaps a "warning: this is for representation purposes only, and may contain properties that the devices pointed by the currently used compatible string may not accept" might work to avoid confusion?). >> reg = <0 0x06789abc 0 0xa123>; >> ranges = <0 0 0x6789abc 0x1000>; >> #dma-cells = <1>; >> clocks = <&clock_controller SOC_CLOCK>; >> clock-names = "dev-clk"; >> #vendor,custom-cells = <2>; >> status = "disabled"; >> >> child_node: child-class@100 { >> reg = <0x100 0x200>; >> /* ... */ >> }; >> }; >> >> /* Board DTS */ >> >> &device_node { >> device-supply = <&board_vreg1>; >> status = "okay"; >> } >> >>> + >>> + // Board DTS >>> + >>> + &usb_1_hsphy { >>> + clocks = <&tcsr TCSR_USB2_CLKREF_EN>; >>> + clock-names = "ref"; >>> + status = "okay"; >>> + }; >>> + >>> + >>> +Indentation >>> +----------- >>> + >>> +1. Use indentation according to :ref:`codingstyle`. >>> +2. For arrays spanning across lines, it is preferred to align the continued >>> + entries with opening < from the first line. >>> +3. Each entry in arrays with multiple cells (e.g. "reg" with two IO addresses) >>> + should be enclosed in <>. >>> + >>> +Example:: >>> + >>> + thermal-sensor@c271000 { >>> + compatible = "qcom,sm8550-tsens", "qcom,tsens-v2"; >>> + reg = <0x0 0x0c271000 0x0 0x1000>, >>> + <0x0 0x0c222000 0x0 0x1000>; >>> + }; >>> + >>> +Organizing DTSI and DTSthat >>> +----------------------- >>> + >>> +The DTSI and DTS files should be organized in a way representing the common >>> +(and re-usable) parts of the hardware. Typically this means organizing DTSI >> >> ^^^^ >> There's a double space here, it was probably unintentional. > > I think I used everywhere double-spaces. At least this was my intention, > so I will fix single-spaces :) > Oh! Okay, yeah, that also works :-D Cheers, Angelo