From nobody Tue Aug 20 04:58:15 2024 X-Original-To: dev-commits-src-all@mlmmj.nyi.freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2610:1c1:1:606c::19:1]) by mlmmj.nyi.freebsd.org (Postfix) with ESMTP id 4Wny073Nv2z5VFrT; Tue, 20 Aug 2024 04:58:15 +0000 (UTC) (envelope-from git@FreeBSD.org) Received: from mxrelay.nyi.freebsd.org (mxrelay.nyi.freebsd.org [IPv6:2610:1c1:1:606c::19:3]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits) server-digest SHA256 client-signature RSA-PSS (4096 bits) client-digest SHA256) (Client CN "mxrelay.nyi.freebsd.org", Issuer "R11" (verified OK)) by mx1.freebsd.org (Postfix) with ESMTPS id 4Wny072sV1z4NdK; Tue, 20 Aug 2024 04:58:15 +0000 (UTC) (envelope-from git@FreeBSD.org) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=freebsd.org; s=dkim; t=1724129895; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding; bh=wBGc7NYxBGZH0Vp8EEzD9xi7K7qBBngUcz0+XKy9q4Q=; b=uSrBBP/YaR8WKupDcBgR7pdhBK5clV1WsMIM2QrPfyt/XBvhSsRzBnDliT9+lw3eVAuIP3 VAKp95wm4og8dtMleg87CX0HenYUJ1FTCNRnncegitzLFuQxYI2RcTVHcrVd1QmLIhAfTH IGCV+LJoeOwCa0SkQSOh09080S4AsoEKPAswulbdwlE7KU5xrxOLIh75KkSbnIVopjAWwj Fk/xKXuRZJU/xX8WlazGcb/GpPy7jx+vGVP+AaI8jLU+IsYPS242kyc6Q8h9I9AQKuXOhn 7x05q2ZFZfPawlPMqbFCxzgpBUkpJbcu07fHOjd0dWEPye3d+C+eHWLVY/u9ew== ARC-Seal: i=1; s=dkim; d=freebsd.org; t=1724129895; a=rsa-sha256; cv=none; b=fz30/92VE1gsKc+PeRzn2FivqF8DlZ7W+1XewREKH1DO2KEYnYepTFiGiJqR5VqxuF6zqo R67YIkVIXWE2gfje4qZyw+vmSVz2K5W+bHXvT+Bj/paX3HpM4mPBb4tNH+qD4uij0oY9RK 5FpkVstX/nB8Qc8bEZwbGXa3PRSn130biOv99vABz9o7+CXNP8MGfBbRKXRky4qNJhGRCn F2iozhYCnm9upqLjlLIvWGBiz0a7aSg/RaR/T7yW3AbVf4S4Bbgaal+0eAfrBCqAOrLAaS iYU83e6HBlR0sLVBHppjE5cpZ8oVAOgUzr117QZr3+xk5PU2EDqDQPSO/UOJVg== ARC-Authentication-Results: i=1; mx1.freebsd.org; none ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=freebsd.org; s=dkim; t=1724129895; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding; bh=wBGc7NYxBGZH0Vp8EEzD9xi7K7qBBngUcz0+XKy9q4Q=; b=ruWKT95Xdh9uRnGqzSUIMTPcKp7yrbTb+MBuAyt/tsRYF8y4BlSTiEz9HD//f5Aw+poSdx 0IAIxUihQlASew0YRYBnYzjk7jEAMRryMcxvABFgS8A1mazfpeBKkF0ISa2VOg7akXjQE/ cpOOCEKKLyAfr8cUMiTXUPeOcZmOeQV/nfpBTHNMQTJ4HedM6o6WZ6CduOKfAxQndQqgA4 LtsDo5bGx/JyN9ZHIEj4eKaRG5r4QN4i4V+R1ojvHz05O4zScq0fhM5GqS2I5k56rU+aLn mmZdfqMUGz36JEWGLtUXzaZaV8htenZHsi1jCa7mdO/HS93A94yzw0Tskeln/Q== Received: from gitrepo.freebsd.org (gitrepo.freebsd.org [IPv6:2610:1c1:1:6068::e6a:5]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits) server-digest SHA256) (Client did not present a certificate) by mxrelay.nyi.freebsd.org (Postfix) with ESMTPS id 4Wny0722mgzn1N; Tue, 20 Aug 2024 04:58:15 +0000 (UTC) (envelope-from git@FreeBSD.org) Received: from gitrepo.freebsd.org ([127.0.1.44]) by gitrepo.freebsd.org (8.18.1/8.18.1) with ESMTP id 47K4wFcj054119; Tue, 20 Aug 2024 04:58:15 GMT (envelope-from git@gitrepo.freebsd.org) Received: (from git@localhost) by gitrepo.freebsd.org (8.18.1/8.18.1/Submit) id 47K4wFgI054116; Tue, 20 Aug 2024 04:58:15 GMT (envelope-from git) Date: Tue, 20 Aug 2024 04:58:15 GMT Message-Id: <202408200458.47K4wFgI054116@gitrepo.freebsd.org> To: src-committers@FreeBSD.org, dev-commits-src-all@FreeBSD.org, dev-commits-src-branches@FreeBSD.org From: Colin Percival Subject: git: 99c5c0cb1556 - stable/14 - dhclient: Switch timeouts from time_t to timespec List-Id: Commit messages for all branches of the src repository List-Archive: https://lists.freebsd.org/archives/dev-commits-src-all List-Help: List-Post: List-Subscribe: List-Unsubscribe: X-BeenThere: dev-commits-src-all@freebsd.org Sender: owner-dev-commits-src-all@FreeBSD.org MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 8bit X-Git-Committer: cperciva X-Git-Repository: src X-Git-Refname: refs/heads/stable/14 X-Git-Reftype: branch X-Git-Commit: 99c5c0cb1556daf2818e99a934dc6a2f99fa30f9 Auto-Submitted: auto-generated The branch stable/14 has been updated by cperciva: URL: https://cgit.FreeBSD.org/src/commit/?id=99c5c0cb1556daf2818e99a934dc6a2f99fa30f9 commit 99c5c0cb1556daf2818e99a934dc6a2f99fa30f9 Author: Isaac Cilia Attard AuthorDate: 2024-07-08 05:43:09 +0000 Commit: Colin Percival CommitDate: 2024-08-20 04:57:08 +0000 dhclient: Switch timeouts from time_t to timespec Introduce a new function, add_timeout_timespec(), to use timespec structs to handle timeouts. Make add_timeout() into a wrapper for the latter function to retain compatibility with the rest of the codebase. No functional change intended. Sponsored by: Google LLC (GSoC 2024) Signed-off-by: Isaac Cilia Attard MFC after: 10 days Reviwed by: cperciva, brooks, Tom Hukins, Alexander Ziaee Pull Request: https://github.com/freebsd/freebsd-src/pull/1368 (cherry picked from commit 16a235f23c066d27b3a53c66cf6aa329be07cdb9) --- sbin/dhclient/dhcpd.h | 3 ++- sbin/dhclient/dispatch.c | 28 +++++++++++++++++++--------- 2 files changed, 21 insertions(+), 10 deletions(-) diff --git a/sbin/dhclient/dhcpd.h b/sbin/dhclient/dhcpd.h index 399b5c1ecf6c..56a38d733501 100644 --- a/sbin/dhclient/dhcpd.h +++ b/sbin/dhclient/dhcpd.h @@ -219,7 +219,7 @@ struct interface_info { struct timeout { struct timeout *next; - time_t when; + struct timespec when; void (*func)(void *); void *what; }; @@ -321,6 +321,7 @@ void reinitialize_interfaces(void); void dispatch(void); void got_one(struct protocol *); void add_timeout(time_t, void (*)(void *), void *); +void add_timeout_timespec(struct timespec, void (*)(void *), void *); void cancel_timeout(void (*)(void *), void *); void add_protocol(const char *, int, void (*)(struct protocol *), void *); void remove_protocol(struct protocol *); diff --git a/sbin/dhclient/dispatch.c b/sbin/dhclient/dispatch.c index 310f477f8a4f..aa15c35a9f15 100644 --- a/sbin/dhclient/dispatch.c +++ b/sbin/dhclient/dispatch.c @@ -155,7 +155,8 @@ dispatch(void) int count, live_interfaces, i, to_msec, nfds = 0; struct protocol *l; struct pollfd *fds; - time_t howlong; + struct timespec howlong; + struct timespec time_now = { .tv_sec = cur_time, .tv_nsec = 0 }; for (l = protocols; l; l = l->next) nfds++; @@ -173,7 +174,7 @@ another: if (timeouts) { struct timeout *t; - if (timeouts->when <= cur_time) { + if (timespeccmp(&timeouts->when, &time_now, <=)) { t = timeouts; timeouts = timeouts->next; (*(t->func))(t->what); @@ -188,10 +189,10 @@ another: * int for poll, while not polling with a * negative timeout and blocking indefinitely. */ - howlong = timeouts->when - cur_time; - if (howlong > INT_MAX / 1000) - howlong = INT_MAX / 1000; - to_msec = howlong * 1000; + timespecsub(&timeouts->when, &time_now, &howlong); + if (howlong.tv_sec > INT_MAX / 1000) + howlong.tv_sec = INT_MAX / 1000; + to_msec = howlong.tv_sec * 1000; } else to_msec = -1; @@ -219,6 +220,7 @@ another: if (count == -1) { if (errno == EAGAIN || errno == EINTR) { time(&cur_time); + time_now.tv_sec = cur_time; continue; } else error("poll: %m"); @@ -226,6 +228,7 @@ another: /* Get the current time... */ time(&cur_time); + time_now.tv_sec = cur_time; i = 0; for (l = protocols; l; l = l->next) { @@ -356,7 +359,14 @@ active: } void -add_timeout(time_t when, void (*where)(void *), void *what) +add_timeout(time_t when_s, void (*where)(void *), void *what) +{ + struct timespec when = { .tv_sec = when_s, .tv_nsec = 0 }; + add_timeout_timespec(when, where, what); +} + +void +add_timeout_timespec(struct timespec when, void (*where)(void *), void *what) { struct timeout *t, *q; @@ -395,7 +405,7 @@ add_timeout(time_t when, void (*where)(void *), void *what) /* Now sort this timeout into the timeout list. */ /* Beginning of list? */ - if (!timeouts || timeouts->when > q->when) { + if (!timeouts || timespeccmp(&timeouts->when, &q->when, >)) { q->next = timeouts; timeouts = q; return; @@ -403,7 +413,7 @@ add_timeout(time_t when, void (*where)(void *), void *what) /* Middle of list? */ for (t = timeouts; t->next; t = t->next) { - if (t->next->when > q->when) { + if (timespeccmp(&t->next->when, &q->when, >)) { q->next = t->next; t->next = q; return;