Commit 9129b792 authored by Martin Sustrik's avatar Martin Sustrik

if TSC jumps backwards (in case of migration to a different CPU core) latency…

if TSC jumps backwards (in case of migration to a different CPU core) latency peak may occur -- fixed
parent e2802d9a
......@@ -111,9 +111,11 @@ bool zmq::app_thread_t::process_commands (bool block_, bool throttle_)
#error
#endif
// Check whether certain time have elapsed since last command
// processing.
if (current_time - last_processing_time <= max_command_delay)
// Check whether TSC haven't jumped backwards (in case of migration
// between CPU cores) and whether certain time have elapsed since
// last command processing. If it didn't do nothing.
if (current_time >= last_processing_time &&
current_time - last_processing_time <= max_command_delay)
return !terminated;
last_processing_time = current_time;
}
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment