]>
git.ipfire.org Git - thirdparty/systemd.git/blob - udevdb.c
3d0a9ea3c2b6cc2a646ebe6b3bf7f5fc88ffd7bc
2 * udevdb.c - udev database library
6 * Copyright (C) 2003 Greg Kroah-Hartman <greg@kroah.com>
7 * Copyright (C) 2003 IBM Corp.
9 * This program is free software; you can redistribute it and/or modify it
10 * under the terms of the GNU General Public License as published by the
11 * Free Software Foundation version 2 of the License.
13 * This program is distributed in the hope that it will be useful, but
14 * WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 * General Public License for more details.
18 * You should have received a copy of the GNU General Public License along
19 * with this program; if not, write to the Free Software Foundation, Inc.,
20 * 675 Mass Ave, Cambridge, MA 02139, USA.
24 #define _KLIBC_HAS_ARCH_SIG_ATOMIC_T
35 #include "libsysfs/sysfs/libsysfs.h"
38 #include "udev_version.h"
44 static TDB_CONTEXT
*udevdb
;
45 sig_atomic_t gotalarm
;
47 int udevdb_add_dev(struct udevice
*udev
)
50 char keystr
[SYSFS_PATH_MAX
];
55 memset(keystr
, 0x00, SYSFS_PATH_MAX
);
56 strfieldcpy(keystr
, udev
->devpath
);
58 key
.dsize
= strlen(keystr
) + 1;
60 data
.dptr
= (void *) udev
;
61 data
.dsize
= UDEVICE_DB_LEN
;
62 dbg("store key '%s' for device '%s'", keystr
, udev
->name
);
64 return tdb_store(udevdb
, key
, data
, TDB_REPLACE
);
67 int udevdb_get_dev(const char *path
, struct udevice
*udev
)
77 key
.dptr
= (void *)path
;
78 key
.dsize
= strlen(path
) + 1;
80 data
= tdb_fetch(udevdb
, key
);
81 if (data
.dptr
== NULL
|| data
.dsize
== 0)
84 memset(udev
, 0x00, sizeof(struct udevice
));
85 memcpy(udev
, data
.dptr
, UDEVICE_DB_LEN
);
90 int udevdb_delete_dev(const char *path
)
93 char keystr
[SYSFS_PATH_MAX
];
101 memset(keystr
, 0, sizeof(keystr
));
102 strfieldcpy(keystr
, path
);
105 key
.dsize
= strlen(keystr
) + 1;
107 return tdb_delete(udevdb
, key
);
111 * udevdb_exit: closes database
113 void udevdb_exit(void)
115 if (udevdb
!= NULL
) {
122 * udevdb_init: initializes database
123 * @init_flag: UDEVDB_INTERNAL - database stays in memory
124 * UDEVDB_DEFAULT - database is written to a file
126 int udevdb_init(int init_flag
)
128 if (init_flag
!= UDEVDB_DEFAULT
&& init_flag
!= UDEVDB_INTERNAL
)
131 tdb_set_lock_alarm(&gotalarm
);
133 udevdb
= tdb_open(udev_db_filename
, 0, init_flag
, O_RDWR
| O_CREAT
, 0644);
134 if (udevdb
== NULL
) {
135 if (init_flag
== UDEVDB_INTERNAL
)
136 dbg("unable to initialize in-memory database");
138 dbg("unable to initialize database at '%s'", udev_db_filename
);
145 * udevdb_open_ro: open database for reading
147 int udevdb_open_ro(void)
149 udevdb
= tdb_open(udev_db_filename
, 0, 0, O_RDONLY
, 0);
150 if (udevdb
== NULL
) {
151 dbg("unable to open database at '%s'", udev_db_filename
);
157 static int (*user_record_callback
) (const char *path
, struct udevice
*dev
);
159 static int traverse_callback(TDB_CONTEXT
*tdb
, TDB_DATA key
, TDB_DATA dbuf
, void *state
)
161 return user_record_callback((char*) key
.dptr
, (struct udevice
*) dbuf
.dptr
);
165 * udevdb_call_foreach: dumps whole database by passing record data to user function
166 * @user_record_handler: user function called for every record in the database
168 int udevdb_call_foreach(int (*user_record_handler
) (const char *path
, struct udevice
*dev
))
175 if (user_record_handler
== NULL
) {
176 dbg("invalid user record handling function");
179 user_record_callback
= user_record_handler
;
180 retval
= tdb_traverse(udevdb
, traverse_callback
, NULL
);
187 static struct udevice
*find_dev
;
188 static char *find_path
;
189 static const char *find_name
;
190 static int find_found
;
192 static int find_device_by_name(const char *path
, struct udevice
*udev
)
197 if (strncmp(udev
->name
, find_name
, sizeof(udev
->name
)) == 0) {
198 memcpy(find_dev
, udev
, sizeof(struct udevice
));
199 strfieldcpymax(find_path
, path
, NAME_SIZE
);
204 /* look for matching symlink*/
205 foreach_strpart(udev
->symlink
, " ", pos
, len
) {
206 if (strncmp(pos
, find_name
, len
) != 0)
209 if (len
!= strlen(find_name
))
212 memcpy(find_dev
, udev
, sizeof(struct udevice
));
213 strfieldcpymax(find_path
, path
, NAME_SIZE
);
221 * udevdb_get_dev_byname: search device with given name by traversing the whole database
223 int udevdb_get_dev_byname(const char *name
, char *path
, struct udevice
*dev
)
229 udevdb_call_foreach(find_device_by_name
);