Received: by 2002:a05:622a:4ca:b0:41c:c224:f26f with SMTP id q10csp517245qtx; Thu, 16 Nov 2023 10:12:35 -0800 (PST) X-Google-Smtp-Source: AGHT+IHhz+8WA8BBbp9NZ8XQNpA/p9KlgoO6uA+OTSfmELdEP18dPTco7ZvMdOQdT4476D+hXTLa X-Received: by 2002:a05:6a20:4326:b0:181:b044:449e with SMTP id h38-20020a056a20432600b00181b044449emr15531693pzk.54.1700158354680; Thu, 16 Nov 2023 10:12:34 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1700158354; cv=none; d=google.com; s=arc-20160816; b=o1d8ORyCNk1tJDhvR+b7d/HmLooFeTHbgsNZYZUZgwJD9rE3Ml/h0o4sw5GURoIuhI xpcQ9gNLQ1zl8Af7dPJ3l4AaZG4VN1x8lYXUJ/vXrbZpOgD5t2HTPpYSvnfdjrZKZjyX KxMCjXsm7t3E23kkFlTX3sLZe2Pn4DeNQ2r30d4lejHi9pjUuEePz5oP1lstyz+4hA7v Klos+ZaW7rqlAar8EBXGu9PGGK1KFMXGdcUSoL2RV/Ubqb0SJ0p4oTQheL33+E0gA4YG FmIuSLpwo4849hgoX8Vs16fyIcApT6bJ3VLZoMcJaEqDd28MVc/djbc3J4zklYjDqdRP DE9Q== 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 :message-id:date:subject:cc:to:from:dkim-signature; bh=qsPp3Fy1desywxNmmnzNYZYsXy6qDHsAAEUlLMwI4gw=; fh=WH9mNsJARTnJcdvmsiEqwvVaEAT83OgyZuVgYB+6y2A=; b=qFYAeRcunkuToTqUeTJjRlaPMXaSTu5Y/AG7JPoqkUiSD0YDUIfjORRxxMxpUkbPku aT5ww7Ib3rf4Zo847OTtAr3lEmX55b6XkhcC06fnIZnokbfzhcvL/q1V4t0UVmnWlAYV ypG0SbEO1q/yA7xipRSdwGjPJo2LeFNR7LB5g2lmfU7B/HWWfUFYmUsBj1wcO8EkBdgZ HKqEgevonbyxDF4L2GuTpnCpb5+4hBdh73lqbfmo52Qn+tNpqAu4z3iCt8/adkJiLJdB Mpc+rzS/nUNvpDZWfgSESzvSm/WXI3ubhIeJfOWJ6o1e1z2ROk3GsT4dadyHIO4Odhda mLyg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b="DY7/6Zww"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.37 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from snail.vger.email (snail.vger.email. [23.128.96.37]) by mx.google.com with ESMTPS id n2-20020a1709026a8200b001ce1605fcb9si12193556plk.540.2023.11.16.10.12.33 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 16 Nov 2023 10:12:34 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.37 as permitted sender) client-ip=23.128.96.37; Authentication-Results: mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b="DY7/6Zww"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.37 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by snail.vger.email (Postfix) with ESMTP id 1C04C81DC78E; Thu, 16 Nov 2023 10:12:33 -0800 (PST) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.11 at snail.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1345401AbjKPSMa (ORCPT + 99 others); Thu, 16 Nov 2023 13:12:30 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:42336 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231327AbjKPSM1 (ORCPT ); Thu, 16 Nov 2023 13:12:27 -0500 Received: from mail-qk1-x734.google.com (mail-qk1-x734.google.com [IPv6:2607:f8b0:4864:20::734]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id AA8F9D5D for ; Thu, 16 Nov 2023 10:12:22 -0800 (PST) Received: by mail-qk1-x734.google.com with SMTP id af79cd13be357-778a20df8c3so66719885a.3 for ; Thu, 16 Nov 2023 10:12:22 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; t=1700158342; x=1700763142; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:message-id:date:subject:cc :to:from:from:to:cc:subject:date:message-id:reply-to; bh=qsPp3Fy1desywxNmmnzNYZYsXy6qDHsAAEUlLMwI4gw=; b=DY7/6ZwwgPWrUqyXx4wamMC64sG+Lz4ucPWt66uTyG+AcjOvdO0ICEI9UIihs9IAxE aLa2pFgVq0bV61DsQmgDrTBg5wL33sfwZCkvlPE18G19NnOG2kSdtOTNp5tqaHCBdYIc E3nChv0X6tCbJ9U4dpS9DrlVtNiUKFZRcr7VcpC35B+SqGYvG1jqdv6NhB0YhPtJsK54 1H3plTCAZtBd4KniF9UqHiI4OU3p84TV+kLrrYbFn3DFwpWUMTFos3560Xsp7HLyp6IC t0nf0EPJU/sBcAG93jRsU6HAK8QSv4bRiJMoxaAgvsHgBwT7IWRMawAwBnTNtzcq7ymO fkqQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1700158342; x=1700763142; h=content-transfer-encoding:mime-version:message-id:date:subject:cc :to:from:x-gm-message-state:from:to:cc:subject:date:message-id :reply-to; bh=qsPp3Fy1desywxNmmnzNYZYsXy6qDHsAAEUlLMwI4gw=; b=eARUUHD+g7ZxtbPaleEkV3D37BhxOSvdrT4zSrX728rpFk/OXRpWx4Yzu34/h6eXHU uUwvJqxkEmF4w3YsNFaZTmCtmbebwYaydQVdfU8qkPbcuIqgdo6quuBA0hw8nTkk65hb I+BpI/J84iVw5bNHgeYMjTa/65EFGNqTjQ4FX6LQ8gQ7a/Ir4TuVWIxywfDRnCM9+7iE YCEBDH/XxD0ekjEomiGbuKGApcETFQEcgaoLHpKz8ecReX0gBAilXHp7fKpt72s9PdS0 Q9ak/wm05QhuC2N5e3XCS9Mq3ZnaHlcDC1dCdwmP65Q4O31/bUKwhGi4PUH4gNoVsBF6 l/cw== X-Gm-Message-State: AOJu0YyP2HljQSOGvTQflPgeSaHNDb4owpFH9Of2hGy6sWO10yio/1gx /L3fn156Dz26rBKLJDIWtikI9qhO2lbcEPn61dA= X-Received: by 2002:a05:620a:191b:b0:772:63d9:5264 with SMTP id bj27-20020a05620a191b00b0077263d95264mr5460176qkb.59.1700158341764; Thu, 16 Nov 2023 10:12:21 -0800 (PST) Received: from krzk-bin.. ([12.161.6.169]) by smtp.gmail.com with ESMTPSA id i8-20020a05620a0a0800b00774652483b7sm4461715qka.33.2023.11.16.10.12.20 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 16 Nov 2023 10:12:21 -0800 (PST) From: Krzysztof Kozlowski To: Rob Herring , Krzysztof Kozlowski , Conor Dooley , devicetree@vger.kernel.org, linux-kernel@vger.kernel.org Cc: Krzysztof Kozlowski , AngeloGioacchino Del Regno , Arnd Bergmann , Bjorn Andersson , Geert Uytterhoeven , Heiko Stuebner , Konrad Dybcio , Matthias Brugger , Michal Simek , Neil Armstrong , Nishanth Menon , Olof Johansson Subject: [PATCH] docs: dt-bindings: add DTS Coding Style document Date: Thu, 16 Nov 2023 19:12:18 +0100 Message-Id: <20231116181218.18886-1-krzysztof.kozlowski@linaro.org> X-Mailer: git-send-email 2.34.1 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_BLOCKED, 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: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (snail.vger.email [0.0.0.0]); Thu, 16 Nov 2023 10:12:33 -0800 (PST) Document preferred coding style for Devicetree sources (DTS and DTSI), to bring consistency among all (sub)architectures and ease in reviews. 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 --- Documentation/devicetree/bindings/index.rst | 1 + .../devicetree/bindings/writing-dts.rst | 137 ++++++++++++++++++ 2 files changed, 138 insertions(+) create mode 100644 Documentation/devicetree/bindings/writing-dts.rst diff --git a/Documentation/devicetree/bindings/index.rst b/Documentation/devicetree/bindings/index.rst index d9002a3a0abb..975449be4862 100644 --- a/Documentation/devicetree/bindings/index.rst +++ b/Documentation/devicetree/bindings/index.rst @@ -5,5 +5,6 @@ ABI writing-bindings + writing-dts writing-schema submitting-patches diff --git a/Documentation/devicetree/bindings/writing-dts.rst b/Documentation/devicetree/bindings/writing-dts.rst new file mode 100644 index 000000000000..10c477ec1eed --- /dev/null +++ b/Documentation/devicetree/bindings/writing-dts.rst @@ -0,0 +1,137 @@ +.. SPDX-License-Identifier: GPL-2.0 +.. _writingdts: + +=================================================== +Writing Devicetree Sources (DTS) - 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). + +4. Hex values in properties, e.g. "reg", should use lowercase hex. Any address + part can be padded with leading zeros. + +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. + +2. Nodes without unit addresses should be ordered alpha-numerically. + +3. When extending nodes in board DTS via &label, the entries should be ordered + alpha-numerically. + +Example:: + + // SoC DTSI + + \ { + 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. All properties with values +5. Boolean properties +6. status (if applicable) +7. Child nodes + +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"; + }; + + // 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, preferred is to align the continued + entries with opening < from first line. + +Example:: + + thermal-sensor@c271000 { + compatible = "qcom,sm8550-tsens", "qcom,tsens-v2"; + reg = <0x0 0x0c271000 0x0 0x1000>, + <0x0 0x0c222000 0x0 0x1000>; + }; -- 2.34.1