sysfs: allow attributes to be added to groups
[safe/jmp/linux-2.6] / include / linux / sysfs.h
1 /*
2  * sysfs.h - definitions for the device driver filesystem
3  *
4  * Copyright (c) 2001,2002 Patrick Mochel
5  * Copyright (c) 2004 Silicon Graphics, Inc.
6  *
7  * Please see Documentation/filesystems/sysfs.txt for more information.
8  */
9
10 #ifndef _SYSFS_H_
11 #define _SYSFS_H_
12
13 #include <linux/compiler.h>
14 #include <linux/list.h>
15 #include <asm/atomic.h>
16
17 struct kobject;
18 struct module;
19 struct nameidata;
20
21 struct attribute {
22         const char              * name;
23         struct module           * owner;
24         mode_t                  mode;
25 };
26
27 struct attribute_group {
28         const char              * name;
29         struct attribute        ** attrs;
30 };
31
32
33
34 /**
35  * Use these macros to make defining attributes easier. See include/linux/device.h
36  * for examples..
37  */
38
39 #define __ATTR(_name,_mode,_show,_store) { \
40         .attr = {.name = __stringify(_name), .mode = _mode, .owner = THIS_MODULE },     \
41         .show   = _show,                                        \
42         .store  = _store,                                       \
43 }
44
45 #define __ATTR_RO(_name) { \
46         .attr   = { .name = __stringify(_name), .mode = 0444, .owner = THIS_MODULE },   \
47         .show   = _name##_show, \
48 }
49
50 #define __ATTR_NULL { .attr = { .name = NULL } }
51
52 #define attr_name(_attr) (_attr).attr.name
53
54 struct vm_area_struct;
55
56 struct bin_attribute {
57         struct attribute        attr;
58         size_t                  size;
59         void                    *private;
60         ssize_t (*read)(struct kobject *, char *, loff_t, size_t);
61         ssize_t (*write)(struct kobject *, char *, loff_t, size_t);
62         int (*mmap)(struct kobject *, struct bin_attribute *attr,
63                     struct vm_area_struct *vma);
64 };
65
66 struct sysfs_ops {
67         ssize_t (*show)(struct kobject *, struct attribute *,char *);
68         ssize_t (*store)(struct kobject *,struct attribute *,const char *, size_t);
69 };
70
71 struct sysfs_dirent {
72         atomic_t                s_count;
73         struct list_head        s_sibling;
74         struct list_head        s_children;
75         void                    * s_element;
76         int                     s_type;
77         umode_t                 s_mode;
78         struct dentry           * s_dentry;
79         struct iattr            * s_iattr;
80         atomic_t                s_event;
81 };
82
83 #define SYSFS_ROOT              0x0001
84 #define SYSFS_DIR               0x0002
85 #define SYSFS_KOBJ_ATTR         0x0004
86 #define SYSFS_KOBJ_BIN_ATTR     0x0008
87 #define SYSFS_KOBJ_LINK         0x0020
88 #define SYSFS_NOT_PINNED        (SYSFS_KOBJ_ATTR | SYSFS_KOBJ_BIN_ATTR | SYSFS_KOBJ_LINK)
89
90 #ifdef CONFIG_SYSFS
91
92 extern int __must_check
93 sysfs_create_dir(struct kobject *, struct dentry *);
94
95 extern void
96 sysfs_remove_dir(struct kobject *);
97
98 extern int __must_check
99 sysfs_rename_dir(struct kobject *, struct dentry *, const char *new_name);
100
101 extern int __must_check
102 sysfs_move_dir(struct kobject *, struct kobject *);
103
104 extern int __must_check
105 sysfs_create_file(struct kobject *, const struct attribute *);
106
107 extern int __must_check
108 sysfs_update_file(struct kobject *, const struct attribute *);
109
110 extern int __must_check
111 sysfs_chmod_file(struct kobject *kobj, struct attribute *attr, mode_t mode);
112
113 extern void
114 sysfs_remove_file(struct kobject *, const struct attribute *);
115
116 extern int __must_check
117 sysfs_create_link(struct kobject * kobj, struct kobject * target, const char * name);
118
119 extern void
120 sysfs_remove_link(struct kobject *, const char * name);
121
122 int __must_check sysfs_create_bin_file(struct kobject *kobj,
123                                         struct bin_attribute *attr);
124 void sysfs_remove_bin_file(struct kobject *kobj, struct bin_attribute *attr);
125
126 int __must_check sysfs_create_group(struct kobject *,
127                                         const struct attribute_group *);
128 void sysfs_remove_group(struct kobject *, const struct attribute_group *);
129 int sysfs_add_file_to_group(struct kobject *kobj,
130                 const struct attribute *attr, const char *group);
131 void sysfs_remove_file_from_group(struct kobject *kobj,
132                 const struct attribute *attr, const char *group);
133
134 void sysfs_notify(struct kobject * k, char *dir, char *attr);
135
136
137 extern int sysfs_make_shadowed_dir(struct kobject *kobj,
138         void * (*follow_link)(struct dentry *, struct nameidata *));
139 extern struct dentry *sysfs_create_shadow_dir(struct kobject *kobj);
140 extern void sysfs_remove_shadow_dir(struct dentry *dir);
141
142 extern int __must_check sysfs_init(void);
143
144 #else /* CONFIG_SYSFS */
145
146 static inline int sysfs_create_dir(struct kobject * k, struct dentry *shadow)
147 {
148         return 0;
149 }
150
151 static inline void sysfs_remove_dir(struct kobject * k)
152 {
153         ;
154 }
155
156 static inline int sysfs_rename_dir(struct kobject * k,
157                                         struct dentry *new_parent,
158                                         const char *new_name)
159 {
160         return 0;
161 }
162
163 static inline int sysfs_move_dir(struct kobject * k, struct kobject * new_parent)
164 {
165         return 0;
166 }
167
168 static inline int sysfs_create_file(struct kobject * k, const struct attribute * a)
169 {
170         return 0;
171 }
172
173 static inline int sysfs_update_file(struct kobject * k, const struct attribute * a)
174 {
175         return 0;
176 }
177 static inline int sysfs_chmod_file(struct kobject *kobj, struct attribute *attr, mode_t mode)
178 {
179         return 0;
180 }
181
182 static inline void sysfs_remove_file(struct kobject * k, const struct attribute * a)
183 {
184         ;
185 }
186
187 static inline int sysfs_create_link(struct kobject * k, struct kobject * t, const char * n)
188 {
189         return 0;
190 }
191
192 static inline void sysfs_remove_link(struct kobject * k, const char * name)
193 {
194         ;
195 }
196
197
198 static inline int sysfs_create_bin_file(struct kobject * k, struct bin_attribute * a)
199 {
200         return 0;
201 }
202
203 static inline int sysfs_remove_bin_file(struct kobject * k, struct bin_attribute * a)
204 {
205         return 0;
206 }
207
208 static inline int sysfs_create_group(struct kobject * k, const struct attribute_group *g)
209 {
210         return 0;
211 }
212
213 static inline void sysfs_remove_group(struct kobject * k, const struct attribute_group * g)
214 {
215         ;
216 }
217
218 static inline int sysfs_add_file_to_group(struct kobject *kobj,
219                 const struct attribute *attr, const char *group)
220 {
221         return 0;
222 }
223
224 static inline void sysfs_remove_file_from_group(struct kobject *kobj,
225                 const struct attribute *attr, const char *group);
226 {
227         ;
228 }
229
230 static inline void sysfs_notify(struct kobject * k, char *dir, char *attr)
231 {
232 }
233
234 static inline int sysfs_make_shadowed_dir(struct kobject *kobj,
235         void * (*follow_link)(struct dentry *, struct nameidata *))
236 {
237         return 0;
238 }
239
240 static inline int __must_check sysfs_init(void)
241 {
242         return 0;
243 }
244
245 #endif /* CONFIG_SYSFS */
246
247 #endif /* _SYSFS_H_ */