17#ifndef ZEPHYR_INCLUDE_DEVICETREE_H_
18#define ZEPHYR_INCLUDE_DEVICETREE_H_
20#include <zephyr/devicetree_generated.h>
23#if !defined(_LINKER) && !defined(_ASMLANGUAGE)
84#define DT_INVALID_NODE _
141#define DT_PATH(...) DT_PATH_INTERNAL(__VA_ARGS__)
197#define DT_NODELABEL(label) DT_CAT(DT_N_NODELABEL_, label)
236#define DT_NODELABEL_C_TOKEN_BY_IDX(node_id, idx) \
237 DT_CAT5(DT_N_NODELABEL_, node_id, _IDX_, idx, _C_TOKEN)
247#define DT_NODELABEL_C_TOKEN(node_id) \
248 DT_NODELABEL_C_TOKEN_BY_IDX(node_id, 0)
288#define DT_ALIAS(alias) DT_CAT(DT_N_ALIAS_, alias)
295#define DT_HAS_ALIAS(alias_name) DT_NODE_EXISTS(DT_ALIAS(alias_name))
305#define DT_NODE_HASH(node_id) DT_CAT(node_id, _HASH)
401#define DT_INST(inst, compat) UTIL_CAT(DT_N_INST, DT_DASH(inst, compat))
426#define DT_PARENT(node_id) DT_CAT(node_id, _PARENT)
451#define DT_GPARENT(node_id) DT_PARENT(DT_PARENT(node_id))
488#define DT_CHILD(node_id, child) UTIL_CAT(node_id, DT_S_PREFIX(child))
522#define DT_CHILD_BY_UNIT_ADDR_INT(node_id, addr) \
523 DT_CAT3(node_id, _CHILD_UNIT_ADDR_INT_, addr)
566#define DT_COMPAT_GET_ANY_STATUS_OKAY(compat) \
567 COND_CODE_1(DT_HAS_COMPAT_STATUS_OKAY(compat), \
568 (DT_INST(0, compat)), \
598#define DT_NODE_PATH(node_id) DT_CAT(node_id, _PATH)
624#define DT_NODE_FULL_NAME(node_id) DT_CAT(node_id, _FULL_NAME)
652#define DT_NODE_FULL_NAME_UNQUOTED(node_id) DT_CAT(node_id, _FULL_NAME_UNQUOTED)
680#define DT_NODE_FULL_NAME_TOKEN(node_id) DT_CAT(node_id, _FULL_NAME_TOKEN)
710#define DT_NODE_FULL_NAME_UPPER_TOKEN(node_id) DT_CAT(node_id, _FULL_NAME_UPPER_TOKEN)
738#define DT_NODE_CHILD_IDX(node_id) DT_CAT(node_id, _CHILD_IDX)
746#define DT_CHILD_NUM(node_id) DT_CAT(node_id, _CHILD_NUM)
755#define DT_CHILD_NUM_STATUS_OKAY(node_id) \
756 DT_CAT(node_id, _CHILD_NUM_STATUS_OKAY)
767#define DT_DESCENDANT_NUM_ON_BUS(node_id, bus) \
768 DT_CAT3(node_id, _DESCENDANT_NUM_ON_BUS_, bus)
780#define DT_DESCENDANT_NUM_ON_BUS_STATUS_OKAY(node_id, bus) \
781 DT_CAT4(node_id, _DESCENDANT_NUM_ON_BUS_, bus, _STATUS_OKAY)
803#define DT_SAME_NODE(node_id1, node_id2) \
804 IS_EQ(DT_DEP_ORD(node_id1), DT_DEP_ORD(node_id2))
830#define DT_NODELABEL_STRING_ARRAY(node_id) \
831 { DT_FOREACH_NODELABEL(node_id, DT_NODELABEL_STRING_ARRAY_ENTRY_INTERNAL) }
873#define DT_PROP(node_id, prop) DT_CAT3(node_id, _P_, prop)
907#define DT_PROP_LEN(node_id, prop) DT_CAT4(node_id, _P_, prop, _LEN)
923#define DT_PROP_LEN_OR(node_id, prop, default_value) \
924 COND_CODE_1(DT_NODE_HAS_PROP(node_id, prop), \
925 (DT_PROP_LEN(node_id, prop)), (default_value))
947#define DT_PROP_HAS_IDX(node_id, prop, idx) \
948 IS_ENABLED(DT_CAT6(node_id, _P_, prop, _IDX_, idx, _EXISTS))
982#define DT_PROP_HAS_NAME(node_id, prop, name) \
983 IS_ENABLED(DT_CAT6(node_id, _P_, prop, _NAME_, name, _EXISTS))
1019#define DT_PROP_BY_IDX(node_id, prop, idx) \
1020 DT_CAT5(node_id, _P_, prop, _IDX_, idx)
1030#define DT_PROP_LAST(node_id, prop) \
1031 DT_PROP_BY_IDX(node_id, prop, UTIL_DEC(DT_PROP_LEN(node_id, prop)))
1046#define DT_PROP_OR(node_id, prop, default_value) \
1047 COND_CODE_1(DT_NODE_HAS_PROP(node_id, prop), \
1048 (DT_PROP(node_id, prop)), (default_value))
1105#define DT_ENUM_IDX_BY_IDX(node_id, prop, idx) \
1106 DT_CAT6(node_id, _P_, prop, _IDX_, idx, _ENUM_IDX)
1114#define DT_ENUM_IDX(node_id, prop) DT_ENUM_IDX_BY_IDX(node_id, prop, 0)
1131#define DT_ENUM_IDX_BY_IDX_OR(node_id, prop, idx, default_idx_value) \
1132 COND_CODE_1(DT_PROP_HAS_IDX(node_id, prop, idx), \
1133 (DT_ENUM_IDX_BY_IDX(node_id, prop, idx)), (default_idx_value))
1143#define DT_ENUM_IDX_OR(node_id, prop, default_idx_value) \
1144 DT_ENUM_IDX_BY_IDX_OR(node_id, prop, 0, default_idx_value)
1155#define DT_ENUM_HAS_VALUE_BY_IDX(node_id, prop, idx, value) \
1156 IS_ENABLED(DT_CAT8(node_id, _P_, prop, _IDX_, idx, _ENUM_VAL_, value, _EXISTS))
1165#define DT_ENUM_HAS_VALUE(node_id, prop, value) \
1166 IS_ENABLED(DT_CAT6(node_id, _P_, prop, _ENUM_VAL_, value, _EXISTS))
1227#define DT_STRING_TOKEN(node_id, prop) \
1228 DT_CAT4(node_id, _P_, prop, _STRING_TOKEN)
1243#define DT_STRING_TOKEN_OR(node_id, prop, default_value) \
1244 COND_CODE_1(DT_NODE_HAS_PROP(node_id, prop), \
1245 (DT_STRING_TOKEN(node_id, prop)), (default_value))
1304#define DT_STRING_UPPER_TOKEN(node_id, prop) \
1305 DT_CAT4(node_id, _P_, prop, _STRING_UPPER_TOKEN)
1321#define DT_STRING_UPPER_TOKEN_OR(node_id, prop, default_value) \
1322 COND_CODE_1(DT_NODE_HAS_PROP(node_id, prop), \
1323 (DT_STRING_UPPER_TOKEN(node_id, prop)), (default_value))
1365#define DT_STRING_UNQUOTED(node_id, prop) \
1366 DT_CAT4(node_id, _P_, prop, _STRING_UNQUOTED)
1382#define DT_STRING_UNQUOTED_OR(node_id, prop, default_value) \
1383 COND_CODE_1(DT_NODE_HAS_PROP(node_id, prop), \
1384 (DT_STRING_UNQUOTED(node_id, prop)), (default_value))
1433#define DT_STRING_TOKEN_BY_IDX(node_id, prop, idx) \
1434 DT_CAT6(node_id, _P_, prop, _IDX_, idx, _STRING_TOKEN)
1444#define DT_STRING_TOKEN_BY_IDX_OR(node_id, prop, idx, default_value) \
1445 COND_CODE_1(DT_PROP_HAS_IDX(node_id, prop, idx), \
1446 (DT_STRING_TOKEN_BY_IDX(node_id, prop, idx)), (default_value))
1495#define DT_STRING_UPPER_TOKEN_BY_IDX(node_id, prop, idx) \
1496 DT_CAT6(node_id, _P_, prop, _IDX_, idx, _STRING_UPPER_TOKEN)
1538#define DT_STRING_UNQUOTED_BY_IDX(node_id, prop, idx) \
1539 DT_CAT6(node_id, _P_, prop, _IDX_, idx, _STRING_UNQUOTED)
1594#define DT_PROP_BY_PHANDLE_IDX(node_id, phs, idx, prop) \
1595 DT_PROP(DT_PHANDLE_BY_IDX(node_id, phs, idx), prop)
1616#define DT_PROP_BY_PHANDLE_IDX_OR(node_id, phs, idx, prop, default_value) \
1617 DT_PROP_OR(DT_PHANDLE_BY_IDX(node_id, phs, idx), prop, default_value)
1630#define DT_PROP_BY_PHANDLE(node_id, ph, prop) \
1631 DT_PROP_BY_PHANDLE_IDX(node_id, ph, 0, prop)
1687#define DT_PHA_BY_IDX(node_id, pha, idx, cell) \
1688 DT_CAT7(node_id, _P_, pha, _IDX_, idx, _VAL_, cell)
1713#define DT_PHA_BY_IDX_OR(node_id, pha, idx, cell, default_value) \
1714 DT_PROP_OR(node_id, DT_CAT5(pha, _IDX_, idx, _VAL_, cell), default_value)
1723#define DT_PHA(node_id, pha, cell) DT_PHA_BY_IDX(node_id, pha, 0, cell)
1739#define DT_PHA_OR(node_id, pha, cell, default_value) \
1740 DT_PHA_BY_IDX_OR(node_id, pha, 0, cell, default_value)
1782#define DT_PHA_BY_NAME(node_id, pha, name, cell) \
1783 DT_CAT7(node_id, _P_, pha, _NAME_, name, _VAL_, cell)
1806#define DT_PHA_BY_NAME_OR(node_id, pha, name, cell, default_value) \
1807 DT_PROP_OR(node_id, DT_CAT5(pha, _NAME_, name, _VAL_, cell), default_value)
1856#define DT_PHANDLE_BY_NAME(node_id, pha, name) \
1857 DT_CAT6(node_id, _P_, pha, _NAME_, name, _PH)
1908#define DT_PHANDLE_BY_IDX(node_id, prop, idx) \
1909 DT_CAT6(node_id, _P_, prop, _IDX_, idx, _PH)
1922#define DT_PHANDLE(node_id, prop) DT_PHANDLE_BY_IDX(node_id, prop, 0)
1970#define DT_NUM_RANGES(node_id) DT_CAT(node_id, _RANGES_NUM)
2024#define DT_RANGES_HAS_IDX(node_id, idx) \
2025 IS_ENABLED(DT_CAT4(node_id, _RANGES_IDX_, idx, _EXISTS))
2079#define DT_RANGES_HAS_CHILD_BUS_FLAGS_AT_IDX(node_id, idx) \
2080 IS_ENABLED(DT_CAT4(node_id, _RANGES_IDX_, idx, _VAL_CHILD_BUS_FLAGS_EXISTS))
2119#define DT_RANGES_CHILD_BUS_FLAGS_BY_IDX(node_id, idx) \
2120 DT_CAT4(node_id, _RANGES_IDX_, idx, _VAL_CHILD_BUS_FLAGS)
2168#define DT_RANGES_CHILD_BUS_ADDRESS_BY_IDX(node_id, idx) \
2169 DT_CAT4(node_id, _RANGES_IDX_, idx, _VAL_CHILD_BUS_ADDRESS)
2217#define DT_RANGES_PARENT_BUS_ADDRESS_BY_IDX(node_id, idx) \
2218 DT_CAT4(node_id, _RANGES_IDX_, idx, _VAL_PARENT_BUS_ADDRESS)
2266#define DT_RANGES_LENGTH_BY_IDX(node_id, idx) \
2267 DT_CAT4(node_id, _RANGES_IDX_, idx, _VAL_LENGTH)
2308#define DT_FOREACH_RANGE(node_id, fn) \
2309 DT_CAT(node_id, _FOREACH_RANGE)(fn)
2356#define DT_NODE_VENDOR_BY_IDX(node_id, idx) \
2357 DT_CAT3(node_id, _COMPAT_VENDOR_IDX_, idx)
2371#define DT_NODE_VENDOR_HAS_IDX(node_id, idx) \
2372 IS_ENABLED(DT_CAT4(node_id, _COMPAT_VENDOR_IDX_, idx, _EXISTS))
2388#define DT_NODE_VENDOR_BY_IDX_OR(node_id, idx, default_value) \
2389 COND_CODE_1(DT_NODE_VENDOR_HAS_IDX(node_id, idx), \
2390 (DT_NODE_VENDOR_BY_IDX(node_id, idx)), (default_value))
2400#define DT_NODE_VENDOR_OR(node_id, default_value) \
2401 DT_NODE_VENDOR_BY_IDX_OR(node_id, 0, default_value)
2432#define DT_NODE_MODEL_BY_IDX(node_id, idx) \
2433 DT_CAT3(node_id, _COMPAT_MODEL_IDX_, idx)
2447#define DT_NODE_MODEL_HAS_IDX(node_id, idx) \
2448 IS_ENABLED(DT_CAT4(node_id, _COMPAT_MODEL_IDX_, idx, _EXISTS))
2464#define DT_NODE_MODEL_BY_IDX_OR(node_id, idx, default_value) \
2465 COND_CODE_1(DT_NODE_MODEL_HAS_IDX(node_id, idx), \
2466 (DT_NODE_MODEL_BY_IDX(node_id, idx)), (default_value))
2476#define DT_NODE_MODEL_OR(node_id, default_value) \
2477 DT_NODE_MODEL_BY_IDX_OR(node_id, 0, default_value)
2496#define DT_NUM_REGS(node_id) DT_CAT(node_id, _REG_NUM)
2509#define DT_REG_HAS_IDX(node_id, idx) \
2510 IS_ENABLED(DT_CAT4(node_id, _REG_IDX_, idx, _EXISTS))
2523#define DT_REG_HAS_NAME(node_id, name) \
2524 IS_ENABLED(DT_CAT4(node_id, _REG_NAME_, name, _EXISTS))
2537#define DT_REG_ADDR_BY_IDX_RAW(node_id, idx) \
2538 DT_CAT4(node_id, _REG_IDX_, idx, _VAL_ADDRESS)
2551#define DT_REG_ADDR_RAW(node_id) \
2552 DT_REG_ADDR_BY_IDX_RAW(node_id, 0)
2560#define DT_REG_ADDR_BY_IDX(node_id, idx) \
2561 DT_U32_C(DT_REG_ADDR_BY_IDX_RAW(node_id, idx))
2574#define DT_REG_SIZE_BY_IDX(node_id, idx) \
2575 DT_U32_C(DT_CAT4(node_id, _REG_IDX_, idx, _VAL_SIZE))
2584#define DT_REG_ADDR(node_id) DT_REG_ADDR_BY_IDX(node_id, 0)
2596#define DT_REG_ADDR_U64(node_id) DT_U64_C(DT_REG_ADDR_BY_IDX_RAW(node_id, 0))
2605#define DT_REG_SIZE(node_id) DT_REG_SIZE_BY_IDX(node_id, 0)
2613#define DT_REG_ADDR_BY_NAME(node_id, name) \
2614 DT_U32_C(DT_CAT4(node_id, _REG_NAME_, name, _VAL_ADDRESS))
2624#define DT_REG_ADDR_BY_NAME_OR(node_id, name, default_value) \
2625 COND_CODE_1(DT_REG_HAS_NAME(node_id, name), \
2626 (DT_REG_ADDR_BY_NAME(node_id, name)), (default_value))
2640#define DT_REG_ADDR_BY_NAME_U64(node_id, name) \
2641 DT_U64_C(DT_CAT4(node_id, _REG_NAME_, name, _VAL_ADDRESS))
2649#define DT_REG_SIZE_BY_NAME(node_id, name) \
2650 DT_U32_C(DT_CAT4(node_id, _REG_NAME_, name, _VAL_SIZE))
2660#define DT_REG_SIZE_BY_NAME_OR(node_id, name, default_value) \
2661 COND_CODE_1(DT_REG_HAS_NAME(node_id, name), \
2662 (DT_REG_SIZE_BY_NAME(node_id, name)), (default_value))
2712#define DT_FOREACH_REG(node_id, fn) \
2713 DT_CAT(node_id, _FOREACH_REG)(fn)
2763#define DT_FOREACH_REG_SEP(node_id, fn, sep) \
2764 DT_CAT(node_id, _FOREACH_REG_SEP)(fn, sep)
2780#define DT_FOREACH_REG_VARGS(node_id, fn, ...) \
2781 DT_CAT(node_id, _FOREACH_REG_VARGS)(fn, __VA_ARGS__)
2799#define DT_FOREACH_REG_SEP_VARGS(node_id, fn, sep, ...) \
2800 DT_CAT(node_id, _FOREACH_REG_SEP_VARGS)(fn, sep, __VA_ARGS__)
2820#define DT_NUM_IRQS(node_id) DT_CAT(node_id, _IRQ_NUM)
2846#define DT_NUM_NODELABELS(node_id) DT_CAT(node_id, _NODELABEL_NUM)
2854#define DT_IRQ_LEVEL(node_id) DT_CAT(node_id, _IRQ_LEVEL)
2866#define DT_IRQ_HAS_IDX(node_id, idx) \
2867 IS_ENABLED(DT_CAT4(node_id, _IRQ_IDX_, idx, _EXISTS))
2879#define DT_IRQ_HAS_CELL_AT_IDX(node_id, idx, cell) \
2880 IS_ENABLED(DT_CAT6(node_id, _IRQ_IDX_, idx, _VAL_, cell, _EXISTS))
2889#define DT_IRQ_HAS_CELL(node_id, cell) DT_IRQ_HAS_CELL_AT_IDX(node_id, 0, cell)
2900#define DT_IRQ_HAS_NAME(node_id, name) \
2901 IS_ENABLED(DT_CAT4(node_id, _IRQ_NAME_, name, _VAL_irq_EXISTS))
2938#define DT_IRQ_BY_IDX(node_id, idx, cell) \
2939 DT_CAT5(node_id, _IRQ_IDX_, idx, _VAL_, cell)
2956#define DT_IRQ_BY_NAME(node_id, name, cell) \
2957 DT_CAT5(node_id, _IRQ_NAME_, name, _VAL_, cell)
2966#define DT_IRQ(node_id, cell) DT_IRQ_BY_IDX(node_id, 0, cell)
3010#define DT_IRQ_INTC_BY_IDX(node_id, idx) \
3011 DT_CAT4(node_id, _IRQ_IDX_, idx, _CONTROLLER)
3057#define DT_IRQ_INTC_BY_NAME(node_id, name) \
3058 DT_CAT4(node_id, _IRQ_NAME_, name, _CONTROLLER)
3099#define DT_IRQ_INTC(node_id) \
3100 DT_IRQ_INTC_BY_IDX(node_id, 0)
3107#define DT_IRQN_L1_INTERNAL(node_id, idx) DT_IRQ_BY_IDX(node_id, idx, irq)
3109#define DT_IRQN_L2_INTERNAL(node_id, idx) \
3110 (IRQ_TO_L2(DT_IRQN_L1_INTERNAL(node_id, idx)) | \
3111 DT_IRQ(DT_IRQ_INTC_BY_IDX(node_id, idx), irq))
3113#define DT_IRQN_L3_INTERNAL(node_id, idx) \
3114 (IRQ_TO_L3(DT_IRQN_L1_INTERNAL(node_id, idx)) | \
3115 IRQ_TO_L2(DT_IRQ(DT_IRQ_INTC_BY_IDX(node_id, idx), irq)) | \
3116 DT_IRQ(DT_IRQ_INTC(DT_IRQ_INTC_BY_IDX(node_id, idx)), irq))
3118#define DT_IRQN_LVL_INTERNAL(node_id, idx, level) DT_CAT3(DT_IRQN_L, level, _INTERNAL)(node_id, idx)
3124#define DT_MULTI_LEVEL_IRQN_INTERNAL(node_id, idx) \
3125 DT_IRQN_LVL_INTERNAL(node_id, idx, DT_IRQ_LEVEL(node_id))
3129#define DT_IRQN_NAME_L1_INTERNAL(node_id, name) DT_IRQ_BY_NAME(node_id, name, irq)
3131#define DT_IRQN_NAME_L2_INTERNAL(node_id, name) \
3132 (IRQ_TO_L2(DT_IRQN_NAME_L1_INTERNAL(node_id, name)) | \
3133 DT_IRQ(DT_IRQ_INTC_BY_NAME(node_id, name), irq))
3135#define DT_IRQN_NAME_L3_INTERNAL(node_id, name) \
3136 (IRQ_TO_L3(DT_IRQN_NAME_L1_INTERNAL(node_id, name)) | \
3137 IRQ_TO_L2(DT_IRQ(DT_IRQ_INTC_BY_NAME(node_id, name), irq)) | \
3138 DT_IRQ(DT_IRQ_INTC(DT_IRQ_INTC_BY_NAME(node_id, name)), irq))
3140#define DT_IRQN_NAME_LVL_INTERNAL(node_id, name, level) \
3141 DT_CAT3(DT_IRQN_NAME_L, level, _INTERNAL)(node_id, name)
3147#define DT_MULTI_LEVEL_IRQN_NAME_INTERNAL(node_id, name) \
3148 DT_IRQN_NAME_LVL_INTERNAL(node_id, name, DT_IRQ_LEVEL(node_id))
3162#define DT_IRQN_BY_IDX(node_id, idx) \
3163 COND_CODE_1(IS_ENABLED(CONFIG_MULTI_LEVEL_INTERRUPTS), \
3164 (DT_MULTI_LEVEL_IRQN_INTERNAL(node_id, idx)), \
3165 (DT_IRQ_BY_IDX(node_id, idx, irq)))
3175#define DT_IRQN_BY_NAME(node_id, name) \
3176 COND_CODE_1(IS_ENABLED(CONFIG_MULTI_LEVEL_INTERRUPTS), \
3177 (DT_MULTI_LEVEL_IRQN_NAME_INTERNAL(node_id, name)), \
3178 (DT_IRQ_BY_NAME(node_id, name, irq)))
3190#define DT_IRQN(node_id) DT_IRQN_BY_IDX(node_id, 0)
3210#define DT_CHOSEN(prop) DT_CAT(DT_CHOSEN_, prop)
3218#define DT_HAS_CHOSEN(prop) IS_ENABLED(DT_CAT3(DT_CHOSEN_, prop, _EXISTS))
3269#define DT_FOREACH_NODE(fn) DT_FOREACH_HELPER(fn)
3283#define DT_FOREACH_NODE_VARGS(fn, ...) DT_FOREACH_VARGS_HELPER(fn, __VA_ARGS__)
3296#define DT_FOREACH_STATUS_OKAY_NODE(fn) DT_FOREACH_OKAY_HELPER(fn)
3312#define DT_FOREACH_STATUS_OKAY_NODE_VARGS(fn, ...) DT_FOREACH_OKAY_VARGS_HELPER(fn, __VA_ARGS__)
3360#define DT_FOREACH_ANCESTOR(node_id, fn) \
3361 DT_CAT(node_id, _FOREACH_ANCESTOR)(fn)
3406#define DT_FOREACH_CHILD(node_id, fn) \
3407 DT_CAT(node_id, _FOREACH_CHILD)(fn)
3449#define DT_FOREACH_CHILD_SEP(node_id, fn, sep) \
3450 DT_CAT(node_id, _FOREACH_CHILD_SEP)(fn, sep)
3467#define DT_FOREACH_CHILD_VARGS(node_id, fn, ...) \
3468 DT_CAT(node_id, _FOREACH_CHILD_VARGS)(fn, __VA_ARGS__)
3485#define DT_FOREACH_CHILD_SEP_VARGS(node_id, fn, sep, ...) \
3486 DT_CAT(node_id, _FOREACH_CHILD_SEP_VARGS)(fn, sep, __VA_ARGS__)
3503#define DT_FOREACH_CHILD_STATUS_OKAY(node_id, fn) \
3504 DT_CAT(node_id, _FOREACH_CHILD_STATUS_OKAY)(fn)
3522#define DT_FOREACH_CHILD_STATUS_OKAY_SEP(node_id, fn, sep) \
3523 DT_CAT(node_id, _FOREACH_CHILD_STATUS_OKAY_SEP)(fn, sep)
3544#define DT_FOREACH_CHILD_STATUS_OKAY_VARGS(node_id, fn, ...) \
3545 DT_CAT(node_id, _FOREACH_CHILD_STATUS_OKAY_VARGS)(fn, __VA_ARGS__)
3565#define DT_FOREACH_CHILD_STATUS_OKAY_SEP_VARGS(node_id, fn, sep, ...) \
3566 DT_CAT(node_id, _FOREACH_CHILD_STATUS_OKAY_SEP_VARGS)(fn, sep, __VA_ARGS__)
3618#define DT_FOREACH_PROP_ELEM(node_id, prop, fn) \
3619 DT_CAT4(node_id, _P_, prop, _FOREACH_PROP_ELEM)(fn)
3663#define DT_FOREACH_PROP_ELEM_SEP(node_id, prop, fn, sep) \
3664 DT_CAT4(node_id, _P_, prop, _FOREACH_PROP_ELEM_SEP)(fn, sep)
3686#define DT_FOREACH_PROP_ELEM_VARGS(node_id, prop, fn, ...) \
3687 DT_CAT4(node_id, _P_, prop, _FOREACH_PROP_ELEM_VARGS)(fn, __VA_ARGS__)
3705#define DT_FOREACH_PROP_ELEM_SEP_VARGS(node_id, prop, fn, sep, ...) \
3706 DT_CAT4(node_id, _P_, prop, _FOREACH_PROP_ELEM_SEP_VARGS)( \
3707 fn, sep, __VA_ARGS__)
3762#define DT_FOREACH_STATUS_OKAY(compat, fn) \
3763 COND_CODE_1(DT_HAS_COMPAT_STATUS_OKAY(compat), \
3764 (UTIL_CAT(DT_FOREACH_OKAY_, compat)(fn)), \
3811#define DT_FOREACH_STATUS_OKAY_VARGS(compat, fn, ...) \
3812 COND_CODE_1(DT_HAS_COMPAT_STATUS_OKAY(compat), \
3813 (DT_CAT(DT_FOREACH_OKAY_VARGS_, \
3814 compat)(fn, __VA_ARGS__)), \
3829#define DT_COMPAT_FOREACH_STATUS_OKAY_VARGS(compat, fn, ...) \
3830 COND_CODE_1(DT_HAS_COMPAT_STATUS_OKAY(compat), \
3831 (UTIL_CAT(DT_FOREACH_OKAY_INST_VARGS_, \
3832 compat)(fn, compat, __VA_ARGS__)), \
3874#define DT_FOREACH_NODELABEL(node_id, fn) DT_CAT(node_id, _FOREACH_NODELABEL)(fn)
3913#define DT_FOREACH_NODELABEL_VARGS(node_id, fn, ...) \
3914 DT_CAT(node_id, _FOREACH_NODELABEL_VARGS)(fn, __VA_ARGS__)
3940#define DT_NODE_EXISTS(node_id) IS_ENABLED(DT_CAT(node_id, _EXISTS))
3963#define DT_NODE_HAS_STATUS(node_id, status) \
3964 DT_NODE_HAS_STATUS_INTERNAL(node_id, status)
3986#define DT_NODE_HAS_STATUS_OKAY(node_id) DT_NODE_HAS_STATUS(node_id, okay)
4007#define DT_HAS_COMPAT_STATUS_OKAY(compat) \
4008 IS_ENABLED(DT_CAT(DT_COMPAT_HAS_OKAY_, compat))
4016#define DT_NUM_INST_STATUS_OKAY(compat) \
4017 UTIL_AND(DT_HAS_COMPAT_STATUS_OKAY(compat), \
4018 UTIL_CAT(DT_N_INST, DT_DASH(compat, NUM_OKAY)))
4047#define DT_NODE_HAS_COMPAT(node_id, compat) \
4048 IS_ENABLED(DT_CAT3(node_id, _COMPAT_MATCHES_, compat))
4064#define DT_NODE_HAS_COMPAT_STATUS(node_id, compat, status) \
4065 UTIL_AND(DT_NODE_HAS_COMPAT(node_id, compat), DT_NODE_HAS_STATUS(node_id, status))
4080#define DT_NODE_HAS_PROP(node_id, prop) \
4081 IS_ENABLED(DT_CAT4(node_id, _P_, prop, _EXISTS))
4100#define DT_PHA_HAS_CELL_AT_IDX(node_id, pha, idx, cell) \
4101 IS_ENABLED(DT_CAT8(node_id, _P_, pha, \
4102 _IDX_, idx, _VAL_, cell, _EXISTS))
4113#define DT_PHA_HAS_CELL(node_id, pha, cell) \
4114 DT_PHA_HAS_CELL_AT_IDX(node_id, pha, 0, cell)
4136#define DT_FOREACH_PHA_CELL_BY_IDX(node_id, pha, idx, fn) \
4137 DT_CAT6(node_id, _P_, pha, _IDX_, idx, _FOREACH_CELL)(fn)
4151#define DT_FOREACH_PHA_CELL_BY_IDX_SEP(node_id, pha, idx, fn, sep) \
4152 DT_CAT6(node_id, _P_, pha, _IDX_, idx, _FOREACH_CELL_SEP)(fn, sep)
4162#define DT_PHA_NUM_CELLS_BY_IDX(node_id, pha, idx) \
4163 DT_CAT6(node_id, _P_, pha, _IDX_, idx, _NUM_CELLS)
4176#define DT_PHA_ELEM_NAME_BY_IDX(node_id, pha, idx) \
4177 DT_CAT6(node_id, _P_, pha, _IDX_, idx, _NAME)
4200#define DT_FOREACH_PHA_CELL_BY_NAME(node_id, pha, name, fn) \
4201 DT_CAT6(node_id, _P_, pha, _NAME_, name, _FOREACH_CELL)(fn)
4215#define DT_FOREACH_PHA_CELL_BY_NAME_SEP(node_id, pha, name, fn, sep) \
4216 DT_CAT6(node_id, _P_, pha, _NAME_, name, _FOREACH_CELL_SEP)(fn, sep)
4226#define DT_PHA_NUM_CELLS_BY_NAME(node_id, pha, name) \
4227 DT_CAT6(node_id, _P_, pha, _NAME_, name, _NUM_CELLS)
4240#define DT_PHA_ELEM_IDX_BY_NAME(node_id, pha, name) \
4241 DT_CAT6(node_id, _P_, pha, _NAME_, name, _IDX)
4285#define DT_BUS(node_id) DT_CAT(node_id, _BUS)
4315#define DT_ON_BUS(node_id, bus) IS_ENABLED(DT_CAT3(node_id, _BUS_, bus))
4333#define DT_DRV_INST(inst) DT_INST(inst, DT_DRV_COMPAT)
4342#define DT_INST_PARENT(inst) DT_PARENT(DT_DRV_INST(inst))
4351#define DT_INST_GPARENT(inst) DT_GPARENT(DT_DRV_INST(inst))
4362#define DT_INST_CHILD(inst, child) \
4363 DT_CHILD(DT_DRV_INST(inst), child)
4377#define DT_INST_CHILD_BY_UNIT_ADDR_INT(inst, addr) \
4378 DT_CHILD_BY_UNIT_ADDR_INT(DT_DRV_INST(inst), addr)
4389#define DT_INST_CHILD_NUM(inst) DT_CHILD_NUM(DT_DRV_INST(inst))
4401#define DT_INST_CHILD_NUM_STATUS_OKAY(inst) \
4402 DT_CHILD_NUM_STATUS_OKAY(DT_DRV_INST(inst))
4416#define DT_INST_DESCENDANT_NUM_ON_BUS(inst, bus) \
4417 DT_DESCENDANT_NUM_ON_BUS(DT_DRV_INST(inst), bus)
4432#define DT_INST_DESCENDANT_NUM_ON_BUS_STATUS_OKAY(inst, bus) \
4433 DT_DESCENDANT_NUM_ON_BUS_STATUS_OKAY(DT_DRV_INST(inst), bus)
4443#define DT_INST_NODELABEL_STRING_ARRAY(inst) DT_NODELABEL_STRING_ARRAY(DT_DRV_INST(inst))
4453#define DT_INST_NUM_NODELABELS(inst) DT_NUM_NODELABELS(DT_DRV_INST(inst))
4469#define DT_INST_FOREACH_CHILD(inst, fn) \
4470 DT_FOREACH_CHILD(DT_DRV_INST(inst), fn)
4485#define DT_INST_FOREACH_CHILD_SEP(inst, fn, sep) \
4486 DT_FOREACH_CHILD_SEP(DT_DRV_INST(inst), fn, sep)
4503#define DT_INST_FOREACH_CHILD_VARGS(inst, fn, ...) \
4504 DT_FOREACH_CHILD_VARGS(DT_DRV_INST(inst), fn, __VA_ARGS__)
4520#define DT_INST_FOREACH_CHILD_SEP_VARGS(inst, fn, sep, ...) \
4521 DT_FOREACH_CHILD_SEP_VARGS(DT_DRV_INST(inst), fn, sep, __VA_ARGS__)
4534#define DT_INST_FOREACH_CHILD_STATUS_OKAY(inst, fn) \
4535 DT_FOREACH_CHILD_STATUS_OKAY(DT_DRV_INST(inst), fn)
4551#define DT_INST_FOREACH_CHILD_STATUS_OKAY_SEP(inst, fn, sep) \
4552 DT_FOREACH_CHILD_STATUS_OKAY_SEP(DT_DRV_INST(inst), fn, sep)
4567#define DT_INST_FOREACH_CHILD_STATUS_OKAY_VARGS(inst, fn, ...) \
4568 DT_FOREACH_CHILD_STATUS_OKAY_VARGS(DT_DRV_INST(inst), fn, __VA_ARGS__)
4585#define DT_INST_FOREACH_CHILD_STATUS_OKAY_SEP_VARGS(inst, fn, sep, ...) \
4586 DT_FOREACH_CHILD_STATUS_OKAY_SEP_VARGS(DT_DRV_INST(inst), fn, sep, __VA_ARGS__)
4602#define DT_INST_FOREACH_REG(inst, fn) \
4603 DT_FOREACH_REG(DT_DRV_INST(inst), fn)
4621#define DT_INST_FOREACH_REG_SEP(inst, fn, sep) \
4622 DT_FOREACH_REG_SEP(DT_DRV_INST(inst), fn, sep)
4640#define DT_INST_FOREACH_REG_VARGS(inst, fn, ...) \
4641 DT_FOREACH_REG_VARGS(DT_DRV_INST(inst), fn, __VA_ARGS__)
4661#define DT_INST_FOREACH_REG_SEP_VARGS(inst, fn, sep, ...) \
4662 DT_FOREACH_REG_SEP_VARGS(DT_DRV_INST(inst), fn, sep, __VA_ARGS__)
4671#define DT_INST_ENUM_IDX_BY_IDX(inst, prop, idx) \
4672 DT_ENUM_IDX_BY_IDX(DT_DRV_INST(inst), prop, idx)
4680#define DT_INST_ENUM_IDX(inst, prop) \
4681 DT_ENUM_IDX(DT_DRV_INST(inst), prop)
4692#define DT_INST_ENUM_IDX_BY_IDX_OR(inst, prop, idx, default_idx_value) \
4693 DT_ENUM_IDX_BY_IDX_OR(DT_DRV_INST(inst), prop, idx, default_idx_value)
4703#define DT_INST_ENUM_IDX_OR(inst, prop, default_idx_value) \
4704 DT_ENUM_IDX_OR(DT_DRV_INST(inst), prop, default_idx_value)
4714#define DT_INST_ENUM_HAS_VALUE_BY_IDX(inst, prop, idx, value) \
4715 DT_ENUM_HAS_VALUE_BY_IDX(DT_DRV_INST(inst), prop, idx, value)
4725#define DT_INST_ENUM_HAS_VALUE(inst, prop, value) \
4726 DT_ENUM_HAS_VALUE(DT_DRV_INST(inst), prop, value)
4734#define DT_INST_PROP(inst, prop) DT_PROP(DT_DRV_INST(inst), prop)
4742#define DT_INST_PROP_LEN(inst, prop) DT_PROP_LEN(DT_DRV_INST(inst), prop)
4753#define DT_INST_PROP_HAS_IDX(inst, prop, idx) \
4754 DT_PROP_HAS_IDX(DT_DRV_INST(inst), prop, idx)
4764#define DT_INST_PROP_HAS_NAME(inst, prop, name) \
4765 DT_PROP_HAS_NAME(DT_DRV_INST(inst), prop, name)
4774#define DT_INST_PROP_BY_IDX(inst, prop, idx) \
4775 DT_PROP_BY_IDX(DT_DRV_INST(inst), prop, idx)
4784#define DT_INST_PROP_OR(inst, prop, default_value) \
4785 DT_PROP_OR(DT_DRV_INST(inst), prop, default_value)
4794#define DT_INST_PROP_LEN_OR(inst, prop, default_value) \
4795 DT_PROP_LEN_OR(DT_DRV_INST(inst), prop, default_value)
4806#define DT_INST_STRING_TOKEN(inst, prop) \
4807 DT_STRING_TOKEN(DT_DRV_INST(inst), prop)
4816#define DT_INST_STRING_UPPER_TOKEN(inst, prop) \
4817 DT_STRING_UPPER_TOKEN(DT_DRV_INST(inst), prop)
4827#define DT_INST_STRING_UNQUOTED(inst, prop) \
4828 DT_STRING_UNQUOTED(DT_DRV_INST(inst), prop)
4837#define DT_INST_STRING_TOKEN_BY_IDX(inst, prop, idx) \
4838 DT_STRING_TOKEN_BY_IDX(DT_DRV_INST(inst), prop, idx)
4848#define DT_INST_STRING_TOKEN_BY_IDX_OR(inst, prop, idx, default_value) \
4849 DT_STRING_TOKEN_BY_IDX_OR(DT_DRV_INST(inst), prop, idx, default_value)
4858#define DT_INST_STRING_UPPER_TOKEN_BY_IDX(inst, prop, idx) \
4859 DT_STRING_UPPER_TOKEN_BY_IDX(DT_DRV_INST(inst), prop, idx)
4868#define DT_INST_STRING_UNQUOTED_BY_IDX(inst, prop, idx) \
4869 DT_STRING_UNQUOTED_BY_IDX(DT_DRV_INST(inst), prop, idx)
4879#define DT_INST_PROP_BY_PHANDLE(inst, ph, prop) \
4880 DT_INST_PROP_BY_PHANDLE_IDX(inst, ph, 0, prop)
4893#define DT_INST_PROP_BY_PHANDLE_IDX(inst, phs, idx, prop) \
4894 DT_PROP_BY_PHANDLE_IDX(DT_DRV_INST(inst), phs, idx, prop)
4904#define DT_INST_PHA_BY_IDX(inst, pha, idx, cell) \
4905 DT_PHA_BY_IDX(DT_DRV_INST(inst), pha, idx, cell)
4916#define DT_INST_PHA_BY_IDX_OR(inst, pha, idx, cell, default_value) \
4917 DT_PHA_BY_IDX_OR(DT_DRV_INST(inst), pha, idx, cell, default_value)
4927#define DT_INST_PHA(inst, pha, cell) DT_INST_PHA_BY_IDX(inst, pha, 0, cell)
4937#define DT_INST_PHA_OR(inst, pha, cell, default_value) \
4938 DT_INST_PHA_BY_IDX_OR(inst, pha, 0, cell, default_value)
4949#define DT_INST_PHA_BY_NAME(inst, pha, name, cell) \
4950 DT_PHA_BY_NAME(DT_DRV_INST(inst), pha, name, cell)
4961#define DT_INST_PHA_BY_NAME_OR(inst, pha, name, cell, default_value) \
4962 DT_PHA_BY_NAME_OR(DT_DRV_INST(inst), pha, name, cell, default_value)
4972#define DT_INST_PHANDLE_BY_NAME(inst, pha, name) \
4973 DT_PHANDLE_BY_NAME(DT_DRV_INST(inst), pha, name) \
4984#define DT_INST_PHANDLE_BY_IDX(inst, prop, idx) \
4985 DT_PHANDLE_BY_IDX(DT_DRV_INST(inst), prop, idx)
4995#define DT_INST_PHANDLE(inst, prop) DT_INST_PHANDLE_BY_IDX(inst, prop, 0)
5004#define DT_INST_REG_HAS_IDX(inst, idx) DT_REG_HAS_IDX(DT_DRV_INST(inst), idx)
5013#define DT_INST_REG_HAS_NAME(inst, name) DT_REG_HAS_NAME(DT_DRV_INST(inst), name)
5021#define DT_INST_REG_ADDR_BY_IDX_RAW(inst, idx) DT_REG_ADDR_BY_IDX_RAW(DT_DRV_INST(inst), idx)
5029#define DT_INST_REG_ADDR_BY_IDX(inst, idx) DT_REG_ADDR_BY_IDX(DT_DRV_INST(inst), idx)
5037#define DT_INST_REG_SIZE_BY_IDX(inst, idx) \
5038 DT_REG_SIZE_BY_IDX(DT_DRV_INST(inst), idx)
5046#define DT_INST_REG_ADDR_BY_NAME(inst, name) \
5047 DT_REG_ADDR_BY_NAME(DT_DRV_INST(inst), name)
5057#define DT_INST_REG_ADDR_BY_NAME_OR(inst, name, default_value) \
5058 DT_REG_ADDR_BY_NAME_OR(DT_DRV_INST(inst), name, default_value)
5072#define DT_INST_REG_ADDR_BY_NAME_U64(inst, name) \
5073 DT_REG_ADDR_BY_NAME_U64(DT_DRV_INST(inst), name)
5081#define DT_INST_REG_SIZE_BY_NAME(inst, name) \
5082 DT_REG_SIZE_BY_NAME(DT_DRV_INST(inst), name)
5092#define DT_INST_REG_SIZE_BY_NAME_OR(inst, name, default_value) \
5093 DT_REG_SIZE_BY_NAME_OR(DT_DRV_INST(inst), name, default_value)
5100#define DT_INST_REG_ADDR_RAW(inst) DT_INST_REG_ADDR_BY_IDX_RAW(inst, 0)
5107#define DT_INST_REG_ADDR(inst) DT_INST_REG_ADDR_BY_IDX(inst, 0)
5120#define DT_INST_REG_ADDR_U64(inst) DT_REG_ADDR_U64(DT_DRV_INST(inst))
5127#define DT_INST_REG_SIZE(inst) DT_INST_REG_SIZE_BY_IDX(inst, 0)
5135#define DT_INST_NUM_IRQS(inst) DT_NUM_IRQS(DT_DRV_INST(inst))
5143#define DT_INST_IRQ_LEVEL(inst) DT_IRQ_LEVEL(DT_DRV_INST(inst))
5152#define DT_INST_IRQ_BY_IDX(inst, idx, cell) \
5153 DT_IRQ_BY_IDX(DT_DRV_INST(inst), idx, cell)
5161#define DT_INST_IRQ_INTC_BY_IDX(inst, idx) \
5162 DT_IRQ_INTC_BY_IDX(DT_DRV_INST(inst), idx)
5170#define DT_INST_IRQ_INTC_BY_NAME(inst, name) \
5171 DT_IRQ_INTC_BY_NAME(DT_DRV_INST(inst), name)
5180#define DT_INST_IRQ_INTC(inst) \
5181 DT_INST_IRQ_INTC_BY_IDX(inst, 0)
5190#define DT_INST_IRQ_BY_NAME(inst, name, cell) \
5191 DT_IRQ_BY_NAME(DT_DRV_INST(inst), name, cell)
5199#define DT_INST_IRQ(inst, cell) DT_INST_IRQ_BY_IDX(inst, 0, cell)
5206#define DT_INST_IRQN(inst) DT_IRQN(DT_DRV_INST(inst))
5214#define DT_INST_IRQN_BY_IDX(inst, idx) DT_IRQN_BY_IDX(DT_DRV_INST(inst), idx)
5222#define DT_INST_IRQN_BY_NAME(inst, name) \
5223 DT_IRQN_BY_NAME(DT_DRV_INST(inst), name)
5230#define DT_INST_BUS(inst) DT_BUS(DT_DRV_INST(inst))
5239#define DT_INST_ON_BUS(inst, bus) DT_ON_BUS(DT_DRV_INST(inst), bus)
5250#define DT_INST_STRING_TOKEN_OR(inst, name, default_value) \
5251 DT_STRING_TOKEN_OR(DT_DRV_INST(inst), name, default_value)
5261#define DT_INST_STRING_UPPER_TOKEN_OR(inst, name, default_value) \
5262 DT_STRING_UPPER_TOKEN_OR(DT_DRV_INST(inst), name, default_value)
5272#define DT_INST_STRING_UNQUOTED_OR(inst, name, default_value) \
5273 DT_STRING_UNQUOTED_OR(DT_DRV_INST(inst), name, default_value)
5305#define DT_HAS_COMPAT_ON_BUS_STATUS_OKAY(compat, bus) \
5306 IS_ENABLED(DT_CAT4(DT_COMPAT_, compat, _BUS_, bus))
5340#define DT_ANY_INST_ON_BUS_STATUS_OKAY(bus) \
5341 DT_HAS_COMPAT_ON_BUS_STATUS_OKAY(DT_DRV_COMPAT, bus)
5387#define DT_ANY_INST_HAS_PROP_STATUS_OKAY(prop) \
5388 UTIL_NOT(IS_EMPTY( \
5389 DT_INST_FOREACH_STATUS_OKAY_VARGS(DT_ANY_INST_HAS_PROP_STATUS_OKAY_, prop)))
5435#define DT_ALL_INST_HAS_PROP_STATUS_OKAY(prop) \
5436 IS_EMPTY(DT_INST_FOREACH_STATUS_OKAY_VARGS(DT_ALL_INST_HAS_PROP_STATUS_OKAY_, prop))
5482#define DT_ANY_COMPAT_HAS_PROP_STATUS_OKAY(compat, prop) \
5483 (DT_COMPAT_FOREACH_STATUS_OKAY_VARGS(compat, DT_COMPAT_NODE_HAS_PROP_AND_OR, prop) 0)
5532#define DT_ANY_INST_HAS_BOOL_STATUS_OKAY(prop) \
5533 UTIL_NOT(IS_EMPTY( \
5534 DT_INST_FOREACH_STATUS_OKAY_VARGS(DT_ANY_INST_HAS_BOOL_STATUS_OKAY_, prop)))
5581#define DT_ALL_INST_HAS_BOOL_STATUS_OKAY(prop) \
5582 IS_EMPTY(DT_INST_FOREACH_STATUS_OKAY_VARGS(DT_ALL_INST_HAS_BOOL_STATUS_OKAY_, prop))
5590#define DT_ANY_INST_REG_HAS_NAME_STATUS_OKAY(name) \
5591 UTIL_NOT(IS_EMPTY( \
5592 DT_INST_FOREACH_STATUS_OKAY_VARGS(DT_ANY_INST_REG_HAS_NAME_STATUS_OKAY_, name)))
5600#define DT_ALL_INST_REG_HAS_NAME_STATUS_OKAY(name) \
5601 IS_EMPTY(DT_INST_FOREACH_STATUS_OKAY_VARGS(DT_ALL_INST_REG_HAS_NAME_STATUS_OKAY_, name))
5668#define DT_INST_FOREACH_STATUS_OKAY(fn) \
5669 COND_CODE_1(DT_HAS_COMPAT_STATUS_OKAY(DT_DRV_COMPAT), \
5670 (UTIL_CAT(DT_FOREACH_OKAY_INST_, \
5671 DT_DRV_COMPAT)(fn)), \
5686#define DT_INST_FOREACH_STATUS_OKAY_VARGS(fn, ...) \
5687 COND_CODE_1(DT_HAS_COMPAT_STATUS_OKAY(DT_DRV_COMPAT), \
5688 (UTIL_CAT(DT_FOREACH_OKAY_INST_VARGS_, \
5689 DT_DRV_COMPAT)(fn, __VA_ARGS__)), \
5701#define DT_INST_FOREACH_NODELABEL(inst, fn) \
5702 DT_FOREACH_NODELABEL(DT_DRV_INST(inst), fn)
5715#define DT_INST_FOREACH_NODELABEL_VARGS(inst, fn, ...) \
5716 DT_FOREACH_NODELABEL_VARGS(DT_DRV_INST(inst), fn, __VA_ARGS__)
5728#define DT_INST_FOREACH_PROP_ELEM(inst, prop, fn) \
5729 DT_FOREACH_PROP_ELEM(DT_DRV_INST(inst), prop, fn)
5743#define DT_INST_FOREACH_PROP_ELEM_SEP(inst, prop, fn, sep) \
5744 DT_FOREACH_PROP_ELEM_SEP(DT_DRV_INST(inst), prop, fn, sep)
5760#define DT_INST_FOREACH_PROP_ELEM_VARGS(inst, prop, fn, ...) \
5761 DT_FOREACH_PROP_ELEM_VARGS(DT_DRV_INST(inst), prop, fn, __VA_ARGS__)
5780#define DT_INST_FOREACH_PROP_ELEM_SEP_VARGS(inst, prop, fn, sep, ...) \
5781 DT_FOREACH_PROP_ELEM_SEP_VARGS(DT_DRV_INST(inst), prop, fn, sep, \
5790#define DT_INST_NODE_HAS_PROP(inst, prop) \
5791 DT_NODE_HAS_PROP(DT_DRV_INST(inst), prop)
5799#define DT_INST_NODE_HAS_COMPAT(inst, compat) \
5800 DT_NODE_HAS_COMPAT(DT_DRV_INST(inst), compat)
5812#define DT_INST_PHA_HAS_CELL_AT_IDX(inst, pha, idx, cell) \
5813 DT_PHA_HAS_CELL_AT_IDX(DT_DRV_INST(inst), pha, idx, cell)
5824#define DT_INST_PHA_HAS_CELL(inst, pha, cell) \
5825 DT_INST_PHA_HAS_CELL_AT_IDX(inst, pha, 0, cell)
5834#define DT_INST_IRQ_HAS_IDX(inst, idx) DT_IRQ_HAS_IDX(DT_DRV_INST(inst), idx)
5844#define DT_INST_IRQ_HAS_CELL_AT_IDX(inst, idx, cell) \
5845 DT_IRQ_HAS_CELL_AT_IDX(DT_DRV_INST(inst), idx, cell)
5854#define DT_INST_IRQ_HAS_CELL(inst, cell) \
5855 DT_INST_IRQ_HAS_CELL_AT_IDX(inst, 0, cell)
5863#define DT_INST_IRQ_HAS_NAME(inst, name) \
5864 DT_IRQ_HAS_NAME(DT_DRV_INST(inst), name)
5883#define DT_ANY_INST_HAS_PROP_STATUS_OKAY_(inst, prop) \
5884 IF_ENABLED(DT_INST_NODE_HAS_PROP(inst, prop), (1,))
5898#define DT_ANY_INST_HAS_BOOL_STATUS_OKAY_(inst, prop) \
5899 IF_ENABLED(DT_INST_PROP(inst, prop), (1,))
5913#define DT_ANY_INST_REG_HAS_NAME_STATUS_OKAY_(inst, name) \
5914 IF_ENABLED(DT_INST_REG_HAS_NAME(inst, name), (1,))
5927#define DT_ALL_INST_HAS_PROP_STATUS_OKAY_(inst, prop) \
5928 IF_DISABLED(DT_INST_NODE_HAS_PROP(inst, prop), (1,))
5942#define DT_ALL_INST_HAS_BOOL_STATUS_OKAY_(inst, prop) \
5943 IF_DISABLED(DT_INST_PROP(inst, prop), (1,))
5957#define DT_ALL_INST_REG_HAS_NAME_STATUS_OKAY_(inst, name) \
5958 IF_DISABLED(DT_INST_REG_HAS_NAME(inst, name), (1,))
5960#define DT_PATH_INTERNAL(...) \
5961 UTIL_CAT(DT_ROOT, MACRO_MAP_CAT(DT_S_PREFIX, __VA_ARGS__))
5967#define DT_S_PREFIX(name) _S_##name
5983#define DT_CAT(a1, a2) a1 ## a2
5985#define DT_CAT3(a1, a2, a3) a1 ## a2 ## a3
5987#define DT_CAT4(a1, a2, a3, a4) a1 ## a2 ## a3 ## a4
5989#define DT_CAT5(a1, a2, a3, a4, a5) a1 ## a2 ## a3 ## a4 ## a5
5991#define DT_CAT6(a1, a2, a3, a4, a5, a6) a1 ## a2 ## a3 ## a4 ## a5 ## a6
5993#define DT_CAT7(a1, a2, a3, a4, a5, a6, a7) \
5994 a1 ## a2 ## a3 ## a4 ## a5 ## a6 ## a7
5996#define DT_CAT8(a1, a2, a3, a4, a5, a6, a7, a8) \
5997 a1 ## a2 ## a3 ## a4 ## a5 ## a6 ## a7 ## a8
6004#define DT_DASH(...) MACRO_MAP_CAT(DT_DASH_PREFIX, __VA_ARGS__)
6006#define DT_DASH_PREFIX(name) _##name
6008#define DT_NODE_HAS_STATUS_INTERNAL(node_id, status) \
6009 IS_ENABLED(DT_CAT3(node_id, _STATUS_, status))
6014#define DT_COMPAT_NODE_HAS_PROP_AND_OR(inst, compat, prop) \
6015 DT_NODE_HAS_PROP(DT_INST(inst, compat), prop) ||
6021#if defined(_LINKER) || defined(_ASMLANGUAGE)
6022#define DT_U32_C(_v) (_v)
6024#define DT_U32_C(_v) UINT32_C(_v)
6031#if defined(_LINKER) || defined(_ASMLANGUAGE)
6032#define DT_U64_C(_v) (_v)
6034#define DT_U64_C(_v) UINT64_C(_v)
6040#define DT_NODELABEL_STRING_ARRAY_ENTRY_INTERNAL(nodelabel) DT_STRINGIFY_INTERNAL(nodelabel),
6041#define DT_STRINGIFY_INTERNAL(arg) DT_STRINGIFY_INTERNAL_HELPER(arg)
6042#define DT_STRINGIFY_INTERNAL_HELPER(arg) #arg
Clocks Devicetree macro public API header file.
CAN devicetree macro public API header file.
Display Devicetree macro public API header file.
DMA Devicetree macro public API header file.
GPIO Devicetree macro public API header file.
HW spinlock Devicetree macro public API header file.
Map devicetree macro public API header file.
MBOX Devicetree macro public API header file.
Flash Devicetree macro public API header file, for partitions.
Devicetree pin control helpers.
Reset Controller Devicetree macro public API header file.
SPI Devicetree macro public API header file.
Wakeup Controller Devicetree macro public API header file.
Flash Devicetree macro public API header file.
IO channels devicetree macro public API header file.
Public interface for multi-level interrupts.
Flash Devicetree macro public API header file, for memory-mapped partitions.
Devicetree node dependency ordinals.
Port / Endpoint Devicetree macro public API header file.
PWMs Devicetree macro public API header file.
Chosen SRAM Devicetree macro public API header file.