Lines Matching +full:phandle +full:- +full:array +full:- +full:foo +full:- +full:cells
2 * SPDX-License-Identifier: Apache-2.0
39 * -----------------
42 * part in DT_N_<path-id>_P_<property-id> macros, or the "prop-suf"
55 * _IDX_<i>_PH: phandle array's phandle by index (or phandle, phandles)
56 * _IDX_<i>_STRING_TOKEN: string array element value as a token
57 * _IDX_<i>_STRING_UPPER_TOKEN: string array element value as a uppercased token
58 * _IDX <i>_STRING_UNQUOTED: string array element value as a sequence of tokens, with no quotes
59 * _IDX_<i>_VAL_<val>: phandle array's specifier value by index
62 * _NAME_<name>_PH: phandle array's phandle by name
63 * _NAME_<name>_VAL_<val>: phandle array's property specifier by name
71 * @defgroup devicetree-generic-id Node identifiers and helpers
96 * The arguments to this macro are the names of non-root nodes in the
98 * Non-alphanumeric characters in each name must be converted to
108 * current-speed = <115200>;
119 * Example usage with DT_PROP() to get the `current-speed` property:
125 * (The `current-speed` property is also in `lowercase-and-underscores`
130 * - the first argument corresponds to a child node of the root (`soc` above)
131 * - a second argument corresponds to a child of the first argument
134 * - and so on for deeper nodes in the desired node's path
136 * @param ... lowercase-and-underscores node names along the node's path,
145 * Convert non-alphanumeric characters in the node label to
155 * current-speed = <115200>;
167 * current-speed property:
177 * L2_0: l2-cache {
178 * cache-level = <2>;
184 * Example usage to get the cache-level property:
193 * @param label lowercase-and-underscores node label name
203 * non-alphanumeric characters in the alias property to underscores to
211 * my-serial = &serial1;
217 * current-speed = <115200>;
225 * `serial@40001000` node. Notice how `my-serial` in the devicetree
227 * DT_PROP() to get the current-speed property:
233 * @param alias lowercase-and-underscores alias name.
240 * @param alias_name lowercase-and-underscores devicetree alias name
249 * instance numbers, which are zero-based indexes specific to that
252 * lowercase-and-underscores version of the compatible, @p compat.
256 * - for each compatible, instance numbers start at 0 and are contiguous
257 * - exactly one instance number is assigned for each node with a compatible,
259 * - enabled nodes (status property is `okay` or missing) are assigned the
265 * - instance numbers **in no way reflect** any numbering scheme that
269 * - there **is no general guarantee** that the same node will have
277 * compatible = "vnd,soc-serial";
279 * current-speed = <9600>;
284 * compatible = "vnd,soc-serial";
286 * current-speed = <57600>;
291 * compatible = "vnd,soc-serial";
292 * current-speed = <115200>;
298 * `"vnd,soc-serial"`, that compatible has nodes with instance numbers
312 * // have instance number 0, so this could be the current-speed
318 * // this expands to 115200, and vice-versa.
327 * Notice how `"vnd,soc-serial"` in the devicetree becomes `vnd_soc_serial`
328 * (without quotes) in the DT_INST() arguments. (As usual, `current-speed`
335 * @param compat lowercase-and-underscores compatible, without quotes
347 * parent: parent-node {
348 * child: child-node {
372 * gparent: grandparent-node {
373 * parent: parent-node {
374 * child: child-node { ... }
398 * soc-label: soc {
401 * current-speed = <115200>;
423 * @param child lowercase-and-underscores child node name
439 * node-a {
444 * node-b {
449 * node-c {
461 * This expands to a node identifier for either `node-a` or `node-b`.
462 * It will not expand to a node identifier for `node-c`, because that
465 * @param compat lowercase-and-underscores compatible, without quotes
485 * node: my-node@12345678 { ... };
493 * DT_NODE_PATH(DT_NODELABEL(node)) // "/soc/my-node@12345678"
504 * @brief Get a devicetree node's name with unit-address as a string literal
506 * This returns the node name and unit-address from a node identifier.
513 * node: my-node@12345678 { ... };
521 * DT_NODE_FULL_NAME(DT_NODELABEL(node)) // "my-node@12345678"
525 * @return the node's name with unit-address as a string in the devicetree
530 * @brief Get the node's full name, including the unit-address, as an unquoted
540 * node: my-node@12345678 { ... };
548 * DT_NODE_FULL_NAME_UNQUOTED(DT_NODELABEL(node)) // my-node@12345678
552 * @return the node's full name with unit-address as a sequence of tokens,
558 * @brief Get the node's full name, including the unit-address, as a token.
561 * converting any non-alphanumeric characters to underscores.
568 * node: my-node@12345678 { ... };
580 * @return the node's full name with unit-address as a token, i.e. without any quotes
589 * converting any non-alphanumeric characters to underscores, and
597 * node: my-node@12345678 { ... };
609 * @return the node's full name with unit-address as an uppercased token,
618 * Indexes are zero-based.
626 * c1: child-1 {};
627 * c2: child-2 {};
686 * @brief Get a devicetree node's node labels as an array of strings
691 * foo: bar: node@deadbeef {};
697 * DT_NODELABEL_STRING_ARRAY(DT_NODELABEL(foo))
703 * { "foo", "bar", }
707 * @return an array initializer for an array of the node's node labels as strings
717 * @defgroup devicetree-generic-prop Property accessors
728 * - string: a string literal
729 * - boolean: `0` if the property is false, or `1` if it is true
730 * - int: the property's value as an integer literal
731 * - array, uint8-array, string-array: an initializer expression in braces,
734 * - phandle: a node identifier for the node with that phandle
739 * type string-array, `status` has type string, and
740 * `interrupt-controller` has type boolean.
749 * @param prop lowercase-and-underscores property name
762 * - for types array, string-array, and uint8-array, this expands
763 * to the number of elements in the array
764 * - for type phandles, this expands to the number of phandles
765 * - for type phandle-array, this expands to the number of
766 * phandle and specifier blocks in the property
767 * - for type phandle, this expands to 1 (so that a phandle
769 * - for type string, this expands to 1 (so that a string can be
770 * treated as a degenerate case of string-array with length 1)
774 * - reg property: use `DT_NUM_REGS(node_id)` instead
775 * - interrupts property: use `DT_NUM_IRQS(node_id)` instead
777 * It is an error to use this macro with the `ranges`, `dma-ranges`, `reg`
783 * @param prop a lowercase-and-underscores property with a logical length
798 * @param prop a lowercase-and-underscores property with a logical length
807 * @brief Is index @p idx valid for an array type property?
815 * - `reg` property: use DT_REG_HAS_IDX(node_id, idx) instead
816 * - `interrupts` property: use DT_IRQ_HAS_IDX(node_id, idx) instead
821 * @param prop a lowercase-and-underscores property with a logical length
830 * @brief Is name @p name available in a `foo-names` property?
834 * - `interrupts` property: use DT_IRQ_HAS_NAME(node_id, idx) instead
841 * nx: node-x {
843 * foo-names = "event", "error";
856 * @param prop a lowercase-and-underscores `prop-names` type property
857 * @param name a lowercase-and-underscores name to check
865 * @brief Get the value at index @p idx in an array type property
868 * `node->property[index]`.
872 * - for types array, string-array, uint8-array, and phandles,
873 * this expands to the idx-th array element as an
877 * - for type phandle, idx must be 0 and the expansion is a node
878 * identifier (this treats phandle like a phandles of length 1)
880 * - for type string, idx must be 0 and the expansion is the
881 * entire string (this treats string like string-array of length 1)
885 * - `reg`: use DT_REG_ADDR_BY_IDX() or DT_REG_SIZE_BY_IDX() instead
886 * - `interrupts`: use DT_IRQ_BY_IDX()
887 * - `ranges`: use DT_NUM_RANGES()
888 * - `dma-ranges`: it is an error to use this property with
894 * @param prop lowercase-and-underscores property name
896 * @return a representation of the idx-th element of the property
902 * @brief Get the last element of an array type property
905 * @param prop lowercase-and-underscores property name
921 * @param prop lowercase-and-underscores property name
930 * @brief Get a property array value's index into its enumeration values
937 * some_node: some-node {
938 * compat = "vend,enum-string-array";
940 * <&phandle val1>,
941 * <&phandle val2>,
942 * <&phandle val3>;
943 * foo-names = "default", "option3", "option1";
950 * compatible: vend,enum-string-array
953 * type: phandle-array
955 * Explanation about what this phandle-array exactly is for.
957 * foo-names:
958 * type: string-array
966 * - default
967 * - option1
968 * - option2
969 * - option3
980 * @param prop lowercase-and-underscores property name
982 * @return zero-based index of the property's value in its enum: list
990 * @param prop lowercase-and-underscores property name
991 * @return zero-based index of the property's value in its enum: list
1004 * @param prop lowercase-and-underscores property name
1007 * @return zero-based index of the property's value in its enum if present,
1017 * @param prop lowercase-and-underscores property name
1019 * @return zero-based index of the property's value in its enum if present,
1026 * @brief Does a node enumeration property array have a given value?
1029 * @param prop lowercase-and-underscores property name
1031 * @param value lowercase-and-underscores enumeration value
1040 * @param prop lowercase-and-underscores property name
1041 * @param value lowercase-and-underscores enumeration value
1051 * converting any non-alphanumeric characters to underscores. This can
1062 * n1: node-1 {
1063 * prop = "foo";
1065 * n2: node-2 {
1066 * prop = "FOO";
1068 * n3: node-3 {
1069 * prop = "123 foo";
1084 * DT_STRING_TOKEN(DT_NODELABEL(n1), prop) // foo
1085 * DT_STRING_TOKEN(DT_NODELABEL(n2), prop) // FOO
1091 * - Unlike C identifiers, the property values may begin with a
1095 * - The uppercased `"FOO"` in the DTS remains `FOO` as a token. It is
1096 * *not* converted to `foo`.
1098 * - The whitespace in the DTS `"123 foo"` string is converted to
1102 * @param prop lowercase-and-underscores property name
1118 * @param prop lowercase-and-underscores property name
1130 * converting any non-alphanumeric characters to underscores, and
1141 * n1: node-1 {
1142 * prop = "foo";
1144 * n2: node-2 {
1145 * prop = "123 foo";
1161 * DT_STRING_UPPER_TOKEN(DT_NODELABEL(n1), prop) // FOO
1167 * - Unlike C identifiers, the property values may begin with a
1171 * - The lowercased `"foo"` in the DTS becomes `FOO` as a token, i.e.
1174 * - The whitespace in the DTS `"123 foo"` string is converted to
1179 * @param prop lowercase-and-underscores property name
1195 * @param prop lowercase-and-underscores property name
1207 * This removes "the quotes" from string-valued properties.
1218 * n1: node-1 {
1221 * n2: node-2 {
1224 * n3: node-3 {
1241 * @param prop lowercase-and-underscores property name
1256 * @param prop lowercase-and-underscores property name
1266 * @brief Get an element out of a string-array property as a token.
1268 * This removes "the quotes" from an element in the array, and converts
1269 * non-alphanumeric characters to underscores. That can be useful, for example,
1273 * string-array type.
1280 * n1: node-1 {
1283 * n2: node-2 {
1284 * prop = "123 foo", "456 FOO";
1293 * type: string-array
1308 * @param prop lowercase-and-underscores property name
1318 * This removes "the quotes" and capitalizes an element in the array, and
1319 * converts non-alphanumeric characters to underscores. That can be useful, for
1323 * string-array type.
1330 * n1: node-1 {
1333 * n2: node-2 {
1334 * prop = "123 foo", "456 FOO";
1343 * type: string-array
1358 * @param prop lowercase-and-underscores property name
1366 * @brief Get a string array item value as an unquoted sequence of tokens.
1368 * This removes "the quotes" from string-valued item.
1374 * string-array type.
1380 * n1: node-1 {
1383 * n2: node-2 {
1391 * type: string-array
1401 * @param prop lowercase-and-underscores property name
1409 * phandle properties
1411 * These are special-cased to manage the impedance mismatch between
1417 * @brief Get a property value from a phandle in a property.
1425 * That is, @p prop is a property of the phandle's node, not a
1431 * n1: node-1 {
1432 * foo = <&n2 &n3>;
1435 * n2: node-2 {
1439 * n3: node-3 {
1449 * DT_PROP_BY_PHANDLE_IDX(N1, foo, 0, bar) // 42
1450 * DT_PROP_BY_PHANDLE_IDX(N1, foo, 1, baz) // 43
1454 * @param phs lowercase-and-underscores property with type `phandle`,
1455 * `phandles`, or `phandle-array`
1457 * has type `phandle`
1458 * @param prop lowercase-and-underscores property of the phandle's node
1475 * @param phs lowercase-and-underscores property with type `phandle`,
1476 * `phandles`, or `phandle-array`
1478 * has type `phandle`
1479 * @param prop lowercase-and-underscores property of the phandle's node
1487 * @brief Get a property value from a phandle's node
1492 * @param ph lowercase-and-underscores property of @p node_id
1493 * with type `phandle`
1494 * @param prop lowercase-and-underscores property of the phandle's node
1501 * @brief Get a phandle-array specifier cell value at an index
1504 * `node->phandle_array[index].cell`. That is, the cell value is in
1512 * #gpio-cells = <2>;
1516 * #gpio-cells = <2>;
1527 * gpio-cells:
1528 * - pin
1529 * - flags
1534 * - index 0 has specifier <17 0x1>, so its `pin` cell is 17, and its
1536 * - index 1 has specifier <5 0x3>, so `pin` is 5 and `flags` is 0x3
1548 * @param pha lowercase-and-underscores property with type `phandle-array`
1550 * @param cell lowercase-and-underscores cell name within the specifier
1573 * @param pha lowercase-and-underscores property with type `phandle-array`
1575 * @param cell lowercase-and-underscores cell name within the specifier
1586 * @param pha lowercase-and-underscores property with type `phandle-array`
1587 * @param cell lowercase-and-underscores cell name
1601 * @param pha lowercase-and-underscores property with type `phandle-array`
1602 * @param cell lowercase-and-underscores cell name
1610 * @brief Get a value within a phandle-array specifier by name
1613 * where each array element has a name.
1616 * `node->phandle_struct.name.cell`. That is, the cell value is in the
1618 * each array element has a name.
1624 * io-channels = <&adc1 10>, <&adc2 20>;
1625 * io-channel-names = "SENSOR", "BANDGAP";
1632 * io-channel-cells:
1633 * - input
1644 * @param pha lowercase-and-underscores property with type `phandle-array`
1645 * @param name lowercase-and-underscores name of a specifier in @p pha
1646 * @param cell lowercase-and-underscores cell name in the named specifier
1667 * @param pha lowercase-and-underscores property with type `phandle-array`
1668 * @param name lowercase-and-underscores name of a specifier in @p pha
1669 * @param cell lowercase-and-underscores cell name in the named specifier
1677 * @brief Get a phandle's node identifier from a phandle array by @p name
1680 * `node->phandle_struct.name.phandle`. That is, the phandle array is
1682 * the node identifier for a phandle inside the structure.
1696 * io-channels = <&adc1 10>, <&adc2 20>;
1697 * io-channel-names = "SENSOR", "BANDGAP";
1701 * Above, "io-channels" has two elements:
1703 * - the element named `"SENSOR"` has phandle `&adc1`
1704 * - the element named `"BANDGAP"` has phandle `&adc2`
1716 * non-alphanumeric characters are converted to underscores.
1719 * @param pha lowercase-and-underscores property with type `phandle-array`
1720 * @param name lowercase-and-underscores name of an element in @p pha
1721 * @return a node identifier for the node with that phandle
1727 * @brief Get a node identifier for a phandle in a property.
1729 * When a node's value at a logical index contains a phandle, this
1730 * macro returns a node identifier for the node with that phandle.
1732 * Therefore, if @p prop has type `phandle`, @p idx must be zero. (A
1733 * `phandle` type is treated as a `phandles` with a fixed length of
1739 * n1: node-1 {
1740 * foo = <&n2 &n3>;
1743 * n2: node-2 { ... };
1744 * n3: node-3 { ... };
1747 * Above, `foo` has type phandles and has two elements:
1749 * - index 0 has phandle `&n2`, which is `node-2`'s phandle
1750 * - index 1 has phandle `&n3`, which is `node-3`'s phandle
1757 * DT_PHANDLE_BY_IDX(N1, foo, 0) // node identifier for node-2
1758 * DT_PHANDLE_BY_IDX(N1, foo, 1) // node identifier for node-3
1761 * Behavior is analogous for phandle-arrays.
1770 * @param prop lowercase-and-underscores property name in @p node_id
1771 * with type `phandle`, `phandles` or `phandle-array`
1773 * @return node identifier for the node with the phandle at that index
1779 * @brief Get a node identifier for a phandle property's value
1782 * benefit is readability when @p prop has type `phandle`.
1785 * @param prop lowercase-and-underscores property of @p node_id
1786 * with type `phandle`
1796 * @defgroup devicetree-ranges-prop ranges property
1810 * compatible = "pcie-controller";
1812 * #address-cells = <3>;
1813 * #size-cells = <2>;
1855 * compatible = "pcie-controller";
1857 * #address-cells = <3>;
1858 * #size-cells = <2>;
1906 * #address-cells = <2>;
1909 * compatible = "pcie-controller";
1911 * #address-cells = <3>;
1912 * #size-cells = <2>;
1942 * @param idx logical index into the ranges array
1959 * #address-cells = <2>;
1962 * compatible = "pcie-controller";
1964 * #address-cells = <3>;
1965 * #size-cells = <2>;
1983 * @param idx logical index into the ranges array
1999 * #address-cells = <2>;
2002 * compatible = "pcie-controller";
2004 * #address-cells = <3>;
2005 * #size-cells = <2>;
2032 * @param idx logical index into the ranges array
2042 * for child bus flags cells when the node is a PCIe bus.
2048 * #address-cells = <2>;
2051 * compatible = "pcie-controller";
2053 * #address-cells = <3>;
2054 * #size-cells = <2>;
2081 * @param idx logical index into the ranges array
2091 * for child bus flags cells when the node is a PCIe bus.
2097 * #address-cells = <2>;
2100 * compatible = "pcie-controller";
2102 * #address-cells = <3>;
2103 * #size-cells = <2>;
2130 * @param idx logical index into the ranges array
2183 * @defgroup devicetree-generic-vendor Vendor and model name helpers
2195 * Example vendor-prefixes.txt:
2197 * vnd A stand-in for a real vendor
2198 * zephyr Zephyr-specific binding
2203 * n1: node-1 {
2211 * DT_NODE_VENDOR_BY_IDX(DT_NODELABEL(n1), 0) // "A stand-in for a real vendor"
2212 * DT_NODE_VENDOR_BY_IDX(DT_NODELABEL(n1), 2) // "Zephyr-specific binding"
2221 * @return string literal of the idx-th vendor
2251 * @return string literal of the idx-th vendor
2253 * @return string literal of the idx-th vendor or "default_value"
2275 * Example vendor-prefixes.txt:
2277 * vnd A stand-in for a real vendor
2278 * zephyr Zephyr-specific binding
2282 * n1: node-1 {
2297 * @return string literal of the idx-th model
2327 * @return string literal of the idx-th model
2329 * @return string literal of the idx-th model or "default_value"
2351 * @defgroup devicetree-reg-prop reg property
2402 * @return address of the idx-th register block
2425 * @return address of the idx-th register block
2439 * @return size of the idx-th register block
2454 * @brief 64-bit version of DT_REG_ADDR()
2456 * This macro version adds the appropriate suffix for 64-bit unsigned
2477 * @param name lowercase-and-underscores register specifier name
2486 * @param name lowercase-and-underscores register specifier name
2496 * @brief 64-bit version of DT_REG_ADDR_BY_NAME()
2498 * This macro version adds the appropriate suffix for 64-bit unsigned
2504 * @param name lowercase-and-underscores register specifier name
2513 * @param name lowercase-and-underscores register specifier name
2522 * @param name lowercase-and-underscores register specifier name
2537 * @defgroup devicetree-interrupts-prop interrupts property
2559 * foo {};
2568 * DT_NUM_NODELABELS(DT_PATH(foo)) // 0
2626 * @param name lowercase-and-underscores interrupt specifier name
2637 * "node->interrupts[index].cell".
2645 * my-serial: serial@abcd1234 {
2650 * Assuming the node's interrupt domain has "#interrupt-cells = <2>;" and
2651 * the individual cells in each interrupt specifier are named "irq" and
2657 * ------------- -----
2664 * @param idx logical index into the interrupt specifier array
2675 * `node->interrupts.name.cell`.
2682 * @param name lowercase-and-underscores interrupt specifier name
2703 * interrupt-controller;
2704 * #interrupt-cells = <2>;
2707 * foo: foo {
2708 * interrupt-parent = <&gpio0>;
2713 * interrupts-extended = <&gpio0 3 3>, <&pic0 4>;
2717 * interrupt-controller;
2718 * #interrupt-cells = <1>;
2722 * interrupt-names = "int1", "int2";
2729 * DT_IRQ_INTC_BY_IDX(DT_NODELABEL(foo), 0) // &gpio0
2730 * DT_IRQ_INTC_BY_IDX(DT_NODELABEL(foo), 1) // &gpio0
2748 * interrupt-controller;
2749 * #interrupt-cells = <2>;
2752 * foo: foo {
2753 * interrupt-parent = <&gpio0>;
2755 * interrupt-names = "int1", "int2";
2759 * interrupts-extended = <&gpio0 3 3>, <&pic0 4>;
2760 * interrupt-names = "int1", "int2";
2764 * interrupt-controller;
2765 * #interrupt-cells = <1>;
2769 * interrupt-names = "int1", "int2";
2776 * DT_IRQ_INTC_BY_NAME(DT_NODELABEL(foo), int1) // &gpio0
2777 * DT_IRQ_INTC_BY_NAME(DT_NODELABEL(foo), int2) // &gpio0
2796 * interrupt-controller;
2797 * #interrupt-cells = <2>;
2800 * foo: foo {
2801 * interrupt-parent = <&gpio0>;
2806 * interrupts-extended = <&gpio0 3 3>;
2810 * interrupt-controller;
2811 * #interrupt-cells = <1>;
2821 * DT_IRQ_INTC(DT_NODELABEL(foo)) // &gpio0
2836 /* DT helper macro to encode a node's IRQN to level 1 according to the multi-level scheme */
2838 /* DT helper macro to encode a node's IRQN to level 2 according to the multi-level scheme */
2842 /* DT helper macro to encode a node's IRQN to level 3 according to the multi-level scheme */
2851 * DT helper macro to encode a node's interrupt number according to the Zephyr's multi-level scheme
2864 * multi-level encoded
2866 * @param idx logical index into the interrupt specifier array
2891 * @defgroup devicetree-generic-chosen Chosen nodes
2900 * @param prop lowercase-and-underscores property name for
2908 * @param prop lowercase-and-underscores devicetree property
2919 * @defgroup devicetree-generic-foreach "For-each" macros
2939 * identifier for the node. The remaining are passed-in by the caller.
2967 * identifier for the node. The remaining are passed-in by the caller.
3040 * child-1 {
3041 * foobar = "foo";
3043 * child-2 {
3063 * "foo", "bar",
3083 * child-1 {
3086 * child-2 {
3104 * "child-1", "child-2"
3120 * identifier for the child node. The remaining are passed-in by the caller.
3139 * identifier for the child node. The remaining are passed-in by the caller.
3194 * identifier for the child node. The remaining are passed-in by the caller.
3216 * identifier for the child node. The remaining are passed-in by the caller.
3237 * DT_FOREACH_PROP_ELEM(), and @p idx is the current index into the array.
3247 * my-ints = <1 2 3>;
3257 * int array[] = {
3265 * int array[] = {
3272 * fn(node_id, prop, 0) fn(node_id, prop, 1) [...] fn(node_id, prop, n-1)
3278 * @param prop lowercase-and-underscores property name
3293 * my-gpios = <&gpioa 0 GPIO_ACTICE_HIGH>,
3320 * @param prop lowercase-and-underscores property name
3337 * the array. The @p idx values are integer literals starting from 0. The
3338 * remaining arguments are passed-in by the caller.
3344 * @param prop lowercase-and-underscores property name
3361 * @param prop lowercase-and-underscores property name
3389 * compatible = "foo";
3393 * compatible = "foo";
3397 * compatible = "foo";
3405 * DT_FOREACH_STATUS_OKAY(foo, DT_NODE_PATH)
3422 * @param compat lowercase-and-underscores devicetree compatible
3443 * compatible = "foo";
3447 * compatible = "foo";
3457 * x = DT_FOREACH_STATUS_OKAY_VARGS(foo, MY_FN, +) 0;
3470 * @param compat lowercase-and-underscores devicetree compatible
3486 * @param compat lowercase-and-underscores devicetree compatible
3509 * passed as tokens to @p fn as-is, without any lowercasing or
3515 * foo: bar: FOO: node@deadbeef {};
3521 * int foo = 1;
3523 * int FOO = 3;
3526 * int sum = 0 DT_FOREACH_NODELABEL(DT_NODELABEL(foo), FN)
3550 * foo: bar: node@deadbeef {};
3556 * int foo = 0;
3561 * DT_FOREACH_NODELABEL_VARGS(DT_NODELABEL(foo), VAR_PLUS, 1)
3567 * int foo = 0;
3569 * int foo_added = foo + 1;
3585 * @defgroup devicetree-generic-exist Existence checks
3618 * - exists in the devicetree, and
3619 * - has a status property matching the second argument
3641 * - exists in the devicetree, and
3642 * - has a status property as `okay`
3668 * @param compat lowercase-and-underscores compatible, without quotes
3677 * @param compat lowercase-and-underscores compatible, without quotes
3691 * compatible = "vnd,specific-device", "generic-device";
3707 * @param compat lowercase-and-underscores compatible, without quotes
3725 * @param compat lowercase-and-underscores compatible, without quotes
3741 * @param prop lowercase-and-underscores property name
3749 * @brief Does a phandle array have a named cell specifier at an index?
3751 * If this returns 1, then the phandle-array property @p pha has a cell
3757 * @param pha lowercase-and-underscores property with type `phandle-array`
3759 * @param cell lowercase-and-underscores cell name whose existence to check
3771 * @param pha lowercase-and-underscores property with type `phandle-array`
3772 * @param cell lowercase-and-underscores cell name whose existence to check
3785 * @defgroup devicetree-generic-bus Bus helpers
3804 * clock-frequency = < 100000 >;
3830 * temp: temperature-sensor@76 {
3831 * compatible = "vnd,some-sensor";
3846 * @param bus lowercase-and-underscores bus type as a C token (i.e.
3858 * @defgroup devicetree-inst Instance-based devicetree APIs
3893 * @param child lowercase-and-underscores child node name
3925 * @brief Get a string array of DT_DRV_INST(inst)'s node labels
3930 * @return an array initializer for an array of the instance's node labels as strings
3981 * identifier for the child node. The remaining are passed-in by the caller.
3999 * identifier for the child node. The remaining are passed-in by the caller.
4048 * identifier for the child node. The remaining are passed-in by the caller.
4064 * identifier for the child node. The remaining are passed-in by the caller.
4078 * @brief Get a `DT_DRV_COMPAT` property array value's index into its enumeration values
4080 * @param prop lowercase-and-underscores property name
4082 * @return zero-based index of the property's value in its enum: list
4090 * @param prop lowercase-and-underscores property name
4091 * @return zero-based index of the property's value in its enum: list
4099 * @param prop lowercase-and-underscores property name
4102 * @return zero-based index of the property's value in its enum if present,
4111 * @param prop lowercase-and-underscores property name
4113 * @return zero-based index of the property's value in its enum if present,
4122 * @param prop lowercase-and-underscores property name
4124 * @param value lowercase-and-underscores enumeration value
4125 * @return zero-based index of the property's value in its enum
4134 * @param prop lowercase-and-underscores property name
4135 * @param value lowercase-and-underscores enumeration value
4144 * @param prop lowercase-and-underscores property name
4152 * @param prop lowercase-and-underscores property name
4158 * @brief Is index @p idx valid for an array type property
4161 * @param prop lowercase-and-underscores property name
4170 * @brief Is name @p name available in a `foo-names` property?
4172 * @param prop a lowercase-and-underscores `prop-names` type property
4173 * @param name a lowercase-and-underscores name to check
4181 * @brief Get a `DT_DRV_COMPAT` element value in an array property
4183 * @param prop lowercase-and-underscores property name
4185 * @return a representation of the idx-th element of the property
4193 * @param prop lowercase-and-underscores property name
4203 * @param prop lowercase-and-underscores property name
4215 * @param prop lowercase-and-underscores property name
4225 * @param prop lowercase-and-underscores property name
4237 * @param prop lowercase-and-underscores property name
4244 * @brief Get an element out of string-array property as a token.
4246 * @param prop lowercase-and-underscores property name
4256 * @param prop lowercase-and-underscores property name
4264 * @brief Get an element out of string-array property as an unquoted sequence of tokens.
4266 * @param prop lowercase-and-underscores property name
4274 * @brief Get a `DT_DRV_COMPAT` instance's property value from a phandle's node
4276 * @param ph lowercase-and-underscores property of @p inst
4277 * with type `phandle`
4278 * @param prop lowercase-and-underscores property of the phandle's node
4285 * @brief Get a `DT_DRV_COMPAT` instance's property value from a phandle in a
4288 * @param phs lowercase-and-underscores property with type `phandle`,
4289 * `phandles`, or `phandle-array`
4291 * has type `phandle`
4292 * @param prop lowercase-and-underscores property of the phandle's node
4299 * @brief Get a `DT_DRV_COMPAT` instance's phandle-array specifier value at an index
4301 * @param pha lowercase-and-underscores property with type `phandle-array`
4312 * @param pha lowercase-and-underscores property with type `phandle-array`
4322 * @brief Get a `DT_DRV_COMPAT` instance's phandle-array specifier value
4325 * @param pha lowercase-and-underscores property with type `phandle-array`
4334 * @param pha lowercase-and-underscores property with type `phandle-array`
4343 * @brief Get a `DT_DRV_COMPAT` instance's value within a phandle-array
4346 * @param pha lowercase-and-underscores property with type `phandle-array`
4347 * @param name lowercase-and-underscores name of a specifier in @p pha
4357 * @param pha lowercase-and-underscores property with type `phandle-array`
4358 * @param name lowercase-and-underscores name of a specifier in @p pha
4367 * @brief Get a `DT_DRV_COMPAT` instance's phandle node identifier from a
4368 * phandle array by name
4370 * @param pha lowercase-and-underscores property with type `phandle-array`
4371 * @param name lowercase-and-underscores name of an element in @p pha
4372 * @return node identifier for the phandle at the element named "name"
4378 * @brief Get a `DT_DRV_COMPAT` instance's node identifier for a phandle in
4381 * @param prop lowercase-and-underscores property name in @p inst
4382 * with type `phandle`, `phandles` or `phandle-array`
4384 * @return a node identifier for the phandle at index @p idx in @p prop
4390 * @brief Get a `DT_DRV_COMPAT` instance's node identifier for a phandle
4393 * @param prop lowercase-and-underscores property of @p inst
4394 * with type `phandle`
4418 * @brief Get a `DT_DRV_COMPAT` instance's idx-th register block's raw address
4421 * @return address of the instance's idx-th register block
4426 * @brief Get a `DT_DRV_COMPAT` instance's idx-th register block's address
4429 * @return address of the instance's idx-th register block
4434 * @brief Get a `DT_DRV_COMPAT` instance's idx-th register block's size
4437 * @return size of the instance's idx-th register block
4445 * @param name lowercase-and-underscores register specifier name
4454 * @param name lowercase-and-underscores register specifier name
4463 * @brief 64-bit version of DT_INST_REG_ADDR_BY_NAME()
4465 * This macro version adds the appropriate suffix for 64-bit unsigned
4471 * @param name lowercase-and-underscores register specifier name
4480 * @param name lowercase-and-underscores register specifier name
4489 * @param name lowercase-and-underscores register specifier name
4512 * @brief 64-bit version of DT_INST_REG_ADDR()
4514 * This macro version adds the appropriate suffix for 64-bit unsigned
4550 * @param idx logical index into the interrupt specifier array
4588 * @param name lowercase-and-underscores interrupt specifier name
4613 * @param idx logical index into the interrupt specifier array
4614 * @return the interrupt number for the node's idx-th interrupt
4637 * @param name lowercase-and-underscores property name
4650 * @param name lowercase-and-underscores property name
4661 * @param name lowercase-and-underscores property name
4679 * temp: temperature-sensor@76 {
4680 * compatible = "vnd,some-sensor";
4693 * @param compat lowercase-and-underscores compatible, without quotes
4705 * This is a special-purpose macro which can be useful when writing
4713 * temp: temperature-sensor@76 {
4714 * compatible = "vnd,some-sensor";
4740 * @param prop lowercase-and-underscores property name
4747 * compatible = "vnd,some-sensor";
4750 * foo = <1>;
4755 * compatible = "vnd,some-sensor";
4758 * foo = <2>;
4762 * compatible = "vnd,some-sensor";
4775 * DT_ANY_INST_HAS_PROP_STATUS_OKAY(foo) // 1
4787 * @param compat lowercase-and-underscores devicetree compatible
4788 * @param prop lowercase-and-underscores property name
4795 * compatible = "vnd,some-sensor";
4798 * foo = <1>;
4803 * compatible = "vnd,some-sensor";
4806 * foo = <2>;
4810 * compatible = "vnd,some-sensor";
4822 * DT_ANY_COMPAT_HAS_PROP_STATUS_OKAY(vnd_some_sensor, foo) // 1
4837 * @param prop lowercase-and-underscores property name
4844 * compatible = "vnd,some-sensor";
4847 * foo;
4852 * compatible = "vnd,some-sensor";
4855 * foo;
4859 * compatible = "vnd,some-sensor";
4872 * DT_ANY_INST_HAS_BOOL_STATUS_OKAY(foo) // 1
5002 * @param prop lowercase-and-underscores property name
5015 * @param prop lowercase-and-underscores property name
5031 * @param prop lowercase-and-underscores property name
5049 * @param prop lowercase-and-underscores property name
5064 * @param prop lowercase-and-underscores property name
5073 * @param compat lowercase-and-underscores compatible, without quotes
5080 * @brief Does a phandle array have a named cell specifier at an index
5083 * @param pha lowercase-and-underscores property with type `phandle-array`
5093 * @brief Does a phandle array have a named cell specifier at index 0
5096 * @param pha lowercase-and-underscores property with type `phandle-array`
5107 * @param idx logical index into the interrupt specifier array
5137 * @param name lowercase-and-underscores interrupt specifier name
5224 * since its macro-based API is fiddly and can be hard to get right.
5293 #include <zephyr/devicetree/io-channels.h>
5299 #include <zephyr/devicetree/fixed-partitions.h>
5305 #include <zephyr/devicetree/port-endpoint.h>