summaryrefslogtreecommitdiff
path: root/src/udev
diff options
context:
space:
mode:
authorYu Watanabe <watanabe.yu+github@gmail.com>2018-10-25 14:56:12 +0900
committerYu Watanabe <watanabe.yu+github@gmail.com>2018-11-12 23:16:54 +0900
commit6b92f42934d0198253c11cedd7dc3239ecaa5bf0 (patch)
treeb5082311e5ac55cb69d24cf7fbae148a67575421 /src/udev
parent216e8bbe342160af60fa20a70b95c1bef8639695 (diff)
downloadsystemd-6b92f42934d0198253c11cedd7dc3239ecaa5bf0.tar.gz
systemd-6b92f42934d0198253c11cedd7dc3239ecaa5bf0.tar.bz2
systemd-6b92f42934d0198253c11cedd7dc3239ecaa5bf0.zip
udevd: use parse_sec() to parse --exec-delay option
Diffstat (limited to 'src/udev')
-rw-r--r--src/udev/udev-event.c8
-rw-r--r--src/udev/udev.h4
-rw-r--r--src/udev/udevd.c10
3 files changed, 11 insertions, 11 deletions
diff --git a/src/udev/udev-event.c b/src/udev/udev-event.c
index c1d0b3662b..d5666c1079 100644
--- a/src/udev/udev-event.c
+++ b/src/udev/udev-event.c
@@ -42,7 +42,7 @@ typedef struct Spawn {
size_t result_len;
} Spawn;
-struct udev_event *udev_event_new(sd_device *dev, int exec_delay, sd_netlink *rtnl) {
+struct udev_event *udev_event_new(sd_device *dev, usec_t exec_delay_usec, sd_netlink *rtnl) {
struct udev_event *event;
assert(dev);
@@ -54,7 +54,7 @@ struct udev_event *udev_event_new(sd_device *dev, int exec_delay, sd_netlink *rt
*event = (struct udev_event) {
.dev = sd_device_ref(dev),
.birth_usec = now(CLOCK_MONOTONIC),
- .exec_delay = exec_delay,
+ .exec_delay_usec = exec_delay_usec,
.rtnl = sd_netlink_ref(rtnl),
};
@@ -896,9 +896,9 @@ void udev_event_execute_run(struct udev_event *event, usec_t timeout_usec, usec_
if (builtin_cmd >= 0 && builtin_cmd < _UDEV_BUILTIN_MAX)
udev_builtin_run(event->dev, builtin_cmd, command, false);
else {
- if (event->exec_delay > 0) {
+ if (event->exec_delay_usec > 0) {
log_debug("delay execution of '%s'", command);
- sleep(event->exec_delay);
+ (void) usleep(event->exec_delay_usec);
}
udev_event_spawn(event, timeout_usec, timeout_warn_usec, false, command, NULL, 0);
diff --git a/src/udev/udev.h b/src/udev/udev.h
index 162859ab40..fb2c6813ef 100644
--- a/src/udev/udev.h
+++ b/src/udev/udev.h
@@ -30,7 +30,7 @@ struct udev_event {
gid_t gid;
Hashmap *seclabel_list;
Hashmap *run_list;
- int exec_delay;
+ usec_t exec_delay_usec;
usec_t birth_usec;
sd_netlink *rtnl;
unsigned builtin_run;
@@ -59,7 +59,7 @@ int udev_rules_apply_to_event(struct udev_rules *rules, struct udev_event *event
int udev_rules_apply_static_dev_perms(struct udev_rules *rules);
/* udev-event.c */
-struct udev_event *udev_event_new(sd_device *dev, int exec_delay, 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);
ssize_t udev_event_apply_format(struct udev_event *event,
const char *src, char *dest, size_t size,
diff --git a/src/udev/udevd.c b/src/udev/udevd.c
index ecec6cafb8..c97e873942 100644
--- a/src/udev/udevd.c
+++ b/src/udev/udevd.c
@@ -63,7 +63,7 @@ static bool arg_debug = false;
static int arg_daemonize = false;
static int arg_resolve_names = 1;
static unsigned arg_children_max = 0;
-static int arg_exec_delay = 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_warn_usec = 180 * USEC_PER_SEC / 3;
@@ -409,7 +409,7 @@ static void worker_spawn(Manager *manager, struct event *event) {
assert(dev);
log_debug("seq %llu running", udev_device_get_seqnum(dev));
- udev_event = udev_event_new(dev->device, arg_exec_delay, rtnl);
+ udev_event = udev_event_new(dev->device, arg_exec_delay_usec, rtnl);
if (!udev_event) {
r = -ENOMEM;
goto out;
@@ -1479,7 +1479,7 @@ static int parse_proc_cmdline_item(const char *key, const char *value, void *dat
if (proc_cmdline_value_missing(key, value))
return 0;
- r = safe_atoi(value, &arg_exec_delay);
+ r = parse_sec(value, &arg_exec_delay_usec);
} else if (startswith(key, "udev."))
log_warning("Unknown udev kernel command line option \"%s\"", key);
@@ -1549,9 +1549,9 @@ static int parse_argv(int argc, char *argv[]) {
log_warning("Invalid --children-max ignored: %s", optarg);
break;
case 'e':
- r = safe_atoi(optarg, &arg_exec_delay);
+ r = parse_sec(optarg, &arg_exec_delay_usec);
if (r < 0)
- log_warning("Invalid --exec-delay ignored: %s", optarg);
+ log_warning_errno(r, "Failed to parse --exec-delay= value '%s', ignoring: %m", optarg);
break;
case 't':
r = safe_atou64(optarg, &arg_event_timeout_usec);