All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH] OF: base: match each node compatible against all given matches first
@ 2013-11-28 18:36 ` Sebastian Hesselbarth
  0 siblings, 0 replies; 32+ messages in thread
From: Sebastian Hesselbarth @ 2013-11-28 18:36 UTC (permalink / raw)
  To: linux-arm-kernel

Currently, of_match_node compares each given match against all node's
compatible strings with of_device_is_compatible.

To achieve multiple compatible strings per node with ordering from
specific to generic, this requires given matches to be ordered from
specific to generic. For most of the drivers this is not true and also
an alphabetical ordering is more sane there.

Therefore, this patch modifies of_match_node to match each of the node's
compatible strings against all given matches first, before checking the
next compatible string. This implies that node's compatibles are ordered
from specific to generic while given matches can be in any order.

Signed-off-by: Sebastian Hesselbarth <sebastian.hesselbarth@gmail.com>
---
Cc: Grant Likely <grant.likely@linaro.org>
Cc: Rob Herring <rob.herring@calxeda.com>
Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Cc: Russell King <linux@arm.linux.org.uk>
Cc: devicetree at vger.kernel.org
Cc: linux-arm-kernel at lists.infradead.org
Cc: linux-kernel at vger.kernel.org
---
 drivers/of/base.c |   47 ++++++++++++++++++++++++++++++++---------------
 1 file changed, 32 insertions(+), 15 deletions(-)

diff --git a/drivers/of/base.c b/drivers/of/base.c
index 7d4c70f..183a9c7 100644
--- a/drivers/of/base.c
+++ b/drivers/of/base.c
@@ -713,23 +713,37 @@ static
 const struct of_device_id *__of_match_node(const struct of_device_id *matches,
 					   const struct device_node *node)
 {
+	const char *cp;
+	int cplen, l;
+
 	if (!matches)
 		return NULL;
 
-	while (matches->name[0] || matches->type[0] || matches->compatible[0]) {
-		int match = 1;
-		if (matches->name[0])
-			match &= node->name
-				&& !strcmp(matches->name, node->name);
-		if (matches->type[0])
-			match &= node->type
-				&& !strcmp(matches->type, node->type);
-		if (matches->compatible[0])
-			match &= __of_device_is_compatible(node,
-							   matches->compatible);
-		if (match)
-			return matches;
-		matches++;
+	cp = __of_get_property(node, "compatible", &cplen);
+	if (!cp)
+		return NULL;
+
+	while (cplen > 0) {
+		const struct of_device_id *m = matches;
+
+		while (m->name[0] || m->type[0] || m->compatible[0]) {
+			int match = 1;
+			if (m->name[0])
+				match &= node->name
+					&& !strcmp(m->name, node->name);
+			if (m->type[0])
+				match &= node->type
+					&& !strcmp(m->type, node->type);
+			if (m->compatible[0])
+				match &= !of_compat_cmp(cp, m->compatible,
+							strlen(m->compatible));
+			if (match)
+				return m;
+			m++;
+		}
+		l = strlen(cp) + 1;
+		cp += l;
+		cplen -= l;
 	}
 	return NULL;
 }
@@ -739,7 +753,10 @@ const struct of_device_id *__of_match_node(const struct of_device_id *matches,
  *	@matches:	array of of device match structures to search in
  *	@node:		the of device structure to match against
  *
- *	Low level utility function used by device matching.
+ *	Low level utility function used by device matching. Matching order
+ *	is to compare each of the node's compatibles with all given matches
+ *	first. This implies node's compatible is sorted from specific to
+ *	generic while matches can be in any order.
  */
 const struct of_device_id *of_match_node(const struct of_device_id *matches,
 					 const struct device_node *node)
-- 
1.7.10.4

^ permalink raw reply related	[flat|nested] 32+ messages in thread

end of thread, other threads:[~2013-12-04 19:23 UTC | newest]

Thread overview: 32+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2013-11-28 18:36 [PATCH] OF: base: match each node compatible against all given matches first Sebastian Hesselbarth
2013-11-28 18:36 ` Sebastian Hesselbarth
2013-11-28 18:36 ` Sebastian Hesselbarth
2013-12-02 12:03 ` Thierry Reding
2013-12-02 12:03   ` Thierry Reding
2013-12-02 12:03   ` Thierry Reding
2013-12-02 14:00   ` Rob Herring
2013-12-02 14:00     ` Rob Herring
2013-12-02 14:00     ` Rob Herring
2013-12-02 14:09     ` Sebastian Hesselbarth
2013-12-02 14:09       ` Sebastian Hesselbarth
2013-12-02 14:09       ` Sebastian Hesselbarth
2013-12-03 13:52 ` [PATCH v2] " Sebastian Hesselbarth
2013-12-03 13:52   ` Sebastian Hesselbarth
2013-12-03 13:52   ` Sebastian Hesselbarth
2013-12-03 20:14   ` Meelis Roos
2013-12-03 20:14     ` Meelis Roos
2013-12-03 20:14     ` Meelis Roos
2013-12-03 22:55     ` Sebastian Hesselbarth
2013-12-03 22:55       ` Sebastian Hesselbarth
2013-12-03 22:55       ` Sebastian Hesselbarth
2013-12-04  9:40       ` Thierry Reding
2013-12-04  9:40         ` Thierry Reding
2013-12-04  9:40         ` Thierry Reding
2013-12-04 13:08         ` Meelis Roos
2013-12-04 13:08           ` Meelis Roos
2013-12-04 13:08           ` Meelis Roos
2013-12-04 14:04           ` Thierry Reding
2013-12-04 14:04             ` Thierry Reding
2013-12-04 14:04             ` Thierry Reding
2013-12-04 19:23   ` Rob Herring
2013-12-04 19:23     ` Rob Herring

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.