Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/kern Make ts2timo(9) always return the absolute start ti...
details: https://anonhg.NetBSD.org/src/rev/65bfbf6b1ef2
branches: trunk
changeset: 786927:65bfbf6b1ef2
user: christos <christos%NetBSD.org@localhost>
date: Wed May 22 16:00:52 2013 +0000
description:
Make ts2timo(9) always return the absolute start time if the start argument
is present, and handle the TIMER_ABSTIME case in nanosleep1(9).
diffstat:
sys/kern/kern_time.c | 12 ++++++++----
sys/kern/subr_time.c | 14 ++++++--------
2 files changed, 14 insertions(+), 12 deletions(-)
diffs (71 lines):
diff -r dd063b987910 -r 65bfbf6b1ef2 sys/kern/kern_time.c
--- a/sys/kern/kern_time.c Wed May 22 13:34:31 2013 +0000
+++ b/sys/kern/kern_time.c Wed May 22 16:00:52 2013 +0000
@@ -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 @@
(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) {
diff -r dd063b987910 -r 65bfbf6b1ef2 sys/kern/subr_time.c
--- a/sys/kern/subr_time.c Wed May 22 13:34:31 2013 +0000
+++ b/sys/kern/subr_time.c Wed May 22 16:00:52 2013 +0000
@@ -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 @@
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);
Home |
Main Index |
Thread Index |
Old Index