aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorStephen Rothwell <sfr@canb.auug.org.au>2007-04-24 03:16:16 -0400
committerStephen Rothwell <sfr@canb.auug.org.au>2007-07-19 23:32:58 -0400
commite679c5f445fe142940e0962de9c5c82f10d9357c (patch)
tree997daf76cc643fdc495ce0a667cfdc5b1c9515ab
parent581b605a83ec241a2aff8ef780e08b9414c8dfd8 (diff)
Consolidate of_get_parent
This requires creating dummy of_node_{get,put} routines for sparc and sparc64. It also adds a read_lock around the parent accesses. Signed-off-by: Stephen Rothwell <sfr@canb.auug.org.au> Acked-by: Paul Mackerras <paulus@samba.org> Acked-by: David S. Miller <davem@davemloft.net>
-rw-r--r--arch/powerpc/kernel/prom.c21
-rw-r--r--arch/sparc/kernel/prom.c13
-rw-r--r--arch/sparc64/kernel/prom.c13
-rw-r--r--drivers/of/base.c21
-rw-r--r--include/asm-sparc/prom.h9
-rw-r--r--include/asm-sparc64/prom.h9
6 files changed, 39 insertions, 47 deletions
diff --git a/arch/powerpc/kernel/prom.c b/arch/powerpc/kernel/prom.c
index 3f6238d96a5d..1ad56d3c6061 100644
--- a/arch/powerpc/kernel/prom.c
+++ b/arch/powerpc/kernel/prom.c
@@ -1241,27 +1241,6 @@ struct device_node *of_find_all_nodes(struct device_node *prev)
1241EXPORT_SYMBOL(of_find_all_nodes); 1241EXPORT_SYMBOL(of_find_all_nodes);
1242 1242
1243/** 1243/**
1244 * of_get_parent - Get a node's parent if any
1245 * @node: Node to get parent
1246 *
1247 * Returns a node pointer with refcount incremented, use
1248 * of_node_put() on it when done.
1249 */
1250struct device_node *of_get_parent(const struct device_node *node)
1251{
1252 struct device_node *np;
1253
1254 if (!node)
1255 return NULL;
1256
1257 read_lock(&devtree_lock);
1258 np = of_node_get(node->parent);
1259 read_unlock(&devtree_lock);
1260 return np;
1261}
1262EXPORT_SYMBOL(of_get_parent);
1263
1264/**
1265 * of_get_next_child - Iterate a node childs 1244 * of_get_next_child - Iterate a node childs
1266 * @node: parent node 1245 * @node: parent node
1267 * @prev: previous child of the parent node, or NULL to get first 1246 * @prev: previous child of the parent node, or NULL to get first
diff --git a/arch/sparc/kernel/prom.c b/arch/sparc/kernel/prom.c
index 0f5aab4326b3..b37871578087 100644
--- a/arch/sparc/kernel/prom.c
+++ b/arch/sparc/kernel/prom.c
@@ -29,19 +29,6 @@ static struct device_node *allnodes;
29 29
30extern rwlock_t devtree_lock; /* temporary while merging */ 30extern rwlock_t devtree_lock; /* temporary while merging */
31 31
32struct device_node *of_get_parent(const struct device_node *node)
33{
34 struct device_node *np;
35
36 if (!node)
37 return NULL;
38
39 np = node->parent;
40
41 return np;
42}
43EXPORT_SYMBOL(of_get_parent);
44
45struct device_node *of_get_next_child(const struct device_node *node, 32struct device_node *of_get_next_child(const struct device_node *node,
46 struct device_node *prev) 33 struct device_node *prev)
47{ 34{
diff --git a/arch/sparc64/kernel/prom.c b/arch/sparc64/kernel/prom.c
index a1ccc00c7958..2462731ac1a3 100644
--- a/arch/sparc64/kernel/prom.c
+++ b/arch/sparc64/kernel/prom.c
@@ -34,19 +34,6 @@ static struct device_node *allnodes;
34 34
35extern rwlock_t devtree_lock; /* temporary while merging */ 35extern rwlock_t devtree_lock; /* temporary while merging */
36 36
37struct device_node *of_get_parent(const struct device_node *node)
38{
39 struct device_node *np;
40
41 if (!node)
42 return NULL;
43
44 np = node->parent;
45
46 return np;
47}
48EXPORT_SYMBOL(of_get_parent);
49
50struct device_node *of_get_next_child(const struct device_node *node, 37struct device_node *of_get_next_child(const struct device_node *node,
51 struct device_node *prev) 38 struct device_node *prev)
52{ 39{
diff --git a/drivers/of/base.c b/drivers/of/base.c
index 70b60845140e..82bb78680ff6 100644
--- a/drivers/of/base.c
+++ b/drivers/of/base.c
@@ -113,3 +113,24 @@ int of_device_is_compatible(const struct device_node *device,
113 return 0; 113 return 0;
114} 114}
115EXPORT_SYMBOL(of_device_is_compatible); 115EXPORT_SYMBOL(of_device_is_compatible);
116
117/**
118 * of_get_parent - Get a node's parent if any
119 * @node: Node to get parent
120 *
121 * Returns a node pointer with refcount incremented, use
122 * of_node_put() on it when done.
123 */
124struct device_node *of_get_parent(const struct device_node *node)
125{
126 struct device_node *np;
127
128 if (!node)
129 return NULL;
130
131 read_lock(&devtree_lock);
132 np = of_node_get(node->parent);
133 read_unlock(&devtree_lock);
134 return np;
135}
136EXPORT_SYMBOL(of_get_parent);
diff --git a/include/asm-sparc/prom.h b/include/asm-sparc/prom.h
index 57f86c84293b..c7d54958a90e 100644
--- a/include/asm-sparc/prom.h
+++ b/include/asm-sparc/prom.h
@@ -69,6 +69,15 @@ extern int of_getintprop_default(struct device_node *np,
69 69
70extern void prom_build_devicetree(void); 70extern void prom_build_devicetree(void);
71 71
72/* Dummy ref counting routines - to be implemented later */
73static inline struct device_node *of_node_get(struct device_node *node)
74{
75 return node;
76}
77static inline void of_node_put(struct device_node *node)
78{
79}
80
72/* 81/*
73 * NB: This is here while we transition from using asm/prom.h 82 * NB: This is here while we transition from using asm/prom.h
74 * to linux/of.h 83 * to linux/of.h
diff --git a/include/asm-sparc64/prom.h b/include/asm-sparc64/prom.h
index 6a5e2405cbf4..e83896f3c141 100644
--- a/include/asm-sparc64/prom.h
+++ b/include/asm-sparc64/prom.h
@@ -78,6 +78,15 @@ extern int of_getintprop_default(struct device_node *np,
78 78
79extern void prom_build_devicetree(void); 79extern void prom_build_devicetree(void);
80 80
81/* Dummy ref counting routines - to be implemented later */
82static inline struct device_node *of_node_get(struct device_node *node)
83{
84 return node;
85}
86static inline void of_node_put(struct device_node *node)
87{
88}
89
81/* 90/*
82 * NB: This is here while we transition from using asm/prom.h 91 * NB: This is here while we transition from using asm/prom.h
83 * to linux/of.h 92 * to linux/of.h