time-r0drv-darwin.cpp revision 8c99dcd207cf5b7bee01f95fbe19728a94076f94
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync/* $Id$ */
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync/** @file
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync * IPRT - Time, Ring-0 Driver, Darwin.
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync */
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync/*
e64031e20c39650a7bc902a3e1aba613b9415deevboxsync * Copyright (C) 2006-2007 Sun Microsystems, Inc.
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync *
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync * This file is part of VirtualBox Open Source Edition (OSE), as
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync * available from http://www.virtualbox.org. This file is free software;
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync * you can redistribute it and/or modify it under the terms of the GNU
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync * General Public License (GPL) as published by the Free Software
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync * Foundation, in version 2 as it comes in the "COPYING" file of the
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync *
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync * The contents of this file may alternatively be used under the terms
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync * of the Common Development and Distribution License Version 1.0
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync * VirtualBox OSE distribution, in which case the provisions of the
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync * CDDL are applicable instead of those of the GPL.
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync *
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync * You may elect to license modified versions of this file under the
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync * terms and conditions of either the GPL or the CDDL or both.
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync *
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa
aa4bcf0a4b2db3ac352b56a291d49cb8d4b66d32vboxsync * Clara, CA 95054 USA or visit http://www.sun.com if you need
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync * additional information or have any questions.
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync */
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync
aa4bcf0a4b2db3ac352b56a291d49cb8d4b66d32vboxsync/*******************************************************************************
aa4bcf0a4b2db3ac352b56a291d49cb8d4b66d32vboxsync* Header Files *
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync*******************************************************************************/
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync#define LOG_GROUP RTLOGGROUP_TIME
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync#include "the-darwin-kernel.h"
9939c713bffcfc4305d99d994552aa2ad9bce097vboxsync#include "internal/iprt.h"
9939c713bffcfc4305d99d994552aa2ad9bce097vboxsync#include <iprt/time.h>
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync
9939c713bffcfc4305d99d994552aa2ad9bce097vboxsync#include <iprt/asm.h>
9939c713bffcfc4305d99d994552aa2ad9bce097vboxsync
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsyncDECLINLINE(uint64_t) rtTimeGetSystemNanoTS(void)
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync{
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync static int8_t s_fSimple = -1;
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync /* first call: check if life is simple or not. */
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync if (s_fSimple < 0)
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync {
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync struct mach_timebase_info Info;
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync clock_timebase_info(&Info);
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync ASMAtomicXchgS8((int8_t * volatile)&s_fSimple, Info.denom == 1 && Info.numer == 1);
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync }
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync /* special case: absolute time is in nanoseconds */
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync if (s_fSimple)
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync return mach_absolute_time();
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync /* general case: let mach do the mult/div for us. */
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync uint64_t u64;
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync absolutetime_to_nanoseconds(mach_absolute_time(), &u64);
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync return u64;
ca3da10d05961c339b5180fbd40a54587d6bad35vboxsync}
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync
8df047381fb076540a191d281498b66ba9182dbdvboxsyncRTDECL(uint64_t) RTTimeNanoTS(void)
8df047381fb076540a191d281498b66ba9182dbdvboxsync{
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync return rtTimeGetSystemNanoTS();
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync}
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsyncRTDECL(uint64_t) RTTimeMilliTS(void)
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync{
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync return rtTimeGetSystemNanoTS() / 1000000;
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync}
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsyncRTDECL(uint64_t) RTTimeSystemNanoTS(void)
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync{
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync return rtTimeGetSystemNanoTS();
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync}
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsyncRTDECL(uint64_t) RTTimeSystemMilliTS(void)
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync{
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync return rtTimeGetSystemNanoTS() / 1000000;
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync}
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsyncRTDECL(PRTTIMESPEC) RTTimeNow(PRTTIMESPEC pTime)
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync{
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync#if MAC_OS_X_VERSION_MIN_REQUIRED < 1060
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync uint32_t uSecs;
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync uint32_t uNanosecs;
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync#else
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync clock_sec_t uSecs;
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync clock_nsec_t uNanosecs;
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync#endif
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync clock_get_calendar_nanotime(&uSecs, &uNanosecs);
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync return RTTimeSpecSetNano(pTime, (uint64_t)uSecs * 1000000000 + uNanosecs);
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync}
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync
8b4a8db7768e94d025f1216ecfcd50d727fa2b7cvboxsync