Blame view
include/linux/of_graph.h
2.78 KB
fd9fdb78a
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
/* * OF graph binding parsing helpers * * Copyright (C) 2012 - 2013 Samsung Electronics Co., Ltd. * Author: Sylwester Nawrocki <s.nawrocki@samsung.com> * * Copyright (C) 2012 Renesas Electronics Corp. * Author: Guennadi Liakhovetski <g.liakhovetski@gmx.de> * * This program is free software; you can redistribute it and/or modify * it under the terms of version 2 of the GNU General Public License as * published by the Free Software Foundation. */ #ifndef __LINUX_OF_GRAPH_H #define __LINUX_OF_GRAPH_H |
01218bf14
|
16 |
#include <linux/types.h> |
011d6f5c3
|
17 |
#include <linux/errno.h> |
01218bf14
|
18 |
|
f2a575f67
|
19 20 21 22 23 24 25 26 27 28 29 |
/** * struct of_endpoint - the OF graph endpoint data structure * @port: identifier (value of reg property) of a port this endpoint belongs to * @id: identifier (value of reg property) of this endpoint * @local_node: pointer to device_node of this endpoint */ struct of_endpoint { unsigned int port; unsigned int id; const struct device_node *local_node; }; |
ee8905963
|
30 31 32 33 34 35 36 37 38 39 |
/** * for_each_endpoint_of_node - iterate over every endpoint in a device node * @parent: parent device node containing ports and endpoints * @child: loop variable pointing to the current endpoint node * * When breaking out of the loop, of_node_put(child) has to be called manually. */ #define for_each_endpoint_of_node(parent, child) \ for (child = of_graph_get_next_endpoint(parent, NULL); child != NULL; \ child = of_graph_get_next_endpoint(parent, child)) |
fd9fdb78a
|
40 |
#ifdef CONFIG_OF |
f2a575f67
|
41 42 |
int of_graph_parse_endpoint(const struct device_node *node, struct of_endpoint *endpoint); |
bfe446e37
|
43 |
struct device_node *of_graph_get_port_by_id(struct device_node *node, u32 id); |
fd9fdb78a
|
44 45 |
struct device_node *of_graph_get_next_endpoint(const struct device_node *parent, struct device_node *previous); |
8ccd0d0ca
|
46 47 |
struct device_node *of_graph_get_endpoint_by_regs( const struct device_node *parent, int port_reg, int reg); |
fd9fdb78a
|
48 49 50 51 |
struct device_node *of_graph_get_remote_port_parent( const struct device_node *node); struct device_node *of_graph_get_remote_port(const struct device_node *node); #else |
f2a575f67
|
52 |
static inline int of_graph_parse_endpoint(const struct device_node *node, |
00fd96191
|
53 |
struct of_endpoint *endpoint) |
f2a575f67
|
54 55 56 |
{ return -ENOSYS; } |
bfe446e37
|
57 58 59 60 61 |
static inline struct device_node *of_graph_get_port_by_id( struct device_node *node, u32 id) { return NULL; } |
fd9fdb78a
|
62 63 64 65 66 67 |
static inline struct device_node *of_graph_get_next_endpoint( const struct device_node *parent, struct device_node *previous) { return NULL; } |
ce0bdb849
|
68 |
static inline struct device_node *of_graph_get_endpoint_by_regs( |
8ccd0d0ca
|
69 70 71 72 |
const struct device_node *parent, int port_reg, int reg) { return NULL; } |
fd9fdb78a
|
73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 |
static inline struct device_node *of_graph_get_remote_port_parent( const struct device_node *node) { return NULL; } static inline struct device_node *of_graph_get_remote_port( const struct device_node *node) { return NULL; } #endif /* CONFIG_OF */ #endif /* __LINUX_OF_GRAPH_H */ |