aboutsummaryrefslogtreecommitdiffstats
path: root/arch/sparc/kernel/prom_common.c
diff options
context:
space:
mode:
authorDavid S. Miller <davem@davemloft.net>2008-12-05 04:21:41 -0500
committerDavid S. Miller <davem@davemloft.net>2008-12-05 21:15:03 -0500
commit6524036a1e5736a07466208362d83ddf31aae3ac (patch)
treedea250164424676bd19505adcbf6ae260559c403 /arch/sparc/kernel/prom_common.c
parent4aef8c53fe517542d8185b7d771f291865b49177 (diff)
sparc: Move core of OF device tree building code into prom_common.c
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'arch/sparc/kernel/prom_common.c')
-rw-r--r--arch/sparc/kernel/prom_common.c57
1 files changed, 55 insertions, 2 deletions
diff --git a/arch/sparc/kernel/prom_common.c b/arch/sparc/kernel/prom_common.c
index d3eddc76763d..3b5de2f3fcd1 100644
--- a/arch/sparc/kernel/prom_common.c
+++ b/arch/sparc/kernel/prom_common.c
@@ -216,8 +216,8 @@ static char * __init get_one_property(phandle node, const char *name)
216 return buf; 216 return buf;
217} 217}
218 218
219struct device_node * __init create_node(phandle node, 219struct device_node * __init prom_create_node(phandle node,
220 struct device_node *parent) 220 struct device_node *parent)
221{ 221{
222 struct device_node *dp; 222 struct device_node *dp;
223 223
@@ -240,3 +240,56 @@ struct device_node * __init create_node(phandle node,
240 240
241 return dp; 241 return dp;
242} 242}
243
244static char * __init build_full_name(struct device_node *dp)
245{
246 int len, ourlen, plen;
247 char *n;
248
249 plen = strlen(dp->parent->full_name);
250 ourlen = strlen(dp->path_component_name);
251 len = ourlen + plen + 2;
252
253 n = prom_early_alloc(len);
254 strcpy(n, dp->parent->full_name);
255 if (!is_root_node(dp->parent)) {
256 strcpy(n + plen, "/");
257 plen++;
258 }
259 strcpy(n + plen, dp->path_component_name);
260
261 return n;
262}
263
264struct device_node * __init prom_build_tree(struct device_node *parent,
265 phandle node,
266 struct device_node ***nextp)
267{
268 struct device_node *ret = NULL, *prev_sibling = NULL;
269 struct device_node *dp;
270
271 while (1) {
272 dp = prom_create_node(node, parent);
273 if (!dp)
274 break;
275
276 if (prev_sibling)
277 prev_sibling->sibling = dp;
278
279 if (!ret)
280 ret = dp;
281 prev_sibling = dp;
282
283 *(*nextp) = dp;
284 *nextp = &dp->allnext;
285
286 dp->path_component_name = build_path_component(dp);
287 dp->full_name = build_full_name(dp);
288
289 dp->child = prom_build_tree(dp, prom_getchild(node), nextp);
290
291 node = prom_getsibling(node);
292 }
293
294 return ret;
295}