Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src Avoid overflowing the "year" value by making the field uint6...
details: https://anonhg.NetBSD.org/src/rev/1b1be5ccdd1c
branches: trunk
changeset: 332108:1b1be5ccdd1c
user: martin <martin%NetBSD.org@localhost>
date: Sun Sep 07 11:50:23 2014 +0000
description:
Avoid overflowing the "year" value by making the field uint64_t. Adapt
arguments and local variables accordingly.
This now fixes PR 49144 for real.
diffstat:
sys/dev/clock_subr.c | 26 ++++++++++++++++++--------
sys/dev/clock_subr.h | 6 +++---
tools/compat/dev/clock_subr.h | 6 +++---
3 files changed, 24 insertions(+), 14 deletions(-)
diffs (138 lines):
diff -r bc713ec6486f -r 1b1be5ccdd1c sys/dev/clock_subr.c
--- a/sys/dev/clock_subr.c Sun Sep 07 09:10:09 2014 +0000
+++ b/sys/dev/clock_subr.c Sun Sep 07 11:50:23 2014 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: clock_subr.c,v 1.21 2014/09/06 18:04:28 martin Exp $ */
+/* $NetBSD: clock_subr.c,v 1.22 2014/09/07 11:50:23 martin Exp $ */
/*
* Copyright (c) 1988 University of Utah.
@@ -50,18 +50,20 @@
#ifdef _KERNEL
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: clock_subr.c,v 1.21 2014/09/06 18:04:28 martin Exp $");
+__KERNEL_RCSID(0, "$NetBSD: clock_subr.c,v 1.22 2014/09/07 11:50:23 martin Exp $");
#include <sys/param.h>
#include <sys/systm.h>
+#include <sys/errno.h>
#else /* ! _KERNEL */
#include <string.h>
#include <time.h>
+#include <errno.h>
#endif /* ! _KERNEL */
#include <dev/clock_subr.h>
-static inline int leapyear(int year);
+static inline int leapyear(uint64_t year);
#define FEBRUARY 2
#define days_in_year(a) (leapyear(a) ? 366 : 365)
#define days_in_month(a) (month_days[(a) - 1])
@@ -92,10 +94,13 @@
* It is otherwise equivalent.
*/
static inline int
-leapyear(int year)
+leapyear(uint64_t year)
{
int rv = 0;
+ if (year < 1969)
+ return EINVAL;
+
if ((year & 3) == 0) {
rv = 1;
if ((year % 100) == 0) {
@@ -110,8 +115,7 @@
time_t
clock_ymdhms_to_secs(struct clock_ymdhms *dt)
{
- uint64_t secs;
- int i, year, days;
+ uint64_t secs, i, year, days;
year = dt->dt_year;
@@ -167,13 +171,17 @@
return secs;
}
-void
+int
clock_secs_to_ymdhms(time_t secs, struct clock_ymdhms *dt)
{
- int i, leap;
+ int leap;
+ uint64_t i;
time_t days;
time_t rsec; /* remainder seconds */
+ if (secs < 0)
+ return EINVAL;
+
days = secs / SECDAY;
rsec = secs % SECDAY;
@@ -225,4 +233,6 @@
dt->dt_min = rsec / 60;
rsec = rsec % 60;
dt->dt_sec = rsec;
+
+ return 0;
}
diff -r bc713ec6486f -r 1b1be5ccdd1c sys/dev/clock_subr.h
--- a/sys/dev/clock_subr.h Sun Sep 07 09:10:09 2014 +0000
+++ b/sys/dev/clock_subr.h Sun Sep 07 11:50:23 2014 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: clock_subr.h,v 1.21 2009/12/12 15:10:34 tsutsui Exp $ */
+/* $NetBSD: clock_subr.h,v 1.22 2014/09/07 11:50:23 martin Exp $ */
/*-
* Copyright (c) 1996 The NetBSD Foundation, Inc.
@@ -36,7 +36,7 @@
* "POSIX time" to/from "YY/MM/DD/hh/mm/ss"
*/
struct clock_ymdhms {
- u_short dt_year;
+ uint64_t dt_year;
u_char dt_mon;
u_char dt_day;
u_char dt_wday; /* Day of week */
@@ -46,7 +46,7 @@
};
time_t clock_ymdhms_to_secs(struct clock_ymdhms *);
-void clock_secs_to_ymdhms(time_t, struct clock_ymdhms *);
+int clock_secs_to_ymdhms(time_t, struct clock_ymdhms *);
/*
* BCD to binary and binary to BCD.
diff -r bc713ec6486f -r 1b1be5ccdd1c tools/compat/dev/clock_subr.h
--- a/tools/compat/dev/clock_subr.h Sun Sep 07 09:10:09 2014 +0000
+++ b/tools/compat/dev/clock_subr.h Sun Sep 07 11:50:23 2014 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: clock_subr.h,v 1.1 2014/09/01 07:48:16 martin Exp $ */
+/* $NetBSD: clock_subr.h,v 1.2 2014/09/07 11:50:23 martin Exp $ */
/*-
* Copyright (c) 1996 The NetBSD Foundation, Inc.
@@ -40,7 +40,7 @@
* "POSIX time" to/from "YY/MM/DD/hh/mm/ss"
*/
struct clock_ymdhms {
- u_short dt_year;
+ uint64_t dt_year;
u_char dt_mon;
u_char dt_day;
u_char dt_wday; /* Day of week */
@@ -50,7 +50,7 @@
};
time_t clock_ymdhms_to_secs(struct clock_ymdhms *);
-void clock_secs_to_ymdhms(time_t, struct clock_ymdhms *);
+int clock_secs_to_ymdhms(time_t, struct clock_ymdhms *);
/* Some handy constants. */
#define SECDAY (24 * 60 * 60)
Home |
Main Index |
Thread Index |
Old Index