xref: /netbsd/share/doc/psd/05.sysman/1.4.t (revision bf9ec67e)
$NetBSD: 1.4.t,v 1.2 1998/01/09 06:54:43 perry Exp $

Copyright (c) 1983, 1993, 1994
The Regents of the University of California. 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.
3. All advertising materials mentioning features or use of this software
must display the following acknowledgement:
This product includes software developed by the University of
California, Berkeley and its contributors.
4. Neither the name of the University nor the names of its contributors
may be used to endorse or promote products derived from this software
without specific prior written permission.

THIS SOFTWARE IS PROVIDED BY THE REGENTS 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 REGENTS 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.

@(#)1.4.t 8.5 (Berkeley) 5/29/94

.Sh 2 "Timers .Sh 3 "Real time

The system's notion of the current time is in Coordinated Universal Time (UTC, previously GMT) and the current time zone is set and returned by the calls: .Fd settimeofday 2 "set date and time settimeofday(tp, tzp); struct timeval *tp; struct timezone *tzp; .Fd gettimeofday 2 "get date and time gettimeofday(tp, tzp); result struct timeval *tp; result struct timezone *tzp; where the structures are defined in <sys/time.h> as:

struct timeval {
long tv_sec; /* seconds since Jan 1, 1970 */
long tv_usec; /* and microseconds */
};
.T&
l s s s
l l l l.
struct timezone {
int tz_minuteswest; /* of Greenwich */
int tz_dsttime; /* type of dst correction to apply */
};
The timezone information is present only for historical reasons and is unused by the current system.

The precision of the system clock is hardware dependent. Earlier versions of UNIX contained only a 1-second resolution version of this call, which remains as a library routine: time(tvsec); result time_t *tvsec; returning only the tv_sec field from the .Fn gettimeofday call.

The .Fn adjtime system calls allows for small changes in time without abrupt changes by skewing the rate at which time advances: .Fd adjtime 2 "synchronization of the system clock adjtime(delta, olddelta); struct timeval *delta; result struct timeval *olddelta; .Sh 3 "Interval time

The system provides each process with three interval timers, defined in <sys/time.h>:

ITIMER_REAL /* real time intervals */
ITIMER_VIRTUAL /* virtual time intervals */
ITIMER_PROF /* user and system virtual time */
The ITIMER_REAL timer decrements in real time. It could be used by a library routine to maintain a wakeup service queue. A SIGALRM signal is delivered when this timer expires.

The ITIMER_VIRTUAL timer decrements in process virtual time. It runs only when the process is executing. A SIGVTALRM signal is delivered when it expires.

The ITIMER_PROF timer decrements both in process virtual time and when the system is running on behalf of the process. It is designed to be used by processes to statistically profile their execution. A SIGPROF signal is delivered when it expires.

A timer value is defined by the itimerval structure:

struct itimerval {
struct timeval it_interval; /* timer interval */
struct timeval it_value; /* current value */
};
and a timer is set or read by the call: .Fd setitimer 3 "set value of interval timer setitimer(which, value, ovalue); int which; struct itimerval *value; result struct itimerval *ovalue; .Fd getitimer 2 "get value of interval timer getitimer(which, value); int which; result struct itimerval *value; The it_value specifies the time until the next signal; the it_interval specifies a new interval that should be loaded into the timer on each expiration. The third argument to .Fn setitimer specifies an optional structure to receive the previous contents of the interval timer. A timer can be disabled by setting it_value and it_interval to 0.

The system rounds argument timer intervals to be not less than the resolution of its clock. This clock resolution can be determined by loading a very small value into a timer and reading the timer back to see what value resulted.

The .Fn alarm system call of earlier versions of UNIX is provided as a library routine using the ITIMER_REAL timer.

The process profiling facilities of earlier versions of UNIX remain because it is not always possible to guarantee the automatic restart of system calls after receipt of a signal. The .Fn profil call arranges for the kernel to begin gathering execution statistics for a process: .Fd profil 4 "control process profiling profil(samples, size, offset, scale); result char *samples; int size, offset, scale; This call begins sampling the program counter, with statistics maintained in the user-provided buffer.