diff options
author | Sakari Ailus <sakari.ailus@linux.intel.com> | 2017-05-24 10:53:55 -0400 |
---|---|---|
committer | Rob Herring <robh@kernel.org> | 2017-06-01 09:50:49 -0400 |
commit | d20dc1493db438fbbfb7733adc82f472dd8a0789 (patch) | |
tree | a81ff52fe7e4ed471df24a2e1c48a7d25deb1fcd /include/linux/of.h | |
parent | debd3a3b27c76c65a7d032b6f01710e6a6d555ab (diff) |
of: Support const and non-const use for to_of_node()
Turn to_of_node() into a macro in order to support both const and
non-const use. Additionally make the fwnode argument to is_of_node() const
as well.
Signed-off-by: Sakari Ailus <sakari.ailus@linux.intel.com>
Reviewed-by: Kieran Bingham <kieran.bingham+renesas@ideasonboard.com>
Signed-off-by: Rob Herring <robh@kernel.org>
Diffstat (limited to 'include/linux/of.h')
-rw-r--r-- | include/linux/of.h | 20 |
1 files changed, 12 insertions, 8 deletions
diff --git a/include/linux/of.h b/include/linux/of.h index f05c87f0c495..29b7b738b509 100644 --- a/include/linux/of.h +++ b/include/linux/of.h | |||
@@ -148,16 +148,20 @@ extern raw_spinlock_t devtree_lock; | |||
148 | #ifdef CONFIG_OF | 148 | #ifdef CONFIG_OF |
149 | void of_core_init(void); | 149 | void of_core_init(void); |
150 | 150 | ||
151 | static inline bool is_of_node(struct fwnode_handle *fwnode) | 151 | static inline bool is_of_node(const struct fwnode_handle *fwnode) |
152 | { | 152 | { |
153 | return !IS_ERR_OR_NULL(fwnode) && fwnode->type == FWNODE_OF; | 153 | return !IS_ERR_OR_NULL(fwnode) && fwnode->type == FWNODE_OF; |
154 | } | 154 | } |
155 | 155 | ||
156 | static inline struct device_node *to_of_node(struct fwnode_handle *fwnode) | 156 | #define to_of_node(__fwnode) \ |
157 | { | 157 | ({ \ |
158 | return is_of_node(fwnode) ? | 158 | typeof(__fwnode) __to_of_node_fwnode = (__fwnode); \ |
159 | container_of(fwnode, struct device_node, fwnode) : NULL; | 159 | \ |
160 | } | 160 | is_of_node(__to_of_node_fwnode) ? \ |
161 | container_of(__to_of_node_fwnode, \ | ||
162 | struct device_node, fwnode) : \ | ||
163 | NULL; \ | ||
164 | }) | ||
161 | 165 | ||
162 | #define of_fwnode_handle(node) \ | 166 | #define of_fwnode_handle(node) \ |
163 | ({ \ | 167 | ({ \ |
@@ -539,12 +543,12 @@ static inline void of_core_init(void) | |||
539 | { | 543 | { |
540 | } | 544 | } |
541 | 545 | ||
542 | static inline bool is_of_node(struct fwnode_handle *fwnode) | 546 | static inline bool is_of_node(const struct fwnode_handle *fwnode) |
543 | { | 547 | { |
544 | return false; | 548 | return false; |
545 | } | 549 | } |
546 | 550 | ||
547 | static inline struct device_node *to_of_node(struct fwnode_handle *fwnode) | 551 | static inline struct device_node *to_of_node(const struct fwnode_handle *fwnode) |
548 | { | 552 | { |
549 | return NULL; | 553 | return NULL; |
550 | } | 554 | } |