From: Yu Watanabe Date: Sat, 12 Mar 2022 11:57:15 +0000 (+0900) Subject: udev: assume there is no blocker when failed to check event dependencies X-Git-Tag: v251-rc1~43 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=2d40f02ee4317233365f53c85234be3af6b000a6;p=thirdparty%2Fsystemd.git udev: assume there is no blocker when failed to check event dependencies Previously, if udevd failed to resolve event dependency, the event is ignored and libudev listeners did not receive the event. This is inconsistent with the case when a worker failed to process a event, in that case, the original uevent sent by the kernel is broadcasted to listeners. --- diff --git a/src/udev/udevd.c b/src/udev/udevd.c index f1f864a4610..8c690357b8d 100644 --- a/src/udev/udevd.c +++ b/src/udev/udevd.c @@ -951,24 +951,21 @@ static int event_queue_start(Manager *manager) { /* do not start event if parent or child event is still running or queued */ r = event_is_blocked(event); + if (r > 0) + continue; if (r < 0) { sd_device_action_t a = _SD_DEVICE_ACTION_INVALID; (void) sd_device_get_action(event->dev, &a); log_device_warning_errno(event->dev, r, - "Failed to check event dependency, " - "skipping event (SEQNUM=%"PRIu64", ACTION=%s)", + "Failed to check dependencies for event (SEQNUM=%"PRIu64", ACTION=%s), " + "assuming there is no blocking event, ignoring: %m", event->seqnum, strna(device_action_to_string(a))); - - event_free(event); - return r; } - if (r > 0) - continue; r = event_run(event); - if (r <= 0) + if (r <= 0) /* 0 means there are no idle workers. Let's escape from the loop. */ return r; }