2010-06-08 09:50:01 +04:00
|
|
|
.\" $NetBSD: microtime.9,v 1.18 2010/06/08 05:50:01 jruoho Exp $
|
1998-09-15 05:38:01 +04:00
|
|
|
.\"
|
|
|
|
.\" Copyright (c) 1998 The NetBSD Foundation, Inc.
|
|
|
|
.\" All rights reserved.
|
|
|
|
.\"
|
|
|
|
.\" This code is derived from software contributed to The NetBSD Foundation
|
|
|
|
.\" by Jeremy Cooper.
|
|
|
|
.\"
|
|
|
|
.\" Redistribution and use in source and binary forms, with or without
|
|
|
|
.\" modification, are permitted provided that the following conditions
|
|
|
|
.\" are met:
|
|
|
|
.\" 1. Redistributions of source code must retain the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer.
|
|
|
|
.\" 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer in the
|
|
|
|
.\" documentation and/or other materials provided with the distribution.
|
|
|
|
.\"
|
|
|
|
.\" THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
|
|
|
|
.\" ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
|
|
|
|
.\" TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
|
2001-09-04 06:51:15 +04:00
|
|
|
.\" PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
|
1998-09-15 05:38:01 +04:00
|
|
|
.\" BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
|
|
.\" CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
|
|
.\" SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
|
|
.\" INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
|
|
.\" CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
|
|
.\" ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
|
|
.\" POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
.\"
|
2008-11-24 16:50:07 +03:00
|
|
|
.\" Copyright (c) 2000 Kelly Yancey
|
|
|
|
.\" All rights reserved.
|
|
|
|
.\"
|
|
|
|
.\" Redistribution and use in source and binary forms, with or without
|
|
|
|
.\" modification, are permitted provided that the following conditions
|
|
|
|
.\" are met:
|
|
|
|
.\" 1. Redistributions of source code must retain the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer.
|
|
|
|
.\" 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer in the
|
|
|
|
.\" documentation and/or other materials provided with the distribution.
|
|
|
|
.\"
|
|
|
|
.\" THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
|
|
|
|
.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
|
|
.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
|
|
.\" ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
|
|
|
|
.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
|
|
.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
|
|
.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
|
|
.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
|
|
.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
|
|
.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
|
|
.\" SUCH DAMAGE.
|
|
|
|
.\"
|
|
|
|
.\" $FreeBSD: src/share/man/man9/microtime.9,v 1.11 2005/10/13 16:01:28 jhb Exp $
|
|
|
|
.\"
|
2010-06-08 09:20:35 +04:00
|
|
|
.Dd June 8, 2010
|
1998-09-15 05:38:01 +04:00
|
|
|
.Dt MICROTIME 9
|
1999-03-16 03:40:46 +03:00
|
|
|
.Os
|
1998-09-15 05:38:01 +04:00
|
|
|
.Sh NAME
|
2008-11-24 16:50:07 +03:00
|
|
|
.Nm bintime ,
|
|
|
|
.Nm getbintime ,
|
|
|
|
.Nm microtime ,
|
|
|
|
.Nm getmicrotime ,
|
|
|
|
.Nm nanotime ,
|
|
|
|
.Nm getnanotime
|
|
|
|
.Nd get the current time
|
1998-09-15 05:38:01 +04:00
|
|
|
.Sh SYNOPSIS
|
2003-04-16 17:34:34 +04:00
|
|
|
.In sys/time.h
|
1998-09-15 05:38:01 +04:00
|
|
|
.Ft void
|
2008-11-24 16:50:07 +03:00
|
|
|
.Fo bintime
|
|
|
|
.Fa "struct bintime *bt"
|
|
|
|
.Fc
|
|
|
|
.Ft void
|
|
|
|
.Fo getbintime
|
|
|
|
.Fa "struct bintime *bt"
|
|
|
|
.Fc
|
|
|
|
.Ft void
|
1998-09-15 05:38:01 +04:00
|
|
|
.Fo "microtime"
|
|
|
|
.Fa "struct timeval *tv"
|
|
|
|
.Fc
|
2008-11-24 16:50:07 +03:00
|
|
|
.Ft void
|
|
|
|
.Fo getmicrotime
|
|
|
|
.Fa "struct timeval *tv"
|
|
|
|
.Fc
|
|
|
|
.Ft void
|
|
|
|
.Fo nanotime
|
|
|
|
.Fa "struct timespec *ts"
|
|
|
|
.Fc
|
|
|
|
.Ft void
|
|
|
|
.Fo getnanotime
|
|
|
|
.Fa "struct timespec *tsp"
|
|
|
|
.Fc
|
1998-09-15 05:38:01 +04:00
|
|
|
.Sh DESCRIPTION
|
2008-11-24 16:50:07 +03:00
|
|
|
The
|
|
|
|
.Fn bintime
|
|
|
|
and
|
|
|
|
.Fn getbintime
|
|
|
|
functions store the system time as a
|
|
|
|
.Vt "struct bintime"
|
|
|
|
at the addresses specified by
|
|
|
|
.Fa bt .
|
|
|
|
The
|
1998-09-15 05:38:01 +04:00
|
|
|
.Fn microtime
|
2008-11-24 16:50:07 +03:00
|
|
|
and
|
|
|
|
.Fn getmicrotime
|
|
|
|
functions perform the same utility, but record the time as a
|
|
|
|
.Vt "struct timeval"
|
|
|
|
instead.
|
|
|
|
Similarly the
|
|
|
|
.Fn nanotime
|
|
|
|
and
|
|
|
|
.Fn getnanotime
|
|
|
|
functions store the time as a
|
|
|
|
.Vt "struct timespec" .
|
2010-05-18 00:25:19 +04:00
|
|
|
The structures are described in
|
|
|
|
.Xr timeval 3 .
|
2008-11-24 16:50:07 +03:00
|
|
|
.Pp
|
|
|
|
The
|
|
|
|
.Fn bintime ,
|
|
|
|
.Fn microtime ,
|
|
|
|
and
|
|
|
|
.Fn nanotime
|
|
|
|
functions
|
|
|
|
always query the timecounter to return the current time as precisely as
|
|
|
|
possible.
|
|
|
|
Whereas
|
|
|
|
.Fn getbintime ,
|
|
|
|
.Fn getmicrotime ,
|
|
|
|
and
|
|
|
|
.Fn getnanotime
|
|
|
|
functions are abstractions which return a less precise, but
|
|
|
|
faster to obtain, time.
|
|
|
|
.Pp
|
|
|
|
The intent of the
|
|
|
|
.Fn getbintime ,
|
|
|
|
.Fn getmicrotime ,
|
|
|
|
and
|
|
|
|
.Fn getnanotime
|
|
|
|
functions is to enforce the user's preference for timer accuracy versus
|
|
|
|
execution time.
|
2008-11-28 13:55:41 +03:00
|
|
|
They should be used where a precision of
|
|
|
|
.Pf 1/ Em HZ
|
|
|
|
(e.g., 10 msec on a
|
|
|
|
.Pf 100 Em HZ
|
|
|
|
machine, see
|
|
|
|
.Xr hz 9 )
|
2008-11-24 16:50:07 +03:00
|
|
|
is acceptable or where performance is priority.
|
|
|
|
.Pp
|
2001-06-19 23:26:01 +04:00
|
|
|
The system realtime clock is guaranteed to be monotonically increasing
|
1998-09-15 05:38:01 +04:00
|
|
|
at all times.
|
2008-11-24 16:50:07 +03:00
|
|
|
As such, all calls to these functions are guaranteed to return a system time
|
|
|
|
greater than or equal to the system time returned in any previous calls.
|
2010-06-08 09:20:35 +04:00
|
|
|
Comparable functions exist to retrieve the time elapsed since boot; see
|
|
|
|
.Xr microuptime 9 .
|
1998-09-15 05:38:01 +04:00
|
|
|
.Sh SEE ALSO
|
2001-09-04 08:03:50 +04:00
|
|
|
.Xr settimeofday 2 ,
|
2010-06-08 09:50:01 +04:00
|
|
|
.Xr bintime_add 9 ,
|
1998-09-15 05:38:01 +04:00
|
|
|
.Xr inittodr 9 ,
|
2008-11-24 16:50:07 +03:00
|
|
|
.Xr time_second 9 ,
|
|
|
|
.Xr tvtohz 9
|
1998-09-15 05:38:01 +04:00
|
|
|
.Sh CODE REFERENCES
|
|
|
|
The implementation of the
|
|
|
|
.Fn microtime
|
2008-11-24 16:50:07 +03:00
|
|
|
family of functions is in
|
|
|
|
.Pa sys/kern/kern_tc.c
|
|
|
|
as a part of the
|
|
|
|
.Xr timecounter 9
|
|
|
|
framework.
|
|
|
|
.Pp
|
|
|
|
The implementation of the time counter sources used by the
|
|
|
|
.Xr timecounter 9
|
|
|
|
is machine dependent,
|
1998-09-15 05:38:01 +04:00
|
|
|
hence its location in the source code tree varies from architecture to
|
|
|
|
architecture.
|
2008-11-24 16:50:07 +03:00
|
|
|
.Sh AUTHORS
|
|
|
|
This manual page was written by
|
|
|
|
.An Jeremy Cooper
|
|
|
|
and
|
|
|
|
.An Kelly Yancey Aq kbyanc@posi.net .
|
1998-09-15 05:38:01 +04:00
|
|
|
.Sh BUGS
|
|
|
|
Despite the guarantee that the system realtime clock will always be
|
2001-06-19 23:26:01 +04:00
|
|
|
monotonically increasing,
|
1998-09-15 05:38:01 +04:00
|
|
|
it is always possible for the system clock to be manually reset by the
|
|
|
|
system administrator to any date.
|