Lines Matching +full:specifier +full:- +full:space

1 .. _dt-phandles:
19 .. code-block:: DTS
22 lbl_a: node-1 {};
23 lbl_b: lbl_c: node-2 {};
28 - ``/node-1`` as ``&lbl_a``
29 - ``/node-2`` as either ``&lbl_b`` or ``&lbl_c``
40 :ref:`dt-bindings-properties` in the devicetree bindings documentation.
47 You can use phandles to refer to ``node-b`` from ``node-a``, where ``node-b``
48 is related to ``node-a`` in some way.
50 One common example is when ``node-a`` represents some hardware that
51 generates an interrupt, and ``node-b`` represents the interrupt
55 .. code-block:: DTS
57 node_b: node-b {
58 interrupt-controller;
61 node-a {
62 interrupt-parent = <&node_b>;
65 This uses the standard ``interrupt-parent`` property defined in the
75 One common example occurs in :ref:`pin control <pinctrl-guide>`. Pin control
76 properties like ``pinctrl-0``, ``pinctrl-1`` etc. may contain multiple
81 .. code-block:: DTS
83 pinctrl-0 = <&quadspi_clk_pe10 &quadspi_ncs_pe11
89 Zero or more nodes with metadata: phandle-array type
98 These properties have type ``phandle-array``.
100 .. _dt-phandle-arrays:
102 phandle-array properties
111 Usually, properties with this type are written like ``phandle-array-prop`` in
114 .. code-block:: dts
117 phandle-array-prop = <&foo 1 2>, <&bar 3>, <&baz 4 5>;
120 That is, the property's value is written as a comma-separated sequence of
131 the resource you are interested in. The specifier describes the resource
135 document more rules about how to use phandle-array properties in practice.
137 Example phandle-arrays: GPIOs
140 Perhaps the most common use case for phandle-array properties is specifying one
143 cases** that are handled in devicetree with phandle-array properties.
158 Instead, you would use a phandle-array property, like this:
160 .. code-block::
162 my-external-ic {
163 irq-gpios = <&gpioX pin flags>;
166 In this example, ``irq-gpios`` is a phandle-array property with just one
170 GPIO_PULL_UP)``); see :zephyr_file:`include/zephyr/dt-bindings/gpio/gpio.h` for
173 The device driver handling the ``my-external-ic`` node can then use the
174 ``irq-gpios`` property's value to set up interrupt handling for the chip as it
180 .. code-block::
182 my-other-external-ic {
183 handshake-gpios = <&gpioX pinX flagsX>, <&gpioY pinY flagsY>;
188 - ``pinX`` on the GPIO controller with phandle ``&gpioX``, flags ``flagsX``
189 - ``pinY`` on ``&gpioY``, flags ``flagsY``
193 specifier spaces before moving on to some information about devicetree
196 .. _dt-specifier-spaces:
198 Specifier spaces
201 *Specifier spaces* are a way to allow nodes to describe how you should
202 use them in phandle-array properties.
204 We'll start with an abstract, high level description of how specifier spaces
212 As described above, a phandle-array property is a sequence of "groups" of
215 .. code-block:: dts
218 phandle-array-prop = <&foo 1 2>, <&bar 3>;
221 The cells that follow each phandle are called a *specifier*. In this example,
227 Every phandle-array property has an associated *specifier space*. This sounds
229 follow each phandle in a hardware specific way. Every specifier space has a
233 Devicetree nodes encode the number of cells that must appear in a specifier, by
234 name, using the ``#SPACE_NAME-cells`` property. For example, let's assume that
235 ``phandle-array-prop``\ 's specifier space is named ``baz``. Then we would need
236 the ``foo`` and ``bar`` nodes to have the following ``#baz-cells`` properties:
238 .. code-block:: DTS
241 #baz-cells = <2>;
245 #baz-cells = <1>;
248 Without the ``#baz-cells`` property, the devicetree tooling would not be able
249 to validate the number of cells in each specifier in ``phandle-array-prop``.
255 A single node can also have different numbers of cells in different specifier
258 .. code-block:: DTS
261 #baz-cells = <2>;
262 #bob-cells = <1>;
266 With that, if ``phandle-array-prop-2`` has specifier space ``bob``, we could
269 .. code-block:: DTS
272 phandle-array-prop = <&foo 1 2>, <&bar 3>;
273 phandle-array-prop-2 = <&foo 4>;
279 case) using different ``#SPACE_NAME-cells`` properties.
281 Example specifier space: gpio
284 From the above example, you're already familiar with how one specifier space
285 works: in the "gpio" space, specifiers almost always have two cells:
293 .. code-block:: DTS
295 gpioX: gpio-controller@deadbeef {
296 gpio-controller;
297 #gpio-cells = <2>;
300 Associating properties with specifier spaces
305 - each phandle-array property has an associated specifier space
306 - specifier spaces are identified by name
307 - devicetree nodes use ``#SPECIFIER_NAME-cells`` properties to
308 configure the number of cells which must appear in a specifier
310 In this section, we explain how phandle-array properties get their specifier
316 In general, a ``phandle-array`` property named ``foos`` implicitly has
317 specifier space ``foo``. For example:
319 .. code-block:: YAML
323 type: phandle-array
325 type: phandle-array
327 The ``dmas`` property's specifier space is "dma". The ``pwm`` property's
328 specifier space is ``pwm``.
333 ``*-gpios`` properties are special-cased so that e.g. ``foo-gpios`` resolves to
334 ``#gpio-cells`` rather than ``#foo-gpio-cells``.
336 Manually specifying a space
339 You can manually specify the specifier space for any ``phandle-array``
340 property. See :ref:`dt-bindings-specifier-space`.
342 Naming the cells in a specifier
345 You should name the cells in each specifier space your hardware supports when
346 writing bindings. For details on how to do this, see :ref:`dt-bindings-cells`.
349 in a specifier by name using devicetree APIs like these:
351 - :c:macro:`DT_PHA_BY_IDX`
352 - :c:macro:`DT_PHA_BY_NAME`
354 This feature and these macros are used internally by numerous hardware-specific
357 - :c:macro:`DT_GPIO_PIN_BY_IDX`
358 - :c:macro:`DT_PWMS_CHANNEL_BY_IDX`
359 - :c:macro:`DT_DMAS_CELL_BY_NAME`
360 - :c:macro:`DT_IO_CHANNELS_INPUT_BY_IDX`
361 - :c:macro:`DT_CLOCKS_CELL_BY_NAME`
366 - :ref:`dt-writing-property-values`: how to write phandles in devicetree
369 - :ref:`dt-bindings-properties`: how to write bindings for properties with
370 phandle types (``phandle``, ``phandles``, ``phandle-array``)
372 - :ref:`dt-bindings-specifier-space`: how to manually specify a phandle-array
373 property's specifier space