OpenBSD manual page server

Manual Page Search Parameters

TIMERADD(3) Library Functions Manual TIMERADD(3)

timeraddoperations on time structure

#include <sys/time.h>

void
timeradd(struct timeval *a, struct timeval *b, struct timeval *res);

void
timersub(struct timeval *a, struct timeval *b, struct timeval *res);

void
timerclear(struct timeval *tv);

int
timerisset(struct timeval *tv);

int
timercmp(struct timeval *a, struct timeval *b, CMP);

void
timespecadd(struct timespec *a, struct timespec *b, struct timespec *res);

void
timespecsub(struct timespec *a, struct timespec *b, struct timespec *res);

void
timespecclear(struct timespec *ts);

int
timespecisset(struct timespec *ts);

int
timespeccmp(struct timespec *a, struct timespec b, CMP);

These macros are provided for manipulating the timeval and timespec structures described in timeval(3).

The timeradd() and timespecadd() macros add the time information stored in a to b, storing the result in res. With timeradd() the results are simplified such that the value of res->tv_usec is always less than 1,000,000 (1 second). With timespecadd() the res->tv_nsec member of struct timespec is always less than 1,000,000,000.

The timersub() and timespecsub() macros subtract the time information stored in b from a and store the resulting structure in res.

The timerclear() and timespecclear() macros initialize the structures to midnight (0 hour) January 1st, 1970 (the Epoch). In other words, they set the members of the structure to zero.

The timerisset() and timespecisset() macros return true if the input structure is set to any time value other than the Epoch.

The timercmp() and timespeccmp() macros compare a to b using the comparison operator given in CMP. The result of the comparison is returned.

timeval(3)

The timeradd() family of macros first appeared in NetBSD 1.1. These were later ported to FreeBSD 2.2.6. The timespec() family of macros first appeared in NetBSD 1.2.

June 7, 2010 NetBSD-7.0.1