X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=blobdiff_plain;f=udev.h;h=59c374365ea44d438e1e8dff052f5eb139811dce;hp=ef7175ea3a8d2c08e1fc27f0aafda9b644e5b52d;hb=ea733a2f00174c3a39c8eb783e330b6a69abd67c;hpb=f0083e3d4eb49e11fd7e37532dc64a6e6f5d4039 diff --git a/udev.h b/udev.h index ef7175ea3..59c374365 100644 --- a/udev.h +++ b/udev.h @@ -26,16 +26,45 @@ #ifdef DEBUG #include - #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