Commit f4653ec9 authored by Saravana Kannan's avatar Saravana Kannan Committed by Rob Herring

of: property: Improve finding the consumer of a remote-endpoint property

We have a more accurate function to find the right consumer of a
remote-endpoint property instead of searching for a parent with
compatible string property. So, use that instead. While at it, make the
code to find the consumer a bit more flexible and based on the property
being parsed.

Fixes: f7514a66 ("of: property: fw_devlink: Add support for remote-endpoint")
Signed-off-by: default avatarSaravana Kannan <saravanak@google.com>
Link: https://lore.kernel.org/r/20240207011803.2637531-2-saravanak@google.comSigned-off-by: default avatarRob Herring <robh@kernel.org>
parent 17adc3f3
...@@ -1063,36 +1063,6 @@ of_fwnode_device_get_match_data(const struct fwnode_handle *fwnode, ...@@ -1063,36 +1063,6 @@ of_fwnode_device_get_match_data(const struct fwnode_handle *fwnode,
return of_device_get_match_data(dev); return of_device_get_match_data(dev);
} }
static struct device_node *of_get_compat_node(struct device_node *np)
{
of_node_get(np);
while (np) {
if (!of_device_is_available(np)) {
of_node_put(np);
np = NULL;
}
if (of_property_present(np, "compatible"))
break;
np = of_get_next_parent(np);
}
return np;
}
static struct device_node *of_get_compat_node_parent(struct device_node *np)
{
struct device_node *parent, *node;
parent = of_get_parent(np);
node = of_get_compat_node(parent);
of_node_put(parent);
return node;
}
static void of_link_to_phandle(struct device_node *con_np, static void of_link_to_phandle(struct device_node *con_np,
struct device_node *sup_np) struct device_node *sup_np)
{ {
...@@ -1222,10 +1192,10 @@ static struct device_node *parse_##fname(struct device_node *np, \ ...@@ -1222,10 +1192,10 @@ static struct device_node *parse_##fname(struct device_node *np, \
* parse_prop.prop_name: Name of property holding a phandle value * parse_prop.prop_name: Name of property holding a phandle value
* parse_prop.index: For properties holding a list of phandles, this is the * parse_prop.index: For properties holding a list of phandles, this is the
* index into the list * index into the list
* @get_con_dev: If the consumer node containing the property is never converted
* to a struct device, implement this ops so fw_devlink can use it
* to find the true consumer.
* @optional: Describes whether a supplier is mandatory or not * @optional: Describes whether a supplier is mandatory or not
* @node_not_dev: The consumer node containing the property is never converted
* to a struct device. Instead, parse ancestor nodes for the
* compatible property to find a node corresponding to a device.
* *
* Returns: * Returns:
* parse_prop() return values are * parse_prop() return values are
...@@ -1236,8 +1206,8 @@ static struct device_node *parse_##fname(struct device_node *np, \ ...@@ -1236,8 +1206,8 @@ static struct device_node *parse_##fname(struct device_node *np, \
struct supplier_bindings { struct supplier_bindings {
struct device_node *(*parse_prop)(struct device_node *np, struct device_node *(*parse_prop)(struct device_node *np,
const char *prop_name, int index); const char *prop_name, int index);
struct device_node *(*get_con_dev)(struct device_node *np);
bool optional; bool optional;
bool node_not_dev;
}; };
DEFINE_SIMPLE_PROP(clocks, "clocks", "#clock-cells") DEFINE_SIMPLE_PROP(clocks, "clocks", "#clock-cells")
...@@ -1352,7 +1322,10 @@ static const struct supplier_bindings of_supplier_bindings[] = { ...@@ -1352,7 +1322,10 @@ static const struct supplier_bindings of_supplier_bindings[] = {
{ .parse_prop = parse_pinctrl6, }, { .parse_prop = parse_pinctrl6, },
{ .parse_prop = parse_pinctrl7, }, { .parse_prop = parse_pinctrl7, },
{ .parse_prop = parse_pinctrl8, }, { .parse_prop = parse_pinctrl8, },
{ .parse_prop = parse_remote_endpoint, .node_not_dev = true, }, {
.parse_prop = parse_remote_endpoint,
.get_con_dev = of_graph_get_port_parent,
},
{ .parse_prop = parse_pwms, }, { .parse_prop = parse_pwms, },
{ .parse_prop = parse_resets, }, { .parse_prop = parse_resets, },
{ .parse_prop = parse_leds, }, { .parse_prop = parse_leds, },
...@@ -1403,8 +1376,8 @@ static int of_link_property(struct device_node *con_np, const char *prop_name) ...@@ -1403,8 +1376,8 @@ static int of_link_property(struct device_node *con_np, const char *prop_name)
while ((phandle = s->parse_prop(con_np, prop_name, i))) { while ((phandle = s->parse_prop(con_np, prop_name, i))) {
struct device_node *con_dev_np; struct device_node *con_dev_np;
con_dev_np = s->node_not_dev con_dev_np = s->get_con_dev
? of_get_compat_node_parent(con_np) ? s->get_con_dev(con_np)
: of_node_get(con_np); : of_node_get(con_np);
matched = true; matched = true;
i++; i++;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment