Commit c029b22f authored by Michael Ellerman's avatar Michael Ellerman

of: Add of_machine_compatible_match()

We have of_machine_is_compatible() to check if a machine is compatible
with a single compatible string. However some code is able to support
multiple compatible boards, and so wants to check for one of many
compatible strings.

So add of_machine_compatible_match() which takes a NULL terminated
array of compatible strings to check against the root node's
compatible property.

Compared to an open coded match this is slightly more self
documenting, and also avoids the caller needing to juggle the root
node either directly or via of_find_node_by_path().
Signed-off-by: default avatarChristophe Leroy <christophe.leroy@csgroup.eu>
Reviewed-by: default avatarRob Herring <robh@kernel.org>
Signed-off-by: default avatarMichael Ellerman <mpe@ellerman.id.au>
Link: https://msgid.link/20231214103152.12269-1-mpe@ellerman.id.au
parent af1ebca5
...@@ -394,6 +394,27 @@ int of_device_compatible_match(const struct device_node *device, ...@@ -394,6 +394,27 @@ int of_device_compatible_match(const struct device_node *device,
} }
EXPORT_SYMBOL_GPL(of_device_compatible_match); EXPORT_SYMBOL_GPL(of_device_compatible_match);
/**
* of_machine_compatible_match - Test root of device tree against a compatible array
* @compats: NULL terminated array of compatible strings to look for in root node's compatible property.
*
* Returns true if the root node has any of the given compatible values in its
* compatible property.
*/
bool of_machine_compatible_match(const char *const *compats)
{
struct device_node *root;
int rc = 0;
root = of_find_node_by_path("/");
if (root) {
rc = of_device_compatible_match(root, compats);
of_node_put(root);
}
return rc != 0;
}
/** /**
* of_machine_is_compatible - Test root of device tree for a given compatible value * of_machine_is_compatible - Test root of device tree for a given compatible value
* @compat: compatible string to look for in root node's compatible property. * @compat: compatible string to look for in root node's compatible property.
......
...@@ -403,6 +403,7 @@ extern int of_alias_get_id(struct device_node *np, const char *stem); ...@@ -403,6 +403,7 @@ extern int of_alias_get_id(struct device_node *np, const char *stem);
extern int of_alias_get_highest_id(const char *stem); extern int of_alias_get_highest_id(const char *stem);
extern int of_machine_is_compatible(const char *compat); extern int of_machine_is_compatible(const char *compat);
bool of_machine_compatible_match(const char *const *compats);
extern int of_add_property(struct device_node *np, struct property *prop); extern int of_add_property(struct device_node *np, struct property *prop);
extern int of_remove_property(struct device_node *np, struct property *prop); extern int of_remove_property(struct device_node *np, struct property *prop);
...@@ -808,6 +809,11 @@ static inline int of_remove_property(struct device_node *np, struct property *pr ...@@ -808,6 +809,11 @@ static inline int of_remove_property(struct device_node *np, struct property *pr
return 0; return 0;
} }
static inline bool of_machine_compatible_match(const char *const *compats)
{
return false;
}
static inline bool of_console_check(const struct device_node *dn, const char *name, int index) static inline bool of_console_check(const struct device_node *dn, const char *name, int index)
{ {
return false; return false;
......
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