fwnode_get_next_parent() can be implemented using fwnode interface. Do that to avoid implementing an additional callback for the function in struct fwnode_operations. Signed-off-by: Sakari Ailus <sakari.ailus@xxxxxxxxxxxxxxx> --- drivers/base/property.c | 12 ++---------- 1 file changed, 2 insertions(+), 10 deletions(-) diff --git a/drivers/base/property.c b/drivers/base/property.c index 6d9476a..9f3d80d 100644 --- a/drivers/base/property.c +++ b/drivers/base/property.c @@ -945,17 +945,9 @@ EXPORT_SYMBOL_GPL(device_add_properties); */ struct fwnode_handle *fwnode_get_next_parent(struct fwnode_handle *fwnode) { - struct fwnode_handle *parent = NULL; + struct fwnode_handle *parent = fwnode_call_ptr_op(fwnode, get_parent); - if (is_of_node(fwnode)) { - struct device_node *node; - - node = of_get_next_parent(to_of_node(fwnode)); - if (node) - parent = &node->fwnode; - } else if (is_acpi_node(fwnode)) { - parent = acpi_node_get_parent(fwnode); - } + fwnode_handle_put(fwnode); return parent; } -- 2.7.4 -- To unsubscribe from this list: send the line "unsubscribe devicetree" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html