mariadb/storage/bdb/os/os_clock.c

92 lines
1.7 KiB
C
Raw Normal View History

2002-10-30 12:57:05 +01:00
/*-
* See the file LICENSE for redistribution information.
*
2005-12-05 19:27:46 +01:00
* Copyright (c) 2001-2005
2002-10-30 12:57:05 +01:00
* Sleepycat Software. All rights reserved.
2005-07-21 00:48:22 +02:00
*
2005-12-05 19:27:46 +01:00
* $Id: os_clock.c,v 12.1 2005/06/16 20:23:23 bostic Exp $
2002-10-30 12:57:05 +01:00
*/
#include "db_config.h"
#ifndef NO_SYSTEM_INCLUDES
#include <sys/types.h>
#if TIME_WITH_SYS_TIME
#include <sys/time.h>
#include <time.h>
#else
#if HAVE_SYS_TIME_H
#include <sys/time.h>
#else
#include <time.h>
#endif /* HAVE_SYS_TIME_H */
#endif /* TIME_WITH SYS_TIME */
#include <string.h>
#endif
#include "db_int.h"
/*
* __os_clock --
* Return the current time-of-day clock in seconds and microseconds.
*
2005-07-21 00:48:22 +02:00
* PUBLIC: void __os_clock __P((DB_ENV *, u_int32_t *, u_int32_t *));
2002-10-30 12:57:05 +01:00
*/
2005-07-21 00:48:22 +02:00
void
2002-10-30 12:57:05 +01:00
__os_clock(dbenv, secsp, usecsp)
DB_ENV *dbenv;
u_int32_t *secsp, *usecsp; /* Seconds and microseconds. */
{
2005-07-21 00:48:22 +02:00
const char *sc;
int ret;
2002-10-30 12:57:05 +01:00
#if defined(HAVE_GETTIMEOFDAY)
struct timeval tp;
2005-07-21 00:48:22 +02:00
RETRY_CHK((gettimeofday(&tp, NULL)), ret);
if (ret != 0) {
sc = "gettimeofday";
goto err;
2002-10-30 12:57:05 +01:00
}
if (secsp != NULL)
2005-07-21 00:48:22 +02:00
*secsp = (u_int32_t)tp.tv_sec;
2002-10-30 12:57:05 +01:00
if (usecsp != NULL)
2005-07-21 00:48:22 +02:00
*usecsp = (u_int32_t)tp.tv_usec;
2002-10-30 12:57:05 +01:00
#endif
#if !defined(HAVE_GETTIMEOFDAY) && defined(HAVE_CLOCK_GETTIME)
struct timespec tp;
2005-07-21 00:48:22 +02:00
RETRY_CHK((clock_gettime(CLOCK_REALTIME, &tp)), ret);
if (ret != 0) {
sc = "clock_gettime";
goto err;
2002-10-30 12:57:05 +01:00
}
if (secsp != NULL)
*secsp = tp.tv_sec;
if (usecsp != NULL)
*usecsp = tp.tv_nsec / 1000;
#endif
#if !defined(HAVE_GETTIMEOFDAY) && !defined(HAVE_CLOCK_GETTIME)
time_t now;
2005-07-21 00:48:22 +02:00
RETRY_CHK((time(&now) == (time_t)-1 ? 1 : 0), ret);
if (ret != 0) {
sc = "time";
goto err;
2002-10-30 12:57:05 +01:00
}
if (secsp != NULL)
*secsp = now;
if (usecsp != NULL)
*usecsp = 0;
#endif
2005-07-21 00:48:22 +02:00
return;
err: __db_err(dbenv, "%s: %s", sc, strerror(ret));
(void)__db_panic(dbenv, ret);
2002-10-30 12:57:05 +01:00
}