1.. _dt-bindings-file-syntax: 2 3Devicetree bindings syntax 4########################## 5 6This page documents the syntax of Zephyr's bindings format. Zephyr bindings 7files are YAML files. A :ref:`simple example <dt-bindings-simple-example>` was 8given in the introduction page. 9 10.. contents:: Contents 11 :local: 12 :depth: 3 13 14Top level keys 15************** 16 17The top level of a bindings file maps keys to values. The top-level keys look 18like this: 19 20.. code-block:: yaml 21 22 # A high level description of the device the binding applies to: 23 description: | 24 This is the Vendomatic company's foo-device. 25 26 Descriptions which span multiple lines (like this) are OK, 27 and are encouraged for complex bindings. 28 29 See https://yaml-multiline.info/ for formatting help. 30 31 # You can include definitions from other bindings using this syntax: 32 include: other.yaml 33 34 # Used to match nodes to this binding: 35 compatible: "manufacturer,foo-device" 36 37 properties: 38 # Requirements for and descriptions of the properties that this 39 # binding's nodes need to satisfy go here. 40 41 child-binding: 42 # You can constrain the children of the nodes matching this binding 43 # using this key. 44 45 # If the node describes bus hardware, like an SPI bus controller 46 # on an SoC, use 'bus:' to say which one, like this: 47 bus: spi 48 49 # If the node instead appears as a device on a bus, like an external 50 # SPI memory chip, use 'on-bus:' to say what type of bus, like this. 51 # Like 'compatible', this key also influences the way nodes match 52 # bindings. 53 on-bus: spi 54 55 foo-cells: 56 # "Specifier" cell names for the 'foo' domain go here; example 'foo' 57 # values are 'gpio', 'pwm', and 'dma'. See below for more information. 58 59These keys are explained in the following sections. 60 61.. _dt-bindings-description: 62 63Description 64*********** 65 66A free-form description of node hardware goes here. You can put links to 67datasheets or example nodes or properties as well. 68 69.. _dt-bindings-compatible: 70 71Compatible 72********** 73 74This key is used to match nodes to this binding as described in 75:ref:`dt-binding-compat`. It should look like this in a binding file: 76 77.. code-block:: YAML 78 79 # Note the comma-separated vendor prefix and device name 80 compatible: "manufacturer,device" 81 82This devicetree node would match the above binding: 83 84.. code-block:: devicetree 85 86 device { 87 compatible = "manufacturer,device"; 88 }; 89 90Assuming no binding has ``compatible: "manufacturer,device-v2"``, it would also 91match this node: 92 93.. code-block:: devicetree 94 95 device-2 { 96 compatible = "manufacturer,device-v2", "manufacturer,device"; 97 }; 98 99Each node's ``compatible`` property is tried in order. The first matching 100binding is used. The :ref:`on-bus: <dt-bindings-on-bus>` key can be used to 101refine the search. 102 103If more than one binding for a compatible is found, an error is raised. 104 105The ``manufacturer`` prefix identifies the device vendor. See 106:zephyr_file:`dts/bindings/vendor-prefixes.txt` for a list of accepted vendor 107prefixes. The ``device`` part is usually from the datasheet. 108 109Some bindings apply to a generic class of devices which do not have a specific 110vendor. In these cases, there is no vendor prefix. One example is the 111:dtcompatible:`gpio-leds` compatible which is commonly used to describe board 112LEDs connected to GPIOs. 113 114.. _dt-bindings-properties: 115 116Properties 117********** 118 119The ``properties:`` key describes properties that nodes which match the binding 120contain. For example, a binding for a UART peripheral might look something like 121this: 122 123.. code-block:: YAML 124 125 compatible: "manufacturer,serial" 126 127 properties: 128 reg: 129 type: array 130 description: UART peripheral MMIO register space 131 required: true 132 current-speed: 133 type: int 134 description: current baud rate 135 required: true 136 137In this example, a node with compatible ``"manufacturer,serial"`` must contain 138a property named ``current-speed``. The property's value must be a single 139integer. Similarly, the node must contain a ``reg`` property. 140 141The build system uses bindings to generate C macros for devicetree properties 142that appear in DTS files. You can read more about how to get property values in 143source code from these macros in :ref:`dt-from-c`. Generally speaking, the 144build system only generates macros for properties listed in the ``properties:`` 145key for the matching binding. Properties not mentioned in the binding are 146generally ignored by the build system. 147 148The one exception is that the build system will always generate macros for 149standard properties, like :ref:`reg <dt-important-props>`, whose meaning is 150defined by the devicetree specification. This happens regardless of whether the 151node has a matching binding or not. 152 153Property entry syntax 154===================== 155 156Property entries in ``properties:`` are written in this syntax: 157 158.. code-block:: none 159 160 <property name>: 161 required: <true | false> 162 type: <string | int | boolean | array | uint8-array | string-array | 163 phandle | phandles | phandle-array | path | compound> 164 deprecated: <true | false> 165 default: <default> 166 description: <description of the property> 167 enum: 168 - <item1> 169 - <item2> 170 ... 171 - <itemN> 172 const: <string | int | array | uint8-array | string-array> 173 specifier-space: <space-name> 174 175.. _dt-bindings-example-properties: 176 177Example property definitions 178============================ 179 180Here are some more examples. 181 182.. code-block:: YAML 183 184 properties: 185 # Describes a property like 'current-speed = <115200>;'. We pretend that 186 # it's obligatory for the example node and set 'required: true'. 187 current-speed: 188 type: int 189 required: true 190 description: Initial baud rate for bar-device 191 192 # Describes an optional property like 'keys = "foo", "bar";' 193 keys: 194 type: string-array 195 description: Keys for bar-device 196 197 # Describes an optional property like 'maximum-speed = "full-speed";' 198 # the enum specifies known values that the string property may take 199 maximum-speed: 200 type: string 201 description: Configures USB controllers to work up to a specific speed. 202 enum: 203 - "low-speed" 204 - "full-speed" 205 - "high-speed" 206 - "super-speed" 207 208 # Describes an optional property like 'resolution = <16>;' 209 # the enum specifies known values that the int property may take 210 resolution: 211 type: int 212 enum: 213 - 8 214 - 16 215 - 24 216 - 32 217 218 # Describes a required property '#address-cells = <1>'; the const 219 # specifies that the value for the property is expected to be the value 1 220 "#address-cells": 221 type: int 222 required: true 223 const: 1 224 225 int-with-default: 226 type: int 227 default: 123 228 description: Value for int register, default is power-up configuration. 229 230 array-with-default: 231 type: array 232 default: [1, 2, 3] # Same as 'array-with-default = <1 2 3>' 233 234 string-with-default: 235 type: string 236 default: "foo" 237 238 string-array-with-default: 239 type: string-array 240 default: ["foo", "bar"] # Same as 'string-array-with-default = "foo", "bar"' 241 242 uint8-array-with-default: 243 type: uint8-array 244 default: [0x12, 0x34] # Same as 'uint8-array-with-default = [12 34]' 245 246required 247======== 248 249Adding ``required: true`` to a property definition will fail the build if a 250node matches the binding, but does not contain the property. 251 252The default setting is ``required: false``; that is, properties are optional by 253default. Using ``required: false`` is therefore redundant and strongly 254discouraged. 255 256type 257==== 258 259The type of a property constrains its values. The following types are 260available. See :ref:`dt-writing-property-values` for more details about writing 261values of each type in a DTS file. See :ref:`dt-phandles` for more information 262about the ``phandle*`` type properties. 263 264.. list-table:: 265 :header-rows: 1 266 :widths: 1 3 2 267 268 * - Type 269 - Description 270 - Example in DTS 271 272 * - ``string`` 273 - exactly one string 274 - ``status = "disabled";`` 275 276 * - ``int`` 277 - exactly one 32-bit value (cell) 278 - ``current-speed = <115200>;`` 279 280 * - ``boolean`` 281 - flags that don't take a value when true, and are absent if false 282 - ``hw-flow-control;`` 283 284 * - ``array`` 285 - zero or more 32-bit values (cells) 286 - ``offsets = <0x100 0x200 0x300>;`` 287 288 * - ``uint8-array`` 289 - zero or more bytes, in hex ('bytestring' in the Devicetree specification) 290 - ``local-mac-address = [de ad be ef 12 34];`` 291 292 * - ``string-array`` 293 - zero or more strings 294 - ``dma-names = "tx", "rx";`` 295 296 * - ``phandle`` 297 - exactly one phandle 298 - ``interrupt-parent = <&gic>;`` 299 300 * - ``phandles`` 301 - zero or more phandles 302 - ``pinctrl-0 = <&usart2_tx_pd5 &usart2_rx_pd6>;`` 303 304 * - ``phandle-array`` 305 - a list of phandles and 32-bit cells (usually specifiers) 306 - ``dmas = <&dma0 2>, <&dma0 3>;`` 307 308 * - ``path`` 309 - a path to a node as a phandle path reference or path string 310 - ``zephyr,bt-c2h-uart = &uart0;`` or 311 ``foo = "/path/to/some/node";`` 312 313 * - ``compound`` 314 - a catch-all for more complex types (no macros will be generated) 315 - ``foo = <&label>, [01 02];`` 316 317deprecated 318========== 319 320A property with ``deprecated: true`` indicates to both the user and the tooling 321that the property is meant to be phased out. 322 323The tooling will report a warning if the devicetree includes the property that 324is flagged as deprecated. (This warning is upgraded to an error in the 325:ref:`twister_script` for upstream pull requests.) 326 327The default setting is ``deprecated: false``. Using ``deprecated: false`` is 328therefore redundant and strongly discouraged. 329 330.. _dt-bindings-default: 331 332default 333======= 334 335The optional ``default:`` setting gives a value that will be used if the 336property is missing from the devicetree node. 337 338For example, with this binding fragment: 339 340.. code-block:: YAML 341 342 properties: 343 foo: 344 type: int 345 default: 3 346 347If property ``foo`` is missing in a matching node, then the output will be as 348if ``foo = <3>;`` had appeared in the DTS (except YAML data types are used for 349the default value). 350 351Note that combining ``default:`` with ``required: true`` will raise an error. 352 353For rules related to ``default`` in upstream Zephyr bindings, see 354:ref:`dt-bindings-default-rules`. 355 356See :ref:`dt-bindings-example-properties` for examples. Putting ``default:`` on 357any property type besides those used in :ref:`dt-bindings-example-properties` 358will raise an error. 359 360enum 361==== 362 363The ``enum:`` line is followed by a list of values the property may contain. If 364a property value in DTS is not in the ``enum:`` list in the binding, an error 365is raised. See :ref:`dt-bindings-example-properties` for examples. 366 367const 368===== 369 370This specifies a constant value the property must take. It is mainly useful for 371constraining the values of common properties for a particular piece of 372hardware. 373 374.. _dt-bindings-specifier-space: 375 376specifier-space 377=============== 378 379.. warning:: 380 381 It is an abuse of this feature to use it to name properties in 382 unconventional ways. 383 384 For example, this feature is not meant for cases like naming a property 385 ``my-pin``, then assigning it to the "gpio" specifier space using this 386 feature. Properties which refer to GPIOs should use conventional names, i.e. 387 end in ``-gpios`` or ``-gpio``. 388 389This property, if present, manually sets the specifier space associated with a 390property with type ``phandle-array``. 391 392Normally, the specifier space is encoded implicitly in the property name. A 393property named ``foos`` with type ``phandle-array`` implicitly has specifier 394space ``foo``. As a special case, ``*-gpios`` properties have specifier space 395"gpio", so that ``foo-gpios`` will have specifier space "gpio" rather than 396"foo-gpio". 397 398You can use ``specifier-space`` to manually provide a space if 399using this convention would result in an awkward or unconventional name. 400 401For example: 402 403.. code-block:: YAML 404 405 compatible: ... 406 properties: 407 bar: 408 type: phandle-array 409 specifier-space: my-custom-space 410 411Above, the ``bar`` property's specifier space is set to "my-custom-space". 412 413You could then use the property in a devicetree like this: 414 415.. code-block:: DTS 416 417 controller1: custom-controller@1000 { 418 #my-custom-space-cells = <2>; 419 }; 420 421 controller2: custom-controller@2000 { 422 #my-custom-space-cells = <1>; 423 }; 424 425 my-node { 426 bar = <&controller1 10 20>, <&controller2 30>; 427 }; 428 429Generally speaking, you should reserve this feature for cases where the 430implicit specifier space naming convention doesn't work. One appropriate 431example is an ``mboxes`` property with specifier space "mbox", not "mboxe". You 432can write this property as follows: 433 434.. code-block:: YAML 435 436 properties: 437 mboxes: 438 type: phandle-array 439 specifier-space: mbox 440 441.. _dt-bindings-child: 442 443Child-binding 444************* 445 446``child-binding`` can be used when a node has children that all share the same 447properties. Each child gets the contents of ``child-binding`` as its binding, 448though an explicit ``compatible = ...`` on the child node takes precedence, if 449a binding is found for it. 450 451Consider a binding for a PWM LED node like this one, where the child nodes are 452required to have a ``pwms`` property: 453 454.. code-block:: devicetree 455 456 pwmleds { 457 compatible = "pwm-leds"; 458 459 red_pwm_led { 460 pwms = <&pwm3 4 15625000>; 461 }; 462 green_pwm_led { 463 pwms = <&pwm3 0 15625000>; 464 }; 465 /* ... */ 466 }; 467 468The binding would look like this: 469 470.. code-block:: YAML 471 472 compatible: "pwm-leds" 473 474 child-binding: 475 description: LED that uses PWM 476 477 properties: 478 pwms: 479 type: phandle-array 480 required: true 481 482``child-binding`` also works recursively. For example, this binding: 483 484.. code-block:: YAML 485 486 compatible: foo 487 488 child-binding: 489 child-binding: 490 properties: 491 my-property: 492 type: int 493 required: true 494 495will apply to the ``grandchild`` node in this DTS: 496 497.. code-block:: devicetree 498 499 parent { 500 compatible = "foo"; 501 child { 502 grandchild { 503 my-property = <123>; 504 }; 505 }; 506 }; 507 508.. _dt-bindings-bus: 509 510Bus 511*** 512 513If the node is a bus controller, use ``bus:`` in the binding to say what type 514of bus. For example, a binding for a SPI peripheral on an SoC would look like 515this: 516 517.. code-block:: YAML 518 519 compatible: "manufacturer,spi-peripheral" 520 bus: spi 521 # ... 522 523The presence of this key in the binding informs the build system that the 524children of any node matching this binding appear on this type of bus. 525 526This in turn influences the way ``on-bus:`` is used to match bindings for the 527child nodes. 528 529For a single bus supporting multiple protocols, e.g. I3C and I2C, the ``bus:`` 530in the binding can have a list as value: 531 532.. code-block:: YAML 533 534 compatible: "manufacturer,i3c-controller" 535 bus: [i3c, i2c] 536 # ... 537 538.. _dt-bindings-on-bus: 539 540On-bus 541****** 542 543If the node appears as a device on a bus, use ``on-bus:`` in the binding to say 544what type of bus. 545 546For example, a binding for an external SPI memory chip should include this line: 547 548.. code-block:: YAML 549 550 on-bus: spi 551 552And a binding for an I2C based temperature sensor should include this line: 553 554.. code-block:: YAML 555 556 on-bus: i2c 557 558When looking for a binding for a node, the build system checks if the binding 559for the parent node contains ``bus: <bus type>``. If it does, then only 560bindings with a matching ``on-bus: <bus type>`` and bindings without an 561explicit ``on-bus`` are considered. Bindings with an explicit ``on-bus: <bus 562type>`` are searched for first, before bindings without an explicit ``on-bus``. 563The search repeats for each item in the node's ``compatible`` property, in 564order. 565 566This feature allows the same device to have different bindings depending on 567what bus it appears on. For example, consider a sensor device with compatible 568``manufacturer,sensor`` which can be used via either I2C or SPI. 569 570The sensor node may therefore appear in the devicetree as a child node of 571either an SPI or an I2C controller, like this: 572 573.. code-block:: devicetree 574 575 spi-bus@0 { 576 /* ... some compatible with 'bus: spi', etc. ... */ 577 578 sensor@0 { 579 compatible = "manufacturer,sensor"; 580 reg = <0>; 581 /* ... */ 582 }; 583 }; 584 585 i2c-bus@0 { 586 /* ... some compatible with 'bus: i2c', etc. ... */ 587 588 sensor@79 { 589 compatible = "manufacturer,sensor"; 590 reg = <79>; 591 /* ... */ 592 }; 593 }; 594 595You can write two separate binding files which match these individual sensor 596nodes, even though they have the same compatible: 597 598.. code-block:: YAML 599 600 # manufacturer,sensor-spi.yaml, which matches sensor@0 on the SPI bus: 601 compatible: "manufacturer,sensor" 602 on-bus: spi 603 604 # manufacturer,sensor-i2c.yaml, which matches sensor@79 on the I2C bus: 605 compatible: "manufacturer,sensor" 606 properties: 607 uses-clock-stretching: 608 type: boolean 609 on-bus: i2c 610 611Only ``sensor@79`` can have a ``use-clock-stretching`` property. The 612bus-sensitive logic ignores :file:`manufacturer,sensor-i2c.yaml` when searching 613for a binding for ``sensor@0``. 614 615.. _dt-bindings-cells: 616 617Specifier cell names (\*-cells) 618******************************* 619 620This section documents how to name the cells in a specifier within a binding. 621These concepts are discussed in detail later in this guide in 622:ref:`dt-phandle-arrays`. 623 624Consider a binding for a node whose phandle may appear in a ``phandle-array`` 625property, like the PWM controllers ``pwm1`` and ``pwm2`` in this example: 626 627.. code-block:: DTS 628 629 pwm1: pwm@deadbeef { 630 compatible = "foo,pwm"; 631 #pwm-cells = <2>; 632 }; 633 634 pwm2: pwm@deadbeef { 635 compatible = "bar,pwm"; 636 #pwm-cells = <1>; 637 }; 638 639 my-node { 640 pwms = <&pwm1 1 2000>, <&pwm2 3000>; 641 }; 642 643The bindings for compatible ``"foo,pwm"`` and ``"bar,pwm"`` must give a name to 644the cells that appear in a PWM specifier using ``pwm-cells:``, like this: 645 646.. code-block:: YAML 647 648 # foo,pwm.yaml 649 compatible: "foo,pwm" 650 ... 651 pwm-cells: 652 - channel 653 - period 654 655 # bar,pwm.yaml 656 compatible: "bar,pwm" 657 ... 658 pwm-cells: 659 - period 660 661A ``*-names`` (e.g. ``pwm-names``) property can appear on the node as well, 662giving a name to each entry. 663 664This allows the cells in the specifiers to be accessed by name, e.g. using APIs 665like :c:macro:`DT_PWMS_CHANNEL_BY_NAME`. 666 667If the specifier is empty (e.g. ``#clock-cells = <0>``), then ``*-cells`` can 668either be omitted (recommended) or set to an empty array. Note that an empty 669array is specified as e.g. ``clock-cells: []`` in YAML. 670 671.. _dt-bindings-include: 672 673Include 674******* 675 676Bindings can include other files, which can be used to share common property 677definitions between bindings. Use the ``include:`` key for this. Its value is 678either a string or a list. 679 680In the simplest case, you can include another file by giving its name as a 681string, like this: 682 683.. code-block:: YAML 684 685 include: foo.yaml 686 687If any file named :file:`foo.yaml` is found (see 688:ref:`dt-where-bindings-are-located` for the search process), it will be 689included into this binding. 690 691Included files are merged into bindings with a simple recursive dictionary 692merge. The build system will check that the resulting merged binding is 693well-formed. It is allowed to include at any level, including ``child-binding``, 694like this: 695 696.. code-block:: YAML 697 698 # foo.yaml will be merged with content at this level 699 include: foo.yaml 700 701 child-binding: 702 # bar.yaml will be merged with content at this level 703 include: bar.yaml 704 705It is an error if a key appears with a different value in a binding and in a 706file it includes, with one exception: a binding can have ``required: true`` for 707a :ref:`property definition <dt-bindings-properties>` for which the included 708file has ``required: false``. The ``required: true`` takes precedence, allowing 709bindings to strengthen requirements from included files. 710 711Note that weakening requirements by having ``required: false`` where the 712included file has ``required: true`` is an error. This is meant to keep the 713organization clean. 714 715The file :zephyr_file:`base.yaml <dts/bindings/base/base.yaml>` contains 716definitions for many common properties. When writing a new binding, it is a 717good idea to check if :file:`base.yaml` already defines some of the needed 718properties, and include it if it does. 719 720Note that you can make a property defined in base.yaml obligatory like this, 721taking :ref:`reg <dt-important-props>` as an example: 722 723.. code-block:: YAML 724 725 reg: 726 required: true 727 728This relies on the dictionary merge to fill in the other keys for ``reg``, like 729``type``. 730 731To include multiple files, you can use a list of strings: 732 733.. code-block:: YAML 734 735 include: 736 - foo.yaml 737 - bar.yaml 738 739This includes the files :file:`foo.yaml` and :file:`bar.yaml`. (You can 740write this list in a single line of YAML as ``include: [foo.yaml, bar.yaml]``.) 741 742When including multiple files, any overlapping ``required`` keys on properties 743in the included files are ORed together. This makes sure that a ``required: 744true`` is always respected. 745 746In some cases, you may want to include some property definitions from a file, 747but not all of them. In this case, ``include:`` should be a list, and you can 748filter out just the definitions you want by putting a mapping in the list, like 749this: 750 751.. code-block:: YAML 752 753 include: 754 - name: foo.yaml 755 property-allowlist: 756 - i-want-this-one 757 - and-this-one 758 - name: bar.yaml 759 property-blocklist: 760 - do-not-include-this-one 761 - or-this-one 762 763Each map element must have a ``name`` key which is the filename to include, and 764may have ``property-allowlist`` and ``property-blocklist`` keys that filter 765which properties are included. 766 767You cannot have a single map element with both ``property-allowlist`` and 768``property-blocklist`` keys. A map element with neither ``property-allowlist`` 769nor ``property-blocklist`` is valid; no additional filtering is done. 770 771You can freely intermix strings and mappings in a single ``include:`` list: 772 773.. code-block:: YAML 774 775 include: 776 - foo.yaml 777 - name: bar.yaml 778 property-blocklist: 779 - do-not-include-this-one 780 - or-this-one 781 782Finally, you can filter from a child binding like this: 783 784.. code-block:: YAML 785 786 include: 787 - name: bar.yaml 788 child-binding: 789 property-allowlist: 790 - child-prop-to-allow 791 792Nexus nodes and maps 793******************** 794 795All ``phandle-array`` type properties support mapping through ``*-map`` 796properties, e.g. ``gpio-map``, as defined by the Devicetree specification. 797 798This is used, for example, to define connector nodes for common breakout 799headers, such as the ``arduino_header`` nodes that are conventionally defined 800in the devicetrees for boards with Arduino compatible expansion headers. 801