#include "fpm_config.h"
#if defined(HAVE_CLOCK_GETTIME)
#include <time.h>
#endif
#include "fpm_clock.h"
#include "zlog.h"
#if defined(HAVE_CLOCK_GETTIME) && defined(CLOCK_MONOTONIC)
static int monotonic_works;
int fpm_clock_init()
{
struct timespec ts;
monotonic_works = 0;
if (0 == clock_gettime(CLOCK_MONOTONIC, &ts)) {
monotonic_works = 1;
}
return 0;
}
int fpm_clock_get(struct timeval *tv)
{
if (monotonic_works) {
struct timespec ts;
if (0 > clock_gettime(CLOCK_MONOTONIC, &ts)) {
zlog(ZLOG_SYSERROR, "clock_gettime() failed");
return -1;
}
tv->tv_sec = ts.tv_sec;
tv->tv_usec = ts.tv_nsec / 1000;
return 0;
}
return gettimeofday(tv, 0);
}
#elif defined(HAVE_CLOCK_GET_TIME)
#include <mach/mach.h>
#include <mach/clock.h>
#include <mach/mach_error.h>
static clock_serv_t mach_clock;
int fpm_clock_init()
{
kern_return_t ret;
mach_timespec_t aTime;
ret = host_get_clock_service(mach_host_self(), REALTIME_CLOCK, &mach_clock);
if (ret != KERN_SUCCESS) {
zlog(ZLOG_ERROR, "host_get_clock_service() failed: %s", mach_error_string(ret));
return -1;
}
ret = clock_get_time(mach_clock, &aTime);
if (ret != KERN_SUCCESS) {
zlog(ZLOG_ERROR, "clock_get_time() failed: %s", mach_error_string(ret));
return -1;
}
return 0;
}
int fpm_clock_get(struct timeval *tv)
{
kern_return_t ret;
mach_timespec_t aTime;
ret = clock_get_time(mach_clock, &aTime);
if (ret != KERN_SUCCESS) {
zlog(ZLOG_ERROR, "clock_get_time() failed: %s", mach_error_string(ret));
return -1;
}
tv->tv_sec = aTime.tv_sec;
tv->tv_usec = aTime.tv_nsec / 1000;
return 0;
}
#else
int fpm_clock_init()
{
return 0;
}
int fpm_clock_get(struct timeval *tv)
{
return gettimeofday(tv, 0);
}
#endif