On Sun, 26 Apr 2026 13:10:44 +1000, David Leadbeater wrote:
> I have left ntpleaps.h here, two macros from it are needed. I think
> this could be cleaned up, but this diff keeps the removal simple
> as a candidate for release.
No need for ntpleaps.h anyore. Instead of using SEC_TO_TAI64 and
then TAI64_TO_SEC, we can just use tv_sec as-is.
Removing the -c option entirely seems like the safer thing to do.
- todd
Index: usr.sbin/rdate/Makefile
===================================================================
RCS file: /cvs/src/usr.sbin/rdate/Makefile,v
diff -u -p -u -r1.8 Makefile
--- usr.sbin/rdate/Makefile 27 Mar 2026 14:33:58 -0000 1.8
+++ usr.sbin/rdate/Makefile 26 Apr 2026 15:02:25 -0000
@@ -1,7 +1,7 @@
# $OpenBSD: Makefile,v 1.8 2026/03/27 14:33:58 deraadt Exp $
PROG= rdate
-SRCS= rdate.c ntp.c ntpleaps.c
+SRCS= rdate.c ntp.c
CFLAGS+=-Wall
DPADD+= ${LIBUTIL}
LDADD+= -lutil
Index: usr.sbin/rdate/ntp.c
===================================================================
RCS file: /cvs/src/usr.sbin/rdate/ntp.c,v
diff -u -p -u -r1.37 ntp.c
--- usr.sbin/rdate/ntp.c 12 Nov 2023 18:53:22 -0000 1.37
+++ usr.sbin/rdate/ntp.c 26 Apr 2026 15:14:04 -0000
@@ -50,8 +50,6 @@
#include <poll.h>
#include <unistd.h>
-#include "ntpleaps.h"
-
/*
* NTP definitions. Note that these assume 8-bit bytes - sigh. There
* is little point in parameterising everything, as it is neither
@@ -120,7 +118,7 @@ struct ntp_data {
u_int64_t xmitck;
};
-void ntp_client(const char *, int, struct timeval *, struct timeval *, int);
+void ntp_client(const char *, int, struct timeval *, struct timeval *);
int sync_ntp(int, const struct sockaddr *, double *, double *);
int write_packet(int, struct ntp_data *);
int read_packet(int, struct ntp_data *, double *, double *);
@@ -132,11 +130,9 @@ void create_timeval(double, struct timev
void print_packet(const struct ntp_data *);
#endif
-int corrleaps;
-
void
ntp_client(const char *hostname, int family, struct timeval *new,
- struct timeval *adjust, int leapflag)
+ struct timeval *adjust)
{
struct addrinfo hints, *res0, *res;
double offset, error;
@@ -154,10 +150,6 @@ ntp_client(const char *hostname, int fam
if (pledge("stdio inet", NULL) == -1)
err(1, "pledge");
- corrleaps = leapflag;
- if (corrleaps)
- ntpleaps_init();
-
s = -1;
for (res = res0; res; res = res->ai_next) {
s = socket(res->ai_family, res->ai_socktype, res->ai_protocol);
@@ -447,21 +439,11 @@ double
current_time(double offset)
{
struct timeval current;
- u_int64_t t;
if (gettimeofday(¤t, NULL))
err(1, "Could not get local time of day");
- /*
- * At this point, current has the current TAI time.
- * Now subtract leap seconds to set the posix tick.
- */
-
- t = SEC_TO_TAI64(current.tv_sec);
- if (corrleaps)
- ntpleaps_sub(&t);
-
- return (offset + TAI64_TO_SEC(t) + 1.0e-6 * current.tv_usec);
+ return (offset + current.tv_sec + 1.0e-6 * current.tv_usec);
}
/*
Index: usr.sbin/rdate/rdate.8
===================================================================
RCS file: /cvs/src/usr.sbin/rdate/rdate.8,v
diff -u -p -u -r1.41 rdate.8
--- usr.sbin/rdate/rdate.8 27 Mar 2026 14:33:58 -0000 1.41
+++ usr.sbin/rdate/rdate.8 26 Apr 2026 15:15:10 -0000
@@ -32,7 +32,7 @@
.Nd set the system's date from a remote host
.Sh SYNOPSIS
.Nm rdate
-.Op Fl 46acnpsv
+.Op Fl 46anpsv
.Ar host
.Sh DESCRIPTION
.Nm
@@ -55,10 +55,6 @@ Use the
.Xr adjtime 2
call to gradually skew the local time to the
remote time rather than just hopping.
-.It Fl c
-Correct leap seconds.
-This should be used only when synchronizing to a server
-which does not correctly account for leap seconds.
.It Fl n
Use SNTP (RFC 5905).
This is the default.
Index: usr.sbin/rdate/rdate.c
===================================================================
RCS file: /cvs/src/usr.sbin/rdate/rdate.c,v
diff -u -p -u -r1.38 rdate.c
--- usr.sbin/rdate/rdate.c 27 Mar 2026 14:33:58 -0000 1.38
+++ usr.sbin/rdate/rdate.c 26 Apr 2026 15:14:33 -0000
@@ -52,7 +52,7 @@
#define logwtmp(a,b,c)
#endif
-void ntp_client(const char *, int, struct timeval *, struct timeval *, int);
+void ntp_client(const char *, int, struct timeval *, struct timeval *);
extern char *__progname;
__dead void usage(void);
@@ -74,12 +74,12 @@ int
main(int argc, char **argv)
{
int pr = 0, silent = 0, verbose = 0;
- int slidetime = 0, corrleaps = 0;
+ int slidetime = 0;
char *hname;
int c, p[2], pid;
int family = PF_UNSPEC;
- while ((c = getopt(argc, argv, "46psanocv")) != -1) {
+ while ((c = getopt(argc, argv, "46psanov")) != -1) {
switch (c) {
case '4':
family = PF_INET;
@@ -105,10 +105,6 @@ main(int argc, char **argv)
/* noop */
break;
- case 'c':
- corrleaps = 1;
- break;
-
case 'v':
verbose = 1;
break;
@@ -144,8 +140,7 @@ main(int argc, char **argv)
setvbuf(stdout, NULL, _IOFBF, 0);
setvbuf(stderr, NULL, _IOFBF, 0);
- ntp_client(hname, family, &pdata.new,
- &pdata.adjust, corrleaps);
+ ntp_client(hname, family, &pdata.new, &pdata.adjust);
if (write(STDOUT_FILENO, &pdata, sizeof pdata) != sizeof pdata)
exit(1);