[PATCH 07/20] linux/of.h: Add of_find_node_by_path()
Sebastian Huber
sebastian.huber at embedded-brains.de
Fri Jan 19 13:53:57 UTC 2018
---
rtemsbsd/powerpc/include/linux/of.h | 3 +++
rtemsbsd/sys/powerpc/compat.c | 16 ++++++++++++++++
2 files changed, 19 insertions(+)
diff --git a/rtemsbsd/powerpc/include/linux/of.h b/rtemsbsd/powerpc/include/linux/of.h
index 8ef046975..e91baaafd 100644
--- a/rtemsbsd/powerpc/include/linux/of.h
+++ b/rtemsbsd/powerpc/include/linux/of.h
@@ -88,6 +88,9 @@ bool of_device_is_available(const struct device_node *dn);
int of_device_is_compatible(const struct device_node *dn, const char *name);
+struct device_node *of_find_node_by_path(struct device_node *dns,
+ const char *path);
+
struct device_node *of_find_compatible_node(struct device_node *dns,
const struct device_node *dn, const char *type, const char *compatible);
diff --git a/rtemsbsd/sys/powerpc/compat.c b/rtemsbsd/sys/powerpc/compat.c
index 400eac578..c0fdebbd5 100644
--- a/rtemsbsd/sys/powerpc/compat.c
+++ b/rtemsbsd/sys/powerpc/compat.c
@@ -90,6 +90,22 @@ of_device_is_compatible(const struct device_node *dn, const char *name)
}
struct device_node *
+of_find_node_by_path(struct device_node *dns, const char *path)
+{
+ const void *fdt = bsp_fdt_get();
+ int node;
+
+ memset(dns, 0, sizeof(*dns));
+
+ node = fdt_path_offset(fdt, path);
+ if (node < 0)
+ return (NULL);
+
+ dns->offset = node;
+ return (dns);
+}
+
+struct device_node *
of_find_compatible_node(struct device_node *dns, const struct device_node *dn,
const char *type, const char *compatible)
{
--
2.12.3
More information about the devel
mailing list