Commit 5b300895 authored by Ian Barber's avatar Ian Barber

port of patch by Martin Sustrik to libxs: This patch instantiate a clock_t instance for each XS

socket. Thus, it is shared between subsequent calls
to xs_recv (and xs_send). That in turn significantly
limits the number of invocations of  getimeofday (or similar)
when timeouts are used and recv/send is called in a
tight loop.
parent f663ad93
...@@ -46,7 +46,6 @@ ...@@ -46,7 +46,6 @@
#include "io_thread.hpp" #include "io_thread.hpp"
#include "session_base.hpp" #include "session_base.hpp"
#include "config.hpp" #include "config.hpp"
#include "clock.hpp"
#include "pipe.hpp" #include "pipe.hpp"
#include "err.hpp" #include "err.hpp"
#include "ctx.hpp" #include "ctx.hpp"
...@@ -560,7 +559,6 @@ int zmq::socket_base_t::send (msg_t *msg_, int flags_) ...@@ -560,7 +559,6 @@ int zmq::socket_base_t::send (msg_t *msg_, int flags_)
// Compute the time when the timeout should occur. // Compute the time when the timeout should occur.
// If the timeout is infite, don't care. // If the timeout is infite, don't care.
clock_t clock ;
int timeout = options.sndtimeo; int timeout = options.sndtimeo;
uint64_t end = timeout < 0 ? 0 : (clock.now_ms () + timeout); uint64_t end = timeout < 0 ? 0 : (clock.now_ms () + timeout);
...@@ -643,7 +641,6 @@ int zmq::socket_base_t::recv (msg_t *msg_, int flags_) ...@@ -643,7 +641,6 @@ int zmq::socket_base_t::recv (msg_t *msg_, int flags_)
// Compute the time when the timeout should occur. // Compute the time when the timeout should occur.
// If the timeout is infite, don't care. // If the timeout is infite, don't care.
clock_t clock ;
int timeout = options.rcvtimeo; int timeout = options.rcvtimeo;
uint64_t end = timeout < 0 ? 0 : (clock.now_ms () + timeout); uint64_t end = timeout < 0 ? 0 : (clock.now_ms () + timeout);
......
...@@ -33,6 +33,7 @@ ...@@ -33,6 +33,7 @@
#include "i_poll_events.hpp" #include "i_poll_events.hpp"
#include "mailbox.hpp" #include "mailbox.hpp"
#include "stdint.hpp" #include "stdint.hpp"
#include "clock.hpp"
#include "pipe.hpp" #include "pipe.hpp"
namespace zmq namespace zmq
...@@ -194,6 +195,9 @@ namespace zmq ...@@ -194,6 +195,9 @@ namespace zmq
// True if the last message received had MORE flag set. // True if the last message received had MORE flag set.
bool rcvmore; bool rcvmore;
// Improves efficiency of time measurement.
clock_t clock;
socket_base_t (const socket_base_t&); socket_base_t (const socket_base_t&);
const socket_base_t &operator = (const socket_base_t&); const socket_base_t &operator = (const socket_base_t&);
mutex_t sync; mutex_t sync;
......
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