Merge tag 'block-6.13-20242901' of git://git.kernel.dk/linux
[drm/drm-misc.git] / Documentation / devicetree / bindings / dts-coding-style.rst
blob8a68331075a098ab8f0a1fece9525c7a2f7d6ddc
1 .. SPDX-License-Identifier: GPL-2.0
3 =====================================
4 Devicetree Sources (DTS) Coding Style
5 =====================================
7 When writing Devicetree Sources (DTS) please observe below guidelines.  They
8 should be considered complementary to any rules expressed already in
9 the Devicetree Specification and the dtc compiler (including W=1 and W=2
10 builds).
12 Individual architectures and subarchitectures can define additional rules,
13 making the coding style stricter.
15 Naming and Valid Characters
16 ---------------------------
18 The Devicetree Specification allows a broad range of characters in node
19 and property names, but this coding style narrows the range down to achieve
20 better code readability.
22 1. Node and property names can use only the following characters:
24    * Lowercase characters: [a-z]
25    * Digits: [0-9]
26    * Dash: -
28 2. Labels can use only the following characters:
30    * Lowercase characters: [a-z]
31    * Digits: [0-9]
32    * Underscore: _
34 3. Unless a bus defines differently, unit addresses shall use lowercase
35    hexadecimal digits, without leading zeros (padding).
37 4. Hex values in properties, e.g. "reg", shall use lowercase hex.  The address
38    part can be padded with leading zeros.
40 Example::
42         gpi_dma2: dma-controller@a00000 {
43                 compatible = "qcom,sm8550-gpi-dma", "qcom,sm6350-gpi-dma";
44                 reg = <0x0 0x00a00000 0x0 0x60000>;
45         }
47 Order of Nodes
48 --------------
50 1. Nodes on any bus, thus using unit addresses for children, shall be
51    ordered by unit address in ascending order.
52    Alternatively for some subarchitectures, nodes of the same type can be
53    grouped together, e.g. all I2C controllers one after another even if this
54    breaks unit address ordering.
56 2. Nodes without unit addresses shall be ordered alpha-numerically by the node
57    name.  For a few node types, they can be ordered by the main property, e.g.
58    pin configuration states ordered by value of "pins" property.
60 3. When extending nodes in the board DTS via &label, the entries shall be
61    ordered either alpha-numerically or by keeping the order from DTSI, where
62    the choice depends on the subarchitecture.
64 The above-described ordering rules are easy to enforce during review, reduce
65 chances of conflicts for simultaneous additions of new nodes to a file and help
66 in navigating through the DTS source.
68 Example::
70         /* SoC DTSI */
72         / {
73                 cpus {
74                         /* ... */
75                 };
77                 psci {
78                         /* ... */
79                 };
81                 soc@0 {
82                         dma: dma-controller@10000 {
83                                 /* ... */
84                         };
86                         clk: clock-controller@80000 {
87                                 /* ... */
88                         };
89                 };
90         };
92         /* Board DTS - alphabetical order */
94         &clk {
95                 /* ... */
96         };
98         &dma {
99                 /* ... */
100         };
102         /* Board DTS - alternative order, keep as DTSI */
104         &dma {
105                 /* ... */
106         };
108         &clk {
109                 /* ... */
110         };
112 Order of Properties in Device Node
113 ----------------------------------
115 The following order of properties in device nodes is preferred:
117 1. "compatible"
118 2. "reg"
119 3. "ranges"
120 4. Standard/common properties (defined by common bindings, e.g. without
121    vendor-prefixes)
122 5. Vendor-specific properties
123 6. "status" (if applicable)
124 7. Child nodes, where each node is preceded with a blank line
126 The "status" property is by default "okay", thus it can be omitted.
128 The above-described ordering follows this approach:
130 1. Most important properties start the node: compatible then bus addressing to
131    match unit address.
132 2. Each node will have common properties in similar place.
133 3. Status is the last information to annotate that device node is or is not
134    finished (board resources are needed).
136 Example::
138         /* SoC DTSI */
140         device_node: device-class@6789abc {
141                 compatible = "vendor,device";
142                 reg = <0x0 0x06789abc 0x0 0xa123>;
143                 ranges = <0x0 0x0 0x06789abc 0x1000>;
144                 #dma-cells = <1>;
145                 clocks = <&clock_controller 0>, <&clock_controller 1>;
146                 clock-names = "bus", "host";
147                 #address-cells = <1>;
148                 #size-cells = <1>;
149                 vendor,custom-property = <2>;
150                 status = "disabled";
152                 child_node: child-class@100 {
153                         reg = <0x100 0x200>;
154                         /* ... */
155                 };
156         };
158         /* Board DTS */
160         &device_node {
161                 vdd-supply = <&board_vreg1>;
162                 status = "okay";
163         }
165 Indentation
166 -----------
168 1. Use indentation according to Documentation/process/coding-style.rst.
169 2. Each entry in arrays with multiple cells, e.g. "reg" with two IO addresses,
170    shall be enclosed in <>.
171 3. For arrays spanning across lines, it is preferred to align the continued
172    entries with opening < from the first line.
174 Example::
176         thermal-sensor@c271000 {
177                 compatible = "qcom,sm8550-tsens", "qcom,tsens-v2";
178                 reg = <0x0 0x0c271000 0x0 0x1000>,
179                       <0x0 0x0c222000 0x0 0x1000>;
180         };
182 Organizing DTSI and DTS
183 -----------------------
185 The DTSI and DTS files shall be organized in a way representing the common,
186 reusable parts of hardware.  Typically, this means organizing DTSI and DTS files
187 into several files:
189 1. DTSI with contents of the entire SoC, without nodes for hardware not present
190    on the SoC.
191 2. If applicable: DTSI with common or re-usable parts of the hardware, e.g.
192    entire System-on-Module.
193 3. DTS representing the board.
195 Hardware components that are present on the board shall be placed in the
196 board DTS, not in the SoC or SoM DTSI.  A partial exception is a common
197 external reference SoC input clock, which could be coded as a fixed-clock in
198 the SoC DTSI with its frequency provided by each board DTS.