X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=blobdiff_plain;f=namedev.h;h=76caaaa9f7a0685868e2ad22d99605fea4580fcf;hp=7a98d66c24ca42c2b5f964c2751c6eac8610ab8d;hb=83b069c6e695446688715cc4404bcfaa3288e649;hpb=2092fbcdebf5313f29b43bdaa57a22baf0c0269f diff --git a/namedev.h b/namedev.h index 7a98d66c2..76caaaa9f 100644 --- a/namedev.h +++ b/namedev.h @@ -28,92 +28,69 @@ struct sysfs_class_device; -#define BUS_SIZE 32 -#define FILE_SIZE 64 -#define VALUE_SIZE 128 -#define ID_SIZE 64 -#define PLACE_SIZE 64 -#define DRIVER_SIZE 64 -#define PROGRAM_SIZE 128 - +#define FIELD_KERNEL "KERNEL" +#define FIELD_SUBSYSTEM "SUBSYSTEM" #define FIELD_BUS "BUS" #define FIELD_SYSFS "SYSFS" #define FIELD_ID "ID" #define FIELD_PLACE "PLACE" #define FIELD_PROGRAM "PROGRAM" #define FIELD_RESULT "RESULT" -#define FIELD_KERNEL "KERNEL" -#define FIELD_SUBSYSTEM "SUBSYSTEM" #define FIELD_DRIVER "DRIVER" #define FIELD_NAME "NAME" #define FIELD_SYMLINK "SYMLINK" #define FIELD_OWNER "OWNER" #define FIELD_GROUP "GROUP" #define FIELD_MODE "MODE" +#define FIELD_OPTIONS "OPTIONS" -#define ATTR_PARTITIONS "all_partitions" -#define PARTITIONS_COUNT 15 +#define OPTION_IGNORE_DEVICE "ignore_device" +#define OPTION_IGNORE_REMOVE "ignore_remove" +#define OPTION_PARTITIONS "all_partitions" #define MAX_SYSFS_PAIRS 5 #define RULEFILE_SUFFIX ".rules" -#define PERMFILE_SUFFIX ".permissions" - -#define set_empty_perms(dev, m, o, g) \ - if (dev->mode == 0) \ - dev->mode = m; \ - if (dev->owner[0] == '\0') \ - strfieldcpy(dev->owner, o); \ - if (dev->group[0] == '\0') \ - strfieldcpy(dev->group, g); struct sysfs_pair { - char file[FILE_SIZE]; + char file[PATH_SIZE]; char value[VALUE_SIZE]; }; struct config_device { struct list_head node; - char bus[BUS_SIZE]; - char id[ID_SIZE]; - char place[PLACE_SIZE]; char kernel[NAME_SIZE]; - char program[PROGRAM_SIZE]; - char result[PROGRAM_SIZE]; - char subsystem[SUBSYSTEM_SIZE]; - char driver[DRIVER_SIZE]; - char name[NAME_SIZE]; - char symlink[NAME_SIZE]; + char subsystem[NAME_SIZE]; + char bus[NAME_SIZE]; + char id[NAME_SIZE]; + char place[NAME_SIZE]; struct sysfs_pair sysfs_pair[MAX_SYSFS_PAIRS]; - char owner[OWNER_SIZE]; - char group[GROUP_SIZE]; - unsigned int mode; - int partitions; - char config_file[NAME_SIZE]; - int config_line; -}; + char program[PATH_SIZE]; + char result[PATH_SIZE]; + char driver[NAME_SIZE]; + char name[PATH_SIZE]; + char symlink[PATH_SIZE]; -struct perm_device { - struct list_head node; + char owner[USER_SIZE]; + char group[USER_SIZE]; + mode_t mode; - char name[NAME_SIZE]; - char owner[OWNER_SIZE]; - char group[GROUP_SIZE]; - unsigned int mode; + int partitions; + int ignore_device; + int ignore_remove; + + char config_file[PATH_SIZE]; + int config_line; }; 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 udevice *udev, struct sysfs_class_device *class_dev); -extern int namedev_init_permissions(void); -extern int namedev_init_rules(void); +extern void namedev_close(void); 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); #endif