2008-08-27 22:11:58 +07:00
|
|
|
/*
|
|
|
|
* libudev - interface to udev device information
|
|
|
|
*
|
2010-03-10 20:52:42 +07:00
|
|
|
* Copyright (C) 2008-2010 Kay Sievers <kay.sievers@vrfy.org>
|
2008-08-27 22:11:58 +07:00
|
|
|
*
|
2009-03-27 01:29:36 +07:00
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
|
|
* License as published by the Free Software Foundation; either
|
|
|
|
* version 2.1 of the License, or (at your option) any later version.
|
2008-08-27 22:11:58 +07:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _LIBUDEV_PRIVATE_H_
|
|
|
|
#define _LIBUDEV_PRIVATE_H_
|
|
|
|
|
2008-09-06 20:45:31 +07:00
|
|
|
#include <syslog.h>
|
2009-09-05 14:48:23 +07:00
|
|
|
#include <signal.h>
|
2010-04-22 23:12:36 +07:00
|
|
|
#include <stdint.h>
|
|
|
|
#include <stdbool.h>
|
2008-08-27 22:11:58 +07:00
|
|
|
#include "libudev.h"
|
|
|
|
|
2008-10-15 19:21:33 +07:00
|
|
|
#define ARRAY_SIZE(x) (sizeof(x) / sizeof((x)[0]))
|
2009-06-10 04:05:25 +07:00
|
|
|
#define READ_END 0
|
|
|
|
#define WRITE_END 1
|
2008-10-15 19:21:33 +07:00
|
|
|
|
2009-06-10 00:03:39 +07:00
|
|
|
static inline void __attribute__((always_inline, format(printf, 2, 3)))
|
2008-10-10 03:24:43 +07:00
|
|
|
udev_log_null(struct udev *udev, const char *format, ...) {}
|
2008-09-29 23:50:21 +07:00
|
|
|
|
2009-06-10 00:03:39 +07:00
|
|
|
#define udev_log_cond(udev, prio, arg...) \
|
|
|
|
do { \
|
|
|
|
if (udev_get_log_priority(udev) >= prio) \
|
2009-12-25 20:47:59 +07:00
|
|
|
udev_log(udev, prio, __FILE__, __LINE__, __FUNCTION__, ## arg); \
|
2009-06-10 00:03:39 +07:00
|
|
|
} while (0)
|
|
|
|
|
2009-06-14 22:53:15 +07:00
|
|
|
#ifdef ENABLE_LOGGING
|
|
|
|
# ifdef ENABLE_DEBUG
|
2009-06-10 00:03:39 +07:00
|
|
|
# define dbg(udev, arg...) udev_log_cond(udev, LOG_DEBUG, ## arg)
|
2008-09-30 21:16:29 +07:00
|
|
|
# else
|
2008-10-10 03:24:43 +07:00
|
|
|
# define dbg(udev, arg...) udev_log_null(udev, ## arg)
|
2008-09-30 21:16:29 +07:00
|
|
|
# endif
|
2009-06-10 00:03:39 +07:00
|
|
|
# define info(udev, arg...) udev_log_cond(udev, LOG_INFO, ## arg)
|
|
|
|
# define err(udev, arg...) udev_log_cond(udev, LOG_ERR, ## arg)
|
2008-09-06 20:45:31 +07:00
|
|
|
#else
|
2008-10-10 03:24:43 +07:00
|
|
|
# define dbg(udev, arg...) udev_log_null(udev, ## arg)
|
|
|
|
# define info(udev, arg...) udev_log_null(udev, ## arg)
|
|
|
|
# define err(udev, arg...) udev_log_null(udev, ## arg)
|
2008-09-06 20:45:31 +07:00
|
|
|
#endif
|
2008-08-27 22:11:58 +07:00
|
|
|
|
2009-06-10 03:47:48 +07:00
|
|
|
static inline void udev_log_init(const char *program_name)
|
|
|
|
{
|
|
|
|
openlog(program_name, LOG_PID | LOG_CONS, LOG_DAEMON);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void udev_log_close(void)
|
|
|
|
{
|
|
|
|
closelog();
|
|
|
|
}
|
|
|
|
|
|
|
|
/* libudev.c */
|
2008-08-27 22:11:58 +07:00
|
|
|
void udev_log(struct udev *udev,
|
|
|
|
int priority, const char *file, int line, const char *fn,
|
|
|
|
const char *format, ...)
|
2009-06-10 00:03:39 +07:00
|
|
|
__attribute__((format(printf, 6, 7)));
|
2009-04-26 18:59:39 +07:00
|
|
|
const char *udev_get_rules_path(struct udev *udev);
|
|
|
|
struct udev_list_entry *udev_add_property(struct udev *udev, const char *key, const char *value);
|
|
|
|
struct udev_list_entry *udev_get_properties_list_entry(struct udev *udev);
|
2008-09-01 23:52:22 +07:00
|
|
|
|
2009-06-10 03:47:48 +07:00
|
|
|
/* libudev-device.c */
|
2009-06-09 18:11:23 +07:00
|
|
|
struct udev_device *udev_device_new(struct udev *udev);
|
2009-04-26 18:59:39 +07:00
|
|
|
int udev_device_set_syspath(struct udev_device *udev_device, const char *syspath);
|
|
|
|
int udev_device_set_subsystem(struct udev_device *udev_device, const char *subsystem);
|
|
|
|
int udev_device_set_devtype(struct udev_device *udev_device, const char *devtype);
|
|
|
|
int udev_device_set_devnode(struct udev_device *udev_device, const char *devnode);
|
2009-09-09 23:18:17 +07:00
|
|
|
int udev_device_add_devlink(struct udev_device *udev_device, const char *devlink, int unique);
|
2009-04-26 18:59:39 +07:00
|
|
|
void udev_device_cleanup_devlinks_list(struct udev_device *udev_device);
|
|
|
|
struct udev_list_entry *udev_device_add_property(struct udev_device *udev_device, const char *key, const char *value);
|
2010-03-17 23:42:35 +07:00
|
|
|
void udev_device_add_property_from_string_parse(struct udev_device *udev_device, const char *property);
|
|
|
|
int udev_device_add_property_from_string_parse_finish(struct udev_device *udev_device);
|
2009-04-26 18:59:39 +07:00
|
|
|
char **udev_device_get_properties_envp(struct udev_device *udev_device);
|
|
|
|
ssize_t udev_device_get_properties_monitor_buf(struct udev_device *udev_device, const char **buf);
|
|
|
|
int udev_device_read_db(struct udev_device *udev_device);
|
|
|
|
int udev_device_read_uevent_file(struct udev_device *udev_device);
|
|
|
|
int udev_device_set_action(struct udev_device *udev_device, const char *action);
|
|
|
|
int udev_device_set_driver(struct udev_device *udev_device, const char *driver);
|
|
|
|
const char *udev_device_get_devpath_old(struct udev_device *udev_device);
|
2009-08-20 01:49:49 +07:00
|
|
|
const char *udev_device_get_sysname_old(struct udev_device *udev_device);
|
2009-04-26 18:59:39 +07:00
|
|
|
int udev_device_set_devpath_old(struct udev_device *udev_device, const char *devpath_old);
|
2009-05-04 09:52:31 +07:00
|
|
|
const char *udev_device_get_knodename(struct udev_device *udev_device);
|
2010-03-10 20:52:42 +07:00
|
|
|
int udev_device_add_tag(struct udev_device *udev_device, const char *tag);
|
2010-04-22 23:12:36 +07:00
|
|
|
void udev_device_cleanup_tags_list(struct udev_device *udev_device);
|
2010-03-10 20:52:42 +07:00
|
|
|
int udev_device_has_tag(struct udev_device *udev_device, const char *tag);
|
2009-05-04 09:52:31 +07:00
|
|
|
int udev_device_set_knodename(struct udev_device *udev_device, const char *knodename);
|
2009-04-26 18:59:39 +07:00
|
|
|
int udev_device_get_timeout(struct udev_device *udev_device);
|
|
|
|
int udev_device_set_timeout(struct udev_device *udev_device, int timeout);
|
|
|
|
int udev_device_get_event_timeout(struct udev_device *udev_device);
|
|
|
|
int udev_device_set_event_timeout(struct udev_device *udev_device, int event_timeout);
|
|
|
|
int udev_device_set_devnum(struct udev_device *udev_device, dev_t devnum);
|
|
|
|
int udev_device_set_seqnum(struct udev_device *udev_device, unsigned long long int seqnum);
|
|
|
|
int udev_device_get_devlink_priority(struct udev_device *udev_device);
|
|
|
|
int udev_device_set_devlink_priority(struct udev_device *udev_device, int prio);
|
|
|
|
int udev_device_get_watch_handle(struct udev_device *udev_device);
|
|
|
|
int udev_device_set_watch_handle(struct udev_device *udev_device, int handle);
|
|
|
|
void udev_device_set_info_loaded(struct udev_device *device);
|
2008-09-01 23:52:22 +07:00
|
|
|
|
2009-06-10 04:12:12 +07:00
|
|
|
/* libudev-device-private.c */
|
2009-04-26 18:59:39 +07:00
|
|
|
int udev_device_update_db(struct udev_device *udev_device);
|
|
|
|
int udev_device_delete_db(struct udev_device *udev_device);
|
2009-08-20 01:49:49 +07:00
|
|
|
int udev_device_rename_db(struct udev_device *udev_device);
|
2010-04-23 14:01:56 +07:00
|
|
|
int udev_device_tag_index(struct udev_device *dev, struct udev_device *dev_old, bool add);
|
2008-10-16 22:30:06 +07:00
|
|
|
|
2009-06-10 03:47:48 +07:00
|
|
|
/* libudev-monitor.c - netlink/unix socket communication */
|
2009-06-04 06:44:04 +07:00
|
|
|
int udev_monitor_disconnect(struct udev_monitor *udev_monitor);
|
|
|
|
int udev_monitor_allow_unicast_sender(struct udev_monitor *udev_monitor, struct udev_monitor *sender);
|
|
|
|
int udev_monitor_send_device(struct udev_monitor *udev_monitor,
|
|
|
|
struct udev_monitor *destination, struct udev_device *udev_device);
|
2008-10-10 04:38:30 +07:00
|
|
|
|
2009-06-10 03:47:48 +07:00
|
|
|
/* libudev-ctrl.c - daemon runtime setup */
|
2008-09-08 22:59:00 +07:00
|
|
|
struct udev_ctrl;
|
2009-04-26 18:59:39 +07:00
|
|
|
struct udev_ctrl *udev_ctrl_new_from_socket(struct udev *udev, const char *socket_path);
|
|
|
|
int udev_ctrl_enable_receiving(struct udev_ctrl *uctrl);
|
|
|
|
struct udev_ctrl *udev_ctrl_ref(struct udev_ctrl *uctrl);
|
|
|
|
void udev_ctrl_unref(struct udev_ctrl *uctrl);
|
|
|
|
struct udev *udev_ctrl_get_udev(struct udev_ctrl *uctrl);
|
|
|
|
int udev_ctrl_get_fd(struct udev_ctrl *uctrl);
|
|
|
|
int udev_ctrl_send_set_log_level(struct udev_ctrl *uctrl, int priority);
|
|
|
|
int udev_ctrl_send_stop_exec_queue(struct udev_ctrl *uctrl);
|
|
|
|
int udev_ctrl_send_start_exec_queue(struct udev_ctrl *uctrl);
|
|
|
|
int udev_ctrl_send_reload_rules(struct udev_ctrl *uctrl);
|
|
|
|
int udev_ctrl_send_settle(struct udev_ctrl *uctrl);
|
|
|
|
int udev_ctrl_send_set_env(struct udev_ctrl *uctrl, const char *key);
|
2010-05-27 22:27:56 +07:00
|
|
|
int udev_ctrl_send_set_children_max(struct udev_ctrl *uctrl, int count);
|
2008-09-08 22:59:00 +07:00
|
|
|
struct udev_ctrl_msg;
|
2009-04-26 18:59:39 +07:00
|
|
|
struct udev_ctrl_msg *udev_ctrl_msg(struct udev_ctrl *uctrl);
|
|
|
|
struct udev_ctrl_msg *udev_ctrl_receive_msg(struct udev_ctrl *uctrl);
|
|
|
|
struct udev_ctrl_msg *udev_ctrl_msg_ref(struct udev_ctrl_msg *ctrl_msg);
|
|
|
|
void udev_ctrl_msg_unref(struct udev_ctrl_msg *ctrl_msg);
|
|
|
|
int udev_ctrl_get_set_log_level(struct udev_ctrl_msg *ctrl_msg);
|
|
|
|
int udev_ctrl_get_stop_exec_queue(struct udev_ctrl_msg *ctrl_msg);
|
|
|
|
int udev_ctrl_get_start_exec_queue(struct udev_ctrl_msg *ctrl_msg);
|
|
|
|
int udev_ctrl_get_reload_rules(struct udev_ctrl_msg *ctrl_msg);
|
|
|
|
pid_t udev_ctrl_get_settle(struct udev_ctrl_msg *ctrl_msg);
|
|
|
|
const char *udev_ctrl_get_set_env(struct udev_ctrl_msg *ctrl_msg);
|
2010-05-27 22:27:56 +07:00
|
|
|
int udev_ctrl_get_set_children_max(struct udev_ctrl_msg *ctrl_msg);
|
2008-09-08 22:59:00 +07:00
|
|
|
|
2009-06-10 03:47:48 +07:00
|
|
|
/* libudev-list.c */
|
2008-10-10 03:24:43 +07:00
|
|
|
struct udev_list_node {
|
|
|
|
struct udev_list_node *next, *prev;
|
2008-09-27 00:44:53 +07:00
|
|
|
};
|
2009-04-26 18:59:39 +07:00
|
|
|
void udev_list_init(struct udev_list_node *list);
|
|
|
|
int udev_list_is_empty(struct udev_list_node *list);
|
|
|
|
void udev_list_node_append(struct udev_list_node *new, struct udev_list_node *list);
|
|
|
|
void udev_list_node_remove(struct udev_list_node *entry);
|
2008-10-17 23:59:08 +07:00
|
|
|
#define udev_list_node_foreach(node, list) \
|
|
|
|
for (node = (list)->next; \
|
|
|
|
node != list; \
|
|
|
|
node = (node)->next)
|
|
|
|
#define udev_list_node_foreach_safe(node, tmp, list) \
|
|
|
|
for (node = (list)->next, tmp = (node)->next; \
|
|
|
|
node != list; \
|
|
|
|
node = tmp, tmp = (tmp)->next)
|
2009-04-26 18:59:39 +07:00
|
|
|
struct udev_list_entry *udev_list_entry_add(struct udev *udev, struct udev_list_node *list,
|
2008-10-10 03:24:43 +07:00
|
|
|
const char *name, const char *value,
|
|
|
|
int unique, int sort);
|
2009-04-26 18:59:39 +07:00
|
|
|
void udev_list_entry_delete(struct udev_list_entry *entry);
|
|
|
|
void udev_list_entry_remove(struct udev_list_entry *entry);
|
|
|
|
void udev_list_entry_insert_before(struct udev_list_entry *new, struct udev_list_entry *entry);
|
|
|
|
void udev_list_entry_append(struct udev_list_entry *new, struct udev_list_node *list);
|
|
|
|
void udev_list_cleanup_entries(struct udev *udev, struct udev_list_node *name_list);
|
|
|
|
struct udev_list_entry *udev_list_get_entry(struct udev_list_node *list);
|
2010-03-10 20:52:42 +07:00
|
|
|
unsigned int udev_list_entry_get_flags(struct udev_list_entry *list_entry);
|
|
|
|
void udev_list_entry_set_flags(struct udev_list_entry *list_entry, unsigned int flags);
|
2008-10-17 01:12:16 +07:00
|
|
|
#define udev_list_entry_foreach_safe(entry, tmp, first) \
|
2008-10-17 23:59:08 +07:00
|
|
|
for (entry = first, tmp = udev_list_entry_get_next(entry); \
|
2008-09-28 06:34:55 +07:00
|
|
|
entry != NULL; \
|
|
|
|
entry = tmp, tmp = udev_list_entry_get_next(tmp))
|
2008-09-25 18:20:27 +07:00
|
|
|
|
2009-06-10 03:47:48 +07:00
|
|
|
/* libudev-queue.c */
|
2009-05-22 03:22:37 +07:00
|
|
|
unsigned long long int udev_get_kernel_seqnum(struct udev *udev);
|
|
|
|
int udev_queue_read_seqnum(FILE *queue_file, unsigned long long int *seqnum);
|
|
|
|
ssize_t udev_queue_read_devpath(FILE *queue_file, char *devpath, size_t size);
|
|
|
|
ssize_t udev_queue_skip_devpath(FILE *queue_file);
|
|
|
|
|
2009-06-10 04:12:12 +07:00
|
|
|
/* libudev-queue-private.c */
|
2009-05-22 03:22:37 +07:00
|
|
|
struct udev_queue_export *udev_queue_export_new(struct udev *udev);
|
|
|
|
void udev_queue_export_unref(struct udev_queue_export *udev_queue_export);
|
|
|
|
void udev_queue_export_cleanup(struct udev_queue_export *udev_queue_export);
|
|
|
|
int udev_queue_export_device_queued(struct udev_queue_export *udev_queue_export, struct udev_device *udev_device);
|
|
|
|
int udev_queue_export_device_finished(struct udev_queue_export *udev_queue_export, struct udev_device *udev_device);
|
|
|
|
int udev_queue_export_device_failed(struct udev_queue_export *udev_queue_export, struct udev_device *udev_device);
|
2008-10-01 14:34:07 +07:00
|
|
|
|
2009-06-10 04:05:25 +07:00
|
|
|
/* libudev-util.c */
|
2008-11-06 03:49:52 +07:00
|
|
|
#define UTIL_PATH_SIZE 1024
|
|
|
|
#define UTIL_NAME_SIZE 512
|
2010-03-03 05:10:02 +07:00
|
|
|
#define UTIL_LINE_SIZE 16384
|
2008-11-06 03:49:52 +07:00
|
|
|
#define UDEV_ALLOWED_CHARS_INPUT "/ $%?,"
|
2009-04-26 18:59:39 +07:00
|
|
|
ssize_t util_get_sys_subsystem(struct udev *udev, const char *syspath, char *subsystem, size_t size);
|
|
|
|
ssize_t util_get_sys_driver(struct udev *udev, const char *syspath, char *driver, size_t size);
|
|
|
|
int util_resolve_sys_link(struct udev *udev, char *syspath, size_t size);
|
|
|
|
int util_log_priority(const char *priority);
|
2009-05-20 22:57:52 +07:00
|
|
|
size_t util_path_encode(const char *src, char *dest, size_t size);
|
2009-04-26 18:59:39 +07:00
|
|
|
size_t util_path_decode(char *s);
|
|
|
|
void util_remove_trailing_chars(char *path, char c);
|
2009-05-20 22:57:52 +07:00
|
|
|
size_t util_strpcpy(char **dest, size_t size, const char *src);
|
2009-06-10 00:03:39 +07:00
|
|
|
size_t util_strpcpyl(char **dest, size_t size, const char *src, ...) __attribute__((sentinel));
|
2009-05-20 22:57:52 +07:00
|
|
|
size_t util_strscpy(char *dest, size_t size, const char *src);
|
2009-06-10 00:03:39 +07:00
|
|
|
size_t util_strscpyl(char *dest, size_t size, const char *src, ...) __attribute__((sentinel));
|
2009-04-26 18:59:39 +07:00
|
|
|
int udev_util_replace_whitespace(const char *str, char *to, size_t len);
|
|
|
|
int udev_util_replace_chars(char *str, const char *white);
|
|
|
|
int udev_util_encode_string(const char *str, char *str_enc, size_t len);
|
2010-04-22 23:12:36 +07:00
|
|
|
unsigned int util_string_hash32(const char *key);
|
|
|
|
uint64_t util_string_bloom64(const char *str);
|
2009-06-10 04:05:25 +07:00
|
|
|
|
|
|
|
/* libudev-util-private.c */
|
|
|
|
int util_create_path(struct udev *udev, const char *path);
|
|
|
|
int util_delete_path(struct udev *udev, const char *path);
|
|
|
|
int util_unlink_secure(struct udev *udev, const char *filename);
|
|
|
|
uid_t util_lookup_user(struct udev *udev, const char *user);
|
|
|
|
gid_t util_lookup_group(struct udev *udev, const char *group);
|
|
|
|
int util_run_program(struct udev *udev, const char *command, char **envp,
|
2009-09-05 14:48:23 +07:00
|
|
|
char *result, size_t ressize, size_t *reslen,
|
2010-05-12 13:46:56 +07:00
|
|
|
const sigset_t *sigmask, bool reset_prio);
|
2009-06-10 04:05:25 +07:00
|
|
|
int util_resolve_subsys_kernel(struct udev *udev, const char *string,
|
|
|
|
char *result, size_t maxsize, int read_value);
|
|
|
|
|
|
|
|
/* libudev-selinux-private.c */
|
2009-06-14 22:53:15 +07:00
|
|
|
#ifndef WITH_SELINUX
|
2009-06-10 04:05:25 +07:00
|
|
|
static inline void udev_selinux_init(struct udev *udev) {}
|
|
|
|
static inline void udev_selinux_exit(struct udev *udev) {}
|
|
|
|
static inline void udev_selinux_lsetfilecon(struct udev *udev, const char *file, unsigned int mode) {}
|
|
|
|
static inline void udev_selinux_setfscreatecon(struct udev *udev, const char *file, unsigned int mode) {}
|
2010-05-20 14:04:26 +07:00
|
|
|
static inline void udev_selinux_setfscreateconat(struct udev *udev, int dirfd, const char *file, unsigned int mode) {}
|
2009-06-10 04:05:25 +07:00
|
|
|
static inline void udev_selinux_resetfscreatecon(struct udev *udev) {}
|
|
|
|
#else
|
|
|
|
void udev_selinux_init(struct udev *udev);
|
|
|
|
void udev_selinux_exit(struct udev *udev);
|
|
|
|
void udev_selinux_lsetfilecon(struct udev *udev, const char *file, unsigned int mode);
|
|
|
|
void udev_selinux_setfscreatecon(struct udev *udev, const char *file, unsigned int mode);
|
2010-05-20 14:04:26 +07:00
|
|
|
void udev_selinux_setfscreateconat(struct udev *udev, int dirfd, const char *file, unsigned int mode);
|
2009-06-10 04:05:25 +07:00
|
|
|
void udev_selinux_resetfscreatecon(struct udev *udev);
|
|
|
|
#endif
|
2010-05-20 14:04:26 +07:00
|
|
|
|
2008-08-27 22:11:58 +07:00
|
|
|
#endif
|