In order to simplify the introduction of the export symbols node handling, group necessary operations done to get a phandle from the __symbols__ node in this dedicated get_phandle_from_symbols_node() function. Signed-off-by: Herve Codina <herve.codina@xxxxxxxxxxx> --- drivers/of/resolver.c | 44 +++++++++++++++++++++++++++---------------- 1 file changed, 28 insertions(+), 16 deletions(-) diff --git a/drivers/of/resolver.c b/drivers/of/resolver.c index 779db058c42f..2560b33fa750 100644 --- a/drivers/of/resolver.c +++ b/drivers/of/resolver.c @@ -214,6 +214,28 @@ static int adjust_local_phandle_references(const struct device_node *local_fixup return 0; } +static int get_phandle_from_symbols_node(const struct device_node *tree_symbols, + const char *symbol_name, + phandle *phandle) +{ + struct device_node *refnode; + const char *refpath; + int err; + + err = of_property_read_string(tree_symbols, symbol_name, &refpath); + if (err) + return err; + + refnode = of_find_node_by_path(refpath); + if (!refnode) + return -ENOENT; + + *phandle = refnode->phandle; + of_node_put(refnode); + + return 0; +} + /** * of_resolve_phandles - Relocate and resolve overlay against live tree * @@ -249,11 +271,10 @@ static int adjust_local_phandle_references(const struct device_node *local_fixup */ int of_resolve_phandles(struct device_node *overlay) { - struct device_node *child, *local_fixups, *refnode; - struct device_node *tree_symbols, *overlay_fixups; - struct property *prop; - const char *refpath; + struct device_node *child, *local_fixups, *overlay_fixups; + struct device_node *tree_symbols; phandle phandle, phandle_delta; + struct property *prop; int err; tree_symbols = NULL; @@ -306,23 +327,14 @@ int of_resolve_phandles(struct device_node *overlay) if (!of_prop_cmp(prop->name, "name")) continue; - err = of_property_read_string(tree_symbols, - prop->name, &refpath); + err = get_phandle_from_symbols_node(tree_symbols, prop->name, + &phandle); if (err) { - pr_err("node label '%s' not found in live devicetree symbols table\n", + pr_err("node label '%s' not found or invalid in live devicetree symbols table\n", prop->name); goto out; } - refnode = of_find_node_by_path(refpath); - if (!refnode) { - err = -ENOENT; - goto out; - } - - phandle = refnode->phandle; - of_node_put(refnode); - err = update_usages_of_a_phandle_reference(overlay, prop, phandle); if (err) break; -- 2.47.0