diff options
-rw-r--r-- | usr.sbin/rdate/ntpleaps.c | 53 |
1 files changed, 32 insertions, 21 deletions
diff --git a/usr.sbin/rdate/ntpleaps.c b/usr.sbin/rdate/ntpleaps.c index f697008994c..ef4c7eb04c3 100644 --- a/usr.sbin/rdate/ntpleaps.c +++ b/usr.sbin/rdate/ntpleaps.c @@ -1,4 +1,4 @@ -/* $OpenBSD: ntpleaps.c,v 1.3 2002/07/31 12:48:46 jakob Exp $ */ +/* $OpenBSD: ntpleaps.c,v 1.4 2002/08/01 06:26:57 jakob Exp $ */ /* * Copyright (c) 2002 by Thorsten "mirabile" Glaser <x86@ePOST.de> @@ -21,35 +21,37 @@ /* Leap second support for NTP clients (generic) */ -static const char RCSId[] = "$OpenBSD: ntpleaps.c,v 1.3 2002/07/31 12:48:46 jakob Exp $"; +static const char RCSId[] = "$OpenBSD: ntpleaps.c,v 1.4 2002/08/01 06:26:57 jakob Exp $"; -/* I could include tzfile.h, but this would make the code unportable +/* + * I could include tzfile.h, but this would make the code unportable * at no real benefit. Read tzfile.h for why. */ #include <fcntl.h> #include <stdio.h> #include <stdlib.h> +#include <string.h> #include <unistd.h> #include <sys/types.h> #include "ntpleaps.h" u_int64_t *leapsecs = NULL; unsigned int leapsecs_num = 0; -static int flaginit = 0; +static int flaginit = -1; static int flagwarn = 0; int ntpleaps_init(void) { - if (flaginit) - return 0; + if (!flaginit) + return (0); if (!ntpleaps_read()) { - flaginit = 1; - return(0); + flaginit = 0; + return (0); } /* This does not really hurt, but users will complain about @@ -69,14 +71,14 @@ ntpleaps_sub(u_int64_t *t) { unsigned int i = 0; u_int64_t u; - int r=1; + int r = 1; - if (ntpleaps_init() == -1) - return(-1); + if ((flaginit ? ntpleaps_init() : 0) == -1) + return (-1); u = *t; - while (i<leapsecs_num) { + while (i < leapsecs_num) { if (u < leapsecs[i]) break; if (u == leapsecs[i++]) @@ -85,17 +87,27 @@ ntpleaps_sub(u_int64_t *t) --r; do_sub: - *t=u-i; + *t = u - i; return (r); } +u_int32_t +read_be_dword(u_int8_t *ptr) +{ + u_int32_t res; + + memcpy(&res, ptr, 4); + return (ntohl(res)); +} + + int ntpleaps_read(void) { int fd; unsigned int r; u_int8_t buf[32]; - u_int32_t m1,m2,m3; + u_int32_t m1, m2, m3; u_int64_t s; u_int64_t *l; @@ -121,9 +133,9 @@ ntpleaps_read(void) read(fd, buf, 28); /* Read number of leap second entries */ - r = ntohl(*((u_int32_t *) (buf + 24))); + r = read_be_dword(&buf[24]); /* Check for plausibility - arbitrary values */ - if (r < 20 || r > 60000) { + if ((r < 20) || (r > 60000)) { close(fd); return (-1); } @@ -134,17 +146,16 @@ ntpleaps_read(void) /* Skip further uninteresting stuff */ read(fd, buf, 12); - m1 = ntohl(*((u_int32_t *)(buf))); - m2 = ntohl(*((u_int32_t *)(buf+4))); - m3 = ntohl(*((u_int32_t *)(buf+8))); + m1 = read_be_dword(buf); + m2 = read_be_dword(&buf[4]); + m3 = read_be_dword(&buf[8]); m3 += (m1 << 2)+m1+(m2 << 2)+(m2 << 1); lseek(fd, (off_t)m3, SEEK_CUR); /* Now go parse the tzfile leap second info */ for (m1 = 0; m1 < r; m1++) { read(fd, buf, 8); - m2 = ntohl(*((u_int32_t *)buf)); - s = SEC_TO_TAI64(m2); + s = SEC_TO_TAI64(read_be_dword(buf)); /* * Assume just _one_ leap second on each entry, and compensate * the lacking error checking by validating the first entry |