VirtualBox

source: vbox/trunk/src/VBox/Runtime/r3/darwin/time-darwin.cpp@ 39872

Last change on this file since 39872 was 34921, checked in by vboxsync, 14 years ago

Runtime/darwin: RTTimeSystemMilliTS incorrectly returned nanosecond resolution

  • Property svn:eol-style set to native
  • Property svn:keywords set to Id
File size: 3.4 KB
Line 
1/* $Id: time-darwin.cpp 34921 2010-12-09 19:46:36Z vboxsync $ */
2/** @file
3 * IPRT - Time, Darwin.
4 */
5
6/*
7 * Copyright (C) 2006-2007 Oracle Corporation
8 *
9 * This file is part of VirtualBox Open Source Edition (OSE), as
10 * available from http://www.virtualbox.org. This file is free software;
11 * you can redistribute it and/or modify it under the terms of the GNU
12 * General Public License (GPL) as published by the Free Software
13 * Foundation, in version 2 as it comes in the "COPYING" file of the
14 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
15 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
16 *
17 * The contents of this file may alternatively be used under the terms
18 * of the Common Development and Distribution License Version 1.0
19 * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
20 * VirtualBox OSE distribution, in which case the provisions of the
21 * CDDL are applicable instead of those of the GPL.
22 *
23 * You may elect to license modified versions of this file under the
24 * terms and conditions of either the GPL or the CDDL or both.
25 */
26
27
28/*******************************************************************************
29* Header Files *
30*******************************************************************************/
31#define LOG_GROUP RTLOGGROUP_TIME
32#define RTTIME_INCL_TIMEVAL
33#include <mach/mach_time.h>
34#include <mach/kern_return.h>
35#include <sys/time.h>
36#include <time.h>
37
38#include <iprt/time.h>
39#include <iprt/assert.h>
40#include "internal/time.h"
41
42
43/*******************************************************************************
44* Global Variables *
45*******************************************************************************/
46static struct mach_timebase_info g_Info = { 0, 0 };
47static double g_rdFactor = 0.0;
48static bool g_fFailedToGetTimeBaseInfo = false;
49
50
51/**
52 * Perform lazy init (pray we're not racing anyone in a bad way).
53 */
54static void rtTimeDarwinLazyInit(void)
55{
56 struct mach_timebase_info Info;
57 if (mach_timebase_info(&Info) == KERN_SUCCESS)
58 {
59 g_rdFactor = (double)Info.numer / (double)Info.denom;
60 g_Info = Info;
61 }
62 else
63 {
64 g_fFailedToGetTimeBaseInfo = true;
65 Assert(g_Info.denom == 0 && g_Info.numer == 0 && g_rdFactor == 0.0);
66 }
67}
68
69
70/**
71 * Internal worker.
72 * @returns Nanosecond timestamp.
73 */
74DECLINLINE(uint64_t) rtTimeGetSystemNanoTS(void)
75{
76 /* Lazy init. */
77 if (RT_UNLIKELY(g_Info.denom == 0 && !g_fFailedToGetTimeBaseInfo))
78 rtTimeDarwinLazyInit();
79
80 /* special case: absolute time is in nanoseconds */
81 if (g_Info.denom == 1 && g_Info.numer == 1)
82 return mach_absolute_time();
83
84 /* general case: multiply by factor to get nanoseconds. */
85 if (g_rdFactor != 0.0)
86 return mach_absolute_time() * g_rdFactor;
87
88 /* worst case: fallback to gettimeofday(). */
89 struct timeval tv;
90 gettimeofday(&tv, NULL);
91 return (uint64_t)tv.tv_sec * (uint64_t)(1000 * 1000 * 1000)
92 + (uint64_t)(tv.tv_usec * 1000);
93}
94
95
96RTDECL(uint64_t) RTTimeSystemNanoTS(void)
97{
98 return rtTimeGetSystemNanoTS();
99}
100
101
102RTDECL(uint64_t) RTTimeSystemMilliTS(void)
103{
104 return rtTimeGetSystemNanoTS() / 1000000;
105}
106
107
108RTDECL(PRTTIMESPEC) RTTimeNow(PRTTIMESPEC pTime)
109{
110 /** @todo find nanosecond API for getting time of day. */
111 struct timeval tv;
112 gettimeofday(&tv, NULL);
113 return RTTimeSpecSetTimeval(pTime, &tv);
114}
115
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette