chiark / gitweb /
doc: update "writing udev rules"
[elogind.git] / udev.h
1 /*
2  * Copyright (C) 2003 Greg Kroah-Hartman <greg@kroah.com>
3  * Copyright (C) 2003-2006 Kay Sievers <kay.sievers@vrfy.org>
4  *
5  *      This program is free software; you can redistribute it and/or modify it
6  *      under the terms of the GNU General Public License as published by the
7  *      Free Software Foundation version 2 of the License.
8  * 
9  *      This program is distributed in the hope that it will be useful, but
10  *      WITHOUT ANY WARRANTY; without even the implied warranty of
11  *      MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
12  *      General Public License for more details.
13  * 
14  *      You should have received a copy of the GNU General Public License along
15  *      with this program; if not, write to the Free Software Foundation, Inc.,
16  *      51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
17  *
18  */
19
20 #ifndef _UDEV_H_
21 #define _UDEV_H_
22
23 #include <sys/types.h>
24 #include <sys/param.h>
25
26 #include "list.h"
27 #include "logging.h"
28 #include "udev_sysdeps.h"
29 #include "udev_version.h"
30
31 #define COMMENT_CHARACTER                       '#'
32 #define LINE_SIZE                               512
33 #define PATH_SIZE                               512
34 #define NAME_SIZE                               256
35 #define VALUE_SIZE                              128
36
37 #define ALLOWED_CHARS                           "#+-.:=@_"
38 #define ALLOWED_CHARS_FILE                      ALLOWED_CHARS "/"
39 #define ALLOWED_CHARS_INPUT                     ALLOWED_CHARS_FILE " $%?,"
40
41 #define DEFAULT_PARTITIONS_COUNT                15
42 #define UDEV_ALARM_TIMEOUT                      180
43
44 #define UDEV_MAX(a,b) ((a) > (b) ? (a) : (b))
45
46 /* pipes */
47 #define READ_END                                0
48 #define WRITE_END                               1
49
50 #define DB_DIR                                  ".udev/db"
51 #define DB_NAME_INDEX_DIR                       ".udev/names"
52 #define RULES_DYN_DIR                           ".udev/rules.d"
53
54 struct udev_rules;
55
56 struct sysfs_device {
57         struct list_head node;                  /* for device cache */
58         struct sysfs_device *parent;            /* already cached parent*/
59         char devpath[PATH_SIZE];
60         char subsystem[NAME_SIZE];              /* $class, $bus, drivers, module */
61         char kernel[NAME_SIZE];                 /* device instance name */
62         char kernel_number[NAME_SIZE];
63         char driver[NAME_SIZE];                 /* device driver name */
64 };
65
66 struct udevice {
67         /* device event */
68         struct sysfs_device *dev;               /* points to dev_local by default */
69         struct sysfs_device dev_local;
70         struct sysfs_device *dev_parent;        /* current parent device used for matching */
71         char action[NAME_SIZE];
72         char *devpath_old;
73
74         /* node */
75         char name[PATH_SIZE];
76         struct list_head symlink_list;
77         int symlink_final;
78         char owner[NAME_SIZE];
79         int owner_final;
80         char group[NAME_SIZE];
81         int group_final;
82         mode_t mode;
83         int mode_final;
84         dev_t devt;
85
86         /* event processing */
87         struct list_head run_list;
88         int run_final;
89         struct list_head env_list;
90         char tmp_node[PATH_SIZE];
91         int partitions;
92         int ignore_device;
93         int ignore_remove;
94         char program_result[PATH_SIZE];
95         int link_priority;
96         int test_run;
97 };
98
99 /* udev_config.c */
100 extern char udev_root[PATH_SIZE];
101 extern char udev_config_filename[PATH_SIZE];
102 extern char udev_rules_dir[PATH_SIZE];
103 extern int udev_log_priority;
104 extern int udev_run;
105 extern void udev_config_init(void);
106
107 /* udev_device.c */
108 extern struct udevice *udev_device_init(struct udevice *udev);
109 extern void udev_device_cleanup(struct udevice *udev);
110 extern int udev_device_event(struct udev_rules *rules, struct udevice *udev);
111 extern dev_t udev_device_get_devt(struct udevice *udev);
112
113 /* udev_sysfs.c */
114 extern char sysfs_path[PATH_SIZE];
115 extern int sysfs_init(void);
116 extern void sysfs_cleanup(void);
117 extern void sysfs_device_set_values(struct sysfs_device *dev, const char *devpath,
118                                     const char *subsystem, const char *driver);
119 extern struct sysfs_device *sysfs_device_get(const char *devpath);
120 extern struct sysfs_device *sysfs_device_get_parent(struct sysfs_device *dev);
121 extern struct sysfs_device *sysfs_device_get_parent_with_subsystem(struct sysfs_device *dev, const char *subsystem);
122 extern char *sysfs_attr_get_value(const char *devpath, const char *attr_name);
123 extern int sysfs_resolve_link(char *path, size_t size);
124 extern int sysfs_lookup_devpath_by_subsys_id(char *devpath, size_t len, const char *subsystem, const char *id);
125
126 /* udev_node.c */
127 extern int udev_node_mknod(struct udevice *udev, const char *file, dev_t devt, mode_t mode, uid_t uid, gid_t gid);
128 extern void udev_node_update_symlinks(struct udevice *udev, struct udevice *udev_old);
129 extern int udev_node_add(struct udevice *udev);
130 extern int udev_node_remove(struct udevice *udev);
131
132 /* udev_db.c */
133 extern int udev_db_add_device(struct udevice *dev);
134 extern int udev_db_delete_device(struct udevice *dev);
135 extern int udev_db_rename(const char *devpath_old, const char *devpath);
136 extern int udev_db_get_device(struct udevice *udev, const char *devpath);
137 extern int udev_db_get_devices_by_name(const char *name, struct list_head *name_list);
138 extern int udev_db_get_all_entries(struct list_head *name_list);
139
140 /* udev_utils.c */
141 struct name_entry {
142         struct list_head node;
143         char name[PATH_SIZE];
144         unsigned int ignore_error:1;
145 };
146
147 extern int log_priority(const char *priority);
148 extern struct name_entry *name_list_add(struct list_head *name_list, const char *name, int sort);
149 extern struct name_entry *name_list_key_add(struct list_head *name_list, const char *key, const char *value);
150 extern int name_list_key_remove(struct list_head *name_list, const char *key);
151 extern void name_list_cleanup(struct list_head *name_list);
152 extern int add_matching_files(struct list_head *name_list, const char *dirname, const char *suffix);
153 extern uid_t lookup_user(const char *user);
154 extern gid_t lookup_group(const char *group);
155
156 /* udev_utils_string.c */
157 extern int string_is_true(const char *str);
158 extern void remove_trailing_chars(char *path, char c);
159 extern size_t path_encode(char *s, size_t len);
160 extern size_t path_decode(char *s);
161 extern int utf8_encoded_valid_unichar(const char *str);
162 extern int replace_chars(char *str, const char *white);
163
164 /* udev_utils_file.c */
165 extern int create_path(const char *path);
166 extern int delete_path(const char *path);
167 extern int file_map(const char *filename, char **buf, size_t *bufsize);
168 extern void file_unmap(void *buf, size_t bufsize);
169 extern int unlink_secure(const char *filename);
170 extern size_t buf_get_line(const char *buf, size_t buflen, size_t cur);
171
172 /* udev commands */
173 extern int udevmonitor(int argc, char *argv[], char *envp[]);
174 extern int udevinfo(int argc, char *argv[], char *envp[]);
175 extern int udevcontrol(int argc, char *argv[], char *envp[]);
176 extern int udevtrigger(int argc, char *argv[], char *envp[]);
177 extern int udevsettle(int argc, char *argv[], char *envp[]);
178 extern int udevtest(int argc, char *argv[], char *envp[]);
179
180 #endif