diff mbox series

[v5,01/20] dm: core: Add helper to compare node names

Message ID 20210721155849.20994-2-kishon@ti.com
State Accepted
Commit 77cbaf8837fd096b876d8a6c05d90683f5f4b82e
Delegated to: Lokesh Vutla
Headers show
Series TI/Cadence: Add Sierra/Torrent SERDES driver | expand

Commit Message

Kishon Vijay Abraham I July 21, 2021, 3:58 p.m. UTC
Add helper to compare node names.

Signed-off-by: Kishon Vijay Abraham I <kishon@ti.com>
---
 drivers/core/ofnode.c | 13 +++++++++++++
 include/dm/ofnode.h   | 10 ++++++++++
 2 files changed, 23 insertions(+)

Comments

Simon Glass July 22, 2021, 1:28 p.m. UTC | #1
Hi Kishon,

On Wed, 21 Jul 2021 at 09:58, Kishon Vijay Abraham I <kishon@ti.com> wrote:
>
> Add helper to compare node names.
>
> Signed-off-by: Kishon Vijay Abraham I <kishon@ti.com>
> ---
>  drivers/core/ofnode.c | 13 +++++++++++++
>  include/dm/ofnode.h   | 10 ++++++++++
>  2 files changed, 23 insertions(+)

Reviewed-by: Simon Glass <sjg@chromium.org>

I don't see a change log on this patch so I'm not sure what changed.

Regards,
Simon
diff mbox series

Patch

diff --git a/drivers/core/ofnode.c b/drivers/core/ofnode.c
index eeeccfb446..e83d3141b2 100644
--- a/drivers/core/ofnode.c
+++ b/drivers/core/ofnode.c
@@ -18,6 +18,19 @@ 
 #include <linux/ioport.h>
 #include <asm/global_data.h>
 
+bool ofnode_name_eq(ofnode node, const char *name)
+{
+	const char *node_name;
+	size_t len;
+
+	assert(ofnode_valid(node));
+
+	node_name = ofnode_get_name(node);
+	len = strchrnul(node_name, '@') - node_name;
+
+	return (strlen(name) == len) && !strncmp(node_name, name, len);
+}
+
 int ofnode_read_u32(ofnode node, const char *propname, u32 *outp)
 {
 	return ofnode_read_u32_index(node, propname, 0, outp);
diff --git a/include/dm/ofnode.h b/include/dm/ofnode.h
index 3da05d8b21..4e1a8447e6 100644
--- a/include/dm/ofnode.h
+++ b/include/dm/ofnode.h
@@ -231,6 +231,16 @@  static inline ofnode ofnode_root(void)
 	return node;
 }
 
+/**
+ * ofnode_name_eq() - Check if the node name is equivalent to a given name
+ *                    ignoring the unit address
+ *
+ * @node:	valid node reference that has to be compared
+ * @name:	name that has to be compared with the node name
+ * @return true if matches, false if it doesn't match
+ */
+bool ofnode_name_eq(ofnode node, const char *name);
+
 /**
  * ofnode_read_u32() - Read a 32-bit integer from a property
  *