_libevent_time.h revision c7f5f8508d98d5952d42ed7648c2a8f30a4da156
1/* $OpenBSD: time.h,v 1.11 2000/10/10 13:36:48 itojun Exp $ */ 2/* $NetBSD: time.h,v 1.18 1996/04/23 10:29:33 mycroft Exp $ */ 3 4/* 5 * Copyright (c) 1982, 1986, 1993 6 * The Regents of the University of California. All rights reserved. 7 * 8 * Redistribution and use in source and binary forms, with or without 9 * modification, are permitted provided that the following conditions 10 * are met: 11 * 1. Redistributions of source code must retain the above copyright 12 * notice, this list of conditions and the following disclaimer. 13 * 2. Redistributions in binary form must reproduce the above copyright 14 * notice, this list of conditions and the following disclaimer in the 15 * documentation and/or other materials provided with the distribution. 16 * 3. Neither the name of the University nor the names of its contributors 17 * may be used to endorse or promote products derived from this software 18 * without specific prior written permission. 19 * 20 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 21 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 22 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 23 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 24 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 25 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 26 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 27 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 28 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 29 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 30 * SUCH DAMAGE. 31 * 32 * @(#)time.h 8.2 (Berkeley) 7/10/94 33 */ 34 35#ifndef _SYS_TIME_H_ 36#define _SYS_TIME_H_ 37 38#include <sys/types.h> 39 40/* 41 * Structure returned by gettimeofday(2) system call, 42 * and used in other calls. 43 */ 44struct timeval { 45 long tv_sec; /* seconds */ 46 long tv_usec; /* and microseconds */ 47}; 48 49/* 50 * Structure defined by POSIX.1b to be like a timeval. 51 */ 52struct timespec { 53 time_t tv_sec; /* seconds */ 54 long tv_nsec; /* and nanoseconds */ 55}; 56 57#define TIMEVAL_TO_TIMESPEC(tv, ts) { \ 58 (ts)->tv_sec = (tv)->tv_sec; \ 59 (ts)->tv_nsec = (tv)->tv_usec * 1000; \ 60} 61#define TIMESPEC_TO_TIMEVAL(tv, ts) { \ 62 (tv)->tv_sec = (ts)->tv_sec; \ 63 (tv)->tv_usec = (ts)->tv_nsec / 1000; \ 64} 65 66struct timezone { 67 int tz_minuteswest; /* minutes west of Greenwich */ 68 int tz_dsttime; /* type of dst correction */ 69}; 70#define DST_NONE 0 /* not on dst */ 71#define DST_USA 1 /* USA style dst */ 72#define DST_AUST 2 /* Australian style dst */ 73#define DST_WET 3 /* Western European dst */ 74#define DST_MET 4 /* Middle European dst */ 75#define DST_EET 5 /* Eastern European dst */ 76#define DST_CAN 6 /* Canada */ 77 78/* Operations on timevals. */ 79#define timerclear(tvp) (tvp)->tv_sec = (tvp)->tv_usec = 0 80#define timerisset(tvp) ((tvp)->tv_sec || (tvp)->tv_usec) 81#define timercmp(tvp, uvp, cmp) \ 82 (((tvp)->tv_sec == (uvp)->tv_sec) ? \ 83 ((tvp)->tv_usec cmp (uvp)->tv_usec) : \ 84 ((tvp)->tv_sec cmp (uvp)->tv_sec)) 85#define timeradd(tvp, uvp, vvp) \ 86 do { \ 87 (vvp)->tv_sec = (tvp)->tv_sec + (uvp)->tv_sec; \ 88 (vvp)->tv_usec = (tvp)->tv_usec + (uvp)->tv_usec; \ 89 if ((vvp)->tv_usec >= 1000000) { \ 90 (vvp)->tv_sec++; \ 91 (vvp)->tv_usec -= 1000000; \ 92 } \ 93 } while (0) 94#define timersub(tvp, uvp, vvp) \ 95 do { \ 96 (vvp)->tv_sec = (tvp)->tv_sec - (uvp)->tv_sec; \ 97 (vvp)->tv_usec = (tvp)->tv_usec - (uvp)->tv_usec; \ 98 if ((vvp)->tv_usec < 0) { \ 99 (vvp)->tv_sec--; \ 100 (vvp)->tv_usec += 1000000; \ 101 } \ 102 } while (0) 103 104/* Operations on timespecs. */ 105#define timespecclear(tsp) (tsp)->tv_sec = (tsp)->tv_nsec = 0 106#define timespecisset(tsp) ((tsp)->tv_sec || (tsp)->tv_nsec) 107#define timespeccmp(tsp, usp, cmp) \ 108 (((tsp)->tv_sec == (usp)->tv_sec) ? \ 109 ((tsp)->tv_nsec cmp (usp)->tv_nsec) : \ 110 ((tsp)->tv_sec cmp (usp)->tv_sec)) 111#define timespecadd(tsp, usp, vsp) \ 112 do { \ 113 (vsp)->tv_sec = (tsp)->tv_sec + (usp)->tv_sec; \ 114 (vsp)->tv_nsec = (tsp)->tv_nsec + (usp)->tv_nsec; \ 115 if ((vsp)->tv_nsec >= 1000000000L) { \ 116 (vsp)->tv_sec++; \ 117 (vsp)->tv_nsec -= 1000000000L; \ 118 } \ 119 } while (0) 120#define timespecsub(tsp, usp, vsp) \ 121 do { \ 122 (vsp)->tv_sec = (tsp)->tv_sec - (usp)->tv_sec; \ 123 (vsp)->tv_nsec = (tsp)->tv_nsec - (usp)->tv_nsec; \ 124 if ((vsp)->tv_nsec < 0) { \ 125 (vsp)->tv_sec--; \ 126 (vsp)->tv_nsec += 1000000000L; \ 127 } \ 128 } while (0) 129 130/* 131 * Names of the interval timers, and structure 132 * defining a timer setting. 133 */ 134#define ITIMER_REAL 0 135#define ITIMER_VIRTUAL 1 136#define ITIMER_PROF 2 137 138struct itimerval { 139 struct timeval it_interval; /* timer interval */ 140 struct timeval it_value; /* current value */ 141}; 142 143/* 144 * Getkerninfo clock information structure 145 */ 146struct clockinfo { 147 int hz; /* clock frequency */ 148 int tick; /* micro-seconds per hz tick */ 149 int tickadj; /* clock skew rate for adjtime() */ 150 int stathz; /* statistics clock frequency */ 151 int profhz; /* profiling clock frequency */ 152}; 153 154#define CLOCK_REALTIME 0 155#define CLOCK_VIRTUAL 1 156#define CLOCK_PROF 2 157 158#define TIMER_RELTIME 0x0 /* relative timer */ 159#define TIMER_ABSTIME 0x1 /* absolute timer */ 160 161/* --- stuff got cut here - niels --- */ 162 163#endif /* !_SYS_TIME_H_ */ 164