- 11 May, 2012 1 commit
-
-
Ian Barber authored
-
- 08 May, 2012 5 commits
-
-
Ian Barber authored
Fix #366 - On Windows, preventing sockets to be inherited by child processes.
-
Ian Barber authored
Simplify encoder's loop
-
Martin Hurton authored
-
Ian Barber authored
Fix issue #268
-
Martin Hurton authored
This patch fixes a bug in the message encoder which was responsible for computing incorrect message offset. The bug affected PGM receiver making it unable to decode inital messages.
-
- 07 May, 2012 1 commit
-
-
unknown authored
-
- 06 May, 2012 1 commit
-
-
Pieter Hintjens authored
Fix for issue 355 and fix for compile error with Visual C++ 2008
-
- 05 May, 2012 2 commits
-
-
Jos Decoster authored
File decoder.cpp does not compile with Visual C++ 2008: 1>c:\tmp\libzmq\src\decoder.cpp(117) : warning C4003: not enough actual parameters for macro 'max' 1>c:\tmp\libzmq\src\decoder.cpp(117) : error C2589: '(' : illegal token on right side of '::' 1>c:\tmp\libzmq\src\decoder.cpp(117) : error C2059: syntax error : '::' 1>c:\tmp\libzmq\src\decoder.cpp(117) : error C2143: syntax error : missing ';' before '{' This error is caused by the precense of a macro 'max' when including 'windows.h'. To solve this problem, the preprocessor macro /DNOMINMAX must be specified.
-
Jos Decoster authored
Fix for issue 355. Added missing source files dealer.cpp, device,cpp and router.cpp. Removed source files no longer present: xrep.cpp and xreq.cpp
-
- 03 May, 2012 2 commits
-
-
Pieter Hintjens authored
Async connect error handling
-
Ian Barber authored
Patch from Mato that fixes a subtle connect bug: EAGAIN was being used as a translation value for EINPROGRESS, thus shadowing a real EAGAIN return value from the OS. This caused later assertions of "Invalid argument" in stream_engine.cpp when it attempted to use a socket which was not connected. I also add EINTR to mean EINPROGRESS, as per the POSIX and FreeBSD documentation which specifies that a connect() call interrupted due to a signal will complete asynchronously. Signed-off-by: Martin Lucina <martin@lucina.net>
-
- 30 Apr, 2012 4 commits
-
-
Pieter Hintjens authored
Fix decoder to properly handle large messages
-
Pieter Hintjens authored
Fix issue #264
-
Pieter Hintjens authored
socket_base: process_unplug () is not used, remove it
-
Pieter Hintjens authored
Do not crash when multiple peers connect to PAIR socket
-
- 29 Apr, 2012 3 commits
-
-
Martin Hurton authored
When more then one peer connected to a ZMQ_PAIR socket, an application aborted due to assertion failure. This patch changes the ZMQ_PAIR socket behaviour so that it rejects any further connection requests.
-
Martin Hurton authored
The decoder did not properly decode large messages on systems where sizeof (size_t) < sizeof (uint64_t).
-
Martin Hurton authored
Before this patch, the stream engine terminated itself whenever it had detected an IO error. If this happened when sending a message, the engine lost all in-flight messages, messages waiting to be decoded, and the last decoded message that had not been accepted, if there was one. The new behaviour is to terminate the engine only after the input error has been detected and the last decoded
-
- 28 Apr, 2012 1 commit
-
-
Martin Hurton authored
-
- 27 Apr, 2012 4 commits
-
-
Pieter Hintjens authored
Tweak FD sockopt text
-
Ian Barber authored
-
Ian Barber authored
Added refinement for ZMQ_FD option
-
Paul Colomiets authored
-
- 26 Apr, 2012 4 commits
-
-
Ian Barber authored
pipe: code cleanup
-
Ian Barber authored
fq: remove unused parameter
-
Martin Hurton authored
The recv function accepted flags parameter but this was unused.
-
Martin Hurton authored
-
- 25 Apr, 2012 4 commits
-
-
Ian Barber authored
Mention limitation of the device implementation
-
Martin Hurton authored
+ fix whitespace errors + drop some unnecessary parens
-
Pieter Hintjens authored
Rename XREP/XREQ to ROUTER/DEALER in tests
-
Pieter Hintjens authored
xsub: fix memory leak
-
- 24 Apr, 2012 4 commits
-
-
Martin Hurton authored
-
Martin Hurton authored
The implementation of the send call for XSUB socket failed to release and initialise empty message when duplicate subscription was detected.
-
Ian Barber authored
Atomic operations for armv7a
-
Patrick Trantham authored
This commit implements atomic operations for the armv7a architecture using gcc inline assembly. This offers higher performance compared to pthread mutexes. Tested on an am3517 evm, clocked at 600MHz: ./inproc_thr 200 1000000 ------------------------ 53-60K messages / sec, pthread mutexes 73-90K messages / sec, assembly atomic ops ./inproc_lat 200 1000000 ------------------------ average latency: 42.234 [us], pthread mutexes average latency: 35.496 [us], assembly atomic ops
-
- 21 Apr, 2012 4 commits
-
-
Pieter Hintjens authored
add process_commands() to the beginning of zmq_connect() and zmq_bind()
-
Sergey KHripchenko authored
I believe there was a conception that zmq_connect() and zmq_bind() will be called only at the socket creation time and therefore don't need it. Now it is not true anymore.
-
Pieter Hintjens authored
ZMQ BUG FOUND + fixes for zmq_unbind() / zmq_disconnect() usage corner cases
-
Sergey KHripchenko authored
1. when we call zmq_bind()/zmq_connect() to create endpoint we send ourselfs(through launch_child()) command to process_own(endpoint) (and add it to own_t::owned) in the application thread we could call zmq_unbind() / zmq_disconnect() _BEFORE_ we run process_own() in ZMQ thread and in this situation we will be unable to find it in own_t::owned. in other words own_t::owned.find(endpoint) will not be deleted but it will be deleted from socket_base_t::endpoints. 2. when you zmq_unbind() the lisnening TCP/IPC socket was terminated only in destructor... so the whole ZMQ_LINGER time listening TCP/IPC socket was able to accept() new connections but unable to handle them. this all geting even worse since unfortunately zmq has a bug and '*_listener_t' object not terminated untill the socket's zmq_close(). AT LEAST FOR PUSH SOCKETS. Everything is ok for SUB sockets. Easy to reproduce without my fix: zmq_socket(PUSH) zmq_bind(tcp); // connect to it from PULL socket zmq_unbind(tcp); sleep(forever) // netstat -anp | grep 'tcp listening socket' With my fix you could see that after zmq_unbind(tcp) all previously connected tcp sessions will not be finished untill the zmq_close(socket) regardless of ZMQ_LINGER value. (*_listener_t terminates all owned session_base_t(connect=false) and they call pipe_t::terminate() which in turn should call session_base_t::terminated() but this never happens)
-