[RFC PATCH 07/16] Add DEVM_FWNODE()
Tomeu Vizoso
tomeu.vizoso at collabora.com
Tue Jul 21 06:50:49 PDT 2015
Signed-off-by: Tomeu Vizoso <tomeu.vizoso at collabora.com>
---
drivers/base/property.c | 17 +++++++++++++++++
include/linux/property.h | 10 ++++++++++
2 files changed, 27 insertions(+)
diff --git a/drivers/base/property.c b/drivers/base/property.c
index d88539c31c67..cc823b283f49 100644
--- a/drivers/base/property.c
+++ b/drivers/base/property.c
@@ -580,3 +580,20 @@ bool fwnode_is_compatible(struct fwnode_handle *fwnode, const char *compatible)
return false;
}
EXPORT_SYMBOL_GPL(fwnode_is_compatible);
+
+int devm_acquire_fwnode(struct device *dev,
+ const struct devm_resource *resource)
+{
+ struct device_node *np;
+ struct fwnode_handle **nodep;
+
+ np = of_parse_phandle(dev->of_node, resource->name, 0);
+ if (IS_ERR(np))
+ return PTR_ERR(np);
+
+ nodep = dev_get_drvdata(dev) + resource->offset;
+ *nodep = &np->fwnode;
+
+ return 0;
+}
+EXPORT_SYMBOL_GPL(devm_acquire_fwnode);
\ No newline at end of file
diff --git a/include/linux/property.h b/include/linux/property.h
index 3fd5fd58ebe9..1c6d5eb65516 100644
--- a/include/linux/property.h
+++ b/include/linux/property.h
@@ -17,6 +17,7 @@
#include <linux/types.h>
struct device;
+struct devm_resource;
enum dev_prop_type {
DEV_PROP_U8,
@@ -172,4 +173,13 @@ void device_add_property_set(struct device *dev, struct property_set *pset);
bool device_dma_is_coherent(struct device *dev);
+int devm_acquire_fwnode(struct device *dev,
+ const struct devm_resource *resource);
+
+#define DEVM_FWNODE(_struct, _member, _name) { \
+ .initfunc = devm_acquire_fwnode, \
+ .offset = offsetof_t(struct _struct, _member, struct fwnode_handle *),\
+ .name = _name, \
+}
+
#endif /* _LINUX_PROPERTY_H_ */
--
2.4.3
More information about the linux-arm-kernel
mailing list