[PATCH 11/12] of: base: add funtion to copy a device tree node

Sascha Hauer s.hauer at pengutronix.de
Tue Sep 19 23:20:00 PDT 2017


In the subject:

s/funtion/function/

Sascha

On Fri, Sep 15, 2017 at 10:39:21AM +0200, Lucas Stach wrote:
> From: Michael Olbrich <m.olbrich at pengutronix.de>
> 
> Signed-off-by: Michael Olbrich <m.olbrich at pengutronix.de>
> Signed-off-by: Lucas Stach <l.stach at pengutronix.de>
> ---
>  drivers/of/base.c | 16 ++++++++++++++++
>  include/of.h      |  8 ++++++++
>  2 files changed, 24 insertions(+)
> 
> diff --git a/drivers/of/base.c b/drivers/of/base.c
> index fb4d2c03946e..3ca13ae44e5c 100644
> --- a/drivers/of/base.c
> +++ b/drivers/of/base.c
> @@ -1988,6 +1988,22 @@ out:
>  	return dn;
>  }
>  
> +struct device_node *of_copy_node(struct device_node *parent, const struct device_node *other)
> +{
> +	struct device_node *np, *child;
> +	struct property *pp;
> +
> +	np = of_new_node(parent, other->name);
> +
> +	list_for_each_entry(pp, &other->properties, list)
> +		of_new_property(np, pp->name, pp->value, pp->length);
> +
> +	for_each_child_of_node(other, child)
> +		of_copy_node(np, child);
> +
> +	return np;
> +}
> +
>  void of_delete_node(struct device_node *node)
>  {
>  	struct device_node *n, *nt;
> diff --git a/include/of.h b/include/of.h
> index 9ba771a395b8..c21a1e95dda8 100644
> --- a/include/of.h
> +++ b/include/of.h
> @@ -144,6 +144,8 @@ extern struct device_node *of_new_node(struct device_node *parent,
>  				const char *name);
>  extern struct device_node *of_create_node(struct device_node *root,
>  					const char *path);
> +extern struct device_node *of_copy_node(struct device_node *parent,
> +				const struct device_node *other);
>  extern void of_delete_node(struct device_node *node);
>  
>  extern int of_machine_is_compatible(const char *compat);
> @@ -576,6 +578,12 @@ static inline struct device_node *of_create_node(struct device_node *root,
>  	return NULL;
>  }
>  
> +static inline struct device_node *of_copy_node(struct device_node *parent,
> +					       const struct device_node *other)
> +{
> +	return NULL;
> +}
> +
>  static inline void of_delete_node(struct device_node *node)
>  {
>  }
> -- 
> 2.11.0
> 
> 
> _______________________________________________
> barebox mailing list
> barebox at lists.infradead.org
> http://lists.infradead.org/mailman/listinfo/barebox
> 

-- 
Pengutronix e.K.                           |                             |
Industrial Linux Solutions                 | http://www.pengutronix.de/  |
Peiner Str. 6-8, 31137 Hildesheim, Germany | Phone: +49-5121-206917-0    |
Amtsgericht Hildesheim, HRA 2686           | Fax:   +49-5121-206917-5555 |



More information about the barebox mailing list