diff options
author | Andrey Smirnov <andrew.smirnov@gmail.com> | 2016-04-25 22:37:00 -0700 |
---|---|---|
committer | Sascha Hauer <s.hauer@pengutronix.de> | 2016-04-28 07:44:04 +0200 |
commit | bd55401e972d630338d3326373f8aef9d204faaf (patch) | |
tree | 7108cc0cf9c6e89824fa2065b59b7c35bb754f7e /drivers/of/device.c | |
parent | 9aa9049cfd999c4a885f214c4d6dfb5eb4bc7bf7 (diff) | |
download | barebox-bd55401e972d630338d3326373f8aef9d204faaf.tar.gz barebox-bd55401e972d630338d3326373f8aef9d204faaf.tar.xz |
OF: Port of_match_device() and of_device_get_match_data()
Port of_match_device() and of_device_get_match_data() from Linux kernel
code.
Signed-off-by: Andrey Smirnov <andrew.smirnov@gmail.com>
Acked-by: Lucas Stach <l.stach@pengutronix.de>
Signed-off-by: Sascha Hauer <s.hauer@pengutronix.de>
Diffstat (limited to 'drivers/of/device.c')
-rw-r--r-- | drivers/of/device.c | 33 |
1 files changed, 33 insertions, 0 deletions
diff --git a/drivers/of/device.c b/drivers/of/device.c new file mode 100644 index 0000000000..e2c3c02d27 --- /dev/null +++ b/drivers/of/device.c @@ -0,0 +1,33 @@ +#include <common.h> +#include <of.h> + + +/** + * of_match_device - Tell if a struct device matches an of_device_id list + * @ids: array of of device match structures to search in + * @dev: the of device structure to match against + * + * Used by a driver to check whether an platform_device present in the + * system is in its list of supported devices. + */ +const struct of_device_id *of_match_device(const struct of_device_id *matches, + const struct device_d *dev) +{ + if ((!matches) || (!dev->device_node)) + return NULL; + + return of_match_node(matches, dev->device_node); +} +EXPORT_SYMBOL(of_match_device); + +const void *of_device_get_match_data(const struct device_d *dev) +{ + const struct of_device_id *match; + + match = of_match_device(dev->driver->of_compatible, dev); + if (!match) + return NULL; + + return match->data; +} +EXPORT_SYMBOL(of_device_get_match_data); |