1
/* Copyright (C) 2004 MySQL AB
3
This program is free software; you can redistribute it and/or modify
4
it under the terms of the GNU General Public License as published by
5
the Free Software Foundation; version 2 of the License.
7
This program is distributed in the hope that it will be useful,
8
but WITHOUT ANY WARRANTY; without even the implied warranty of
9
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
10
GNU General Public License for more details.
12
You should have received a copy of the GNU General Public License
13
along with this program; if not, write to the Free Software
14
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
16
/* get time since epoc in 100 nanosec units */
17
/* thus to get the current time we should use the system function
18
with the highest possible resolution */
21
TODO: in functions my_micro_time() and my_micro_time_and_time() there
22
exists some common code that should be merged into a function.
25
#include "mysys_priv.h"
26
#include "my_static.h"
28
#if TIME_WITH_SYS_TIME
29
# include <sys/time.h>
33
# include <sys/time.h>
39
uint64_t my_getsystime()
41
#ifdef HAVE_CLOCK_GETTIME
43
clock_gettime(CLOCK_REALTIME, &tp);
44
return (uint64_t)tp.tv_sec*10000000+(uint64_t)tp.tv_nsec/100;
46
/* TODO: check for other possibilities for hi-res timestamping */
48
gettimeofday(&tv,NULL);
49
return (uint64_t)tv.tv_sec*10000000+(uint64_t)tv.tv_usec*10;
59
flags If MY_WME is set, write error if time call fails
63
time_t my_time(myf flags __attribute__((unused)))
67
(void) my_micro_time_and_time(&t);
70
/* The following loop is here beacuse time() may fail on some systems */
71
while ((t= time(0)) == (time_t) -1)
74
fprintf(stderr, "%s: Warning: time() call failed\n", my_progname);
82
Return time in micro seconds
88
This function is to be used to measure performance in micro seconds.
89
As it's not defined whats the start time for the clock, this function
90
us only useful to measure time between two moments.
92
For windows platforms we need the frequency value of the CUP. This is
93
initalized in my_init.c through QueryPerformanceFrequency().
95
If Windows platform doesn't support QueryPerformanceFrequency() we will
96
obtain the time via GetClockCount, which only supports milliseconds.
99
Value in microseconds from some undefined point in time
102
uint64_t my_micro_time()
104
#if defined(HAVE_GETHRTIME)
105
return gethrtime()/1000;
110
The following loop is here because gettimeofday may fail on some systems
112
while (gettimeofday(&t, NULL) != 0)
114
newtime= (uint64_t)t.tv_sec * 1000000 + t.tv_usec;
116
#endif /* defined(HAVE_GETHRTIME) */
121
Return time in seconds and timer in microseconds (not different start!)
124
my_micro_time_and_time()
125
time_arg Will be set to seconds since epoch (00:00:00 UTC,
129
This function is to be useful when we need both the time and microtime.
130
For example in MySQL this is used to get the query time start of a query
131
and to measure the time of a query (for the slow query log)
134
Value of time is as in time() call.
135
Value of microtime is same as my_micro_time(), which may be totally
139
Value in microseconds from some undefined point in time
143
uint64_t my_micro_time_and_time(time_t *time_arg)
145
#if defined(HAVE_GETHRTIME)
147
Solaris has a very slow time() call. We optimize this by using the very
148
fast gethrtime() call and only calling time() every 1/2 second
151
#define DELTA_FOR_SECONDS 500000000LL /* Half a second */
153
static hrtime_t prev_gethrtime= 0;
154
static time_t cur_time= 0;
155
hrtime_t cur_gethrtime;
157
pthread_mutex_lock(&THR_LOCK_time);
158
cur_gethrtime= gethrtime();
159
if ((cur_gethrtime - prev_gethrtime) > DELTA_FOR_SECONDS)
162
prev_gethrtime= cur_gethrtime;
165
pthread_mutex_unlock(&THR_LOCK_time);
166
return cur_gethrtime/1000;
171
The following loop is here because gettimeofday may fail on some systems
173
while (gettimeofday(&t, NULL) != 0)
176
newtime= (uint64_t)t.tv_sec * 1000000 + t.tv_usec;
178
#endif /* defined(HAVE_GETHRTIME) */
186
my_time_possible_from_micro()
187
microtime Value from very recent my_micro_time()
190
This function returns the current time. The microtime argument is only used
191
if my_micro_time() uses a function that can safely be converted to the
198
time_t my_time_possible_from_micro(uint64_t microtime __attribute__((unused)))
200
#if defined(HAVE_GETHRTIME)
201
return my_time(0); /* Cached time */
203
return (time_t) (microtime / 1000000);
204
#endif /* defined(HAVE_GETHRTIME) */