chiark / gitweb /
[PATCH] fix permission handling logic
[elogind.git] / namedev.h
index d5aaae202cf28e4fa7eefb9f6a9b5e26850ae45f..f7b8a676673afc6235f22aa7cd4261350a77651c 100644 (file)
--- a/namedev.h
+++ b/namedev.h
@@ -28,7 +28,6 @@
 
 struct sysfs_class_device;
 
-#define COMMENT_CHARACTER              '#'
 
 enum config_type {
        KERNEL_NAME     = 0,    /* must be 0 to let memset() default to this value */
@@ -45,12 +44,17 @@ enum config_type {
 #define ID_SIZE                50
 #define PLACE_SIZE     50
 
+#define TYPE_LABEL     "LABEL"
+#define TYPE_NUMBER    "NUMBER"
+#define TYPE_TOPOLOGY  "TOPOLOGY"
+#define TYPE_REPLACE   "REPLACE"
+#define TYPE_CALLOUT   "CALLOUT"
+#define CALLOUT_MAXARG 8
 
 struct config_device {
        struct list_head node;
 
        enum config_type type;
-
        char bus[BUS_SIZE];
        char sysfs_file[FILE_SIZE];
        char sysfs_value[VALUE_SIZE];
@@ -58,13 +62,33 @@ struct config_device {
        char place[PLACE_SIZE];
        char kernel_name[NAME_SIZE];
        char exec_program[FILE_SIZE];
-       
-       /* what to set the device to */
-       struct device_attr attr;
+       char name[NAME_SIZE];
 };
 
+struct perm_device {
+       struct list_head node;
+
+       char name[NAME_SIZE];
+       char owner[OWNER_SIZE];
+       char group[GROUP_SIZE];
+       mode_t mode;
+};
+
+extern struct list_head config_device_list;
+extern struct list_head perm_device_list;
 
 extern int namedev_init(void);
-extern int namedev_name_device(struct sysfs_class_device *class_dev, struct device_attr *attr);
+extern int namedev_name_device(struct sysfs_class_device *class_dev, struct udevice *dev);
+extern int namedev_init_permissions(void);
+extern int namedev_init_rules(void);
+
+extern int add_config_dev(struct config_device *new_dev);
+extern int add_perm_dev(struct perm_device *new_dev);
+extern void dump_config_dev(struct config_device *dev);
+extern void dump_config_dev_list(void);
+extern void dump_perm_dev(struct perm_device *dev);
+extern void dump_perm_dev_list(void);
+
+extern int get_pair(char **orig_string, char **left, char **right);
 
 #endif