Module Name:    src
Committed By:   christos
Date:           Wed May 22 16:00:52 UTC 2013

Modified Files:
        src/sys/kern: kern_time.c subr_time.c

Log Message:
Make ts2timo(9) always return the absolute start time if the start argument
is present, and handle the TIMER_ABSTIME case in nanosleep1(9).


To generate a diff of this commit:
cvs rdiff -u -r1.178 -r1.179 src/sys/kern/kern_time.c
cvs rdiff -u -r1.16 -r1.17 src/sys/kern/subr_time.c

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.

Modified files:

Index: src/sys/kern/kern_time.c
diff -u src/sys/kern/kern_time.c:1.178 src/sys/kern/kern_time.c:1.179
--- src/sys/kern/kern_time.c:1.178	Sun Mar 31 12:45:06 2013
+++ src/sys/kern/kern_time.c	Wed May 22 12:00:52 2013
@@ -1,4 +1,4 @@
-/*	$NetBSD: kern_time.c,v 1.178 2013/03/31 16:45:06 christos Exp $	*/
+/*	$NetBSD: kern_time.c,v 1.179 2013/05/22 16:00:52 christos Exp $	*/
 
 /*-
  * Copyright (c) 2000, 2004, 2005, 2007, 2008, 2009 The NetBSD Foundation, Inc.
@@ -61,7 +61,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: kern_time.c,v 1.178 2013/03/31 16:45:06 christos Exp $");
+__KERNEL_RCSID(0, "$NetBSD: kern_time.c,v 1.179 2013/05/22 16:00:52 christos Exp $");
 
 #include <sys/param.h>
 #include <sys/resourcevar.h>
@@ -345,8 +345,12 @@ again:
 
 		(void)clock_gettime1(clock_id, &rmtend);
 		t = (rmt != NULL) ? rmt : &t0;
-		timespecsub(&rmtend, &rmtstart, t);
-		timespecsub(rqt, t, t);
+		if (flags & TIMER_ABSTIME) {
+			timespecsub(rqt, &rmtend, t);
+		} else {
+			timespecsub(&rmtend, &rmtstart, t);
+			timespecsub(rqt, t, t);
+		}
 		if (t->tv_sec < 0)
 			timespecclear(t);
 		if (error == 0) {

Index: src/sys/kern/subr_time.c
diff -u src/sys/kern/subr_time.c:1.16 src/sys/kern/subr_time.c:1.17
--- src/sys/kern/subr_time.c:1.16	Tue May 21 12:25:55 2013
+++ src/sys/kern/subr_time.c	Wed May 22 12:00:52 2013
@@ -1,4 +1,4 @@
-/*	$NetBSD: subr_time.c,v 1.16 2013/05/21 16:25:55 bouyer Exp $	*/
+/*	$NetBSD: subr_time.c,v 1.17 2013/05/22 16:00:52 christos Exp $	*/
 
 /*
  * Copyright (c) 1982, 1986, 1989, 1993
@@ -33,7 +33,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: subr_time.c,v 1.16 2013/05/21 16:25:55 bouyer Exp $");
+__KERNEL_RCSID(0, "$NetBSD: subr_time.c,v 1.17 2013/05/22 16:00:52 christos Exp $");
 
 #include <sys/param.h>
 #include <sys/kernel.h>
@@ -246,15 +246,13 @@ ts2timo(clockid_t clock_id, int flags, s
 	int error;
 	struct timespec tsd;
 
-	if (flags && start != NULL)
-		memset(start, 0, sizeof(*start));
-
 	flags &= TIMER_ABSTIME;
-	if (start == NULL || flags)
+	if (start == NULL)
 		start = &tsd;
 
-	if ((error = clock_gettime1(clock_id, start)) != 0)
-		return error;
+	if (flags || start != &tsd)
+		if ((error = clock_gettime1(clock_id, start)) != 0)
+			return error;
 
 	if (flags)
 		timespecsub(ts, start, ts);

Reply via email to