1. ft_create_node was returning the internal pointer rather than a phandle. 2. ft_find_device_rel was treating a "top" phandle of NULL as an error, rather than as the root of the tree. 3. Return the node's name when getprop() is called with the "name" property.
Signed-off-by: Scott Wood <[EMAIL PROTECTED]> --- arch/powerpc/boot/flatdevtree.c | 24 +++++++++++++++++++----- 1 files changed, 19 insertions(+), 5 deletions(-) diff --git a/arch/powerpc/boot/flatdevtree.c b/arch/powerpc/boot/flatdevtree.c index 13761bf..61b710f 100644 --- a/arch/powerpc/boot/flatdevtree.c +++ b/arch/powerpc/boot/flatdevtree.c @@ -109,9 +109,10 @@ static char *ft_next(struct ft_cxt *cxt, char *p, struct ft_atom *ret) switch (ret->tag) { /* Tag */ case OF_DT_BEGIN_NODE: + ret->size = strlen(p); ret->name = p; ret->data = (void *)(p - 4); /* start of node */ - p += _ALIGN(strlen(p) + 1, 4); + p += _ALIGN(ret->size + 1, 4); break; case OF_DT_PROP: ret->size = sz = be32_to_cpu(*(u32 *) p); @@ -641,9 +642,13 @@ void *ft_find_device_rel(struct ft_cxt *cxt, const void *top, { char *node; - node = ft_node_ph2node(cxt, top); - if (node == NULL) - return NULL; + if (top) { + node = ft_node_ph2node(cxt, top); + if (node == NULL) + return NULL; + } else { + node = ft_root_node(cxt); + } node = ft_find_descendent(cxt, node, srch_path); return ft_get_phandle(cxt, node); @@ -757,10 +762,19 @@ static const void *__ft_get_prop(struct ft_cxt *cxt, void *node, { struct ft_atom atom; int depth = 0; + int prop_is_name = !strcmp(propname, "name"); + while ((node = ft_next(cxt, node, &atom)) != NULL) { switch (atom.tag) { case OF_DT_BEGIN_NODE: + if (prop_is_name) { + if (len) + *len = atom.size; + + return atom.name; + } + ++depth; break; @@ -972,7 +986,7 @@ void *ft_create_node(struct ft_cxt *cxt, const void *parent, const char *name) cxt->p = p; ft_begin_node(cxt, name); ft_end_node(cxt); - return p; + return ft_find_device_rel(cxt, parent, name); } p = next; } -- 1.5.0.3 _______________________________________________ Linuxppc-dev mailing list Linuxppc-dev@ozlabs.org https://ozlabs.org/mailman/listinfo/linuxppc-dev