richardphibel / rpms / systemd

Forked from rpms/systemd 2 years ago
Clone
803fb7
From e7cd53f60cc2cb5e98efa0e88cfd0e7dd8325085 Mon Sep 17 00:00:00 2001
803fb7
From: Nir Soffer <nirsof@gmail.com>
803fb7
Date: Sun, 19 Apr 2015 02:49:47 +0300
803fb7
Subject: [PATCH] udev: Fix ping timeout when settle timeout is 0
803fb7
803fb7
When running udevadm settle --timeout=0, the ping always times out, and
803fb7
udevadm will return 0 without checking the queue state.
803fb7
803fb7
(David: Use a reasonable timeout to still get the barrier provided by
803fb7
 ctrl-ping)
803fb7
803fb7
Cherry-picked from: 7375b3c4871861f100860ea4c2848e66b60e6ca4
803fb7
Resolves: #1210981
803fb7
---
803fb7
 src/udev/udevadm-settle.c | 2 +-
803fb7
 1 file changed, 1 insertion(+), 1 deletion(-)
803fb7
803fb7
diff --git a/src/udev/udevadm-settle.c b/src/udev/udevadm-settle.c
803fb7
index 40e3e28b1..33597bc20 100644
803fb7
--- a/src/udev/udevadm-settle.c
803fb7
+++ b/src/udev/udevadm-settle.c
803fb7
@@ -114,7 +114,7 @@ static int adm_settle(struct udev *udev, int argc, char *argv[]) {
803fb7
 
803fb7
                 uctrl = udev_ctrl_new(udev);
803fb7
                 if (uctrl != NULL) {
803fb7
-                        if (udev_ctrl_send_ping(uctrl, timeout) < 0) {
803fb7
+                        if (udev_ctrl_send_ping(uctrl, MAX(5U, timeout)) < 0) {
803fb7
                                 log_debug("no connection to daemon");
803fb7
                                 udev_ctrl_unref(uctrl);
803fb7
                                 return EXIT_SUCCESS;