blob: 0544edda716888ee3ee26823be8cd82ac497c606 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001/*
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
Andrew Morton4a7fb632006-08-14 22:43:17 -070013#include <linux/compiler.h>
Frank Haverkampbf0acc32007-01-17 17:51:18 +010014#include <linux/list.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070015#include <asm/atomic.h>
16
17struct kobject;
18struct module;
Eric W. Biedermanb592fcf2007-01-24 12:35:52 -070019struct nameidata;
Adam J. Richterd56c3ea2007-02-16 21:35:25 +080020struct dentry;
Linus Torvalds1da177e2005-04-16 15:20:36 -070021
22struct attribute {
Dmitry Torokhovd48593b2005-04-29 00:58:46 -050023 const char * name;
Linus Torvalds1da177e2005-04-16 15:20:36 -070024 struct module * owner;
25 mode_t mode;
26};
27
28struct attribute_group {
Dmitry Torokhovd48593b2005-04-29 00:58:46 -050029 const char * name;
Linus Torvalds1da177e2005-04-16 15:20:36 -070030 struct attribute ** attrs;
31};
32
33
34
35/**
36 * Use these macros to make defining attributes easier. See include/linux/device.h
37 * for examples..
38 */
39
40#define __ATTR(_name,_mode,_show,_store) { \
41 .attr = {.name = __stringify(_name), .mode = _mode, .owner = THIS_MODULE }, \
42 .show = _show, \
43 .store = _store, \
44}
45
46#define __ATTR_RO(_name) { \
47 .attr = { .name = __stringify(_name), .mode = 0444, .owner = THIS_MODULE }, \
48 .show = _name##_show, \
49}
50
51#define __ATTR_NULL { .attr = { .name = NULL } }
52
53#define attr_name(_attr) (_attr).attr.name
54
55struct vm_area_struct;
56
57struct bin_attribute {
58 struct attribute attr;
59 size_t size;
60 void *private;
61 ssize_t (*read)(struct kobject *, char *, loff_t, size_t);
62 ssize_t (*write)(struct kobject *, char *, loff_t, size_t);
63 int (*mmap)(struct kobject *, struct bin_attribute *attr,
64 struct vm_area_struct *vma);
65};
66
67struct sysfs_ops {
68 ssize_t (*show)(struct kobject *, struct attribute *,char *);
69 ssize_t (*store)(struct kobject *,struct attribute *,const char *, size_t);
70};
71
Linus Torvalds1da177e2005-04-16 15:20:36 -070072#define SYSFS_ROOT 0x0001
73#define SYSFS_DIR 0x0002
74#define SYSFS_KOBJ_ATTR 0x0004
75#define SYSFS_KOBJ_BIN_ATTR 0x0008
76#define SYSFS_KOBJ_LINK 0x0020
77#define SYSFS_NOT_PINNED (SYSFS_KOBJ_ATTR | SYSFS_KOBJ_BIN_ATTR | SYSFS_KOBJ_LINK)
78
79#ifdef CONFIG_SYSFS
80
Alan Sternd9a9cdf2007-03-15 15:50:34 -040081extern int sysfs_schedule_callback(struct kobject *kobj,
82 void (*func)(void *), void *data);
83
Andrew Morton4a7fb632006-08-14 22:43:17 -070084extern int __must_check
Eric W. Biedermanb592fcf2007-01-24 12:35:52 -070085sysfs_create_dir(struct kobject *, struct dentry *);
Linus Torvalds1da177e2005-04-16 15:20:36 -070086
87extern void
88sysfs_remove_dir(struct kobject *);
89
Andrew Morton4a7fb632006-08-14 22:43:17 -070090extern int __must_check
Eric W. Biedermanb592fcf2007-01-24 12:35:52 -070091sysfs_rename_dir(struct kobject *, struct dentry *, const char *new_name);
Linus Torvalds1da177e2005-04-16 15:20:36 -070092
Andrew Morton4a7fb632006-08-14 22:43:17 -070093extern int __must_check
Cornelia Huck8a824722006-11-20 17:07:51 +010094sysfs_move_dir(struct kobject *, struct kobject *);
95
96extern int __must_check
Linus Torvalds1da177e2005-04-16 15:20:36 -070097sysfs_create_file(struct kobject *, const struct attribute *);
98
Andrew Morton4a7fb632006-08-14 22:43:17 -070099extern int __must_check
Linus Torvalds1da177e2005-04-16 15:20:36 -0700100sysfs_update_file(struct kobject *, const struct attribute *);
101
Andrew Morton4a7fb632006-08-14 22:43:17 -0700102extern int __must_check
Kay Sievers31e5abe2005-04-18 21:57:32 -0700103sysfs_chmod_file(struct kobject *kobj, struct attribute *attr, mode_t mode);
104
Linus Torvalds1da177e2005-04-16 15:20:36 -0700105extern void
106sysfs_remove_file(struct kobject *, const struct attribute *);
107
Andrew Morton4a7fb632006-08-14 22:43:17 -0700108extern int __must_check
Dmitry Torokhove3a15db2005-04-26 02:31:08 -0500109sysfs_create_link(struct kobject * kobj, struct kobject * target, const char * name);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700110
111extern void
Dmitry Torokhove3a15db2005-04-26 02:31:08 -0500112sysfs_remove_link(struct kobject *, const char * name);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700113
Andrew Morton4a7fb632006-08-14 22:43:17 -0700114int __must_check sysfs_create_bin_file(struct kobject *kobj,
115 struct bin_attribute *attr);
Randy.Dunlap995982c2006-07-10 23:05:25 -0700116void sysfs_remove_bin_file(struct kobject *kobj, struct bin_attribute *attr);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700117
Andrew Morton4a7fb632006-08-14 22:43:17 -0700118int __must_check sysfs_create_group(struct kobject *,
119 const struct attribute_group *);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700120void sysfs_remove_group(struct kobject *, const struct attribute_group *);
Alan Sterndfa87c82007-02-20 15:02:44 -0500121int sysfs_add_file_to_group(struct kobject *kobj,
122 const struct attribute *attr, const char *group);
123void sysfs_remove_file_from_group(struct kobject *kobj,
124 const struct attribute *attr, const char *group);
125
NeilBrown4508a7a2006-03-20 17:53:53 +1100126void sysfs_notify(struct kobject * k, char *dir, char *attr);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700127
Eric W. Biedermanb592fcf2007-01-24 12:35:52 -0700128
129extern int sysfs_make_shadowed_dir(struct kobject *kobj,
130 void * (*follow_link)(struct dentry *, struct nameidata *));
131extern struct dentry *sysfs_create_shadow_dir(struct kobject *kobj);
132extern void sysfs_remove_shadow_dir(struct dentry *dir);
133
Andrew Mortonf20a9ea2006-08-14 22:43:23 -0700134extern int __must_check sysfs_init(void);
135
Linus Torvalds1da177e2005-04-16 15:20:36 -0700136#else /* CONFIG_SYSFS */
137
Alan Sternd9a9cdf2007-03-15 15:50:34 -0400138static inline int sysfs_schedule_callback(struct kobject *kobj,
139 void (*func)(void *), void *data)
140{
141 return -ENOSYS;
142}
143
Eric W. Biedermanb592fcf2007-01-24 12:35:52 -0700144static inline int sysfs_create_dir(struct kobject * k, struct dentry *shadow)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700145{
146 return 0;
147}
148
149static inline void sysfs_remove_dir(struct kobject * k)
150{
151 ;
152}
153
Eric W. Biedermanb592fcf2007-01-24 12:35:52 -0700154static inline int sysfs_rename_dir(struct kobject * k,
155 struct dentry *new_parent,
156 const char *new_name)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700157{
158 return 0;
159}
160
Cornelia Huck8a824722006-11-20 17:07:51 +0100161static inline int sysfs_move_dir(struct kobject * k, struct kobject * new_parent)
162{
163 return 0;
164}
165
Linus Torvalds1da177e2005-04-16 15:20:36 -0700166static inline int sysfs_create_file(struct kobject * k, const struct attribute * a)
167{
168 return 0;
169}
170
171static inline int sysfs_update_file(struct kobject * k, const struct attribute * a)
172{
173 return 0;
174}
Kay Sievers31e5abe2005-04-18 21:57:32 -0700175static inline int sysfs_chmod_file(struct kobject *kobj, struct attribute *attr, mode_t mode)
176{
177 return 0;
178}
Linus Torvalds1da177e2005-04-16 15:20:36 -0700179
180static inline void sysfs_remove_file(struct kobject * k, const struct attribute * a)
181{
182 ;
183}
184
Dmitry Torokhove3a15db2005-04-26 02:31:08 -0500185static inline int sysfs_create_link(struct kobject * k, struct kobject * t, const char * n)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700186{
187 return 0;
188}
189
Dmitry Torokhove3a15db2005-04-26 02:31:08 -0500190static inline void sysfs_remove_link(struct kobject * k, const char * name)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700191{
192 ;
193}
194
195
196static inline int sysfs_create_bin_file(struct kobject * k, struct bin_attribute * a)
197{
198 return 0;
199}
200
201static inline int sysfs_remove_bin_file(struct kobject * k, struct bin_attribute * a)
202{
203 return 0;
204}
205
206static inline int sysfs_create_group(struct kobject * k, const struct attribute_group *g)
207{
208 return 0;
209}
210
211static inline void sysfs_remove_group(struct kobject * k, const struct attribute_group * g)
212{
213 ;
214}
215
Alan Sterndfa87c82007-02-20 15:02:44 -0500216static inline int sysfs_add_file_to_group(struct kobject *kobj,
217 const struct attribute *attr, const char *group)
218{
219 return 0;
220}
221
222static inline void sysfs_remove_file_from_group(struct kobject *kobj,
Ralf Baechled701d8a2007-03-01 12:40:21 +0000223 const struct attribute *attr, const char *group)
Alan Sterndfa87c82007-02-20 15:02:44 -0500224{
Alan Sterndfa87c82007-02-20 15:02:44 -0500225}
226
NeilBrown4508a7a2006-03-20 17:53:53 +1100227static inline void sysfs_notify(struct kobject * k, char *dir, char *attr)
228{
229}
230
Eric W. Biedermanb592fcf2007-01-24 12:35:52 -0700231static inline int sysfs_make_shadowed_dir(struct kobject *kobj,
232 void * (*follow_link)(struct dentry *, struct nameidata *))
233{
234 return 0;
235}
236
Andrew Mortonf20a9ea2006-08-14 22:43:23 -0700237static inline int __must_check sysfs_init(void)
238{
239 return 0;
240}
241
Linus Torvalds1da177e2005-04-16 15:20:36 -0700242#endif /* CONFIG_SYSFS */
243
244#endif /* _SYSFS_H_ */