Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
L
libzmq
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
libzmq
Commits
de5a7878
Commit
de5a7878
authored
Nov 07, 2013
by
Pieter Hintjens
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #742 from psl-felipefarinon/master
Fixing issue #583. Using low resolution timer for clock::now_ms
parents
e3898b5d
b8a9f299
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
54 additions
and
0 deletions
+54
-0
clock.cpp
src/clock.cpp
+54
-0
No files found.
src/clock.cpp
View file @
de5a7878
...
...
@@ -22,6 +22,7 @@
#include "likely.hpp"
#include "config.hpp"
#include "err.hpp"
#include "mutex.hpp"
#include <stddef.h>
...
...
@@ -41,9 +42,47 @@
#include <time.h>
#endif
typedef
ULONGLONG
(
*
f_compatible_get_tick_count64
)();
static
zmq
::
mutex_t
compatible_get_tick_count64_mutex
;
ULONGLONG
compatible_get_tick_count64
()
{
compatible_get_tick_count64_mutex
.
lock
();
static
DWORD
s_wrap
=
0
;
static
DWORD
s_last_tick
=
0
;
const
DWORD
current_tick
=
::
GetTickCount
();
if
(
current_tick
<
s_last_tick
)
++
s_wrap
;
s_last_tick
=
current_tick
;
const
ULONGLONG
result
=
(
static_cast
<
ULONGLONG
>
(
s_wrap
)
<<
32
)
+
static_cast
<
ULONGLONG
>
(
current_tick
);
compatible_get_tick_count64_mutex
.
unlock
();
return
result
;
}
f_compatible_get_tick_count64
init_compatible_get_tick_count64
()
{
f_compatible_get_tick_count64
func
=
NULL
;
HMODULE
module
=
::
LoadLibraryA
(
"Kernel32.dll"
);
if
(
module
!=
NULL
)
func
=
reinterpret_cast
<
f_compatible_get_tick_count64
>
(
::
GetProcAddress
(
module
,
"GetTickCount64"
));
if
(
func
==
NULL
)
func
=
compatible_get_tick_count64
;
return
func
;
}
static
f_compatible_get_tick_count64
my_get_tick_count64
=
init_compatible_get_tick_count64
();
zmq
::
clock_t
::
clock_t
()
:
last_tsc
(
rdtsc
()),
#ifdef ZMQ_HAVE_WINDOWS
last_time
(
static_cast
<
uint64_t
>
((
*
my_get_tick_count64
)()))
#else
last_time
(
now_us
()
/
1000
)
#endif
{
}
...
...
@@ -106,7 +145,18 @@ uint64_t zmq::clock_t::now_ms ()
// If TSC is not supported, get precise time and chop off the microseconds.
if
(
!
tsc
)
{
#ifdef ZMQ_HAVE_WINDOWS
// Under Windows, now_us is not so reliable since QueryPerformanceCounter
// does not guarantee that it will use a hardware that offers a monotonic timer.
// So, lets use GetTickCount when GetTickCount64 is not available with an workaround
// to its 32 bit limitation.
static_assert
(
sizeof
(
uint64_t
)
>=
sizeof
(
ULONGLONG
),
"Loosing timer information"
);
return
static_cast
<
uint64_t
>
((
*
my_get_tick_count64
)());
#else
return
now_us
()
/
1000
;
#endif
}
// If TSC haven't jumped back (in case of migration to a different
// CPU core) and if not too much time elapsed since last measurement,
...
...
@@ -115,7 +165,11 @@ uint64_t zmq::clock_t::now_ms ()
return
last_time
;
last_tsc
=
tsc
;
#ifdef ZMQ_HAVE_WINDOWS
last_time
=
static_cast
<
uint64_t
>
((
*
my_get_tick_count64
)());
#else
last_time
=
now_us
()
/
1000
;
#endif
return
last_time
;
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment