diff options
author | Grant Likely <grant.likely@linaro.org> | 2014-02-20 13:02:11 -0500 |
---|---|---|
committer | Grant Likely <grant.likely@linaro.org> | 2014-03-11 16:48:26 -0400 |
commit | 75b57ecf9d1d1e17d099ab13b8f48e6e038676be (patch) | |
tree | 1fcf03dae1722cf5c7917023a404958be2bce036 /include/linux/of.h | |
parent | dab2310d9d90eded48625c5382c6a60389bf8ca9 (diff) |
of: Make device nodes kobjects so they show up in sysfs
Device tree nodes are already treated as objects, and we already want to
expose them to userspace which is done using the /proc filesystem today.
Right now the kernel has to do a lot of work to keep the /proc view in
sync with the in-kernel representation. If device_nodes are switched to
be kobjects then the device tree code can be a whole lot simpler. It
also turns out that switching to using /sysfs from /proc results in
smaller code and data size, and the userspace ABI won't change if
/proc/device-tree symlinks to /sys/firmware/devicetree/base.
v7: Add missing sysfs_bin_attr_init()
v6: Add __of_add_property() early init fixes from Pantelis
v5: Rename firmware/ofw to firmware/devicetree
Fix updating property values in sysfs
v4: Fixed build error on Powerpc
Fixed handling of dynamic nodes on powerpc
v3: Fixed handling of duplicate attribute and child node names
v2: switch to using sysfs bin_attributes which solve the problem of
reporting incorrect property size.
Signed-off-by: Grant Likely <grant.likely@secretlab.ca>
Tested-by: Sascha Hauer <s.hauer@pengutronix.de>
Cc: Rob Herring <rob.herring@calxeda.com>
Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Cc: David S. Miller <davem@davemloft.net>
Cc: Nathan Fontenot <nfont@linux.vnet.ibm.com>
Cc: Pantelis Antoniou <panto@antoniou-consulting.com>
Diffstat (limited to 'include/linux/of.h')
-rw-r--r-- | include/linux/of.h | 9 |
1 files changed, 7 insertions, 2 deletions
diff --git a/include/linux/of.h b/include/linux/of.h index b3d0f6d86e3b..bd45be5bd565 100644 --- a/include/linux/of.h +++ b/include/linux/of.h | |||
@@ -18,7 +18,7 @@ | |||
18 | #include <linux/types.h> | 18 | #include <linux/types.h> |
19 | #include <linux/bitops.h> | 19 | #include <linux/bitops.h> |
20 | #include <linux/errno.h> | 20 | #include <linux/errno.h> |
21 | #include <linux/kref.h> | 21 | #include <linux/kobject.h> |
22 | #include <linux/mod_devicetable.h> | 22 | #include <linux/mod_devicetable.h> |
23 | #include <linux/spinlock.h> | 23 | #include <linux/spinlock.h> |
24 | #include <linux/topology.h> | 24 | #include <linux/topology.h> |
@@ -37,6 +37,7 @@ struct property { | |||
37 | struct property *next; | 37 | struct property *next; |
38 | unsigned long _flags; | 38 | unsigned long _flags; |
39 | unsigned int unique_id; | 39 | unsigned int unique_id; |
40 | struct bin_attribute attr; | ||
40 | }; | 41 | }; |
41 | 42 | ||
42 | #if defined(CONFIG_SPARC) | 43 | #if defined(CONFIG_SPARC) |
@@ -57,7 +58,7 @@ struct device_node { | |||
57 | struct device_node *next; /* next device of same type */ | 58 | struct device_node *next; /* next device of same type */ |
58 | struct device_node *allnext; /* next in list of all nodes */ | 59 | struct device_node *allnext; /* next in list of all nodes */ |
59 | struct proc_dir_entry *pde; /* this node's proc directory */ | 60 | struct proc_dir_entry *pde; /* this node's proc directory */ |
60 | struct kref kref; | 61 | struct kobject kobj; |
61 | unsigned long _flags; | 62 | unsigned long _flags; |
62 | void *data; | 63 | void *data; |
63 | #if defined(CONFIG_SPARC) | 64 | #if defined(CONFIG_SPARC) |
@@ -74,6 +75,8 @@ struct of_phandle_args { | |||
74 | uint32_t args[MAX_PHANDLE_ARGS]; | 75 | uint32_t args[MAX_PHANDLE_ARGS]; |
75 | }; | 76 | }; |
76 | 77 | ||
78 | extern int of_node_add(struct device_node *node); | ||
79 | |||
77 | #ifdef CONFIG_OF_DYNAMIC | 80 | #ifdef CONFIG_OF_DYNAMIC |
78 | extern struct device_node *of_node_get(struct device_node *node); | 81 | extern struct device_node *of_node_get(struct device_node *node); |
79 | extern void of_node_put(struct device_node *node); | 82 | extern void of_node_put(struct device_node *node); |
@@ -187,6 +190,8 @@ static inline const char *of_node_full_name(const struct device_node *np) | |||
187 | return np ? np->full_name : "<no-node>"; | 190 | return np ? np->full_name : "<no-node>"; |
188 | } | 191 | } |
189 | 192 | ||
193 | #define for_each_of_allnodes(dn) \ | ||
194 | for (dn = of_allnodes; dn; dn = dn->allnext) | ||
190 | extern struct device_node *of_find_node_by_name(struct device_node *from, | 195 | extern struct device_node *of_find_node_by_name(struct device_node *from, |
191 | const char *name); | 196 | const char *name); |
192 | extern struct device_node *of_find_node_by_type(struct device_node *from, | 197 | extern struct device_node *of_find_node_by_type(struct device_node *from, |