chiark / gitweb /
[PATCH] split udev main logic into udev-add and udev-remove.
[elogind.git] / udev.h
diff --git a/udev.h b/udev.h
index ef7175e..59c3743 100644 (file)
--- a/udev.h
+++ b/udev.h
 
 #ifdef DEBUG
 #include <syslog.h>
-       #define dbg(format, arg...) do { log_message (LOG_DEBUG, __FUNCTION__ ": " format, ## arg); } while (0)
+#define dbg(format, arg...)                                                            \
+       do {                                                                            \
+               log_message (LOG_DEBUG , "%s: " format , __FUNCTION__ , ## arg);        \
+       } while (0)
 #else
        #define dbg(format, arg...) do { } while (0)
 #endif
 
 
 /* Lots of constants that should be in a config file sometime */
+
+/* Location of sysfs mount */
 #define SYSFS_ROOT     "/sys"
+
+/* Where udev should create its device nodes, trailing / needed */
+#define UDEV_ROOT      "/udev/"
+
+/* device file in sysfs that contains major/minor number, leading / needed */
+#define DEV_FILE       "/dev"
+
+/* Binaries that udev calls to do stuff */
 #define MKNOD          "/bin/mknod"
 
+extern int log_message (int level, const char *format, ...)
+       __attribute__ ((format (printf, 2, 3)));
+
+#define NAME_SIZE      100
+#define OWNER_SIZE     30
+#define GROUP_SIZE     30
+
+struct device_attr {
+       char name[NAME_SIZE];
+       char owner[OWNER_SIZE];
+       char group[GROUP_SIZE];
+       int mode;
+};
+
+extern int udev_add_device(char *device, char *subsystem);
+extern int udev_remove_device(char *device, char *subsystem);
 
 #endif