Commit b7b89a8f authored by Marc Sune's avatar Marc Sune

Fix ROUTER's xhas_out() in MANDATORY mode

Before this commit, xhas_out() was returning true regardless. This
was correct before the ZMQ_ROUTER_MANDATORY flag as introduced.
However, ZMQ_POLLOUT.

With this commit, _if_ ZMQ_ROUTER_MANDATORY is set, xhas_out() will
return false if ALL peer's outgoing pipes are full.

There is an outstanding high-level design question:

If ZMQ_ROUTER_MANDATORY is set, and zmq_poll() waits for ZMQ_POLLOUT
events, zmq_poll() will immediately wake up if only 1 pipe has
room to send, regardless of the peer, creating a busy loop of
zmq_poll() wake-up, zmq_send() (EAGAIN). There is no way for
the application to selectively wait for ZMQ_POLLOUT for specific
peer(s), which seems somehow necessary in ZMQ_ROUTER_MANDATORY.

This discussion will be addressed in a separate issue.
Signed-off-by: 's avatarMarc Sune <marc@voltanet.io>
Signed-off-by: 's avatarFredi Raspall <fredi@voltanet.io>
parent 30ab0ed8
...@@ -423,10 +423,19 @@ bool zmq::router_t::xhas_in () ...@@ -423,10 +423,19 @@ bool zmq::router_t::xhas_in ()
bool zmq::router_t::xhas_out () bool zmq::router_t::xhas_out ()
{ {
// In theory, ROUTER socket is always ready for writing. Whether actual // In theory, ROUTER socket is always ready for writing (except when
// attempt to write succeeds depends on which pipe the message is going // MANDATORY is set). Whether actual attempt to write succeeds depends
// to be routed to. // on whitch pipe the message is going to be routed to.
if(!mandatory)
return true; return true;
bool has_out = false;
outpipes_t::iterator it;
for (it = outpipes.begin (); it != outpipes.end (); ++it)
has_out |= it->second.pipe->check_hwm();
return has_out;
} }
zmq::blob_t zmq::router_t::get_credential () const zmq::blob_t zmq::router_t::get_credential () const
......
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