goto out;
}
- assert_se(event = udev_event_new(dev, 0));
+ assert_se(event = udev_event_new(dev, 0, NULL));
assert_se(sigprocmask_many(SIG_BLOCK, NULL, SIGTERM, SIGINT, SIGHUP, SIGCHLD, -1) >= 0);
size_t result_len;
} Spawn;
-struct udev_event *udev_event_new(struct udev_device *dev, int exec_delay) {
+struct udev_event *udev_event_new(struct udev_device *dev, int exec_delay, sd_netlink *rtnl) {
struct udev_event *event;
assert(dev);
.dev = dev,
.birth_usec = now(CLOCK_MONOTONIC),
.exec_delay = exec_delay,
+ .rtnl = sd_netlink_ref(rtnl),
};
return event;
int udev_rules_apply_static_dev_perms(struct udev_rules *rules);
/* udev-event.c */
-struct udev_event *udev_event_new(struct udev_device *dev, int exec_delay);
+struct udev_event *udev_event_new(struct udev_device *dev, int exec_delay, 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,
/* don't read info from the db */
udev_device_set_info_loaded(dev);
- event = udev_event_new(dev, 0);
+ event = udev_event_new(dev, 0, NULL);
sigfillset(&mask);
sigprocmask(SIG_SETMASK, &mask, &sigmask_orig);
assert(dev);
log_debug("seq %llu running", udev_device_get_seqnum(dev));
- udev_event = udev_event_new(dev, arg_exec_delay);
+ udev_event = udev_event_new(dev, arg_exec_delay, rtnl);
if (!udev_event) {
r = -ENOMEM;
goto out;
}
}
- /* needed for renaming netifs */
- udev_event->rtnl = rtnl;
-
/* apply rules, create node, symlinks */
udev_event_execute_rules(udev_event,
arg_event_timeout_usec, arg_event_timeout_warn_usec,
udev_event_execute_run(udev_event,
arg_event_timeout_usec, arg_event_timeout_warn_usec);
- if (udev_event->rtnl)
+ if (!rtnl)
/* in case rtnl was initialized */
rtnl = sd_netlink_ref(udev_event->rtnl);