mirror of
https://github.com/systemd/systemd-stable.git
synced 2025-01-15 23:24:12 +03:00
udev: introduce enum ResolveNameTiming for --resolve-names argument
This commit is contained in:
parent
6b92f42934
commit
c4d44cba4d
@ -84,7 +84,7 @@ int main(int argc, char *argv[]) {
|
|||||||
action = argv[1];
|
action = argv[1];
|
||||||
devpath = argv[2];
|
devpath = argv[2];
|
||||||
|
|
||||||
rules = udev_rules_new(1);
|
rules = udev_rules_new(RESOLVE_NAME_EARLY);
|
||||||
|
|
||||||
const char *syspath = strjoina("/sys", devpath);
|
const char *syspath = strjoina("/sys", devpath);
|
||||||
r = device_new_from_synthetic_event(&dev, syspath, action);
|
r = device_new_from_synthetic_event(&dev, syspath, action);
|
||||||
|
@ -30,6 +30,7 @@
|
|||||||
#include "stat-util.h"
|
#include "stat-util.h"
|
||||||
#include "stdio-util.h"
|
#include "stdio-util.h"
|
||||||
#include "strbuf.h"
|
#include "strbuf.h"
|
||||||
|
#include "string-table.h"
|
||||||
#include "string-util.h"
|
#include "string-util.h"
|
||||||
#include "strv.h"
|
#include "strv.h"
|
||||||
#include "sysctl-util.h"
|
#include "sysctl-util.h"
|
||||||
@ -57,7 +58,7 @@ static const char* const rules_dirs[] = {
|
|||||||
|
|
||||||
struct udev_rules {
|
struct udev_rules {
|
||||||
usec_t dirs_ts_usec;
|
usec_t dirs_ts_usec;
|
||||||
int resolve_names;
|
ResolveNameTiming resolve_name_timing;
|
||||||
|
|
||||||
/* every key in the rules file becomes a token */
|
/* every key in the rules file becomes a token */
|
||||||
struct token *tokens;
|
struct token *tokens;
|
||||||
@ -1335,10 +1336,10 @@ static void add_rule(struct udev_rules *rules, char *line,
|
|||||||
uid = strtoul(value, &endptr, 10);
|
uid = strtoul(value, &endptr, 10);
|
||||||
if (endptr[0] == '\0')
|
if (endptr[0] == '\0')
|
||||||
rule_add_key(&rule_tmp, TK_A_OWNER_ID, op, NULL, &uid);
|
rule_add_key(&rule_tmp, TK_A_OWNER_ID, op, NULL, &uid);
|
||||||
else if (rules->resolve_names > 0 && strchr("$%", value[0]) == NULL) {
|
else if (rules->resolve_name_timing == RESOLVE_NAME_EARLY && strchr("$%", value[0]) == NULL) {
|
||||||
uid = add_uid(rules, value);
|
uid = add_uid(rules, value);
|
||||||
rule_add_key(&rule_tmp, TK_A_OWNER_ID, op, NULL, &uid);
|
rule_add_key(&rule_tmp, TK_A_OWNER_ID, op, NULL, &uid);
|
||||||
} else if (rules->resolve_names >= 0)
|
} else if (rules->resolve_name_timing != RESOLVE_NAME_NEVER)
|
||||||
rule_add_key(&rule_tmp, TK_A_OWNER, op, value, NULL);
|
rule_add_key(&rule_tmp, TK_A_OWNER, op, value, NULL);
|
||||||
|
|
||||||
rule_tmp.rule.rule.can_set_name = true;
|
rule_tmp.rule.rule.can_set_name = true;
|
||||||
@ -1353,10 +1354,10 @@ static void add_rule(struct udev_rules *rules, char *line,
|
|||||||
gid = strtoul(value, &endptr, 10);
|
gid = strtoul(value, &endptr, 10);
|
||||||
if (endptr[0] == '\0')
|
if (endptr[0] == '\0')
|
||||||
rule_add_key(&rule_tmp, TK_A_GROUP_ID, op, NULL, &gid);
|
rule_add_key(&rule_tmp, TK_A_GROUP_ID, op, NULL, &gid);
|
||||||
else if ((rules->resolve_names > 0) && strchr("$%", value[0]) == NULL) {
|
else if ((rules->resolve_name_timing == RESOLVE_NAME_EARLY) && strchr("$%", value[0]) == NULL) {
|
||||||
gid = add_gid(rules, value);
|
gid = add_gid(rules, value);
|
||||||
rule_add_key(&rule_tmp, TK_A_GROUP_ID, op, NULL, &gid);
|
rule_add_key(&rule_tmp, TK_A_GROUP_ID, op, NULL, &gid);
|
||||||
} else if (rules->resolve_names >= 0)
|
} else if (rules->resolve_name_timing != RESOLVE_NAME_NEVER)
|
||||||
rule_add_key(&rule_tmp, TK_A_GROUP, op, value, NULL);
|
rule_add_key(&rule_tmp, TK_A_GROUP, op, value, NULL);
|
||||||
|
|
||||||
rule_tmp.rule.rule.can_set_name = true;
|
rule_tmp.rule.rule.can_set_name = true;
|
||||||
@ -1512,18 +1513,20 @@ static int parse_file(struct udev_rules *rules, const char *filename) {
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
struct udev_rules *udev_rules_new(int resolve_names) {
|
struct udev_rules *udev_rules_new(ResolveNameTiming resolve_name_timing) {
|
||||||
struct udev_rules *rules;
|
struct udev_rules *rules;
|
||||||
struct token end_token;
|
struct token end_token;
|
||||||
char **files, **f;
|
char **files, **f;
|
||||||
int r;
|
int r;
|
||||||
|
|
||||||
|
assert(resolve_name_timing >= 0 && resolve_name_timing < _RESOLVE_NAME_TIMING_MAX);
|
||||||
|
|
||||||
rules = new(struct udev_rules, 1);
|
rules = new(struct udev_rules, 1);
|
||||||
if (!rules)
|
if (!rules)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
*rules = (struct udev_rules) {
|
*rules = (struct udev_rules) {
|
||||||
.resolve_names = resolve_names,
|
.resolve_name_timing = resolve_name_timing,
|
||||||
};
|
};
|
||||||
|
|
||||||
/* init token array and string buffer */
|
/* init token array and string buffer */
|
||||||
@ -2598,3 +2601,11 @@ finish:
|
|||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static const char* const resolve_name_timing_table[_RESOLVE_NAME_TIMING_MAX] = {
|
||||||
|
[RESOLVE_NAME_NEVER] = "never",
|
||||||
|
[RESOLVE_NAME_LATE] = "late",
|
||||||
|
[RESOLVE_NAME_EARLY] = "early",
|
||||||
|
};
|
||||||
|
|
||||||
|
DEFINE_STRING_TABLE_LOOKUP(resolve_name_timing, ResolveNameTiming);
|
||||||
|
@ -48,9 +48,17 @@ struct udev_event {
|
|||||||
bool run_final;
|
bool run_final;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
typedef enum ResolveNameTiming {
|
||||||
|
RESOLVE_NAME_NEVER,
|
||||||
|
RESOLVE_NAME_LATE,
|
||||||
|
RESOLVE_NAME_EARLY,
|
||||||
|
_RESOLVE_NAME_TIMING_MAX,
|
||||||
|
_RESOLVE_NAME_TIMING_INVALID = -1,
|
||||||
|
} ResolveNameTiming;
|
||||||
|
|
||||||
/* udev-rules.c */
|
/* udev-rules.c */
|
||||||
struct udev_rules;
|
struct udev_rules;
|
||||||
struct udev_rules *udev_rules_new(int resolve_names);
|
struct udev_rules *udev_rules_new(ResolveNameTiming resolve_name_timing);
|
||||||
struct udev_rules *udev_rules_unref(struct udev_rules *rules);
|
struct udev_rules *udev_rules_unref(struct udev_rules *rules);
|
||||||
bool udev_rules_check_timestamp(struct udev_rules *rules);
|
bool udev_rules_check_timestamp(struct udev_rules *rules);
|
||||||
int udev_rules_apply_to_event(struct udev_rules *rules, struct udev_event *event,
|
int udev_rules_apply_to_event(struct udev_rules *rules, struct udev_event *event,
|
||||||
@ -58,6 +66,9 @@ int udev_rules_apply_to_event(struct udev_rules *rules, struct udev_event *event
|
|||||||
Hashmap *properties_list);
|
Hashmap *properties_list);
|
||||||
int udev_rules_apply_static_dev_perms(struct udev_rules *rules);
|
int udev_rules_apply_static_dev_perms(struct udev_rules *rules);
|
||||||
|
|
||||||
|
ResolveNameTiming resolve_name_timing_from_string(const char *s) _pure_;
|
||||||
|
const char *resolve_name_timing_to_string(ResolveNameTiming i) _const_;
|
||||||
|
|
||||||
/* udev-event.c */
|
/* udev-event.c */
|
||||||
struct udev_event *udev_event_new(sd_device *dev, usec_t exec_delay_usec, sd_netlink *rtnl);
|
struct udev_event *udev_event_new(sd_device *dev, usec_t exec_delay_usec, sd_netlink *rtnl);
|
||||||
struct udev_event *udev_event_free(struct udev_event *event);
|
struct udev_event *udev_event_free(struct udev_event *event);
|
||||||
|
@ -22,7 +22,7 @@
|
|||||||
#include "udevadm.h"
|
#include "udevadm.h"
|
||||||
|
|
||||||
static const char *arg_action = "add";
|
static const char *arg_action = "add";
|
||||||
static int arg_resolve_names = 1;
|
static ResolveNameTiming arg_resolve_name_timing = RESOLVE_NAME_EARLY;
|
||||||
static char arg_syspath[UTIL_PATH_SIZE] = {};
|
static char arg_syspath[UTIL_PATH_SIZE] = {};
|
||||||
|
|
||||||
static int help(void) {
|
static int help(void) {
|
||||||
@ -55,14 +55,9 @@ static int parse_argv(int argc, char *argv[]) {
|
|||||||
arg_action = optarg;
|
arg_action = optarg;
|
||||||
break;
|
break;
|
||||||
case 'N':
|
case 'N':
|
||||||
if (streq (optarg, "early")) {
|
arg_resolve_name_timing = resolve_name_timing_from_string(optarg);
|
||||||
arg_resolve_names = 1;
|
if (arg_resolve_name_timing < 0) {
|
||||||
} else if (streq (optarg, "late")) {
|
log_error("--resolve-names= must be early, late or never");
|
||||||
arg_resolve_names = 0;
|
|
||||||
} else if (streq (optarg, "never")) {
|
|
||||||
arg_resolve_names = -1;
|
|
||||||
} else {
|
|
||||||
log_error("resolve-names must be early, late or never");
|
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -115,7 +110,7 @@ int test_main(int argc, char *argv[], void *userdata) {
|
|||||||
|
|
||||||
udev_builtin_init();
|
udev_builtin_init();
|
||||||
|
|
||||||
rules = udev_rules_new(arg_resolve_names);
|
rules = udev_rules_new(arg_resolve_name_timing);
|
||||||
if (!rules) {
|
if (!rules) {
|
||||||
log_error("Failed to read udev rules.");
|
log_error("Failed to read udev rules.");
|
||||||
r = -ENOMEM;
|
r = -ENOMEM;
|
||||||
|
@ -61,7 +61,7 @@
|
|||||||
|
|
||||||
static bool arg_debug = false;
|
static bool arg_debug = false;
|
||||||
static int arg_daemonize = false;
|
static int arg_daemonize = false;
|
||||||
static int arg_resolve_names = 1;
|
static ResolveNameTiming arg_resolve_name_timing = RESOLVE_NAME_EARLY;
|
||||||
static unsigned arg_children_max = 0;
|
static unsigned arg_children_max = 0;
|
||||||
static usec_t arg_exec_delay_usec = 0;
|
static usec_t arg_exec_delay_usec = 0;
|
||||||
static usec_t arg_event_timeout_usec = 180 * USEC_PER_SEC;
|
static usec_t arg_event_timeout_usec = 180 * USEC_PER_SEC;
|
||||||
@ -851,7 +851,7 @@ static void event_queue_start(Manager *manager) {
|
|||||||
udev_builtin_init();
|
udev_builtin_init();
|
||||||
|
|
||||||
if (!manager->rules) {
|
if (!manager->rules) {
|
||||||
manager->rules = udev_rules_new(arg_resolve_names);
|
manager->rules = udev_rules_new(arg_resolve_name_timing);
|
||||||
if (!manager->rules)
|
if (!manager->rules)
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -1565,18 +1565,16 @@ static int parse_argv(int argc, char *argv[]) {
|
|||||||
case 'D':
|
case 'D':
|
||||||
arg_debug = true;
|
arg_debug = true;
|
||||||
break;
|
break;
|
||||||
case 'N':
|
case 'N': {
|
||||||
if (streq(optarg, "early")) {
|
ResolveNameTiming t;
|
||||||
arg_resolve_names = 1;
|
|
||||||
} else if (streq(optarg, "late")) {
|
t = resolve_name_timing_from_string(optarg);
|
||||||
arg_resolve_names = 0;
|
if (t < 0)
|
||||||
} else if (streq(optarg, "never")) {
|
log_warning("Invalid --resolve-names= value '%s', ignoring.", optarg);
|
||||||
arg_resolve_names = -1;
|
else
|
||||||
} else {
|
arg_resolve_name_timing = t;
|
||||||
log_error("resolve-names must be early, late or never");
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
case 'h':
|
case 'h':
|
||||||
return help();
|
return help();
|
||||||
case 'V':
|
case 'V':
|
||||||
@ -1611,7 +1609,7 @@ static int manager_new(Manager **ret, int fd_ctrl, int fd_uevent, const char *cg
|
|||||||
|
|
||||||
udev_builtin_init();
|
udev_builtin_init();
|
||||||
|
|
||||||
manager->rules = udev_rules_new(arg_resolve_names);
|
manager->rules = udev_rules_new(arg_resolve_name_timing);
|
||||||
if (!manager->rules)
|
if (!manager->rules)
|
||||||
return log_error_errno(ENOMEM, "error reading rules");
|
return log_error_errno(ENOMEM, "error reading rules");
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user