1 /* SPDX-License-Identifier: GPL-2.0 */
3 * OF graph binding parsing helpers
5 * Copyright (C) 2012 - 2013 Samsung Electronics Co., Ltd.
6 * Author: Sylwester Nawrocki <s.nawrocki@samsung.com>
8 * Copyright (C) 2012 Renesas Electronics Corp.
9 * Author: Guennadi Liakhovetski <g.liakhovetski@gmx.de>
11 #ifndef __LINUX_OF_GRAPH_H
12 #define __LINUX_OF_GRAPH_H
14 #include <linux/cleanup.h>
15 #include <linux/types.h>
16 #include <linux/errno.h>
19 * struct of_endpoint - the OF graph endpoint data structure
20 * @port: identifier (value of reg property) of a port this endpoint belongs to
21 * @id: identifier (value of reg property) of this endpoint
22 * @local_node: pointer to device_node of this endpoint
27 const struct device_node
*local_node
;
31 * for_each_endpoint_of_node - iterate over every endpoint in a device node
32 * @parent: parent device node containing ports and endpoints
33 * @child: loop variable pointing to the current endpoint node
35 * When breaking out of the loop, of_node_put(child) has to be called manually.
37 #define for_each_endpoint_of_node(parent, child) \
38 for (child = of_graph_get_next_endpoint(parent, NULL); child != NULL; \
39 child = of_graph_get_next_endpoint(parent, child))
42 * for_each_of_graph_port - iterate over every port in a device or ports node
43 * @parent: parent device or ports node containing port
44 * @child: loop variable pointing to the current port node
46 * When breaking out of the loop, and continue to use the @child, you need to
47 * use return_ptr(@child) or no_free_ptr(@child) not to call __free() for it.
49 #define for_each_of_graph_port(parent, child) \
50 for (struct device_node *child __free(device_node) = of_graph_get_next_port(parent, NULL);\
51 child != NULL; child = of_graph_get_next_port(parent, child))
54 * for_each_of_graph_port_endpoint - iterate over every endpoint in a port node
55 * @parent: parent port node
56 * @child: loop variable pointing to the current endpoint node
58 * When breaking out of the loop, and continue to use the @child, you need to
59 * use return_ptr(@child) or no_free_ptr(@child) not to call __free() for it.
61 #define for_each_of_graph_port_endpoint(parent, child) \
62 for (struct device_node *child __free(device_node) = of_graph_get_next_port_endpoint(parent, NULL);\
63 child != NULL; child = of_graph_get_next_port_endpoint(parent, child))
66 bool of_graph_is_present(const struct device_node
*node
);
67 int of_graph_parse_endpoint(const struct device_node
*node
,
68 struct of_endpoint
*endpoint
);
69 unsigned int of_graph_get_endpoint_count(const struct device_node
*np
);
70 unsigned int of_graph_get_port_count(struct device_node
*np
);
71 struct device_node
*of_graph_get_port_by_id(struct device_node
*node
, u32 id
);
72 struct device_node
*of_graph_get_next_endpoint(const struct device_node
*parent
,
73 struct device_node
*previous
);
74 struct device_node
*of_graph_get_next_port(const struct device_node
*parent
,
75 struct device_node
*port
);
76 struct device_node
*of_graph_get_next_port_endpoint(const struct device_node
*port
,
77 struct device_node
*prev
);
78 struct device_node
*of_graph_get_endpoint_by_regs(
79 const struct device_node
*parent
, int port_reg
, int reg
);
80 struct device_node
*of_graph_get_remote_endpoint(
81 const struct device_node
*node
);
82 struct device_node
*of_graph_get_port_parent(struct device_node
*node
);
83 struct device_node
*of_graph_get_remote_port_parent(
84 const struct device_node
*node
);
85 struct device_node
*of_graph_get_remote_port(const struct device_node
*node
);
86 struct device_node
*of_graph_get_remote_node(const struct device_node
*node
,
87 u32 port
, u32 endpoint
);
90 static inline bool of_graph_is_present(const struct device_node
*node
)
95 static inline int of_graph_parse_endpoint(const struct device_node
*node
,
96 struct of_endpoint
*endpoint
)
101 static inline unsigned int of_graph_get_endpoint_count(const struct device_node
*np
)
106 static inline unsigned int of_graph_get_port_count(struct device_node
*np
)
111 static inline struct device_node
*of_graph_get_port_by_id(
112 struct device_node
*node
, u32 id
)
117 static inline struct device_node
*of_graph_get_next_endpoint(
118 const struct device_node
*parent
,
119 struct device_node
*previous
)
124 static inline struct device_node
*of_graph_get_next_port(
125 const struct device_node
*parent
,
126 struct device_node
*previous
)
131 static inline struct device_node
*of_graph_get_next_port_endpoint(
132 const struct device_node
*parent
,
133 struct device_node
*previous
)
138 static inline struct device_node
*of_graph_get_endpoint_by_regs(
139 const struct device_node
*parent
, int port_reg
, int reg
)
144 static inline struct device_node
*of_graph_get_remote_endpoint(
145 const struct device_node
*node
)
150 static inline struct device_node
*of_graph_get_port_parent(
151 struct device_node
*node
)
156 static inline struct device_node
*of_graph_get_remote_port_parent(
157 const struct device_node
*node
)
162 static inline struct device_node
*of_graph_get_remote_port(
163 const struct device_node
*node
)
167 static inline struct device_node
*of_graph_get_remote_node(
168 const struct device_node
*node
,
169 u32 port
, u32 endpoint
)
174 #endif /* CONFIG_OF */
176 #endif /* __LINUX_OF_GRAPH_H */