mirror of
https://github.com/zeromq/libzmq.git
synced 2025-01-07 09:48:07 +01:00
renamed from zs to zmq
This commit is contained in:
parent
183b688764
commit
cc3755a16f
3
.gitignore
vendored
3
.gitignore
vendored
@ -0,0 +1,3 @@
|
|||||||
|
*.o
|
||||||
|
*.lo
|
||||||
|
*.la
|
@ -1,4 +1,4 @@
|
|||||||
include_HEADERS = include/zs.h include/zs.hpp
|
include_HEADERS = include/zmq.h include/zmq.hpp
|
||||||
|
|
||||||
SUBDIRS = src examples
|
SUBDIRS = src examples
|
||||||
DIST_SUBDIRS = src examples
|
DIST_SUBDIRS = src examples
|
||||||
|
38
configure.in
38
configure.in
@ -1,7 +1,7 @@
|
|||||||
# -*- Autoconf -*-
|
# -*- Autoconf -*-
|
||||||
# Process this file with autoconf to produce a configure script.
|
# Process this file with autoconf to produce a configure script.
|
||||||
AC_PREREQ(2.61)
|
AC_PREREQ(2.61)
|
||||||
AC_INIT([zsock],[dev])
|
AC_INIT([zeromq],[dev])
|
||||||
AC_CONFIG_AUX_DIR(config)
|
AC_CONFIG_AUX_DIR(config)
|
||||||
AM_CONFIG_HEADER(src/platform.hpp)
|
AM_CONFIG_HEADER(src/platform.hpp)
|
||||||
AM_INIT_AUTOMAKE(AC_PACKAGE_NAME, AC_PACKAGE_VERSION)
|
AM_INIT_AUTOMAKE(AC_PACKAGE_NAME, AC_PACKAGE_VERSION)
|
||||||
@ -20,7 +20,7 @@ AC_CANONICAL_HOST
|
|||||||
|
|
||||||
case "${host_os}" in
|
case "${host_os}" in
|
||||||
*linux*)
|
*linux*)
|
||||||
AC_DEFINE(ZS_HAVE_LINUX, 1, [Have Linux OS])
|
AC_DEFINE(ZMQ_HAVE_LINUX, 1, [Have Linux OS])
|
||||||
CPPFLAGS="-D_REENTRANT $CPPFLAGS"
|
CPPFLAGS="-D_REENTRANT $CPPFLAGS"
|
||||||
sed < libtool > libtool-2 \
|
sed < libtool > libtool-2 \
|
||||||
's/^hardcode_libdir_flag_spec.*$'/'hardcode_libdir_flag_spec=" "/'
|
's/^hardcode_libdir_flag_spec.*$'/'hardcode_libdir_flag_spec=" "/'
|
||||||
@ -29,7 +29,7 @@ case "${host_os}" in
|
|||||||
AC_CHECK_LIB(uuid, uuid_generate)
|
AC_CHECK_LIB(uuid, uuid_generate)
|
||||||
;;
|
;;
|
||||||
*solaris*)
|
*solaris*)
|
||||||
AC_DEFINE(ZS_HAVE_SOLARIS, 1, [Have Solaris OS])
|
AC_DEFINE(ZMQ_HAVE_SOLARIS, 1, [Have Solaris OS])
|
||||||
AC_CHECK_LIB(socket, main)
|
AC_CHECK_LIB(socket, main)
|
||||||
AC_CHECK_LIB(nsl, main)
|
AC_CHECK_LIB(nsl, main)
|
||||||
AC_CHECK_LIB(rt, main)
|
AC_CHECK_LIB(rt, main)
|
||||||
@ -45,37 +45,37 @@ case "${host_os}" in
|
|||||||
AC_MSG_RESULT([$solaris_has_atomic])
|
AC_MSG_RESULT([$solaris_has_atomic])
|
||||||
# Solaris 8 does not have atomic operations exported to user space.
|
# Solaris 8 does not have atomic operations exported to user space.
|
||||||
if test "x$solaris_has_atomic" = "xno"; then
|
if test "x$solaris_has_atomic" = "xno"; then
|
||||||
AC_DEFINE(ZS_FORCE_MUTEXES, 1, [Force to use mutexes])
|
AC_DEFINE(ZMQ_FORCE_MUTEXES, 1, [Force to use mutexes])
|
||||||
fi
|
fi
|
||||||
;;
|
;;
|
||||||
*freebsd*)
|
*freebsd*)
|
||||||
AC_DEFINE(ZS_HAVE_FREEBSD, 1, [Have FreeBSD OS])
|
AC_DEFINE(ZMQ_HAVE_FREEBSD, 1, [Have FreeBSD OS])
|
||||||
CPPFLAGS="-D_THREAD_SAFE $CPPFLAGS"
|
CPPFLAGS="-D_THREAD_SAFE $CPPFLAGS"
|
||||||
LIBS="-pthread"
|
LIBS="-pthread"
|
||||||
;;
|
;;
|
||||||
*darwin*)
|
*darwin*)
|
||||||
AC_DEFINE(ZS_HAVE_OSX, 1, [Have DarwinOSX OS])
|
AC_DEFINE(ZMQ_HAVE_OSX, 1, [Have DarwinOSX OS])
|
||||||
LIBS="-pthread"
|
LIBS="-pthread"
|
||||||
ZS_EXTRA_CXXFLAGS+="-Wno-uninitialized"
|
ZMQ_EXTRA_CXXFLAGS+="-Wno-uninitialized"
|
||||||
;;
|
;;
|
||||||
*openbsd*)
|
*openbsd*)
|
||||||
AC_DEFINE(ZS_HAVE_OPENBSD, 1, [Have OpenBSD OS])
|
AC_DEFINE(ZMQ_HAVE_OPENBSD, 1, [Have OpenBSD OS])
|
||||||
CPPFLAGS="-pthread $CPPFLAGS"
|
CPPFLAGS="-pthread $CPPFLAGS"
|
||||||
LIBS="-pthread"
|
LIBS="-pthread"
|
||||||
;;
|
;;
|
||||||
*nto-qnx*)
|
*nto-qnx*)
|
||||||
AC_DEFINE(ZS_HAVE_QNXNTO, 1, [Have QNX Neutrino OS])
|
AC_DEFINE(ZMQ_HAVE_QNXNTO, 1, [Have QNX Neutrino OS])
|
||||||
CPPFLAGS="-D_THREAD_SAFE $CPPFLAGS"
|
CPPFLAGS="-D_THREAD_SAFE $CPPFLAGS"
|
||||||
AC_CHECK_LIB(socket,main)
|
AC_CHECK_LIB(socket,main)
|
||||||
;;
|
;;
|
||||||
*aix*)
|
*aix*)
|
||||||
AC_DEFINE(ZS_HAVE_AIX, 1, [Have AIX OS])
|
AC_DEFINE(ZMQ_HAVE_AIX, 1, [Have AIX OS])
|
||||||
if test "x$GXX" = "xyes"; then
|
if test "x$GXX" = "xyes"; then
|
||||||
CPPFLAGS="-D_THREAD_SAFE $CPPFLAGS"
|
CPPFLAGS="-D_THREAD_SAFE $CPPFLAGS"
|
||||||
fi
|
fi
|
||||||
;;
|
;;
|
||||||
*hpux*)
|
*hpux*)
|
||||||
AC_DEFINE(ZS_HAVE_HPUX, 1, [Have HPUX OS])
|
AC_DEFINE(ZMQ_HAVE_HPUX, 1, [Have HPUX OS])
|
||||||
if test "x$GXX" = "xyes"; then
|
if test "x$GXX" = "xyes"; then
|
||||||
CPPFLAGS="-D_THREAD_SAFE $CPPFLAGS"
|
CPPFLAGS="-D_THREAD_SAFE $CPPFLAGS"
|
||||||
fi
|
fi
|
||||||
@ -86,8 +86,8 @@ case "${host_os}" in
|
|||||||
chmod 755 libtool
|
chmod 755 libtool
|
||||||
;;
|
;;
|
||||||
*mingw32*)
|
*mingw32*)
|
||||||
AC_DEFINE(ZS_HAVE_WINDOWS, 1, [Have Windows OS])
|
AC_DEFINE(ZMQ_HAVE_WINDOWS, 1, [Have Windows OS])
|
||||||
AC_DEFINE(ZS_HAVE_MINGW32, 1, [Have MinGW32])
|
AC_DEFINE(ZMQ_HAVE_MINGW32, 1, [Have MinGW32])
|
||||||
AC_CHECK_HEADERS(windows.h)
|
AC_CHECK_HEADERS(windows.h)
|
||||||
LIBS="-lwsock32 -lws2_32 -no-undefined"
|
LIBS="-lwsock32 -lws2_32 -no-undefined"
|
||||||
CFLAGS="-std=c99"
|
CFLAGS="-std=c99"
|
||||||
@ -122,10 +122,10 @@ AC_CHECK_HEADERS(errno.h arpa/inet.h netinet/tcp.h netinet/in.h stddef.h \
|
|||||||
stdlib.h string.h sys/socket.h sys/time.h unistd.h limits.h)
|
stdlib.h string.h sys/socket.h sys/time.h unistd.h limits.h)
|
||||||
|
|
||||||
# Check if we have eventfd.h header file.
|
# Check if we have eventfd.h header file.
|
||||||
AC_CHECK_HEADERS(sys/eventfd.h, [AC_DEFINE(ZS_HAVE_EVENTFD, 1, [Have eventfd extension.])])
|
AC_CHECK_HEADERS(sys/eventfd.h, [AC_DEFINE(ZMQ_HAVE_EVENTFD, 1, [Have eventfd extension.])])
|
||||||
|
|
||||||
# Check if we have ifaddrs.h header file.
|
# Check if we have ifaddrs.h header file.
|
||||||
AC_CHECK_HEADERS(ifaddrs.h, [AC_DEFINE(ZS_HAVE_IFADDRS, 1, [Have ifaddrs.h header.])])
|
AC_CHECK_HEADERS(ifaddrs.h, [AC_DEFINE(ZMQ_HAVE_IFADDRS, 1, [Have ifaddrs.h header.])])
|
||||||
|
|
||||||
# Use c++ in subsequent tests
|
# Use c++ in subsequent tests
|
||||||
AC_LANG(C++)
|
AC_LANG(C++)
|
||||||
@ -162,8 +162,8 @@ fi
|
|||||||
AC_SUBST(stdint)
|
AC_SUBST(stdint)
|
||||||
AC_SUBST(inttypes)
|
AC_SUBST(inttypes)
|
||||||
|
|
||||||
# Subst ZS_EXTRA_CXXFLAGS
|
# Subst ZMQ_EXTRA_CXXFLAGS
|
||||||
AC_SUBST(ZS_EXTRA_CXXFLAGS)
|
AC_SUBST(ZMQ_EXTRA_CXXFLAGS)
|
||||||
|
|
||||||
|
|
||||||
# Checks for library functions.
|
# Checks for library functions.
|
||||||
@ -175,7 +175,7 @@ AC_OUTPUT(Makefile src/Makefile examples/Makefile examples/chat/Makefile)
|
|||||||
|
|
||||||
AC_MSG_RESULT([])
|
AC_MSG_RESULT([])
|
||||||
AC_MSG_RESULT([ ******************************************************** ])
|
AC_MSG_RESULT([ ******************************************************** ])
|
||||||
AC_MSG_RESULT([ 0SOCKETS ])
|
AC_MSG_RESULT([ 0MQ ])
|
||||||
AC_MSG_RESULT([ ******************************************************** ])
|
AC_MSG_RESULT([ ******************************************************** ])
|
||||||
AC_MSG_RESULT([ This software is distributed under the terms and ])
|
AC_MSG_RESULT([ This software is distributed under the terms and ])
|
||||||
AC_MSG_RESULT([ conditions of the LESSER GNU GENERAL PUBLIC LICENSE. ])
|
AC_MSG_RESULT([ conditions of the LESSER GNU GENERAL PUBLIC LICENSE. ])
|
||||||
@ -183,6 +183,6 @@ AC_MSG_RESULT([ See the file COPYING and COPYING.LESSER for the full ])
|
|||||||
AC_MSG_RESULT([ license text. ])
|
AC_MSG_RESULT([ license text. ])
|
||||||
AC_MSG_RESULT([ ******************************************************** ])
|
AC_MSG_RESULT([ ******************************************************** ])
|
||||||
AC_MSG_RESULT([])
|
AC_MSG_RESULT([])
|
||||||
AC_MSG_RESULT([ zsock install dir: $prefix])
|
AC_MSG_RESULT([ 0MQ install dir: $prefix])
|
||||||
AC_MSG_RESULT([])
|
AC_MSG_RESULT([])
|
||||||
|
|
||||||
|
@ -3,13 +3,13 @@ INCLUDES = -I$(top_builddir) -I$(top_builddir)/include
|
|||||||
noinst_PROGRAMS = chatroom display prompt
|
noinst_PROGRAMS = chatroom display prompt
|
||||||
|
|
||||||
chatroom_SOURCES = chatroom.cpp
|
chatroom_SOURCES = chatroom.cpp
|
||||||
chatroom_LDADD = $(top_builddir)/src/libzs.la
|
chatroom_LDADD = $(top_builddir)/src/libzmq.la
|
||||||
chatroom_CXXFLAGS = -Wall -pedantic -Werror
|
chatroom_CXXFLAGS = -Wall -pedantic -Werror
|
||||||
|
|
||||||
display_SOURCES = display.cpp
|
display_SOURCES = display.cpp
|
||||||
display_LDADD = $(top_builddir)/src/libzs.la
|
display_LDADD = $(top_builddir)/src/libzmq.la
|
||||||
display_CXXFLAGS = -Wall -pedantic -Werror
|
display_CXXFLAGS = -Wall -pedantic -Werror
|
||||||
|
|
||||||
prompt_SOURCES = prompt.cpp
|
prompt_SOURCES = prompt.cpp
|
||||||
prompt_LDADD = $(top_builddir)/src/libzs.la
|
prompt_LDADD = $(top_builddir)/src/libzmq.la
|
||||||
prompt_CXXFLAGS = -Wall -pedantic -Werror
|
prompt_CXXFLAGS = -Wall -pedantic -Werror
|
||||||
|
@ -23,7 +23,7 @@
|
|||||||
|
|
||||||
using namespace std;
|
using namespace std;
|
||||||
|
|
||||||
#include <zs.hpp>
|
#include <zmq.hpp>
|
||||||
|
|
||||||
int main (int argc, const char *argv [])
|
int main (int argc, const char *argv [])
|
||||||
{
|
{
|
||||||
@ -38,19 +38,19 @@ int main (int argc, const char *argv [])
|
|||||||
const char *out_interface = argv [2];
|
const char *out_interface = argv [2];
|
||||||
|
|
||||||
// Initialise 0MQ infrastructure
|
// Initialise 0MQ infrastructure
|
||||||
zs::context_t ctx (1, 1);
|
zmq::context_t ctx (1, 1);
|
||||||
|
|
||||||
// Create two sockets. One for receiving messages from 'propmt'
|
// Create two sockets. One for receiving messages from 'propmt'
|
||||||
// applications, one for sending messages to 'display' applications
|
// applications, one for sending messages to 'display' applications
|
||||||
zs::socket_t in_socket (ctx, ZS_SUB);
|
zmq::socket_t in_socket (ctx, ZMQ_SUB);
|
||||||
in_socket.bind (in_interface);
|
in_socket.bind (in_interface);
|
||||||
zs::socket_t out_socket (ctx, ZS_PUB);
|
zmq::socket_t out_socket (ctx, ZMQ_PUB);
|
||||||
out_socket.bind (out_interface);
|
out_socket.bind (out_interface);
|
||||||
|
|
||||||
while (true) {
|
while (true) {
|
||||||
|
|
||||||
// Get a message
|
// Get a message
|
||||||
zs::message_t in_message;
|
zmq::message_t in_message;
|
||||||
in_socket.recv (&in_message);
|
in_socket.recv (&in_message);
|
||||||
|
|
||||||
// Get the current time. Replace the newline character at the end
|
// Get the current time. Replace the newline character at the end
|
||||||
@ -62,7 +62,7 @@ int main (int argc, const char *argv [])
|
|||||||
timebuf [strlen (timebuf) - 1] = ' ';
|
timebuf [strlen (timebuf) - 1] = ' ';
|
||||||
|
|
||||||
// Create and fill in the message
|
// Create and fill in the message
|
||||||
zs::message_t out_message (strlen (timebuf) + in_message.size ());
|
zmq::message_t out_message (strlen (timebuf) + in_message.size ());
|
||||||
char *data = (char*) out_message.data ();
|
char *data = (char*) out_message.data ();
|
||||||
memcpy (data, timebuf, strlen (timebuf));
|
memcpy (data, timebuf, strlen (timebuf));
|
||||||
data += strlen (timebuf);
|
data += strlen (timebuf);
|
||||||
|
@ -23,7 +23,7 @@
|
|||||||
|
|
||||||
using namespace std;
|
using namespace std;
|
||||||
|
|
||||||
#include <zs.hpp>
|
#include <zmq.hpp>
|
||||||
|
|
||||||
int main (int argc, const char *argv [])
|
int main (int argc, const char *argv [])
|
||||||
{
|
{
|
||||||
@ -38,17 +38,17 @@ int main (int argc, const char *argv [])
|
|||||||
|
|
||||||
// Initialise 0MQ infrastructure, connect to the chatroom and ask for all
|
// Initialise 0MQ infrastructure, connect to the chatroom and ask for all
|
||||||
// messages and gap notifications.
|
// messages and gap notifications.
|
||||||
zs::context_t ctx (1, 1);
|
zmq::context_t ctx (1, 1);
|
||||||
zs::socket_t s (ctx, ZS_SUB);
|
zmq::socket_t s (ctx, ZMQ_SUB);
|
||||||
s.connect (chatroom_out_address);
|
s.connect (chatroom_out_address);
|
||||||
s.subscribe ("*");
|
s.subscribe ("*");
|
||||||
|
|
||||||
while (true) {
|
while (true) {
|
||||||
|
|
||||||
// Get a message and print it to the console.
|
// Get a message and print it to the console.
|
||||||
zs::message_t message;
|
zmq::message_t message;
|
||||||
s.recv (&message);
|
s.recv (&message);
|
||||||
if (message.type () == zs::message_gap)
|
if (message.type () == zmq::message_gap)
|
||||||
cout << "Problems connecting to the chatroom..." << endl;
|
cout << "Problems connecting to the chatroom..." << endl;
|
||||||
else
|
else
|
||||||
cout << (char*) message.data () << flush;
|
cout << (char*) message.data () << flush;
|
||||||
|
@ -23,7 +23,7 @@
|
|||||||
|
|
||||||
using namespace std;
|
using namespace std;
|
||||||
|
|
||||||
#include <zs.hpp>
|
#include <zmq.hpp>
|
||||||
|
|
||||||
int main (int argc, const char *argv [])
|
int main (int argc, const char *argv [])
|
||||||
{
|
{
|
||||||
@ -38,8 +38,8 @@ int main (int argc, const char *argv [])
|
|||||||
const char *user_name = argv [2];
|
const char *user_name = argv [2];
|
||||||
|
|
||||||
// Initialise 0MQ infrastructure and connect to the chatroom.
|
// Initialise 0MQ infrastructure and connect to the chatroom.
|
||||||
zs::context_t ctx (1, 1);
|
zmq::context_t ctx (1, 1);
|
||||||
zs::socket_t s (ctx, ZS_PUB);
|
zmq::socket_t s (ctx, ZMQ_PUB);
|
||||||
s.connect (chatroom_in_address);
|
s.connect (chatroom_in_address);
|
||||||
|
|
||||||
while (true) {
|
while (true) {
|
||||||
@ -52,7 +52,7 @@ int main (int argc, const char *argv [])
|
|||||||
text = text + ": " + textbuf;
|
text = text + ": " + textbuf;
|
||||||
|
|
||||||
// Create the message (terminating zero is part of the message)
|
// Create the message (terminating zero is part of the message)
|
||||||
zs::message_t message (text.size () + 1);
|
zmq::message_t message (text.size () + 1);
|
||||||
memcpy (message.data (), text.c_str (), text.size () + 1);
|
memcpy (message.data (), text.c_str (), text.size () + 1);
|
||||||
|
|
||||||
// Send the message
|
// Send the message
|
||||||
|
@ -17,8 +17,8 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZSOCKETS_H_INCLUDED__
|
#ifndef __ZMQ_H_INCLUDED__
|
||||||
#define __ZSOCKETS_H_INCLUDED__
|
#define __ZMQ_H_INCLUDED__
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C" {
|
extern "C" {
|
||||||
@ -27,75 +27,75 @@ extern "C" {
|
|||||||
#include <stddef.h>
|
#include <stddef.h>
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
|
|
||||||
#if defined MSC_VER && defined ZS_BUILDING_LIBZS
|
#if defined MSC_VER && defined ZMQ_BUILDING_LIBZMQ
|
||||||
#define ZS_EXPORT __declspec(dllexport)
|
#define ZMQ_EXPORT __declspec(dllexport)
|
||||||
#else
|
#else
|
||||||
#define ZS_EXPORT
|
#define ZMQ_EXPORT
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Maximal size of "Very Small Message". VSMs are passed by value
|
// Maximal size of "Very Small Message". VSMs are passed by value
|
||||||
// to avoid excessive memory allocation/deallocation.
|
// to avoid excessive memory allocation/deallocation.
|
||||||
#define ZS_MAX_VSM_SIZE 30
|
#define ZMQ_MAX_VSM_SIZE 30
|
||||||
|
|
||||||
// Message & notification types.
|
// Message & notification types.
|
||||||
#define ZS_GAP 1
|
#define ZMQ_GAP 1
|
||||||
#define ZS_DELIMITER 31
|
#define ZMQ_DELIMITER 31
|
||||||
#define ZS_VSM 32
|
#define ZMQ_VSM 32
|
||||||
|
|
||||||
// The operation should be performed in non-blocking mode. I.e. if it cannot
|
// The operation should be performed in non-blocking mode. I.e. if it cannot
|
||||||
// be processed immediately, error should be returned with errno set to EAGAIN.
|
// be processed immediately, error should be returned with errno set to EAGAIN.
|
||||||
#define ZS_NOBLOCK 1
|
#define ZMQ_NOBLOCK 1
|
||||||
|
|
||||||
// zs_send should not flush the message downstream immediately. Instead, it
|
// zmq_send should not flush the message downstream immediately. Instead, it
|
||||||
// should batch ZS_NOFLUSH messages and send them downstream only when zs_flush
|
// should batch ZMQ_NOFLUSH messages and send them downstream only if zmq_flush
|
||||||
// is invoked. This is an optimisation for cases where several messages are
|
// is invoked. This is an optimisation for cases where several messages are
|
||||||
// sent in a single business transaction. However, the effect is measurable
|
// sent in a single business transaction. However, the effect is measurable
|
||||||
// only in extremely high-perf scenarios (million messages a second or so).
|
// only in extremely high-perf scenarios (million messages a second or so).
|
||||||
// If that's not your case, use standard flushing send instead. See exchange
|
// If that's not your case, use standard flushing send instead. See exchange
|
||||||
// example for illustration of ZS_NOFLUSH functionality.
|
// example for illustration of ZMQ_NOFLUSH functionality.
|
||||||
#define ZS_NOFLUSH 2
|
#define ZMQ_NOFLUSH 2
|
||||||
|
|
||||||
// Socket to communicate with a single peer. Allows for a singe connect or a
|
// Socket to communicate with a single peer. Allows for a singe connect or a
|
||||||
// single accept. There's no message routing or message filtering involved.
|
// single accept. There's no message routing or message filtering involved.
|
||||||
#define ZS_P2P 0
|
#define ZMQ_P2P 0
|
||||||
|
|
||||||
// Socket to distribute data. Recv fuction is not implemeted for this socket
|
// Socket to distribute data. Recv fuction is not implemeted for this socket
|
||||||
// type. Messages are distributed in fanout fashion to all peers.
|
// type. Messages are distributed in fanout fashion to all peers.
|
||||||
#define ZS_PUB 1
|
#define ZMQ_PUB 1
|
||||||
|
|
||||||
// Socket to subscribe to distributed data. Send function is not implemented
|
// Socket to subscribe to distributed data. Send function is not implemented
|
||||||
// for this socket type. However, subscribe function can be used to modify the
|
// for this socket type. However, subscribe function can be used to modify the
|
||||||
// message filter.
|
// message filter.
|
||||||
#define ZS_SUB 2
|
#define ZMQ_SUB 2
|
||||||
|
|
||||||
// Socket to send requests on and receive replies from. Requests are
|
// Socket to send requests on and receive replies from. Requests are
|
||||||
// load-balanced among all the peers. This socket type doesn't allow for more
|
// load-balanced among all the peers. This socket type doesn't allow for more
|
||||||
// recv's that there were send's.
|
// recv's that there were send's.
|
||||||
#define ZS_REQ 3
|
#define ZMQ_REQ 3
|
||||||
|
|
||||||
// Socket to receive requests from and send replies to. This socket type allows
|
// Socket to receive requests from and send replies to. This socket type allows
|
||||||
// only an alternated sequence of recv's and send's. Each send is routed to
|
// only an alternated sequence of recv's and send's. Each send is routed to
|
||||||
// the peer that the previous recv delivered message from.
|
// the peer that the previous recv delivered message from.
|
||||||
#define ZS_REP 4
|
#define ZMQ_REP 4
|
||||||
|
|
||||||
// Prototype for the message body deallocation functions.
|
// Prototype for the message body deallocation functions.
|
||||||
// It is deliberately defined in the way to comply with standard C free.
|
// It is deliberately defined in the way to comply with standard C free.
|
||||||
typedef void (zs_free_fn) (void *data);
|
typedef void (zmq_free_fn) (void *data);
|
||||||
|
|
||||||
// A message. If 'shared' is true, message content pointed to by 'content'
|
// A message. If 'shared' is true, message content pointed to by 'content'
|
||||||
// is shared, i.e. reference counting is used to manage its lifetime
|
// is shared, i.e. reference counting is used to manage its lifetime
|
||||||
// rather than straighforward malloc/free. struct zs_msg_content is
|
// rather than straighforward malloc/free. struct zmq_msg_content is
|
||||||
// not declared in the API.
|
// not declared in the API.
|
||||||
struct zs_msg
|
struct zmq_msg
|
||||||
{
|
{
|
||||||
struct zs_msg_content *content;
|
struct zmq_msg_content *content;
|
||||||
unsigned char shared;
|
unsigned char shared;
|
||||||
uint16_t vsm_size;
|
uint16_t vsm_size;
|
||||||
unsigned char vsm_data [ZS_MAX_VSM_SIZE];
|
unsigned char vsm_data [ZMQ_MAX_VSM_SIZE];
|
||||||
};
|
};
|
||||||
|
|
||||||
// TODO: Different options...
|
// TODO: Different options...
|
||||||
struct zs_opts
|
struct zmq_opts
|
||||||
{
|
{
|
||||||
uint64_t hwm;
|
uint64_t hwm;
|
||||||
uint64_t lwm;
|
uint64_t lwm;
|
||||||
@ -107,41 +107,41 @@ struct zs_opts
|
|||||||
};
|
};
|
||||||
|
|
||||||
// Initialise an empty message (zero bytes long).
|
// Initialise an empty message (zero bytes long).
|
||||||
ZS_EXPORT int zs_msg_init (zs_msg *msg);
|
ZMQ_EXPORT int zmq_msg_init (zmq_msg *msg);
|
||||||
|
|
||||||
// Initialise a message 'size' bytes long.
|
// Initialise a message 'size' bytes long.
|
||||||
//
|
//
|
||||||
// Errors: ENOMEM - the size is too large to allocate.
|
// Errors: ENOMEM - the size is too large to allocate.
|
||||||
ZS_EXPORT int zs_msg_init_size (zs_msg *msg, size_t size);
|
ZMQ_EXPORT int zmq_msg_init_size (zmq_msg *msg, size_t size);
|
||||||
|
|
||||||
// Initialise a message from an existing buffer. Message isn't copied,
|
// Initialise a message from an existing buffer. Message isn't copied,
|
||||||
// instead 0SOCKETS infrastructure take ownership of the buffer and call
|
// instead 0SOCKETS infrastructure take ownership of the buffer and call
|
||||||
// deallocation functio (ffn) once it's not needed anymore.
|
// deallocation functio (ffn) once it's not needed anymore.
|
||||||
ZS_EXPORT int zs_msg_init_data (zs_msg *msg, void *data, size_t size,
|
ZMQ_EXPORT int zmq_msg_init_data (zmq_msg *msg, void *data, size_t size,
|
||||||
zs_free_fn *ffn);
|
zmq_free_fn *ffn);
|
||||||
|
|
||||||
// Deallocate the message.
|
// Deallocate the message.
|
||||||
ZS_EXPORT int zs_msg_close (zs_msg *msg);
|
ZMQ_EXPORT int zmq_msg_close (zmq_msg *msg);
|
||||||
|
|
||||||
// Move the content of the message from 'src' to 'dest'. The content isn't
|
// Move the content of the message from 'src' to 'dest'. The content isn't
|
||||||
// copied, just moved. 'src' is an empty message after the call. Original
|
// copied, just moved. 'src' is an empty message after the call. Original
|
||||||
// content of 'dest' message is deallocated.
|
// content of 'dest' message is deallocated.
|
||||||
ZS_EXPORT int zs_msg_move (zs_msg *dest, zs_msg *src);
|
ZMQ_EXPORT int zmq_msg_move (zmq_msg *dest, zmq_msg *src);
|
||||||
|
|
||||||
// Copy the 'src' message to 'dest'. The content isn't copied, instead
|
// Copy the 'src' message to 'dest'. The content isn't copied, instead
|
||||||
// reference count is increased. Don't modify the message data after the
|
// reference count is increased. Don't modify the message data after the
|
||||||
// call as they are shared between two messages. Original content of 'dest'
|
// call as they are shared between two messages. Original content of 'dest'
|
||||||
// message is deallocated.
|
// message is deallocated.
|
||||||
ZS_EXPORT int zs_msg_copy (zs_msg *dest, zs_msg *src);
|
ZMQ_EXPORT int zmq_msg_copy (zmq_msg *dest, zmq_msg *src);
|
||||||
|
|
||||||
// Returns pointer to message data.
|
// Returns pointer to message data.
|
||||||
ZS_EXPORT void *zs_msg_data (zs_msg *msg);
|
ZMQ_EXPORT void *zmq_msg_data (zmq_msg *msg);
|
||||||
|
|
||||||
// Return size of message data (in bytes).
|
// Return size of message data (in bytes).
|
||||||
ZS_EXPORT size_t zs_msg_size (zs_msg *msg);
|
ZMQ_EXPORT size_t zmq_msg_size (zmq_msg *msg);
|
||||||
|
|
||||||
// Returns type of the message.
|
// Returns type of the message.
|
||||||
ZS_EXPORT int zs_msg_type (zs_msg *msg);
|
ZMQ_EXPORT int zmq_msg_type (zmq_msg *msg);
|
||||||
|
|
||||||
// Initialise 0SOCKETS context. 'app_threads' specifies maximal number
|
// Initialise 0SOCKETS context. 'app_threads' specifies maximal number
|
||||||
// of application threads that can have open sockets at the same time.
|
// of application threads that can have open sockets at the same time.
|
||||||
@ -149,55 +149,56 @@ ZS_EXPORT int zs_msg_type (zs_msg *msg);
|
|||||||
//
|
//
|
||||||
// Errors: EINVAL - one of the arguments is less than zero or there are no
|
// Errors: EINVAL - one of the arguments is less than zero or there are no
|
||||||
// threads declared at all.
|
// threads declared at all.
|
||||||
ZS_EXPORT void *zs_init (int app_threads, int io_threads);
|
ZMQ_EXPORT void *zmq_init (int app_threads, int io_threads);
|
||||||
|
|
||||||
// Deinitialise 0SOCKETS context including all the open sockets. Closing
|
// Deinitialise 0SOCKETS context including all the open sockets. Closing
|
||||||
// sockets after zs_term has been called will result in undefined behaviour.
|
// sockets after zmq_term has been called will result in undefined behaviour.
|
||||||
ZS_EXPORT int zs_term (void *context);
|
ZMQ_EXPORT int zmq_term (void *context);
|
||||||
|
|
||||||
// Open a socket.
|
// Open a socket.
|
||||||
//
|
//
|
||||||
// Errors: EINVAL - invalid socket type.
|
// Errors: EINVAL - invalid socket type.
|
||||||
// EMFILE - the number of application threads entitled to hold open
|
// EMFILE - the number of application threads entitled to hold open
|
||||||
// sockets at the same time was exceeded.
|
// sockets at the same time was exceeded.
|
||||||
ZS_EXPORT void *zs_socket (void *context, int type);
|
ZMQ_EXPORT void *zmq_socket (void *context, int type);
|
||||||
|
|
||||||
// Close the socket.
|
// Close the socket.
|
||||||
ZS_EXPORT int zs_close (void *s);
|
ZMQ_EXPORT int zmq_close (void *s);
|
||||||
|
|
||||||
// Bind the socket to a particular address.
|
// Bind the socket to a particular address.
|
||||||
ZS_EXPORT int zs_bind (void *s, const char *addr, zs_opts *opts);
|
ZMQ_EXPORT int zmq_bind (void *s, const char *addr, zmq_opts *opts);
|
||||||
|
|
||||||
// Connect the socket to a particular address.
|
// Connect the socket to a particular address.
|
||||||
ZS_EXPORT int zs_connect (void *s, const char *addr, zs_opts *opts);
|
ZMQ_EXPORT int zmq_connect (void *s, const char *addr, zmq_opts *opts);
|
||||||
|
|
||||||
// Subscribe for the subset of messages identified by 'criteria' argument.
|
// Subscribe for the subset of messages identified by 'criteria' argument.
|
||||||
ZS_EXPORT int zs_subscribe (void *s, const char *criteria);
|
ZMQ_EXPORT int zmq_subscribe (void *s, const char *criteria);
|
||||||
|
|
||||||
// Send the message 'msg' to the socket 's'. 'flags' argument can be
|
// Send the message 'msg' to the socket 's'. 'flags' argument can be
|
||||||
// combination of following values:
|
// combination of following values:
|
||||||
// ZS_NOBLOCK - if message cannot be sent, return immediately.
|
// ZMQ_NOBLOCK - if message cannot be sent, return immediately.
|
||||||
// ZS_NOFLUSH - message won't be sent immediately. It'll be sent with either
|
// ZMQ_NOFLUSH - message won't be sent immediately. It'll be sent with either
|
||||||
// subsequent flushing send or explicit call to zs_flush function.
|
// subsequent flushing send or explicit call to zmq_flush
|
||||||
|
// function.
|
||||||
//
|
//
|
||||||
// Errors: EAGAIN - message cannot be sent at the moment (applies only to
|
// Errors: EAGAIN - message cannot be sent at the moment (applies only to
|
||||||
// non-blocking send).
|
// non-blocking send).
|
||||||
// ENOTSUP - function isn't supported by particular socket type.
|
// ENOTSUP - function isn't supported by particular socket type.
|
||||||
ZS_EXPORT int zs_send (void *s, zs_msg *msg, int flags);
|
ZMQ_EXPORT int zmq_send (void *s, zmq_msg *msg, int flags);
|
||||||
|
|
||||||
// Flush the messages that were send using ZS_NOFLUSH flag down the stream.
|
// Flush the messages that were send using ZMQ_NOFLUSH flag down the stream.
|
||||||
//
|
//
|
||||||
// Errors: ENOTSUP - function isn't supported by particular socket type.
|
// Errors: ENOTSUP - function isn't supported by particular socket type.
|
||||||
ZS_EXPORT int zs_flush (void *s);
|
ZMQ_EXPORT int zmq_flush (void *s);
|
||||||
|
|
||||||
// Send a message from the socket 's'. 'flags' argument can be combination
|
// Send a message from the socket 's'. 'flags' argument can be combination
|
||||||
// of following values:
|
// of following values:
|
||||||
// ZS_NOBLOCK - if message cannot be received, return immediately.
|
// ZMQ_NOBLOCK - if message cannot be received, return immediately.
|
||||||
//
|
//
|
||||||
// Errors: EAGAIN - message cannot be received at the moment (applies only to
|
// Errors: EAGAIN - message cannot be received at the moment (applies only to
|
||||||
// non-blocking receive).
|
// non-blocking receive).
|
||||||
// ENOTSUP - function isn't supported by particular socket type.
|
// ENOTSUP - function isn't supported by particular socket type.
|
||||||
ZS_EXPORT int zs_recv (void *s, zs_msg *msg, int flags);
|
ZMQ_EXPORT int zmq_recv (void *s, zmq_msg *msg, int flags);
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
@ -17,30 +17,30 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZSOCKETS_HPP_INCLUDED__
|
#ifndef __ZMQ_HPP_INCLUDED__
|
||||||
#define __ZSOCKETS_HPP_INCLUDED__
|
#define __ZMQ_HPP_INCLUDED__
|
||||||
|
|
||||||
#include "zs.h"
|
#include "zmq.h"
|
||||||
|
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
typedef zs_free_fn free_fn;
|
typedef zmq_free_fn free_fn;
|
||||||
|
|
||||||
enum message_type_t
|
enum message_type_t
|
||||||
{
|
{
|
||||||
message_data = 1 << 0,
|
message_data = 1 << 0,
|
||||||
message_gap = 1 << ZS_GAP,
|
message_gap = 1 << ZMQ_GAP,
|
||||||
message_delimiter = 1 << ZS_DELIMITER
|
message_delimiter = 1 << ZMQ_DELIMITER
|
||||||
};
|
};
|
||||||
|
|
||||||
// A message. Caution: Don't change the body of the message once you've
|
// A message. Caution: Don't change the body of the message once you've
|
||||||
// copied it - the behaviour is undefined. Don't change the body of the
|
// copied it - the behaviour is undefined. Don't change the body of the
|
||||||
// received message either - other threads may be accessing it in parallel.
|
// received message either - other threads may be accessing it in parallel.
|
||||||
|
|
||||||
class message_t : private zs_msg
|
class message_t : private zmq_msg
|
||||||
{
|
{
|
||||||
friend class socket_t;
|
friend class socket_t;
|
||||||
|
|
||||||
@ -49,7 +49,7 @@ namespace zs
|
|||||||
// Creates message size_ bytes long.
|
// Creates message size_ bytes long.
|
||||||
inline message_t (size_t size_ = 0)
|
inline message_t (size_t size_ = 0)
|
||||||
{
|
{
|
||||||
int rc = zs_msg_init_size (this, size_);
|
int rc = zmq_msg_init_size (this, size_);
|
||||||
assert (rc == 0);
|
assert (rc == 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -60,14 +60,14 @@ namespace zs
|
|||||||
inline message_t (void *data_, size_t size_,
|
inline message_t (void *data_, size_t size_,
|
||||||
free_fn *ffn_)
|
free_fn *ffn_)
|
||||||
{
|
{
|
||||||
int rc = zs_msg_init_data (this, data_, size_, ffn_);
|
int rc = zmq_msg_init_data (this, data_, size_, ffn_);
|
||||||
assert (rc == 0);
|
assert (rc == 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Destroys the message.
|
// Destroys the message.
|
||||||
inline ~message_t ()
|
inline ~message_t ()
|
||||||
{
|
{
|
||||||
int rc = zs_msg_close (this);
|
int rc = zmq_msg_close (this);
|
||||||
assert (rc == 0);
|
assert (rc == 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -76,9 +76,9 @@ namespace zs
|
|||||||
// to reuse once-allocated message for multiple times.
|
// to reuse once-allocated message for multiple times.
|
||||||
inline void rebuild (size_t size_)
|
inline void rebuild (size_t size_)
|
||||||
{
|
{
|
||||||
int rc = zs_msg_close (this);
|
int rc = zmq_msg_close (this);
|
||||||
assert (rc == 0);
|
assert (rc == 0);
|
||||||
rc = zs_msg_init_size (this, size_);
|
rc = zmq_msg_init_size (this, size_);
|
||||||
assert (rc == 0);
|
assert (rc == 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -87,9 +87,9 @@ namespace zs
|
|||||||
// deallocation mechanism.
|
// deallocation mechanism.
|
||||||
inline void rebuild (void *data_, size_t size_, free_fn *ffn_)
|
inline void rebuild (void *data_, size_t size_, free_fn *ffn_)
|
||||||
{
|
{
|
||||||
int rc = zs_msg_close (this);
|
int rc = zmq_msg_close (this);
|
||||||
assert (rc == 0);
|
assert (rc == 0);
|
||||||
rc = zs_msg_init_data (this, data_, size_, ffn_);
|
rc = zmq_msg_init_data (this, data_, size_, ffn_);
|
||||||
assert (rc == 0);
|
assert (rc == 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -99,7 +99,7 @@ namespace zs
|
|||||||
// of data after the operation.
|
// of data after the operation.
|
||||||
inline void move_to (message_t *msg_)
|
inline void move_to (message_t *msg_)
|
||||||
{
|
{
|
||||||
int rc = zs_msg_move (this, (zs_msg*) msg_);
|
int rc = zmq_msg_move (this, (zmq_msg*) msg_);
|
||||||
assert (rc == 0);
|
assert (rc == 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -108,26 +108,26 @@ namespace zs
|
|||||||
// these get deallocated.
|
// these get deallocated.
|
||||||
inline void copy_to (message_t *msg_)
|
inline void copy_to (message_t *msg_)
|
||||||
{
|
{
|
||||||
int rc = zs_msg_copy (this, (zs_msg*) msg_);
|
int rc = zmq_msg_copy (this, (zmq_msg*) msg_);
|
||||||
assert (rc == 0);
|
assert (rc == 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Returns message type.
|
// Returns message type.
|
||||||
inline message_type_t type ()
|
inline message_type_t type ()
|
||||||
{
|
{
|
||||||
return (message_type_t) (1 << zs_msg_type (this));
|
return (message_type_t) (1 << zmq_msg_type (this));
|
||||||
}
|
}
|
||||||
|
|
||||||
// Returns pointer to message's data buffer.
|
// Returns pointer to message's data buffer.
|
||||||
inline void *data ()
|
inline void *data ()
|
||||||
{
|
{
|
||||||
return zs_msg_data (this);
|
return zmq_msg_data (this);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Returns the size of message data buffer.
|
// Returns the size of message data buffer.
|
||||||
inline size_t size ()
|
inline size_t size ()
|
||||||
{
|
{
|
||||||
return zs_msg_size (this);
|
return zmq_msg_size (this);
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
@ -146,13 +146,13 @@ namespace zs
|
|||||||
|
|
||||||
inline context_t (int app_threads_, int io_threads_)
|
inline context_t (int app_threads_, int io_threads_)
|
||||||
{
|
{
|
||||||
ptr = zs_init (app_threads_, io_threads_);
|
ptr = zmq_init (app_threads_, io_threads_);
|
||||||
assert (ptr);
|
assert (ptr);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline ~context_t ()
|
inline ~context_t ()
|
||||||
{
|
{
|
||||||
int rc = zs_term (ptr);
|
int rc = zmq_term (ptr);
|
||||||
assert (rc == 0);
|
assert (rc == 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -171,49 +171,49 @@ namespace zs
|
|||||||
|
|
||||||
inline socket_t (context_t &context_, int type_ = 0)
|
inline socket_t (context_t &context_, int type_ = 0)
|
||||||
{
|
{
|
||||||
ptr = zs_socket (context_.ptr, type_);
|
ptr = zmq_socket (context_.ptr, type_);
|
||||||
assert (ptr);
|
assert (ptr);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline ~socket_t ()
|
inline ~socket_t ()
|
||||||
{
|
{
|
||||||
int rc = zs_close (ptr);
|
int rc = zmq_close (ptr);
|
||||||
assert (rc == 0);
|
assert (rc == 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void bind (const char *addr_, zs_opts *opts_ = NULL)
|
inline void bind (const char *addr_, zmq_opts *opts_ = NULL)
|
||||||
{
|
{
|
||||||
int rc = zs_bind (ptr, addr_, opts_);
|
int rc = zmq_bind (ptr, addr_, opts_);
|
||||||
assert (rc == 0);
|
assert (rc == 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void connect (const char *addr_, zs_opts *opts_ = NULL)
|
inline void connect (const char *addr_, zmq_opts *opts_ = NULL)
|
||||||
{
|
{
|
||||||
int rc = zs_connect (ptr, addr_, opts_);
|
int rc = zmq_connect (ptr, addr_, opts_);
|
||||||
assert (rc == 0);
|
assert (rc == 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void subscribe (const char *criteria_)
|
inline void subscribe (const char *criteria_)
|
||||||
{
|
{
|
||||||
int rc = zs_subscribe (ptr, criteria_);
|
int rc = zmq_subscribe (ptr, criteria_);
|
||||||
assert (rc == 0);
|
assert (rc == 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void send (message_t &msg_, int flags_ = 0)
|
inline void send (message_t &msg_, int flags_ = 0)
|
||||||
{
|
{
|
||||||
int rc = zs_send (ptr, &msg_, flags_);
|
int rc = zmq_send (ptr, &msg_, flags_);
|
||||||
assert (rc == 0);
|
assert (rc == 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void flush ()
|
inline void flush ()
|
||||||
{
|
{
|
||||||
int rc = zs_flush (ptr);
|
int rc = zmq_flush (ptr);
|
||||||
assert (rc == 0);
|
assert (rc == 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void recv (message_t *msg_, int flags_ = 0)
|
inline void recv (message_t *msg_, int flags_ = 0)
|
||||||
{
|
{
|
||||||
int rc = zs_recv (ptr, msg_, flags_);
|
int rc = zmq_recv (ptr, msg_, flags_);
|
||||||
assert (rc == 0);
|
assert (rc == 0);
|
||||||
}
|
}
|
||||||
|
|
@ -1,6 +1,6 @@
|
|||||||
lib_LTLIBRARIES = libzs.la
|
lib_LTLIBRARIES = libzmq.la
|
||||||
|
|
||||||
libzs_la_SOURCES = \
|
libzmq_la_SOURCES = \
|
||||||
app_thread.hpp \
|
app_thread.hpp \
|
||||||
atomic_bitmap.hpp \
|
atomic_bitmap.hpp \
|
||||||
atomic_counter.hpp \
|
atomic_counter.hpp \
|
||||||
@ -109,10 +109,10 @@ libzs_la_SOURCES = \
|
|||||||
zmq_decoder.cpp \
|
zmq_decoder.cpp \
|
||||||
zmq_encoder.cpp \
|
zmq_encoder.cpp \
|
||||||
zmq_tcp_engine.cpp \
|
zmq_tcp_engine.cpp \
|
||||||
zs.cpp
|
zmq.cpp
|
||||||
|
|
||||||
libzs_la_LDFLAGS = -version-info 0:0:0
|
libzmq_la_LDFLAGS = -version-info 0:0:0
|
||||||
libzs_la_CXXFLAGS = -Wall -pedantic -Werror @ZS_EXTRA_CXXFLAGS@
|
libzmq_la_CXXFLAGS = -Wall -pedantic -Werror @ZMQ_EXTRA_CXXFLAGS@
|
||||||
|
|
||||||
dist-hook:
|
dist-hook:
|
||||||
-rm $(distdir)/src/platform.hpp
|
-rm $(distdir)/src/platform.hpp
|
||||||
|
@ -17,9 +17,9 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "../include/zs.h"
|
#include "../include/zmq.h"
|
||||||
|
|
||||||
#if defined ZS_HAVE_WINDOWS
|
#if defined ZMQ_HAVE_WINDOWS
|
||||||
#include "windows.hpp"
|
#include "windows.hpp"
|
||||||
#else
|
#else
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
@ -48,17 +48,17 @@
|
|||||||
// system with x86 architecture and gcc or MSVC compiler.
|
// system with x86 architecture and gcc or MSVC compiler.
|
||||||
#if (defined __GNUC__ && (defined __i386__ || defined __x86_64__)) ||\
|
#if (defined __GNUC__ && (defined __i386__ || defined __x86_64__)) ||\
|
||||||
(defined _MSC_VER && (defined _M_IX86 || defined _M_X64))
|
(defined _MSC_VER && (defined _M_IX86 || defined _M_X64))
|
||||||
#define ZS_DELAY_COMMANDS
|
#define ZMQ_DELAY_COMMANDS
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
zs::app_thread_t::app_thread_t (dispatcher_t *dispatcher_, int thread_slot_) :
|
zmq::app_thread_t::app_thread_t (dispatcher_t *dispatcher_, int thread_slot_) :
|
||||||
object_t (dispatcher_, thread_slot_),
|
object_t (dispatcher_, thread_slot_),
|
||||||
tid (0),
|
tid (0),
|
||||||
last_processing_time (0)
|
last_processing_time (0)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::app_thread_t::shutdown ()
|
void zmq::app_thread_t::shutdown ()
|
||||||
{
|
{
|
||||||
// Deallocate all the sessions associated with the thread.
|
// Deallocate all the sessions associated with the thread.
|
||||||
while (!sessions.empty ())
|
while (!sessions.empty ())
|
||||||
@ -67,17 +67,17 @@ void zs::app_thread_t::shutdown ()
|
|||||||
delete this;
|
delete this;
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::app_thread_t::~app_thread_t ()
|
zmq::app_thread_t::~app_thread_t ()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::app_thread_t::attach_session (session_t *session_)
|
void zmq::app_thread_t::attach_session (session_t *session_)
|
||||||
{
|
{
|
||||||
session_->set_index (sessions.size ());
|
session_->set_index (sessions.size ());
|
||||||
sessions.push_back (session_);
|
sessions.push_back (session_);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::app_thread_t::detach_session (session_t *session_)
|
void zmq::app_thread_t::detach_session (session_t *session_)
|
||||||
{
|
{
|
||||||
// O(1) removal of the session from the list.
|
// O(1) removal of the session from the list.
|
||||||
sessions_t::size_type i = session_->get_index ();
|
sessions_t::size_type i = session_->get_index ();
|
||||||
@ -86,22 +86,22 @@ void zs::app_thread_t::detach_session (session_t *session_)
|
|||||||
sessions.pop_back ();
|
sessions.pop_back ();
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::i_poller *zs::app_thread_t::get_poller ()
|
zmq::i_poller *zmq::app_thread_t::get_poller ()
|
||||||
{
|
{
|
||||||
zs_assert (false);
|
zmq_assert (false);
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::i_signaler *zs::app_thread_t::get_signaler ()
|
zmq::i_signaler *zmq::app_thread_t::get_signaler ()
|
||||||
{
|
{
|
||||||
return &pollset;
|
return &pollset;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool zs::app_thread_t::is_current ()
|
bool zmq::app_thread_t::is_current ()
|
||||||
{
|
{
|
||||||
return !sessions.empty () && tid == getpid ();
|
return !sessions.empty () && tid == getpid ();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool zs::app_thread_t::make_current ()
|
bool zmq::app_thread_t::make_current ()
|
||||||
{
|
{
|
||||||
// If there are object managed by this slot we cannot assign the slot
|
// If there are object managed by this slot we cannot assign the slot
|
||||||
// to a different thread.
|
// to a different thread.
|
||||||
@ -112,7 +112,7 @@ bool zs::app_thread_t::make_current ()
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::i_api *zs::app_thread_t::create_socket (int type_)
|
zmq::i_api *zmq::app_thread_t::create_socket (int type_)
|
||||||
{
|
{
|
||||||
i_mux *mux = NULL;
|
i_mux *mux = NULL;
|
||||||
i_demux *demux = NULL;
|
i_demux *demux = NULL;
|
||||||
@ -120,43 +120,43 @@ zs::i_api *zs::app_thread_t::create_socket (int type_)
|
|||||||
i_api *api = NULL;
|
i_api *api = NULL;
|
||||||
|
|
||||||
switch (type_) {
|
switch (type_) {
|
||||||
case ZS_P2P:
|
case ZMQ_P2P:
|
||||||
mux = new dummy_aggregator_t;
|
mux = new dummy_aggregator_t;
|
||||||
zs_assert (mux);
|
zmq_assert (mux);
|
||||||
demux = new dummy_distributor_t;
|
demux = new dummy_distributor_t;
|
||||||
zs_assert (demux);
|
zmq_assert (demux);
|
||||||
session = new session_t (this, this, mux, demux, true, false);
|
session = new session_t (this, this, mux, demux, true, false);
|
||||||
zs_assert (session);
|
zmq_assert (session);
|
||||||
api = new p2p_t (this, session);
|
api = new p2p_t (this, session);
|
||||||
zs_assert (api);
|
zmq_assert (api);
|
||||||
break;
|
break;
|
||||||
case ZS_PUB:
|
case ZMQ_PUB:
|
||||||
demux = new data_distributor_t;
|
demux = new data_distributor_t;
|
||||||
zs_assert (demux);
|
zmq_assert (demux);
|
||||||
session = new session_t (this, this, mux, demux, true, false);
|
session = new session_t (this, this, mux, demux, true, false);
|
||||||
zs_assert (session);
|
zmq_assert (session);
|
||||||
api = new pub_t (this, session);
|
api = new pub_t (this, session);
|
||||||
zs_assert (api);
|
zmq_assert (api);
|
||||||
break;
|
break;
|
||||||
case ZS_SUB:
|
case ZMQ_SUB:
|
||||||
mux = new fair_aggregator_t;
|
mux = new fair_aggregator_t;
|
||||||
zs_assert (mux);
|
zmq_assert (mux);
|
||||||
session = new session_t (this, this, mux, demux, true, false);
|
session = new session_t (this, this, mux, demux, true, false);
|
||||||
zs_assert (session);
|
zmq_assert (session);
|
||||||
api = new sub_t (this, session);
|
api = new sub_t (this, session);
|
||||||
zs_assert (api);
|
zmq_assert (api);
|
||||||
break;
|
break;
|
||||||
case ZS_REQ:
|
case ZMQ_REQ:
|
||||||
// TODO
|
// TODO
|
||||||
zs_assert (false);
|
zmq_assert (false);
|
||||||
api = new req_t (this, session);
|
api = new req_t (this, session);
|
||||||
zs_assert (api);
|
zmq_assert (api);
|
||||||
break;
|
break;
|
||||||
case ZS_REP:
|
case ZMQ_REP:
|
||||||
// TODO
|
// TODO
|
||||||
zs_assert (false);
|
zmq_assert (false);
|
||||||
api = new rep_t (this, session);
|
api = new rep_t (this, session);
|
||||||
zs_assert (api);
|
zmq_assert (api);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
errno = EINVAL;
|
errno = EINVAL;
|
||||||
@ -168,14 +168,14 @@ zs::i_api *zs::app_thread_t::create_socket (int type_)
|
|||||||
return api;
|
return api;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::app_thread_t::process_commands (bool block_)
|
void zmq::app_thread_t::process_commands (bool block_)
|
||||||
{
|
{
|
||||||
ypollset_t::signals_t signals;
|
ypollset_t::signals_t signals;
|
||||||
if (block_)
|
if (block_)
|
||||||
signals = pollset.poll ();
|
signals = pollset.poll ();
|
||||||
else {
|
else {
|
||||||
|
|
||||||
#if defined ZS_DELAY_COMMANDS
|
#if defined ZMQ_DELAY_COMMANDS
|
||||||
// Optimised version of command processing - it doesn't have to check
|
// Optimised version of command processing - it doesn't have to check
|
||||||
// for incoming commands each time. It does so only if certain time
|
// for incoming commands each time. It does so only if certain time
|
||||||
// elapsed since last command processing. Command delay varies
|
// elapsed since last command processing. Command delay varies
|
||||||
|
@ -17,8 +17,8 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_APP_THREAD_HPP_INCLUDED__
|
#ifndef __ZMQ_APP_THREAD_HPP_INCLUDED__
|
||||||
#define __ZS_APP_THREAD_HPP_INCLUDED__
|
#define __ZMQ_APP_THREAD_HPP_INCLUDED__
|
||||||
|
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
@ -27,7 +27,7 @@
|
|||||||
#include "object.hpp"
|
#include "object.hpp"
|
||||||
#include "ypollset.hpp"
|
#include "ypollset.hpp"
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
class app_thread_t : public object_t, public i_thread
|
class app_thread_t : public object_t, public i_thread
|
||||||
@ -36,7 +36,7 @@ namespace zs
|
|||||||
|
|
||||||
app_thread_t (class dispatcher_t *dispatcher_, int thread_slot_);
|
app_thread_t (class dispatcher_t *dispatcher_, int thread_slot_);
|
||||||
|
|
||||||
// To be called when the whole infrastrucure is being closed (zs_term).
|
// To be called when the whole infrastrucure is being closed.
|
||||||
void shutdown ();
|
void shutdown ();
|
||||||
|
|
||||||
// Returns signaler associated with this application thread.
|
// Returns signaler associated with this application thread.
|
||||||
|
@ -17,24 +17,24 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_ATOMIC_HPP_INCLUDED__
|
#ifndef __ZMQ_ATOMIC_HPP_INCLUDED__
|
||||||
#define __ZS_ATOMIC_HPP_INCLUDED__
|
#define __ZMQ_ATOMIC_HPP_INCLUDED__
|
||||||
|
|
||||||
#include "stdint.hpp"
|
#include "stdint.hpp"
|
||||||
|
|
||||||
#if defined ZS_FORCE_MUTEXES
|
#if defined ZMQ_FORCE_MUTEXES
|
||||||
#define ZS_ATOMIC_MUTEX
|
#define ZMQ_ATOMIC_MUTEX
|
||||||
#elif (defined __i386__ || defined __x86_64__) && defined __GNUC__
|
#elif (defined __i386__ || defined __x86_64__) && defined __GNUC__
|
||||||
#define ZS_ATOMIC_X86
|
#define ZMQ_ATOMIC_X86
|
||||||
#elif defined ZMQ_HAVE_WINDOWS
|
#elif defined ZMQ_HAVE_WINDOWS
|
||||||
#define ZS_ATOMIC_WINDOWS
|
#define ZMQ_ATOMIC_WINDOWS
|
||||||
#elif defined ZMQ_HAVE_SOLARIS
|
#elif defined ZMQ_HAVE_SOLARIS
|
||||||
#define ZS_ATOMIC_SOLARIS
|
#define ZMQ_ATOMIC_SOLARIS
|
||||||
#else
|
#else
|
||||||
#define ZS_ATOMIC_MUTEX
|
#define ZMQ_ATOMIC_MUTEX
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
// Atomic assignement.
|
// Atomic assignement.
|
||||||
@ -56,11 +56,11 @@ namespace zs
|
|||||||
// Atomic addition. Returns the old value.
|
// Atomic addition. Returns the old value.
|
||||||
inline uint32_t atomic_uint32_add (volatile uint32_t *p_, uint32_t delta_)
|
inline uint32_t atomic_uint32_add (volatile uint32_t *p_, uint32_t delta_)
|
||||||
{
|
{
|
||||||
#if defined ZS_ATOMIC_WINDOWS
|
#if defined ZMQ_ATOMIC_WINDOWS
|
||||||
return InterlockedExchangeAdd ((LONG*) &value, increment_);
|
return InterlockedExchangeAdd ((LONG*) &value, increment_);
|
||||||
#elif defined ZS_ATOMIC_SOLARIS
|
#elif defined ZMQ_ATOMIC_SOLARIS
|
||||||
return atomic_add_32_nv (&value, increment_) - delta_;
|
return atomic_add_32_nv (&value, increment_) - delta_;
|
||||||
#elif defined ZS_ATOMIC_X86
|
#elif defined ZMQ_ATOMIC_X86
|
||||||
uint32_t old;
|
uint32_t old;
|
||||||
__asm__ volatile (
|
__asm__ volatile (
|
||||||
"lock; xadd %0, %1\n\t"
|
"lock; xadd %0, %1\n\t"
|
||||||
@ -80,13 +80,13 @@ namespace zs
|
|||||||
// Atomic subtraction. Returns the old value.
|
// Atomic subtraction. Returns the old value.
|
||||||
inline uint32_t atomic_uint32_sub (volatile uint32_t *p_, uint32_t delta_)
|
inline uint32_t atomic_uint32_sub (volatile uint32_t *p_, uint32_t delta_)
|
||||||
{
|
{
|
||||||
#if defined ZS_ATOMIC_WINDOWS
|
#if defined ZMQ_ATOMIC_WINDOWS
|
||||||
LONG delta = - ((LONG) delta_);
|
LONG delta = - ((LONG) delta_);
|
||||||
return InterlockedExchangeAdd ((LONG*) &value, delta);
|
return InterlockedExchangeAdd ((LONG*) &value, delta);
|
||||||
#elif defined ZS_ATOMIC_SOLARIS
|
#elif defined ZMQ_ATOMIC_SOLARIS
|
||||||
int32_t delta = - ((int32_t) delta_);
|
int32_t delta = - ((int32_t) delta_);
|
||||||
return atomic_add_32_nv (&value, delta) + delta_;
|
return atomic_add_32_nv (&value, delta) + delta_;
|
||||||
#elif defined ZS_ATOMIC_X86
|
#elif defined ZMQ_ATOMIC_X86
|
||||||
uint32_t old = -delta_;
|
uint32_t old = -delta_;
|
||||||
__asm__ volatile ("lock; xaddl %0,%1"
|
__asm__ volatile ("lock; xaddl %0,%1"
|
||||||
: "=r" (old), "=m" (*p_)
|
: "=r" (old), "=m" (*p_)
|
||||||
@ -116,11 +116,11 @@ namespace zs
|
|||||||
template <typename T>
|
template <typename T>
|
||||||
inline void *atomic_ptr_xchg (volatile T **p_, T *value_)
|
inline void *atomic_ptr_xchg (volatile T **p_, T *value_)
|
||||||
{
|
{
|
||||||
#if defined ZS_ATOMIC_WINDOWS
|
#if defined ZMQ_ATOMIC_WINDOWS
|
||||||
return InterlockedExchangePointer (p_, value_);
|
return InterlockedExchangePointer (p_, value_);
|
||||||
#elif defined ZS_ATOMIC_SOLARIS
|
#elif defined ZMQ_ATOMIC_SOLARIS
|
||||||
return atomic_swap_ptr (p_, value_);
|
return atomic_swap_ptr (p_, value_);
|
||||||
#elif defined ZS_ATOMIC_X86
|
#elif defined ZMQ_ATOMIC_X86
|
||||||
void *old;
|
void *old;
|
||||||
__asm__ volatile (
|
__asm__ volatile (
|
||||||
"lock; xchg %0, %2"
|
"lock; xchg %0, %2"
|
||||||
@ -144,11 +144,11 @@ namespace zs
|
|||||||
template <typename T>
|
template <typename T>
|
||||||
inline void *atomic_ptr_cas (volatile T **p_, T *cmp_, T *value_)
|
inline void *atomic_ptr_cas (volatile T **p_, T *cmp_, T *value_)
|
||||||
{
|
{
|
||||||
#if defined ZS_ATOMIC_WINDOWS
|
#if defined ZMQ_ATOMIC_WINDOWS
|
||||||
return InterlockedCompareExchangePointer (p_, value_, cmp_);
|
return InterlockedCompareExchangePointer (p_, value_, cmp_);
|
||||||
#elif defined ZS_ATOMIC_SOLARIS
|
#elif defined ZMQ_ATOMIC_SOLARIS
|
||||||
return atomic_cas_ptr (p_, cmp_, value_);
|
return atomic_cas_ptr (p_, cmp_, value_);
|
||||||
#elif defined ZS_ATOMIC_X86
|
#elif defined ZMQ_ATOMIC_X86
|
||||||
void *old;
|
void *old;
|
||||||
__asm__ volatile (
|
__asm__ volatile (
|
||||||
"lock; cmpxchg %2, %3"
|
"lock; cmpxchg %2, %3"
|
||||||
@ -167,7 +167,7 @@ namespace zs
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
#if defined ZS_ATOMIC_X86 && defined __x86_64__
|
#if defined ZMQ_ATOMIC_X86 && defined __x86_64__
|
||||||
typedef uint64_t atomic_bitmap_t;
|
typedef uint64_t atomic_bitmap_t;
|
||||||
#else
|
#else
|
||||||
typedef uint32_t atomic_bitmap_t;
|
typedef uint32_t atomic_bitmap_t;
|
||||||
@ -187,7 +187,7 @@ namespace zs
|
|||||||
inline bool atomic_bitmap_btsr (volatile atomic_bitmap_t *p_,
|
inline bool atomic_bitmap_btsr (volatile atomic_bitmap_t *p_,
|
||||||
int set_index_, int reset_index_)
|
int set_index_, int reset_index_)
|
||||||
{
|
{
|
||||||
#if defined ZS_ATOMIC_WINDOWS
|
#if defined ZMQ_ATOMIC_WINDOWS
|
||||||
while (true) {
|
while (true) {
|
||||||
atomic_bitmap_t oldval = *p_;
|
atomic_bitmap_t oldval = *p_;
|
||||||
atomic_bitmap_t newval = (oldval | (atomic_bitmap_t (1) <<
|
atomic_bitmap_t newval = (oldval | (atomic_bitmap_t (1) <<
|
||||||
@ -197,7 +197,7 @@ namespace zs
|
|||||||
return (oldval & (atomic_bitmap_t (1) << reset_index_)) ?
|
return (oldval & (atomic_bitmap_t (1) << reset_index_)) ?
|
||||||
true : false;
|
true : false;
|
||||||
}
|
}
|
||||||
#elif defined ZS_ATOMIC_SOLARIS
|
#elif defined ZMQ_ATOMIC_SOLARIS
|
||||||
while (true) {
|
while (true) {
|
||||||
atomic_bitmap_t oldval = *p_;
|
atomic_bitmap_t oldval = *p_;
|
||||||
atomic_bitmap_t newval = (oldval | (atomic_bitmap_t (1) <<
|
atomic_bitmap_t newval = (oldval | (atomic_bitmap_t (1) <<
|
||||||
@ -206,7 +206,7 @@ namespace zs
|
|||||||
return (oldval & (atomic_bitmap_t (1) << reset_index_)) ?
|
return (oldval & (atomic_bitmap_t (1) << reset_index_)) ?
|
||||||
true : false;
|
true : false;
|
||||||
}
|
}
|
||||||
#elif defined ZS_ATOMIC_X86
|
#elif defined ZMQ_ATOMIC_X86
|
||||||
atomic_bitmap_t oldval, dummy;
|
atomic_bitmap_t oldval, dummy;
|
||||||
__asm__ volatile (
|
__asm__ volatile (
|
||||||
"mov %0, %1\n\t"
|
"mov %0, %1\n\t"
|
||||||
@ -236,11 +236,11 @@ namespace zs
|
|||||||
inline atomic_bitmap_t atomic_bitmap_xchg (volatile atomic_bitmap_t *p_,
|
inline atomic_bitmap_t atomic_bitmap_xchg (volatile atomic_bitmap_t *p_,
|
||||||
atomic_bitmap_t newval_)
|
atomic_bitmap_t newval_)
|
||||||
{
|
{
|
||||||
#if defined ZS_ATOMIC_WINDOWS
|
#if defined ZMQ_ATOMIC_WINDOWS
|
||||||
return InterlockedExchange ((volatile LONG*) p_, newval_);
|
return InterlockedExchange ((volatile LONG*) p_, newval_);
|
||||||
#elif defined ZS_ATOMIC_SOLARIS
|
#elif defined ZMQ_ATOMIC_SOLARIS
|
||||||
return atomic_swap_32 (p_, newval_);
|
return atomic_swap_32 (p_, newval_);
|
||||||
#elif defined ZS_ATOMIC_X86
|
#elif defined ZMQ_ATOMIC_X86
|
||||||
atomic_bitmap_t oldval = newval_;
|
atomic_bitmap_t oldval = newval_;
|
||||||
__asm__ volatile (
|
__asm__ volatile (
|
||||||
"lock; xchg %0, %1"
|
"lock; xchg %0, %1"
|
||||||
@ -263,7 +263,7 @@ namespace zs
|
|||||||
inline atomic_bitmap_t atomic_bitmap_izte (volatile atomic_bitmap_t *p_,
|
inline atomic_bitmap_t atomic_bitmap_izte (volatile atomic_bitmap_t *p_,
|
||||||
atomic_bitmap_t thenval_, atomic_bitmap_t elseval_)
|
atomic_bitmap_t thenval_, atomic_bitmap_t elseval_)
|
||||||
{
|
{
|
||||||
#if defined ZS_ATOMIC_WINDOWS
|
#if defined ZMQ_ATOMIC_WINDOWS
|
||||||
while (true) {
|
while (true) {
|
||||||
atomic_bitmap_t oldval = *p_;
|
atomic_bitmap_t oldval = *p_;
|
||||||
atomic_bitmap_t newval = (oldval ? elseval_ : thenval_);
|
atomic_bitmap_t newval = (oldval ? elseval_ : thenval_);
|
||||||
@ -271,14 +271,14 @@ namespace zs
|
|||||||
oldval) == (LONG) oldval)
|
oldval) == (LONG) oldval)
|
||||||
return oldval;
|
return oldval;
|
||||||
}
|
}
|
||||||
#elif defined ZS_ATOMIC_SOLARIS
|
#elif defined ZMQ_ATOMIC_SOLARIS
|
||||||
while (true) {
|
while (true) {
|
||||||
atomic_bitmap_t oldval = *p_;
|
atomic_bitmap_t oldval = *p_;
|
||||||
atomic_bitmap_t newval = (oldval ? elseval_ : thenval_);
|
atomic_bitmap_t newval = (oldval ? elseval_ : thenval_);
|
||||||
if (atomic_cas_32 (p_, oldval, newval) == oldval)
|
if (atomic_cas_32 (p_, oldval, newval) == oldval)
|
||||||
return oldval;
|
return oldval;
|
||||||
}
|
}
|
||||||
#elif defined ZS_ATOMIC_X86
|
#elif defined ZMQ_ATOMIC_X86
|
||||||
atomic_bitmap_t oldval;
|
atomic_bitmap_t oldval;
|
||||||
atomic_bitmap_t dummy;
|
atomic_bitmap_t dummy;
|
||||||
__asm__ volatile (
|
__asm__ volatile (
|
||||||
|
@ -17,8 +17,8 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_ATOMIC_BITMAP_HPP_INCLUDED__
|
#ifndef __ZMQ_ATOMIC_BITMAP_HPP_INCLUDED__
|
||||||
#define __ZS_ATOMIC_BITMAP_HPP_INCLUDED__
|
#define __ZMQ_ATOMIC_BITMAP_HPP_INCLUDED__
|
||||||
|
|
||||||
#include "stdint.hpp"
|
#include "stdint.hpp"
|
||||||
#include "platform.hpp"
|
#include "platform.hpp"
|
||||||
@ -26,29 +26,29 @@
|
|||||||
// These are the conditions to choose between different implementations
|
// These are the conditions to choose between different implementations
|
||||||
// of atomic_bitmap.
|
// of atomic_bitmap.
|
||||||
|
|
||||||
#if defined ZS_FORCE_MUTEXES
|
#if defined ZMQ_FORCE_MUTEXES
|
||||||
#define ZS_ATOMIC_BITMAP_MUTEX
|
#define ZMQ_ATOMIC_BITMAP_MUTEX
|
||||||
#elif (defined __i386__ || defined __x86_64__) && defined __GNUC__
|
#elif (defined __i386__ || defined __x86_64__) && defined __GNUC__
|
||||||
#define ZS_ATOMIC_BITMAP_X86
|
#define ZMQ_ATOMIC_BITMAP_X86
|
||||||
#elif 0 && defined __sparc__ && defined __GNUC__
|
#elif 0 && defined __sparc__ && defined __GNUC__
|
||||||
#define ZS_ATOMIC_BITMAP_SPARC
|
#define ZMQ_ATOMIC_BITMAP_SPARC
|
||||||
#elif defined ZS_HAVE_WINDOWS
|
#elif defined ZMQ_HAVE_WINDOWS
|
||||||
#define ZS_ATOMIC_BITMAP_WINDOWS
|
#define ZMQ_ATOMIC_BITMAP_WINDOWS
|
||||||
#elif defined ZS_HAVE_SOLARIS
|
#elif defined ZMQ_HAVE_SOLARIS
|
||||||
#define ZS_ATOMIC_BITMAP_SOLARIS
|
#define ZMQ_ATOMIC_BITMAP_SOLARIS
|
||||||
#else
|
#else
|
||||||
#define ZS_ATOMIC_BITMAP_MUTEX
|
#define ZMQ_ATOMIC_BITMAP_MUTEX
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined ZS_ATOMIC_BITMAP_MUTEX
|
#if defined ZMQ_ATOMIC_BITMAP_MUTEX
|
||||||
#include "mutex.hpp"
|
#include "mutex.hpp"
|
||||||
#elif defined ZS_ATOMIC_BITMAP_WINDOWS
|
#elif defined ZMQ_ATOMIC_BITMAP_WINDOWS
|
||||||
#include "windows.hpp"
|
#include "windows.hpp"
|
||||||
#elif defined ZS_ATOMIC_BITMAP_SOLARIS
|
#elif defined ZMQ_ATOMIC_BITMAP_SOLARIS
|
||||||
#include <atomic.h>
|
#include <atomic.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
// This class encapuslates several bitwise atomic operations on unsigned
|
// This class encapuslates several bitwise atomic operations on unsigned
|
||||||
@ -79,7 +79,7 @@ namespace zs
|
|||||||
// another one. Returns the original value of the reset bit.
|
// another one. Returns the original value of the reset bit.
|
||||||
inline bool btsr (int set_index_, int reset_index_)
|
inline bool btsr (int set_index_, int reset_index_)
|
||||||
{
|
{
|
||||||
#if defined ZS_ATOMIC_BITMAP_WINDOWS
|
#if defined ZMQ_ATOMIC_BITMAP_WINDOWS
|
||||||
while (true) {
|
while (true) {
|
||||||
bitmap_t oldval = value;
|
bitmap_t oldval = value;
|
||||||
bitmap_t newval = (oldval | (bitmap_t (1) << set_index_)) &
|
bitmap_t newval = (oldval | (bitmap_t (1) << set_index_)) &
|
||||||
@ -89,7 +89,7 @@ namespace zs
|
|||||||
return (oldval & (bitmap_t (1) << reset_index_)) ?
|
return (oldval & (bitmap_t (1) << reset_index_)) ?
|
||||||
true : false;
|
true : false;
|
||||||
}
|
}
|
||||||
#elif defined ZS_ATOMIC_BITMAP_SOLARIS
|
#elif defined ZMQ_ATOMIC_BITMAP_SOLARIS
|
||||||
while (true) {
|
while (true) {
|
||||||
bitmap_t oldval = value;
|
bitmap_t oldval = value;
|
||||||
bitmap_t newval = (oldval | (bitmap_t (1) << set_index_)) &
|
bitmap_t newval = (oldval | (bitmap_t (1) << set_index_)) &
|
||||||
@ -98,7 +98,7 @@ namespace zs
|
|||||||
return (oldval & (bitmap_t (1) << reset_index_)) ?
|
return (oldval & (bitmap_t (1) << reset_index_)) ?
|
||||||
true : false;
|
true : false;
|
||||||
}
|
}
|
||||||
#elif defined ZS_ATOMIC_BITMAP_X86
|
#elif defined ZMQ_ATOMIC_BITMAP_X86
|
||||||
bitmap_t oldval, dummy;
|
bitmap_t oldval, dummy;
|
||||||
__asm__ volatile (
|
__asm__ volatile (
|
||||||
"mov %0, %1\n\t"
|
"mov %0, %1\n\t"
|
||||||
@ -112,7 +112,7 @@ namespace zs
|
|||||||
: "r" (bitmap_t(set_index_)), "r" (bitmap_t(reset_index_))
|
: "r" (bitmap_t(set_index_)), "r" (bitmap_t(reset_index_))
|
||||||
: "cc");
|
: "cc");
|
||||||
return (bool) (oldval & (bitmap_t(1) << reset_index_));
|
return (bool) (oldval & (bitmap_t(1) << reset_index_));
|
||||||
#elif defined ZS_ATOMIC_BITMAP_SPARC
|
#elif defined ZMQ_ATOMIC_BITMAP_SPARC
|
||||||
volatile bitmap_t* valptr = &value;
|
volatile bitmap_t* valptr = &value;
|
||||||
bitmap_t set_val = bitmap_t(1) << set_index_;
|
bitmap_t set_val = bitmap_t(1) << set_index_;
|
||||||
bitmap_t reset_val = ~(bitmap_t(1) << reset_index_);
|
bitmap_t reset_val = ~(bitmap_t(1) << reset_index_);
|
||||||
@ -132,7 +132,7 @@ namespace zs
|
|||||||
: "r" (valptr)
|
: "r" (valptr)
|
||||||
: "cc");
|
: "cc");
|
||||||
return oldval;
|
return oldval;
|
||||||
#elif defined ZS_ATOMIC_BITMAP_MUTEX
|
#elif defined ZMQ_ATOMIC_BITMAP_MUTEX
|
||||||
sync.lock ();
|
sync.lock ();
|
||||||
bitmap_t oldval = value;
|
bitmap_t oldval = value;
|
||||||
value = (oldval | (bitmap_t (1) << set_index_)) &
|
value = (oldval | (bitmap_t (1) << set_index_)) &
|
||||||
@ -148,18 +148,18 @@ namespace zs
|
|||||||
inline bitmap_t xchg (bitmap_t newval_)
|
inline bitmap_t xchg (bitmap_t newval_)
|
||||||
{
|
{
|
||||||
bitmap_t oldval;
|
bitmap_t oldval;
|
||||||
#if defined ZS_ATOMIC_BITMAP_WINDOWS
|
#if defined ZMQ_ATOMIC_BITMAP_WINDOWS
|
||||||
oldval = InterlockedExchange ((volatile LONG*) &value, newval_);
|
oldval = InterlockedExchange ((volatile LONG*) &value, newval_);
|
||||||
#elif defined ZS_ATOMIC_BITMAP_SOLARIS
|
#elif defined ZMQ_ATOMIC_BITMAP_SOLARIS
|
||||||
oldval = atomic_swap_32 (&value, newval_);
|
oldval = atomic_swap_32 (&value, newval_);
|
||||||
#elif defined ZS_ATOMIC_BITMAP_X86
|
#elif defined ZMQ_ATOMIC_BITMAP_X86
|
||||||
oldval = newval_;
|
oldval = newval_;
|
||||||
__asm__ volatile (
|
__asm__ volatile (
|
||||||
"lock; xchg %0, %1"
|
"lock; xchg %0, %1"
|
||||||
: "=r" (oldval)
|
: "=r" (oldval)
|
||||||
: "m" (value), "0" (oldval)
|
: "m" (value), "0" (oldval)
|
||||||
: "memory");
|
: "memory");
|
||||||
#elif defined ZS_ATOMIC_BITMAP_SPARC
|
#elif defined ZMQ_ATOMIC_BITMAP_SPARC
|
||||||
oldval = value;
|
oldval = value;
|
||||||
volatile bitmap_t* ptrin = &value;
|
volatile bitmap_t* ptrin = &value;
|
||||||
bitmap_t tmp;
|
bitmap_t tmp;
|
||||||
@ -176,7 +176,7 @@ namespace zs
|
|||||||
: "r" (ptrin)
|
: "r" (ptrin)
|
||||||
: "cc");
|
: "cc");
|
||||||
return prev;
|
return prev;
|
||||||
#elif defined ZS_ATOMIC_BITMAP_MUTEX
|
#elif defined ZMQ_ATOMIC_BITMAP_MUTEX
|
||||||
sync.lock ();
|
sync.lock ();
|
||||||
oldval = value;
|
oldval = value;
|
||||||
value = newval_;
|
value = newval_;
|
||||||
@ -193,7 +193,7 @@ namespace zs
|
|||||||
inline bitmap_t izte (bitmap_t thenval_,
|
inline bitmap_t izte (bitmap_t thenval_,
|
||||||
bitmap_t elseval_)
|
bitmap_t elseval_)
|
||||||
{
|
{
|
||||||
#if defined ZS_ATOMIC_BITMAP_WINDOWS
|
#if defined ZMQ_ATOMIC_BITMAP_WINDOWS
|
||||||
while (true) {
|
while (true) {
|
||||||
bitmap_t oldval = value;
|
bitmap_t oldval = value;
|
||||||
bitmap_t newval = oldval == 0 ? thenval_ : elseval_;
|
bitmap_t newval = oldval == 0 ? thenval_ : elseval_;
|
||||||
@ -201,14 +201,14 @@ namespace zs
|
|||||||
newval, oldval) == (LONG) oldval)
|
newval, oldval) == (LONG) oldval)
|
||||||
return oldval;
|
return oldval;
|
||||||
}
|
}
|
||||||
#elif defined ZS_ATOMIC_BITMAP_SOLARIS
|
#elif defined ZMQ_ATOMIC_BITMAP_SOLARIS
|
||||||
while (true) {
|
while (true) {
|
||||||
bitmap_t oldval = value;
|
bitmap_t oldval = value;
|
||||||
bitmap_t newval = oldval == 0 ? thenval_ : elseval_;
|
bitmap_t newval = oldval == 0 ? thenval_ : elseval_;
|
||||||
if (atomic_cas_32 (&value, oldval, newval) == oldval)
|
if (atomic_cas_32 (&value, oldval, newval) == oldval)
|
||||||
return oldval;
|
return oldval;
|
||||||
}
|
}
|
||||||
#elif defined ZS_ATOMIC_BITMAP_X86
|
#elif defined ZMQ_ATOMIC_BITMAP_X86
|
||||||
bitmap_t oldval;
|
bitmap_t oldval;
|
||||||
bitmap_t dummy;
|
bitmap_t dummy;
|
||||||
__asm__ volatile (
|
__asm__ volatile (
|
||||||
@ -225,7 +225,7 @@ namespace zs
|
|||||||
: "r" (thenval_), "r" (elseval_)
|
: "r" (thenval_), "r" (elseval_)
|
||||||
: "cc");
|
: "cc");
|
||||||
return oldval;
|
return oldval;
|
||||||
#elif defined ZS_ATOMIC_BITMAP_SPARC
|
#elif defined ZMQ_ATOMIC_BITMAP_SPARC
|
||||||
volatile bitmap_t* ptrin = &value;
|
volatile bitmap_t* ptrin = &value;
|
||||||
bitmap_t tmp;
|
bitmap_t tmp;
|
||||||
bitmap_t prev;
|
bitmap_t prev;
|
||||||
@ -242,7 +242,7 @@ namespace zs
|
|||||||
: "r" (ptrin), "r" (thenval_), "r" (elseval_)
|
: "r" (ptrin), "r" (thenval_), "r" (elseval_)
|
||||||
: "cc");
|
: "cc");
|
||||||
return prev;
|
return prev;
|
||||||
#elif defined ZS_ATOMIC_BITMAP_MUTEX
|
#elif defined ZMQ_ATOMIC_BITMAP_MUTEX
|
||||||
sync.lock ();
|
sync.lock ();
|
||||||
bitmap_t oldval = value;
|
bitmap_t oldval = value;
|
||||||
value = oldval ? elseval_ : thenval_;
|
value = oldval ? elseval_ : thenval_;
|
||||||
@ -256,7 +256,7 @@ namespace zs
|
|||||||
private:
|
private:
|
||||||
|
|
||||||
volatile bitmap_t value;
|
volatile bitmap_t value;
|
||||||
#if defined ZS_ATOMIC_BITMAP_MUTEX
|
#if defined ZMQ_ATOMIC_BITMAP_MUTEX
|
||||||
mutex_t sync;
|
mutex_t sync;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -267,20 +267,20 @@ namespace zs
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Remove macros local to this file.
|
// Remove macros local to this file.
|
||||||
#if defined ZS_ATOMIC_BITMAP_WINDOWS
|
#if defined ZMQ_ATOMIC_BITMAP_WINDOWS
|
||||||
#undef ZS_ATOMIC_BITMAP_WINDOWS
|
#undef ZMQ_ATOMIC_BITMAP_WINDOWS
|
||||||
#endif
|
#endif
|
||||||
#if defined ZS_ATOMIC_BITMAP_SOLARIS
|
#if defined ZMQ_ATOMIC_BITMAP_SOLARIS
|
||||||
#undef ZS_ATOMIC_BITMAP_SOLARIS
|
#undef ZMQ_ATOMIC_BITMAP_SOLARIS
|
||||||
#endif
|
#endif
|
||||||
#if defined ZS_ATOMIC_BITMAP_X86
|
#if defined ZMQ_ATOMIC_BITMAP_X86
|
||||||
#undef ZS_ATOMIC_BITMAP_X86
|
#undef ZMQ_ATOMIC_BITMAP_X86
|
||||||
#endif
|
#endif
|
||||||
#if defined ZS_ATOMIC_BITMAP_SPARC
|
#if defined ZMQ_ATOMIC_BITMAP_SPARC
|
||||||
#undef ZS_ATOMIC_BITMAP_SPARC
|
#undef ZMQ_ATOMIC_BITMAP_SPARC
|
||||||
#endif
|
#endif
|
||||||
#if defined ZS_ATOMIC_BITMAP_MUTEX
|
#if defined ZMQ_ATOMIC_BITMAP_MUTEX
|
||||||
#undef ZS_ATOMIC_BITMAP_MUTEX
|
#undef ZMQ_ATOMIC_BITMAP_MUTEX
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -18,35 +18,35 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
#ifndef __ZS_ATOMIC_COUNTER_HPP_INCLUDED__
|
#ifndef __ZMQ_ATOMIC_COUNTER_HPP_INCLUDED__
|
||||||
#define __ZS_ATOMIC_COUNTER_HPP_INCLUDED__
|
#define __ZMQ_ATOMIC_COUNTER_HPP_INCLUDED__
|
||||||
|
|
||||||
#include "stdint.hpp"
|
#include "stdint.hpp"
|
||||||
#include "platform.hpp"
|
#include "platform.hpp"
|
||||||
|
|
||||||
#if defined ZS_FORCE_MUTEXES
|
#if defined ZMQ_FORCE_MUTEXES
|
||||||
#define ZS_ATOMIC_COUNTER_MUTEX
|
#define ZMQ_ATOMIC_COUNTER_MUTEX
|
||||||
#elif (defined __i386__ || defined __x86_64__) && defined __GNUC__
|
#elif (defined __i386__ || defined __x86_64__) && defined __GNUC__
|
||||||
#define ZS_ATOMIC_COUNTER_X86
|
#define ZMQ_ATOMIC_COUNTER_X86
|
||||||
#elif 0 && defined __sparc__ && defined __GNUC__
|
#elif 0 && defined __sparc__ && defined __GNUC__
|
||||||
#define ZS_ATOMIC_COUNTER_SPARC
|
#define ZMQ_ATOMIC_COUNTER_SPARC
|
||||||
#elif defined ZS_HAVE_WINDOWS
|
#elif defined ZMQ_HAVE_WINDOWS
|
||||||
#define ZS_ATOMIC_COUNTER_WINDOWS
|
#define ZMQ_ATOMIC_COUNTER_WINDOWS
|
||||||
#elif defined ZS_HAVE_SOLARIS
|
#elif defined ZMQ_HAVE_SOLARIS
|
||||||
#define ZS_ATOMIC_COUNTER_SOLARIS
|
#define ZMQ_ATOMIC_COUNTER_SOLARIS
|
||||||
#else
|
#else
|
||||||
#define ZS_ATOMIC_COUNTER_MUTEX
|
#define ZMQ_ATOMIC_COUNTER_MUTEX
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined ZS_ATOMIC_COUNTER_MUTEX
|
#if defined ZMQ_ATOMIC_COUNTER_MUTEX
|
||||||
#include "mutex.hpp"
|
#include "mutex.hpp"
|
||||||
#elif defined ZS_ATOMIC_COUNTER_WINDOWS
|
#elif defined ZMQ_ATOMIC_COUNTER_WINDOWS
|
||||||
#include "windows.hpp"
|
#include "windows.hpp"
|
||||||
#elif defined ZS_ATOMIC_COUNTER_SOLARIS
|
#elif defined ZMQ_ATOMIC_COUNTER_SOLARIS
|
||||||
#include <atomic.h>
|
#include <atomic.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
// This class represents an integer that can be incremented/decremented
|
// This class represents an integer that can be incremented/decremented
|
||||||
@ -78,18 +78,18 @@ namespace zs
|
|||||||
{
|
{
|
||||||
integer_t old_value;
|
integer_t old_value;
|
||||||
|
|
||||||
#if defined ZS_ATOMIC_COUNTER_WINDOWS
|
#if defined ZMQ_ATOMIC_COUNTER_WINDOWS
|
||||||
old_value = InterlockedExchangeAdd ((LONG*) &value, increment_);
|
old_value = InterlockedExchangeAdd ((LONG*) &value, increment_);
|
||||||
#elif defined ZS_ATOMIC_COUNTER_SOLARIS
|
#elif defined ZMQ_ATOMIC_COUNTER_SOLARIS
|
||||||
integer_t new_value = atomic_add_32_nv (&value, increment_);
|
integer_t new_value = atomic_add_32_nv (&value, increment_);
|
||||||
old_value = new_value - increment_;
|
old_value = new_value - increment_;
|
||||||
#elif defined ZS_ATOMIC_COUNTER_X86
|
#elif defined ZMQ_ATOMIC_COUNTER_X86
|
||||||
__asm__ volatile (
|
__asm__ volatile (
|
||||||
"lock; xadd %0, %1 \n\t"
|
"lock; xadd %0, %1 \n\t"
|
||||||
: "=r" (old_value), "=m" (value)
|
: "=r" (old_value), "=m" (value)
|
||||||
: "0" (increment_), "m" (value)
|
: "0" (increment_), "m" (value)
|
||||||
: "cc", "memory");
|
: "cc", "memory");
|
||||||
#elif defined ZS_ATOMIC_COUNTER_SPARC
|
#elif defined ZMQ_ATOMIC_COUNTER_SPARC
|
||||||
integer_t tmp;
|
integer_t tmp;
|
||||||
__asm__ volatile (
|
__asm__ volatile (
|
||||||
"ld [%4], %0 \n\t"
|
"ld [%4], %0 \n\t"
|
||||||
@ -102,7 +102,7 @@ namespace zs
|
|||||||
: "=&r" (old_value), "=&r" (tmp), "=m" (value)
|
: "=&r" (old_value), "=&r" (tmp), "=m" (value)
|
||||||
: "r" (increment_), "r" (&value)
|
: "r" (increment_), "r" (&value)
|
||||||
: "cc", "memory");
|
: "cc", "memory");
|
||||||
#elif defined ZS_ATOMIC_COUNTER_MUTEX
|
#elif defined ZMQ_ATOMIC_COUNTER_MUTEX
|
||||||
sync.lock ();
|
sync.lock ();
|
||||||
old_value = value;
|
old_value = value;
|
||||||
value += increment_;
|
value += increment_;
|
||||||
@ -116,15 +116,15 @@ namespace zs
|
|||||||
// Atomic subtraction. Returns false if the counter drops to zero.
|
// Atomic subtraction. Returns false if the counter drops to zero.
|
||||||
inline bool sub (integer_t decrement)
|
inline bool sub (integer_t decrement)
|
||||||
{
|
{
|
||||||
#if defined ZS_ATOMIC_COUNTER_WINDOWS
|
#if defined ZMQ_ATOMIC_COUNTER_WINDOWS
|
||||||
LONG delta = - ((LONG) decrement);
|
LONG delta = - ((LONG) decrement);
|
||||||
integer_t old = InterlockedExchangeAdd ((LONG*) &value, delta);
|
integer_t old = InterlockedExchangeAdd ((LONG*) &value, delta);
|
||||||
return old - decrement != 0;
|
return old - decrement != 0;
|
||||||
#elif defined ZS_ATOMIC_COUNTER_SOLARIS
|
#elif defined ZMQ_ATOMIC_COUNTER_SOLARIS
|
||||||
int32_t delta = - ((int32_t) decrement);
|
int32_t delta = - ((int32_t) decrement);
|
||||||
integer_t nv = atomic_add_32_nv (&value, delta);
|
integer_t nv = atomic_add_32_nv (&value, delta);
|
||||||
return nv != 0;
|
return nv != 0;
|
||||||
#elif defined ZS_ATOMIC_COUNTER_X86
|
#elif defined ZMQ_ATOMIC_COUNTER_X86
|
||||||
integer_t oldval = -decrement;
|
integer_t oldval = -decrement;
|
||||||
volatile integer_t *val = &value;
|
volatile integer_t *val = &value;
|
||||||
__asm__ volatile ("lock; xaddl %0,%1"
|
__asm__ volatile ("lock; xaddl %0,%1"
|
||||||
@ -132,7 +132,7 @@ namespace zs
|
|||||||
: "0" (oldval), "m" (*val)
|
: "0" (oldval), "m" (*val)
|
||||||
: "cc");
|
: "cc");
|
||||||
return oldval != decrement;
|
return oldval != decrement;
|
||||||
#elif defined ZS_ATOMIC_COUNTER_SPARC
|
#elif defined ZMQ_ATOMIC_COUNTER_SPARC
|
||||||
volatile integer_t *val = &value;
|
volatile integer_t *val = &value;
|
||||||
integer_t tmp;
|
integer_t tmp;
|
||||||
integer_t result;
|
integer_t result;
|
||||||
@ -148,7 +148,7 @@ namespace zs
|
|||||||
: "r" (val)
|
: "r" (val)
|
||||||
: "cc");
|
: "cc");
|
||||||
return result <= decrement;
|
return result <= decrement;
|
||||||
#elif defined ZS_ATOMIC_COUNTER_MUTEX
|
#elif defined ZMQ_ATOMIC_COUNTER_MUTEX
|
||||||
sync.lock ();
|
sync.lock ();
|
||||||
value -= decrement;
|
value -= decrement;
|
||||||
bool result = value ? true : false;
|
bool result = value ? true : false;
|
||||||
@ -167,7 +167,7 @@ namespace zs
|
|||||||
private:
|
private:
|
||||||
|
|
||||||
volatile integer_t value;
|
volatile integer_t value;
|
||||||
#if defined ZS_ATOMIC_COUNTER_MUTEX
|
#if defined ZMQ_ATOMIC_COUNTER_MUTEX
|
||||||
mutex_t sync;
|
mutex_t sync;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -178,20 +178,20 @@ namespace zs
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Remove macros local to this file.
|
// Remove macros local to this file.
|
||||||
#if defined ZS_ATOMIC_COUNTER_WINDOWS
|
#if defined ZMQ_ATOMIC_COUNTER_WINDOWS
|
||||||
#undef ZS_ATOMIC_COUNTER_WINDOWS
|
#undef ZMQ_ATOMIC_COUNTER_WINDOWS
|
||||||
#endif
|
#endif
|
||||||
#if defined ZS_ATOMIC_COUNTER_SOLARIS
|
#if defined ZMQ_ATOMIC_COUNTER_SOLARIS
|
||||||
#undef ZS_ATOMIC_COUNTER_SOLARIS
|
#undef ZMQ_ATOMIC_COUNTER_SOLARIS
|
||||||
#endif
|
#endif
|
||||||
#if defined ZS_ATOMIC_COUNTER_X86
|
#if defined ZMQ_ATOMIC_COUNTER_X86
|
||||||
#undef ZS_ATOMIC_COUNTER_X86
|
#undef ZMQ_ATOMIC_COUNTER_X86
|
||||||
#endif
|
#endif
|
||||||
#if defined ZS_ATOMIC_COUNTER_SPARC
|
#if defined ZMQ_ATOMIC_COUNTER_SPARC
|
||||||
#undef ZS_ATOMIC_COUNTER_SPARC
|
#undef ZMQ_ATOMIC_COUNTER_SPARC
|
||||||
#endif
|
#endif
|
||||||
#if defined ZS_ATOMIC_COUNTER_MUTEX
|
#if defined ZMQ_ATOMIC_COUNTER_MUTEX
|
||||||
#undef ZS_ATOMIC_COUNTER_MUTEX
|
#undef ZMQ_ATOMIC_COUNTER_MUTEX
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -18,34 +18,34 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
#ifndef __ZS_ATOMIC_PTR_HPP_INCLUDED__
|
#ifndef __ZMQ_ATOMIC_PTR_HPP_INCLUDED__
|
||||||
#define __ZS_ATOMIC_PTR_HPP_INCLUDED__
|
#define __ZMQ_ATOMIC_PTR_HPP_INCLUDED__
|
||||||
|
|
||||||
#include "platform.hpp"
|
#include "platform.hpp"
|
||||||
|
|
||||||
#if defined ZS_FORCE_MUTEXES
|
#if defined ZMQ_FORCE_MUTEXES
|
||||||
#define ZS_ATOMIC_PTR_MUTEX
|
#define ZMQ_ATOMIC_PTR_MUTEX
|
||||||
#elif (defined __i386__ || defined __x86_64__) && defined __GNUC__
|
#elif (defined __i386__ || defined __x86_64__) && defined __GNUC__
|
||||||
#define ZS_ATOMIC_PTR_X86
|
#define ZMQ_ATOMIC_PTR_X86
|
||||||
#elif 0 && defined __sparc__ && defined __GNUC__
|
#elif 0 && defined __sparc__ && defined __GNUC__
|
||||||
#define ZS_ATOMIC_PTR_SPARC
|
#define ZMQ_ATOMIC_PTR_SPARC
|
||||||
#elif defined ZS_HAVE_WINDOWS
|
#elif defined ZMQ_HAVE_WINDOWS
|
||||||
#define ZS_ATOMIC_PTR_WINDOWS
|
#define ZMQ_ATOMIC_PTR_WINDOWS
|
||||||
#elif defined ZS_HAVE_SOLARIS
|
#elif defined ZMQ_HAVE_SOLARIS
|
||||||
#define ZS_ATOMIC_PTR_SOLARIS
|
#define ZMQ_ATOMIC_PTR_SOLARIS
|
||||||
#else
|
#else
|
||||||
#define ZS_ATOMIC_PTR_MUTEX
|
#define ZMQ_ATOMIC_PTR_MUTEX
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined ZS_ATOMIC_PTR_MUTEX
|
#if defined ZMQ_ATOMIC_PTR_MUTEX
|
||||||
#include "mutex.hpp"
|
#include "mutex.hpp"
|
||||||
#elif defined ZS_ATOMIC_PTR_WINDOWS
|
#elif defined ZMQ_ATOMIC_PTR_WINDOWS
|
||||||
#include "windows.hpp"
|
#include "windows.hpp"
|
||||||
#elif defined ZS_ATOMIC_PTR_SOLARIS
|
#elif defined ZMQ_ATOMIC_PTR_SOLARIS
|
||||||
#include <atomic.h>
|
#include <atomic.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
// This class encapsulates several atomic operations on pointers.
|
// This class encapsulates several atomic operations on pointers.
|
||||||
@ -77,18 +77,18 @@ namespace zs
|
|||||||
// to the 'val' value. Old value is returned.
|
// to the 'val' value. Old value is returned.
|
||||||
inline T *xchg (T *val_)
|
inline T *xchg (T *val_)
|
||||||
{
|
{
|
||||||
#if defined ZS_ATOMIC_PTR_WINDOWS
|
#if defined ZMQ_ATOMIC_PTR_WINDOWS
|
||||||
return (T*) InterlockedExchangePointer (&ptr, val_);
|
return (T*) InterlockedExchangePointer (&ptr, val_);
|
||||||
#elif defined ZS_ATOMIC_PTR_SOLARIS
|
#elif defined ZMQ_ATOMIC_PTR_SOLARIS
|
||||||
return (T*) atomic_swap_ptr (&ptr, val_);
|
return (T*) atomic_swap_ptr (&ptr, val_);
|
||||||
#elif defined ZS_ATOMIC_PTR_X86
|
#elif defined ZMQ_ATOMIC_PTR_X86
|
||||||
T *old;
|
T *old;
|
||||||
__asm__ volatile (
|
__asm__ volatile (
|
||||||
"lock; xchg %0, %2"
|
"lock; xchg %0, %2"
|
||||||
: "=r" (old), "=m" (ptr)
|
: "=r" (old), "=m" (ptr)
|
||||||
: "m" (ptr), "0" (val_));
|
: "m" (ptr), "0" (val_));
|
||||||
return old;
|
return old;
|
||||||
#elif defined ZS_ATOMIC_PTR_SPARC
|
#elif defined ZMQ_ATOMIC_PTR_SPARC
|
||||||
T* newptr = val_;
|
T* newptr = val_;
|
||||||
volatile T** ptrin = &ptr;
|
volatile T** ptrin = &ptr;
|
||||||
T* tmp;
|
T* tmp;
|
||||||
@ -105,7 +105,7 @@ namespace zs
|
|||||||
: "r" (ptrin)
|
: "r" (ptrin)
|
||||||
: "cc");
|
: "cc");
|
||||||
return prev;
|
return prev;
|
||||||
#elif defined ZS_ATOMIC_PTR_MUTEX
|
#elif defined ZMQ_ATOMIC_PTR_MUTEX
|
||||||
sync.lock ();
|
sync.lock ();
|
||||||
T *old = (T*) ptr;
|
T *old = (T*) ptr;
|
||||||
ptr = val_;
|
ptr = val_;
|
||||||
@ -122,12 +122,12 @@ namespace zs
|
|||||||
// is returned.
|
// is returned.
|
||||||
inline T *cas (T *cmp_, T *val_)
|
inline T *cas (T *cmp_, T *val_)
|
||||||
{
|
{
|
||||||
#if defined ZS_ATOMIC_PTR_WINDOWS
|
#if defined ZMQ_ATOMIC_PTR_WINDOWS
|
||||||
return (T*) InterlockedCompareExchangePointer (
|
return (T*) InterlockedCompareExchangePointer (
|
||||||
(volatile PVOID*) &ptr, val_, cmp_);
|
(volatile PVOID*) &ptr, val_, cmp_);
|
||||||
#elif defined ZS_ATOMIC_PTR_SOLARIS
|
#elif defined ZMQ_ATOMIC_PTR_SOLARIS
|
||||||
return (T*) atomic_cas_ptr (&ptr, cmp_, val_);
|
return (T*) atomic_cas_ptr (&ptr, cmp_, val_);
|
||||||
#elif defined ZS_ATOMIC_PTR_X86
|
#elif defined ZMQ_ATOMIC_PTR_X86
|
||||||
T *old;
|
T *old;
|
||||||
__asm__ volatile (
|
__asm__ volatile (
|
||||||
"lock; cmpxchg %2, %3"
|
"lock; cmpxchg %2, %3"
|
||||||
@ -135,7 +135,7 @@ namespace zs
|
|||||||
: "r" (val_), "m" (ptr), "0" (cmp_)
|
: "r" (val_), "m" (ptr), "0" (cmp_)
|
||||||
: "cc");
|
: "cc");
|
||||||
return old;
|
return old;
|
||||||
#elif defined ZS_ATOMIC_PTR_SPARC
|
#elif defined ZMQ_ATOMIC_PTR_SPARC
|
||||||
volatile T** ptrin = &ptr;
|
volatile T** ptrin = &ptr;
|
||||||
volatile T* prev = ptr;
|
volatile T* prev = ptr;
|
||||||
__asm__ __volatile__(
|
__asm__ __volatile__(
|
||||||
@ -144,7 +144,7 @@ namespace zs
|
|||||||
: "r" (cmp_), "r" (val_), "r" (ptrin)
|
: "r" (cmp_), "r" (val_), "r" (ptrin)
|
||||||
: "cc");
|
: "cc");
|
||||||
return prev;
|
return prev;
|
||||||
#elif defined ZS_ATOMIC_PTR_MUTEX
|
#elif defined ZMQ_ATOMIC_PTR_MUTEX
|
||||||
sync.lock ();
|
sync.lock ();
|
||||||
T *old = (T*) ptr;
|
T *old = (T*) ptr;
|
||||||
if (ptr == cmp_)
|
if (ptr == cmp_)
|
||||||
@ -159,7 +159,7 @@ namespace zs
|
|||||||
private:
|
private:
|
||||||
|
|
||||||
volatile T *ptr;
|
volatile T *ptr;
|
||||||
#if defined ZS_ATOMIC_PTR_MUTEX
|
#if defined ZMQ_ATOMIC_PTR_MUTEX
|
||||||
mutex_t sync;
|
mutex_t sync;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -170,20 +170,20 @@ namespace zs
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Remove macros local to this file.
|
// Remove macros local to this file.
|
||||||
#if defined ZS_ATOMIC_PTR_WINDOWS
|
#if defined ZMQ_ATOMIC_PTR_WINDOWS
|
||||||
#undef ZS_ATOMIC_PTR_WINDOWS
|
#undef ZMQ_ATOMIC_PTR_WINDOWS
|
||||||
#endif
|
#endif
|
||||||
#if defined ZS_ATOMIC_PTR_SOLARIS
|
#if defined ZMQ_ATOMIC_PTR_SOLARIS
|
||||||
#undef ZS_ATOMIC_PTR_SOLARIS
|
#undef ZMQ_ATOMIC_PTR_SOLARIS
|
||||||
#endif
|
#endif
|
||||||
#if defined ZS_ATOMIC_PTR_X86
|
#if defined ZMQ_ATOMIC_PTR_X86
|
||||||
#undef ZS_ATOMIC_PTR_X86
|
#undef ZMQ_ATOMIC_PTR_X86
|
||||||
#endif
|
#endif
|
||||||
#if defined ZS_ATOMIC_PTR_SPARC
|
#if defined ZMQ_ATOMIC_PTR_SPARC
|
||||||
#undef ZS_ATOMIC_PTR_SPARC
|
#undef ZMQ_ATOMIC_PTR_SPARC
|
||||||
#endif
|
#endif
|
||||||
#if defined ZS_ATOMIC_PTR_MUTEX
|
#if defined ZMQ_ATOMIC_PTR_MUTEX
|
||||||
#undef ZS_ATOMIC_PTR_MUTEX
|
#undef ZMQ_ATOMIC_PTR_MUTEX
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -17,12 +17,12 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_COMMAND_HPP_INCLUDED__
|
#ifndef __ZMQ_COMMAND_HPP_INCLUDED__
|
||||||
#define __ZS_COMMAND_HPP_INCLUDED__
|
#define __ZMQ_COMMAND_HPP_INCLUDED__
|
||||||
|
|
||||||
#include "stdint.hpp"
|
#include "stdint.hpp"
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
// This structure defines the commands that can be sent between threads.
|
// This structure defines the commands that can be sent between threads.
|
||||||
|
@ -17,10 +17,10 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_CONFIG_HPP_INCLUDED__
|
#ifndef __ZMQ_CONFIG_HPP_INCLUDED__
|
||||||
#define __ZS_CONFIG_HPP_INCLUDED__
|
#define __ZMQ_CONFIG_HPP_INCLUDED__
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
// Compile-time settings.
|
// Compile-time settings.
|
||||||
|
@ -24,7 +24,7 @@
|
|||||||
#include "simple_semaphore.hpp"
|
#include "simple_semaphore.hpp"
|
||||||
#include "zmq_tcp_engine.hpp"
|
#include "zmq_tcp_engine.hpp"
|
||||||
|
|
||||||
zs::connecter_t::connecter_t (io_thread_t *thread_, const char *addr_,
|
zmq::connecter_t::connecter_t (io_thread_t *thread_, const char *addr_,
|
||||||
session_t *session_) :
|
session_t *session_) :
|
||||||
io_object_t (thread_),
|
io_object_t (thread_),
|
||||||
state (idle),
|
state (idle),
|
||||||
@ -36,24 +36,24 @@ zs::connecter_t::connecter_t (io_thread_t *thread_, const char *addr_,
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::connecter_t::terminate ()
|
void zmq::connecter_t::terminate ()
|
||||||
{
|
{
|
||||||
delete this;
|
delete this;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::connecter_t::shutdown ()
|
void zmq::connecter_t::shutdown ()
|
||||||
{
|
{
|
||||||
delete this;
|
delete this;
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::connecter_t::~connecter_t ()
|
zmq::connecter_t::~connecter_t ()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::connecter_t::process_reg (simple_semaphore_t *smph_)
|
void zmq::connecter_t::process_reg (simple_semaphore_t *smph_)
|
||||||
{
|
{
|
||||||
// Fet poller pointer for further use.
|
// Fet poller pointer for further use.
|
||||||
zs_assert (!poller);
|
zmq_assert (!poller);
|
||||||
poller = get_poller ();
|
poller = get_poller ();
|
||||||
|
|
||||||
// Ask the session to register itself with the I/O thread. Note that
|
// Ask the session to register itself with the I/O thread. Note that
|
||||||
@ -71,10 +71,10 @@ void zs::connecter_t::process_reg (simple_semaphore_t *smph_)
|
|||||||
timer_event ();
|
timer_event ();
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::connecter_t::process_unreg (simple_semaphore_t *smph_)
|
void zmq::connecter_t::process_unreg (simple_semaphore_t *smph_)
|
||||||
{
|
{
|
||||||
// Unregister connecter/engine from the poller.
|
// Unregister connecter/engine from the poller.
|
||||||
zs_assert (poller);
|
zmq_assert (poller);
|
||||||
if (state == connecting)
|
if (state == connecting)
|
||||||
poller->rm_fd (handle);
|
poller->rm_fd (handle);
|
||||||
else if (state == waiting)
|
else if (state == waiting)
|
||||||
@ -87,22 +87,22 @@ void zs::connecter_t::process_unreg (simple_semaphore_t *smph_)
|
|||||||
smph_->post ();
|
smph_->post ();
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::connecter_t::in_event ()
|
void zmq::connecter_t::in_event ()
|
||||||
{
|
{
|
||||||
// Error occured in asynchronous connect. Retry to connect after a while.
|
// Error occured in asynchronous connect. Retry to connect after a while.
|
||||||
if (state == connecting) {
|
if (state == connecting) {
|
||||||
fd_t fd = tcp_connecter.connect ();
|
fd_t fd = tcp_connecter.connect ();
|
||||||
zs_assert (fd == retired_fd);
|
zmq_assert (fd == retired_fd);
|
||||||
poller->rm_fd (handle);
|
poller->rm_fd (handle);
|
||||||
poller->add_timer (this);
|
poller->add_timer (this);
|
||||||
state = waiting;
|
state = waiting;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
zs_assert (false);
|
zmq_assert (false);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::connecter_t::out_event ()
|
void zmq::connecter_t::out_event ()
|
||||||
{
|
{
|
||||||
if (state == connecting) {
|
if (state == connecting) {
|
||||||
|
|
||||||
@ -116,18 +116,18 @@ void zs::connecter_t::out_event ()
|
|||||||
|
|
||||||
poller->rm_fd (handle);
|
poller->rm_fd (handle);
|
||||||
engine = new zmq_tcp_engine_t (fd);
|
engine = new zmq_tcp_engine_t (fd);
|
||||||
zs_assert (engine);
|
zmq_assert (engine);
|
||||||
engine->attach (poller, this);
|
engine->attach (poller, this);
|
||||||
state = sending;
|
state = sending;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
zs_assert (false);
|
zmq_assert (false);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::connecter_t::timer_event ()
|
void zmq::connecter_t::timer_event ()
|
||||||
{
|
{
|
||||||
zs_assert (state == waiting);
|
zmq_assert (state == waiting);
|
||||||
|
|
||||||
// Initiate async connect and start polling for its completion. If async
|
// Initiate async connect and start polling for its completion. If async
|
||||||
// connect fails instantly, try to reconnect after a while.
|
// connect fails instantly, try to reconnect after a while.
|
||||||
@ -147,21 +147,21 @@ void zs::connecter_t::timer_event ()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::connecter_t::set_engine (struct i_engine *engine_)
|
void zmq::connecter_t::set_engine (struct i_engine *engine_)
|
||||||
{
|
{
|
||||||
engine = engine_;
|
engine = engine_;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool zs::connecter_t::read (zs_msg *msg_)
|
bool zmq::connecter_t::read (zmq_msg *msg_)
|
||||||
{
|
{
|
||||||
zs_assert (state == sending);
|
zmq_assert (state == sending);
|
||||||
|
|
||||||
// Deallocate old content of the message just in case.
|
// Deallocate old content of the message just in case.
|
||||||
zs_msg_close (msg_);
|
zmq_msg_close (msg_);
|
||||||
|
|
||||||
// Send the identity.
|
// Send the identity.
|
||||||
zs_msg_init_size (msg_, identity.size ());
|
zmq_msg_init_size (msg_, identity.size ());
|
||||||
memcpy (zs_msg_data (msg_), identity.c_str (), identity.size ());
|
memcpy (zmq_msg_data (msg_), identity.c_str (), identity.size ());
|
||||||
|
|
||||||
// Ask engine to unregister from the poller.
|
// Ask engine to unregister from the poller.
|
||||||
i_engine *e = engine;
|
i_engine *e = engine;
|
||||||
@ -177,13 +177,13 @@ bool zs::connecter_t::read (zs_msg *msg_)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool zs::connecter_t::write (struct zs_msg *msg_)
|
bool zmq::connecter_t::write (struct zmq_msg *msg_)
|
||||||
{
|
{
|
||||||
// No incoming messages are accepted till identity is sent.
|
// No incoming messages are accepted till identity is sent.
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::connecter_t::flush ()
|
void zmq::connecter_t::flush ()
|
||||||
{
|
{
|
||||||
// No incoming messages are accepted till identity is sent.
|
// No incoming messages are accepted till identity is sent.
|
||||||
}
|
}
|
||||||
|
@ -17,12 +17,12 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_CONNECTER_HPP_INCLUDED__
|
#ifndef __ZMQ_CONNECTER_HPP_INCLUDED__
|
||||||
#define __ZS_CONNECTER_HPP_INCLUDED__
|
#define __ZMQ_CONNECTER_HPP_INCLUDED__
|
||||||
|
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
#include "../include/zs.h"
|
#include "../include/zmq.h"
|
||||||
|
|
||||||
#include "i_poller.hpp"
|
#include "i_poller.hpp"
|
||||||
#include "io_object.hpp"
|
#include "io_object.hpp"
|
||||||
@ -30,7 +30,7 @@
|
|||||||
#include "i_session.hpp"
|
#include "i_session.hpp"
|
||||||
#include "tcp_connecter.hpp"
|
#include "tcp_connecter.hpp"
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
class connecter_t : public io_object_t, public i_poll_events,
|
class connecter_t : public io_object_t, public i_poll_events,
|
||||||
@ -55,8 +55,8 @@ namespace zs
|
|||||||
// i_session implementation
|
// i_session implementation
|
||||||
void set_engine (struct i_engine *engine_);
|
void set_engine (struct i_engine *engine_);
|
||||||
// void shutdown ();
|
// void shutdown ();
|
||||||
bool read (struct zs_msg *msg_);
|
bool read (struct zmq_msg *msg_);
|
||||||
bool write (struct zs_msg *msg_);
|
bool write (struct zmq_msg *msg_);
|
||||||
void flush ();
|
void flush ();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@ -17,7 +17,7 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "../include/zs.h"
|
#include "../include/zmq.h"
|
||||||
|
|
||||||
#include "data_distributor.hpp"
|
#include "data_distributor.hpp"
|
||||||
#include "pipe_writer.hpp"
|
#include "pipe_writer.hpp"
|
||||||
@ -25,25 +25,25 @@
|
|||||||
#include "session.hpp"
|
#include "session.hpp"
|
||||||
#include "msg.hpp"
|
#include "msg.hpp"
|
||||||
|
|
||||||
zs::data_distributor_t::data_distributor_t () :
|
zmq::data_distributor_t::data_distributor_t () :
|
||||||
session (NULL)
|
session (NULL)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::data_distributor_t::set_session (session_t *session_)
|
void zmq::data_distributor_t::set_session (session_t *session_)
|
||||||
{
|
{
|
||||||
zs_assert (!session);
|
zmq_assert (!session);
|
||||||
session = session_;
|
session = session_;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::data_distributor_t::shutdown ()
|
void zmq::data_distributor_t::shutdown ()
|
||||||
{
|
{
|
||||||
// No need to deallocate pipes here. They'll be deallocated during the
|
// No need to deallocate pipes here. They'll be deallocated during the
|
||||||
// shutdown of the dispatcher.
|
// shutdown of the dispatcher.
|
||||||
delete this;
|
delete this;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::data_distributor_t::terminate ()
|
void zmq::data_distributor_t::terminate ()
|
||||||
{
|
{
|
||||||
// Pipe unregisters itself during the call to terminate, so the pipes
|
// Pipe unregisters itself during the call to terminate, so the pipes
|
||||||
// list shinks by one in each iteration.
|
// list shinks by one in each iteration.
|
||||||
@ -53,11 +53,11 @@ void zs::data_distributor_t::terminate ()
|
|||||||
delete this;
|
delete this;
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::data_distributor_t::~data_distributor_t ()
|
zmq::data_distributor_t::~data_distributor_t ()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::data_distributor_t::attach_pipe (pipe_writer_t *pipe_)
|
void zmq::data_distributor_t::attach_pipe (pipe_writer_t *pipe_)
|
||||||
{
|
{
|
||||||
// Associate demux with a new pipe.
|
// Associate demux with a new pipe.
|
||||||
pipe_->set_demux (this);
|
pipe_->set_demux (this);
|
||||||
@ -65,7 +65,7 @@ void zs::data_distributor_t::attach_pipe (pipe_writer_t *pipe_)
|
|||||||
pipes.push_back (pipe_);
|
pipes.push_back (pipe_);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::data_distributor_t::detach_pipe (pipe_writer_t *pipe_)
|
void zmq::data_distributor_t::detach_pipe (pipe_writer_t *pipe_)
|
||||||
{
|
{
|
||||||
// Release the reference to the pipe.
|
// Release the reference to the pipe.
|
||||||
int index = pipe_->get_index ();
|
int index = pipe_->get_index ();
|
||||||
@ -75,19 +75,19 @@ void zs::data_distributor_t::detach_pipe (pipe_writer_t *pipe_)
|
|||||||
pipes.pop_back ();
|
pipes.pop_back ();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool zs::data_distributor_t::empty ()
|
bool zmq::data_distributor_t::empty ()
|
||||||
{
|
{
|
||||||
return pipes.empty ();
|
return pipes.empty ();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool zs::data_distributor_t::send (zs_msg *msg_)
|
bool zmq::data_distributor_t::send (zmq_msg *msg_)
|
||||||
{
|
{
|
||||||
int pipes_count = pipes.size ();
|
int pipes_count = pipes.size ();
|
||||||
|
|
||||||
// If there are no pipes available, simply drop the message.
|
// If there are no pipes available, simply drop the message.
|
||||||
if (pipes_count == 0) {
|
if (pipes_count == 0) {
|
||||||
zs_msg_close (msg_);
|
zmq_msg_close (msg_);
|
||||||
zs_msg_init (msg_);
|
zmq_msg_init (msg_);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -98,10 +98,10 @@ bool zs::data_distributor_t::send (zs_msg *msg_)
|
|||||||
// return false;
|
// return false;
|
||||||
|
|
||||||
// For VSMs the copying is straighforward.
|
// For VSMs the copying is straighforward.
|
||||||
if (msg_->content == (zs_msg_content*) ZS_VSM) {
|
if (msg_->content == (zmq_msg_content*) ZMQ_VSM) {
|
||||||
for (pipes_t::iterator it = pipes.begin (); it != pipes.end (); it ++)
|
for (pipes_t::iterator it = pipes.begin (); it != pipes.end (); it ++)
|
||||||
write_to_pipe (*it, msg_);
|
write_to_pipe (*it, msg_);
|
||||||
zs_msg_init (msg_);
|
zmq_msg_init (msg_);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -110,7 +110,7 @@ bool zs::data_distributor_t::send (zs_msg *msg_)
|
|||||||
// operations) needed.
|
// operations) needed.
|
||||||
if (pipes_count == 1) {
|
if (pipes_count == 1) {
|
||||||
write_to_pipe (*pipes.begin (), msg_);
|
write_to_pipe (*pipes.begin (), msg_);
|
||||||
zs_msg_init (msg_);
|
zmq_msg_init (msg_);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -130,12 +130,12 @@ bool zs::data_distributor_t::send (zs_msg *msg_)
|
|||||||
write_to_pipe (*it, msg_);
|
write_to_pipe (*it, msg_);
|
||||||
|
|
||||||
// Detach the original message from the data buffer.
|
// Detach the original message from the data buffer.
|
||||||
zs_msg_init (msg_);
|
zmq_msg_init (msg_);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::data_distributor_t::flush ()
|
void zmq::data_distributor_t::flush ()
|
||||||
{
|
{
|
||||||
// Flush all pipes. If there's large number of pipes, it can be pretty
|
// Flush all pipes. If there's large number of pipes, it can be pretty
|
||||||
// inefficient (especially if there's new message only in a single pipe).
|
// inefficient (especially if there's new message only in a single pipe).
|
||||||
@ -144,12 +144,12 @@ void zs::data_distributor_t::flush ()
|
|||||||
(*it)->flush ();
|
(*it)->flush ();
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::data_distributor_t::write_to_pipe (class pipe_writer_t *pipe_,
|
void zmq::data_distributor_t::write_to_pipe (class pipe_writer_t *pipe_,
|
||||||
struct zs_msg *msg_)
|
struct zmq_msg *msg_)
|
||||||
{
|
{
|
||||||
if (!pipe_->write (msg_)) {
|
if (!pipe_->write (msg_)) {
|
||||||
// TODO: Push gap notification to the pipe.
|
// TODO: Push gap notification to the pipe.
|
||||||
zs_assert (false);
|
zmq_assert (false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -17,14 +17,14 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_DATA_DISTRIBUTOR_HPP_INCLUDED__
|
#ifndef __ZMQ_DATA_DISTRIBUTOR_HPP_INCLUDED__
|
||||||
#define __ZS_DATA_DISTRIBUTOR_HPP_INCLUDED__
|
#define __ZMQ_DATA_DISTRIBUTOR_HPP_INCLUDED__
|
||||||
|
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
#include <i_demux.hpp>
|
#include <i_demux.hpp>
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
// Object to distribute messages to outbound pipes.
|
// Object to distribute messages to outbound pipes.
|
||||||
@ -42,7 +42,7 @@ namespace zs
|
|||||||
void attach_pipe (class pipe_writer_t *pipe_);
|
void attach_pipe (class pipe_writer_t *pipe_);
|
||||||
void detach_pipe (class pipe_writer_t *pipe_);
|
void detach_pipe (class pipe_writer_t *pipe_);
|
||||||
bool empty ();
|
bool empty ();
|
||||||
bool send (struct zs_msg *msg_);
|
bool send (struct zmq_msg *msg_);
|
||||||
void flush ();
|
void flush ();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
@ -55,7 +55,7 @@ namespace zs
|
|||||||
|
|
||||||
// Writes the message to the pipe if possible. If it isn't, writes
|
// Writes the message to the pipe if possible. If it isn't, writes
|
||||||
// a gap notification to the pipe.
|
// a gap notification to the pipe.
|
||||||
void write_to_pipe (class pipe_writer_t *pipe_, struct zs_msg *msg_);
|
void write_to_pipe (class pipe_writer_t *pipe_, struct zmq_msg *msg_);
|
||||||
|
|
||||||
// The list of outbound pipes.
|
// The list of outbound pipes.
|
||||||
typedef std::vector <class pipe_writer_t*> pipes_t;
|
typedef std::vector <class pipe_writer_t*> pipes_t;
|
||||||
|
@ -17,14 +17,14 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_DECODER_HPP_INCLUDED__
|
#ifndef __ZMQ_DECODER_HPP_INCLUDED__
|
||||||
#define __ZS_DECODER_HPP_INCLUDED__
|
#define __ZMQ_DECODER_HPP_INCLUDED__
|
||||||
|
|
||||||
#include <stddef.h>
|
#include <stddef.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
// Helper base class for decoders that know the amount of data to read
|
// Helper base class for decoders that know the amount of data to read
|
||||||
|
@ -19,7 +19,7 @@
|
|||||||
|
|
||||||
#include "platform.hpp"
|
#include "platform.hpp"
|
||||||
|
|
||||||
#if defined ZS_HAVE_SOLARIS || defined ZS_HAVE_HPUX
|
#if defined ZMQ_HAVE_SOLARIS || defined ZMQ_HAVE_HPUX
|
||||||
|
|
||||||
#include <sys/devpoll.h>
|
#include <sys/devpoll.h>
|
||||||
#include <sys/time.h>
|
#include <sys/time.h>
|
||||||
@ -35,7 +35,7 @@
|
|||||||
#include "err.hpp"
|
#include "err.hpp"
|
||||||
#include "config.hpp"
|
#include "config.hpp"
|
||||||
|
|
||||||
zs::devpoll_t::devpoll_t ()
|
zmq::devpoll_t::devpoll_t ()
|
||||||
{
|
{
|
||||||
// Get limit on open files
|
// Get limit on open files
|
||||||
struct rlimit rl;
|
struct rlimit rl;
|
||||||
@ -50,19 +50,19 @@ zs::devpoll_t::devpoll_t ()
|
|||||||
errno_assert (devpoll_fd != -1);
|
errno_assert (devpoll_fd != -1);
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::devpoll_t::~devpoll_t ()
|
zmq::devpoll_t::~devpoll_t ()
|
||||||
{
|
{
|
||||||
close (devpoll_fd);
|
close (devpoll_fd);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::devpoll_t::devpoll_ctl (fd_t fd_, short events_)
|
void zmq::devpoll_t::devpoll_ctl (fd_t fd_, short events_)
|
||||||
{
|
{
|
||||||
struct pollfd pfd = {fd_, events_, 0};
|
struct pollfd pfd = {fd_, events_, 0};
|
||||||
ssize_t rc = write (devpoll_fd, &pfd, sizeof pfd);
|
ssize_t rc = write (devpoll_fd, &pfd, sizeof pfd);
|
||||||
zs_assert (rc == sizeof pfd);
|
zmq_assert (rc == sizeof pfd);
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::handle_t zs::devpoll_t::add_fd (fd_t fd_, i_poll_events *reactor_)
|
zmq::handle_t zmq::devpoll_t::add_fd (fd_t fd_, i_poll_events *reactor_)
|
||||||
{
|
{
|
||||||
assert (!fd_table [fd_].valid);
|
assert (!fd_table [fd_].valid);
|
||||||
|
|
||||||
@ -82,7 +82,7 @@ zs::handle_t zs::devpoll_t::add_fd (fd_t fd_, i_poll_events *reactor_)
|
|||||||
return handle;
|
return handle;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::devpoll_t::rm_fd (handle_t handle_)
|
void zmq::devpoll_t::rm_fd (handle_t handle_)
|
||||||
{
|
{
|
||||||
assert (fd_table [handle_.fd].valid);
|
assert (fd_table [handle_.fd].valid);
|
||||||
|
|
||||||
@ -93,7 +93,7 @@ void zs::devpoll_t::rm_fd (handle_t handle_)
|
|||||||
load.sub (1);
|
load.sub (1);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::devpoll_t::set_pollin (handle_t handle_)
|
void zmq::devpoll_t::set_pollin (handle_t handle_)
|
||||||
{
|
{
|
||||||
fd_t fd = handle_.fd;
|
fd_t fd = handle_.fd;
|
||||||
devpoll_ctl (fd, POLLREMOVE);
|
devpoll_ctl (fd, POLLREMOVE);
|
||||||
@ -101,7 +101,7 @@ void zs::devpoll_t::set_pollin (handle_t handle_)
|
|||||||
devpoll_ctl (fd, fd_table [fd].events);
|
devpoll_ctl (fd, fd_table [fd].events);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::devpoll_t::reset_pollin (handle_t handle_)
|
void zmq::devpoll_t::reset_pollin (handle_t handle_)
|
||||||
{
|
{
|
||||||
fd_t fd = handle_.fd;
|
fd_t fd = handle_.fd;
|
||||||
devpoll_ctl (fd, POLLREMOVE);
|
devpoll_ctl (fd, POLLREMOVE);
|
||||||
@ -109,7 +109,7 @@ void zs::devpoll_t::reset_pollin (handle_t handle_)
|
|||||||
devpoll_ctl (fd, fd_table [fd].events);
|
devpoll_ctl (fd, fd_table [fd].events);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::devpoll_t::set_pollout (handle_t handle_)
|
void zmq::devpoll_t::set_pollout (handle_t handle_)
|
||||||
{
|
{
|
||||||
fd_t fd = handle_.fd;
|
fd_t fd = handle_.fd;
|
||||||
devpoll_ctl (fd, POLLREMOVE);
|
devpoll_ctl (fd, POLLREMOVE);
|
||||||
@ -117,7 +117,7 @@ void zs::devpoll_t::set_pollout (handle_t handle_)
|
|||||||
devpoll_ctl (fd, fd_table [fd].events);
|
devpoll_ctl (fd, fd_table [fd].events);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::devpoll_t::reset_pollout (handle_t handle_)
|
void zmq::devpoll_t::reset_pollout (handle_t handle_)
|
||||||
{
|
{
|
||||||
fd_t fd = handle_.fd;
|
fd_t fd = handle_.fd;
|
||||||
devpoll_ctl (fd, POLLREMOVE);
|
devpoll_ctl (fd, POLLREMOVE);
|
||||||
@ -125,39 +125,39 @@ void zs::devpoll_t::reset_pollout (handle_t handle_)
|
|||||||
devpoll_ctl (fd, fd_table [fd].events);
|
devpoll_ctl (fd, fd_table [fd].events);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::devpoll_t::add_timer (i_poll_events *events_)
|
void zmq::devpoll_t::add_timer (i_poll_events *events_)
|
||||||
{
|
{
|
||||||
timers.push_back (events_);
|
timers.push_back (events_);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::devpoll_t::cancel_timer (i_poll_events *events_)
|
void zmq::devpoll_t::cancel_timer (i_poll_events *events_)
|
||||||
{
|
{
|
||||||
timers_t::iterator it = std::find (timers.begin (), timers.end (), events_);
|
timers_t::iterator it = std::find (timers.begin (), timers.end (), events_);
|
||||||
if (it != timers.end ())
|
if (it != timers.end ())
|
||||||
timers.erase (it);
|
timers.erase (it);
|
||||||
}
|
}
|
||||||
|
|
||||||
int zs::devpoll_t::get_load ()
|
int zmq::devpoll_t::get_load ()
|
||||||
{
|
{
|
||||||
return load.get ();
|
return load.get ();
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::devpoll_t::start ()
|
void zmq::devpoll_t::start ()
|
||||||
{
|
{
|
||||||
worker.start (worker_routine, this);
|
worker.start (worker_routine, this);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::devpoll_t::stop ()
|
void zmq::devpoll_t::stop ()
|
||||||
{
|
{
|
||||||
stopping = true;
|
stopping = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::devpoll_t::join ()
|
void zmq::devpoll_t::join ()
|
||||||
{
|
{
|
||||||
worker.stop ();
|
worker.stop ();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool zs::devpoll_t::loop ()
|
bool zmq::devpoll_t::loop ()
|
||||||
{
|
{
|
||||||
// According to the poll(7d) man page, we can retrieve
|
// According to the poll(7d) man page, we can retrieve
|
||||||
// no more then (OPEN_MAX - 1) events.
|
// no more then (OPEN_MAX - 1) events.
|
||||||
@ -216,7 +216,7 @@ bool zs::devpoll_t::loop ()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::devpoll_t::worker_routine (void *arg_)
|
void zmq::devpoll_t::worker_routine (void *arg_)
|
||||||
{
|
{
|
||||||
((devpoll_t*) arg_)->loop ();
|
((devpoll_t*) arg_)->loop ();
|
||||||
}
|
}
|
||||||
|
@ -17,12 +17,12 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_DEVPOLL_HPP_INCLUDED__
|
#ifndef __ZMQ_DEVPOLL_HPP_INCLUDED__
|
||||||
#define __ZS_DEVPOLL_HPP_INCLUDED__
|
#define __ZMQ_DEVPOLL_HPP_INCLUDED__
|
||||||
|
|
||||||
#include "platform.hpp"
|
#include "platform.hpp"
|
||||||
|
|
||||||
#if defined ZS_HAVE_SOLARIS || ZS_HAVE_HPUX
|
#if defined ZMQ_HAVE_SOLARIS || ZMQ_HAVE_HPUX
|
||||||
|
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
@ -31,7 +31,7 @@
|
|||||||
#include "thread.hpp"
|
#include "thread.hpp"
|
||||||
#include "atomic_counter.hpp"
|
#include "atomic_counter.hpp"
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
// Implements socket polling mechanism using the Solaris-specific
|
// Implements socket polling mechanism using the Solaris-specific
|
||||||
|
@ -17,7 +17,7 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "../include/zs.h"
|
#include "../include/zmq.h"
|
||||||
|
|
||||||
#include "dispatcher.hpp"
|
#include "dispatcher.hpp"
|
||||||
#include "app_thread.hpp"
|
#include "app_thread.hpp"
|
||||||
@ -30,27 +30,27 @@
|
|||||||
#include "session.hpp"
|
#include "session.hpp"
|
||||||
#include "i_api.hpp"
|
#include "i_api.hpp"
|
||||||
|
|
||||||
#if defined ZS_HAVE_WINDOWS
|
#if defined ZMQ_HAVE_WINDOWS
|
||||||
#include "windows.h"
|
#include "windows.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
zs::dispatcher_t::dispatcher_t (int app_threads_, int io_threads_)
|
zmq::dispatcher_t::dispatcher_t (int app_threads_, int io_threads_)
|
||||||
{
|
{
|
||||||
#ifdef ZS_HAVE_WINDOWS
|
#ifdef ZMQ_HAVE_WINDOWS
|
||||||
// Intialise Windows sockets. Note that WSAStartup can be called multiple
|
// Intialise Windows sockets. Note that WSAStartup can be called multiple
|
||||||
// times given that WSACleanup will be called for each WSAStartup.
|
// times given that WSACleanup will be called for each WSAStartup.
|
||||||
WORD version_requested = MAKEWORD (2, 2);
|
WORD version_requested = MAKEWORD (2, 2);
|
||||||
WSADATA wsa_data;
|
WSADATA wsa_data;
|
||||||
int rc = WSAStartup (version_requested, &wsa_data);
|
int rc = WSAStartup (version_requested, &wsa_data);
|
||||||
zs_assert (rc == 0);
|
zmq_assert (rc == 0);
|
||||||
zs_assert (LOBYTE (wsa_data.wVersion) == 2 &&
|
zmq_assert (LOBYTE (wsa_data.wVersion) == 2 &&
|
||||||
HIBYTE (wsa_data.wVersion) == 2);
|
HIBYTE (wsa_data.wVersion) == 2);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Create application thread proxies.
|
// Create application thread proxies.
|
||||||
for (int i = 0; i != app_threads_; i++) {
|
for (int i = 0; i != app_threads_; i++) {
|
||||||
app_thread_t *app_thread = new app_thread_t (this, i);
|
app_thread_t *app_thread = new app_thread_t (this, i);
|
||||||
zs_assert (app_thread);
|
zmq_assert (app_thread);
|
||||||
app_threads.push_back (app_thread);
|
app_threads.push_back (app_thread);
|
||||||
signalers.push_back (app_thread->get_signaler ());
|
signalers.push_back (app_thread->get_signaler ());
|
||||||
}
|
}
|
||||||
@ -58,26 +58,26 @@ zs::dispatcher_t::dispatcher_t (int app_threads_, int io_threads_)
|
|||||||
// Create I/O thread objects.
|
// Create I/O thread objects.
|
||||||
for (int i = 0; i != io_threads_; i++) {
|
for (int i = 0; i != io_threads_; i++) {
|
||||||
io_thread_t *io_thread = new io_thread_t (this, i + app_threads_);
|
io_thread_t *io_thread = new io_thread_t (this, i + app_threads_);
|
||||||
zs_assert (io_thread);
|
zmq_assert (io_thread);
|
||||||
io_threads.push_back (io_thread);
|
io_threads.push_back (io_thread);
|
||||||
signalers.push_back (io_thread->get_signaler ());
|
signalers.push_back (io_thread->get_signaler ());
|
||||||
}
|
}
|
||||||
|
|
||||||
// Create command pipe matrix.
|
// Create command pipe matrix.
|
||||||
command_pipes = new command_pipe_t [signalers.size () * signalers.size ()];
|
command_pipes = new command_pipe_t [signalers.size () * signalers.size ()];
|
||||||
zs_assert (command_pipes);
|
zmq_assert (command_pipes);
|
||||||
|
|
||||||
// Launch I/O threads.
|
// Launch I/O threads.
|
||||||
for (int i = 0; i != io_threads_; i++)
|
for (int i = 0; i != io_threads_; i++)
|
||||||
io_threads [i]->start ();
|
io_threads [i]->start ();
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::dispatcher_t::shutdown ()
|
void zmq::dispatcher_t::shutdown ()
|
||||||
{
|
{
|
||||||
delete this;
|
delete this;
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::dispatcher_t::~dispatcher_t ()
|
zmq::dispatcher_t::~dispatcher_t ()
|
||||||
{
|
{
|
||||||
// Ask I/O threads to terminate.
|
// Ask I/O threads to terminate.
|
||||||
for (io_threads_t::size_type i = 0; i != io_threads.size (); i++)
|
for (io_threads_t::size_type i = 0; i != io_threads.size (); i++)
|
||||||
@ -103,19 +103,19 @@ zs::dispatcher_t::~dispatcher_t ()
|
|||||||
delete it->writer;
|
delete it->writer;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef ZS_HAVE_WINDOWS
|
#ifdef ZMQ_HAVE_WINDOWS
|
||||||
// On Windows, uninitialise socket layer.
|
// On Windows, uninitialise socket layer.
|
||||||
int rc = WSACleanup ();
|
int rc = WSACleanup ();
|
||||||
wsa_assert (rc != SOCKET_ERROR);
|
wsa_assert (rc != SOCKET_ERROR);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
int zs::dispatcher_t::thread_slot_count ()
|
int zmq::dispatcher_t::thread_slot_count ()
|
||||||
{
|
{
|
||||||
return signalers.size ();
|
return signalers.size ();
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::i_api *zs::dispatcher_t::create_socket (int type_)
|
zmq::i_api *zmq::dispatcher_t::create_socket (int type_)
|
||||||
{
|
{
|
||||||
threads_sync.lock ();
|
threads_sync.lock ();
|
||||||
app_thread_t *thread = choose_app_thread ();
|
app_thread_t *thread = choose_app_thread ();
|
||||||
@ -128,7 +128,7 @@ zs::i_api *zs::dispatcher_t::create_socket (int type_)
|
|||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::app_thread_t *zs::dispatcher_t::choose_app_thread ()
|
zmq::app_thread_t *zmq::dispatcher_t::choose_app_thread ()
|
||||||
{
|
{
|
||||||
// Check whether thread ID is already assigned. If so, return it.
|
// Check whether thread ID is already assigned. If so, return it.
|
||||||
for (app_threads_t::size_type i = 0; i != app_threads.size (); i++)
|
for (app_threads_t::size_type i = 0; i != app_threads.size (); i++)
|
||||||
@ -145,9 +145,9 @@ zs::app_thread_t *zs::dispatcher_t::choose_app_thread ()
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::io_thread_t *zs::dispatcher_t::choose_io_thread (uint64_t taskset_)
|
zmq::io_thread_t *zmq::dispatcher_t::choose_io_thread (uint64_t taskset_)
|
||||||
{
|
{
|
||||||
zs_assert (io_threads.size () > 0);
|
zmq_assert (io_threads.size () > 0);
|
||||||
|
|
||||||
// Find the I/O thread with minimum load.
|
// Find the I/O thread with minimum load.
|
||||||
int min_load = io_threads [0]->get_load ();
|
int min_load = io_threads [0]->get_load ();
|
||||||
@ -165,19 +165,19 @@ zs::io_thread_t *zs::dispatcher_t::choose_io_thread (uint64_t taskset_)
|
|||||||
return io_threads [result];
|
return io_threads [result];
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::dispatcher_t::create_pipe (object_t *reader_parent_,
|
void zmq::dispatcher_t::create_pipe (object_t *reader_parent_,
|
||||||
object_t *writer_parent_, uint64_t hwm_, uint64_t lwm_,
|
object_t *writer_parent_, uint64_t hwm_, uint64_t lwm_,
|
||||||
pipe_reader_t **reader_, pipe_writer_t **writer_)
|
pipe_reader_t **reader_, pipe_writer_t **writer_)
|
||||||
{
|
{
|
||||||
// Create the pipe, reader & writer triple.
|
// Create the pipe, reader & writer triple.
|
||||||
pipe_t *pipe = new pipe_t;
|
pipe_t *pipe = new pipe_t;
|
||||||
zs_assert (pipe);
|
zmq_assert (pipe);
|
||||||
pipe_reader_t *reader = new pipe_reader_t (reader_parent_, pipe,
|
pipe_reader_t *reader = new pipe_reader_t (reader_parent_, pipe,
|
||||||
hwm_, lwm_);
|
hwm_, lwm_);
|
||||||
zs_assert (reader);
|
zmq_assert (reader);
|
||||||
pipe_writer_t *writer = new pipe_writer_t (writer_parent_, pipe, reader,
|
pipe_writer_t *writer = new pipe_writer_t (writer_parent_, pipe, reader,
|
||||||
hwm_, lwm_);
|
hwm_, lwm_);
|
||||||
zs_assert (writer);
|
zmq_assert (writer);
|
||||||
reader->set_peer (writer);
|
reader->set_peer (writer);
|
||||||
|
|
||||||
// Store the pipe in the repository.
|
// Store the pipe in the repository.
|
||||||
@ -191,7 +191,7 @@ void zs::dispatcher_t::create_pipe (object_t *reader_parent_,
|
|||||||
*writer_ = writer;
|
*writer_ = writer;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::dispatcher_t::destroy_pipe (pipe_t *pipe_)
|
void zmq::dispatcher_t::destroy_pipe (pipe_t *pipe_)
|
||||||
{
|
{
|
||||||
// Remove the pipe from the repository.
|
// Remove the pipe from the repository.
|
||||||
pipe_info_t info;
|
pipe_info_t info;
|
||||||
@ -203,13 +203,13 @@ void zs::dispatcher_t::destroy_pipe (pipe_t *pipe_)
|
|||||||
pipes_sync.unlock ();
|
pipes_sync.unlock ();
|
||||||
|
|
||||||
// Deallocate the pipe and associated pipe reader & pipe writer.
|
// Deallocate the pipe and associated pipe reader & pipe writer.
|
||||||
zs_assert (info.pipe == pipe_);
|
zmq_assert (info.pipe == pipe_);
|
||||||
delete info.pipe;
|
delete info.pipe;
|
||||||
delete info.reader;
|
delete info.reader;
|
||||||
delete info.writer;
|
delete info.writer;
|
||||||
}
|
}
|
||||||
|
|
||||||
int zs::dispatcher_t::register_inproc_endpoint (const char *endpoint_,
|
int zmq::dispatcher_t::register_inproc_endpoint (const char *endpoint_,
|
||||||
session_t *session_)
|
session_t *session_)
|
||||||
{
|
{
|
||||||
inproc_endpoint_sync.lock ();
|
inproc_endpoint_sync.lock ();
|
||||||
@ -227,7 +227,7 @@ int zs::dispatcher_t::register_inproc_endpoint (const char *endpoint_,
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::object_t *zs::dispatcher_t::get_inproc_endpoint (const char *endpoint_)
|
zmq::object_t *zmq::dispatcher_t::get_inproc_endpoint (const char *endpoint_)
|
||||||
{
|
{
|
||||||
inproc_endpoint_sync.lock ();
|
inproc_endpoint_sync.lock ();
|
||||||
inproc_endpoints_t::iterator it = inproc_endpoints.find (endpoint_);
|
inproc_endpoints_t::iterator it = inproc_endpoints.find (endpoint_);
|
||||||
@ -245,7 +245,7 @@ zs::object_t *zs::dispatcher_t::get_inproc_endpoint (const char *endpoint_)
|
|||||||
return session;
|
return session;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::dispatcher_t::unregister_inproc_endpoints (session_t *session_)
|
void zmq::dispatcher_t::unregister_inproc_endpoints (session_t *session_)
|
||||||
{
|
{
|
||||||
inproc_endpoint_sync.lock ();
|
inproc_endpoint_sync.lock ();
|
||||||
|
|
||||||
|
@ -17,8 +17,8 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_DISPATCHER_HPP_INCLUDED__
|
#ifndef __ZMQ_DISPATCHER_HPP_INCLUDED__
|
||||||
#define __ZS_DISPATCHER_HPP_INCLUDED__
|
#define __ZMQ_DISPATCHER_HPP_INCLUDED__
|
||||||
|
|
||||||
#include <vector>
|
#include <vector>
|
||||||
#include <map>
|
#include <map>
|
||||||
@ -31,7 +31,7 @@
|
|||||||
#include "mutex.hpp"
|
#include "mutex.hpp"
|
||||||
#include "stdint.hpp"
|
#include "stdint.hpp"
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
// Dispatcher implements bidirectional thread-safe passing of commands
|
// Dispatcher implements bidirectional thread-safe passing of commands
|
||||||
@ -51,7 +51,7 @@ namespace zs
|
|||||||
// signalers.
|
// signalers.
|
||||||
dispatcher_t (int app_threads_, int io_threads_);
|
dispatcher_t (int app_threads_, int io_threads_);
|
||||||
|
|
||||||
// To be called to terminate the whole infrastructure (zs_term).
|
// To be called to terminate the whole infrastructure (zmq_term).
|
||||||
void shutdown ();
|
void shutdown ();
|
||||||
|
|
||||||
// Create a socket engine.
|
// Create a socket engine.
|
||||||
|
@ -17,7 +17,7 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "../include/zs.h"
|
#include "../include/zmq.h"
|
||||||
|
|
||||||
#include "dummy_aggregator.hpp"
|
#include "dummy_aggregator.hpp"
|
||||||
#include "err.hpp"
|
#include "err.hpp"
|
||||||
@ -30,27 +30,27 @@
|
|||||||
pipes [i1_]->set_index (i1_);\
|
pipes [i1_]->set_index (i1_);\
|
||||||
pipes [i2_]->set_index (i2_);
|
pipes [i2_]->set_index (i2_);
|
||||||
|
|
||||||
zs::dummy_aggregator_t::dummy_aggregator_t () :
|
zmq::dummy_aggregator_t::dummy_aggregator_t () :
|
||||||
session (NULL),
|
session (NULL),
|
||||||
pipe (NULL),
|
pipe (NULL),
|
||||||
active (false)
|
active (false)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::dummy_aggregator_t::set_session (session_t *session_)
|
void zmq::dummy_aggregator_t::set_session (session_t *session_)
|
||||||
{
|
{
|
||||||
zs_assert (!session);
|
zmq_assert (!session);
|
||||||
session = session_;
|
session = session_;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::dummy_aggregator_t::shutdown ()
|
void zmq::dummy_aggregator_t::shutdown ()
|
||||||
{
|
{
|
||||||
// No need to deallocate the pipe here. It'll be deallocated during the
|
// No need to deallocate the pipe here. It'll be deallocated during the
|
||||||
// shutdown of the dispatcher.
|
// shutdown of the dispatcher.
|
||||||
delete this;
|
delete this;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::dummy_aggregator_t::terminate ()
|
void zmq::dummy_aggregator_t::terminate ()
|
||||||
{
|
{
|
||||||
if (pipe)
|
if (pipe)
|
||||||
pipe->terminate ();
|
pipe->terminate ();
|
||||||
@ -58,13 +58,13 @@ void zs::dummy_aggregator_t::terminate ()
|
|||||||
delete this;
|
delete this;
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::dummy_aggregator_t::~dummy_aggregator_t ()
|
zmq::dummy_aggregator_t::~dummy_aggregator_t ()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::dummy_aggregator_t::attach_pipe (pipe_reader_t *pipe_)
|
void zmq::dummy_aggregator_t::attach_pipe (pipe_reader_t *pipe_)
|
||||||
{
|
{
|
||||||
zs_assert (!pipe);
|
zmq_assert (!pipe);
|
||||||
pipe = pipe_;
|
pipe = pipe_;
|
||||||
active = true;
|
active = true;
|
||||||
|
|
||||||
@ -73,22 +73,22 @@ void zs::dummy_aggregator_t::attach_pipe (pipe_reader_t *pipe_)
|
|||||||
session->revive ();
|
session->revive ();
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::dummy_aggregator_t::detach_pipe (pipe_reader_t *pipe_)
|
void zmq::dummy_aggregator_t::detach_pipe (pipe_reader_t *pipe_)
|
||||||
{
|
{
|
||||||
zs_assert (pipe == pipe_);
|
zmq_assert (pipe == pipe_);
|
||||||
deactivate (pipe_);
|
deactivate (pipe_);
|
||||||
pipe = NULL;
|
pipe = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool zs::dummy_aggregator_t::empty ()
|
bool zmq::dummy_aggregator_t::empty ()
|
||||||
{
|
{
|
||||||
return pipe == NULL;
|
return pipe == NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool zs::dummy_aggregator_t::recv (zs_msg *msg_)
|
bool zmq::dummy_aggregator_t::recv (zmq_msg *msg_)
|
||||||
{
|
{
|
||||||
// Deallocate old content of the message.
|
// Deallocate old content of the message.
|
||||||
zs_msg_close (msg_);
|
zmq_msg_close (msg_);
|
||||||
|
|
||||||
// Try to read from the pipe.
|
// Try to read from the pipe.
|
||||||
if (pipe && pipe->read (msg_))
|
if (pipe && pipe->read (msg_))
|
||||||
@ -96,16 +96,16 @@ bool zs::dummy_aggregator_t::recv (zs_msg *msg_)
|
|||||||
|
|
||||||
// No message is available. Initialise the output parameter
|
// No message is available. Initialise the output parameter
|
||||||
// to be a 0-byte message.
|
// to be a 0-byte message.
|
||||||
zs_msg_init (msg_);
|
zmq_msg_init (msg_);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::dummy_aggregator_t::deactivate (pipe_reader_t *pipe_)
|
void zmq::dummy_aggregator_t::deactivate (pipe_reader_t *pipe_)
|
||||||
{
|
{
|
||||||
active = false;
|
active = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::dummy_aggregator_t::reactivate (pipe_reader_t *pipe_)
|
void zmq::dummy_aggregator_t::reactivate (pipe_reader_t *pipe_)
|
||||||
{
|
{
|
||||||
active = true;
|
active = true;
|
||||||
}
|
}
|
||||||
|
@ -17,14 +17,14 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_DUMMY_AGGREGATOR_HPP_INCLUDED__
|
#ifndef __ZMQ_DUMMY_AGGREGATOR_HPP_INCLUDED__
|
||||||
#define __ZS_DUMMY_AGGREGATOR_HPP_INCLUDED__
|
#define __ZMQ_DUMMY_AGGREGATOR_HPP_INCLUDED__
|
||||||
|
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
#include "i_mux.hpp"
|
#include "i_mux.hpp"
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
// Fake message aggregator. There can be at most one pipe bound to it,
|
// Fake message aggregator. There can be at most one pipe bound to it,
|
||||||
@ -47,7 +47,7 @@ namespace zs
|
|||||||
bool empty ();
|
bool empty ();
|
||||||
void deactivate (class pipe_reader_t *pipe_);
|
void deactivate (class pipe_reader_t *pipe_);
|
||||||
void reactivate (class pipe_reader_t *pipe_);
|
void reactivate (class pipe_reader_t *pipe_);
|
||||||
bool recv (struct zs_msg *msg_);
|
bool recv (struct zmq_msg *msg_);
|
||||||
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@ -17,7 +17,7 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "../include/zs.h"
|
#include "../include/zmq.h"
|
||||||
|
|
||||||
#include "dummy_distributor.hpp"
|
#include "dummy_distributor.hpp"
|
||||||
#include "pipe_writer.hpp"
|
#include "pipe_writer.hpp"
|
||||||
@ -25,25 +25,25 @@
|
|||||||
#include "session.hpp"
|
#include "session.hpp"
|
||||||
#include "msg.hpp"
|
#include "msg.hpp"
|
||||||
|
|
||||||
zs::dummy_distributor_t::dummy_distributor_t () :
|
zmq::dummy_distributor_t::dummy_distributor_t () :
|
||||||
session (NULL)
|
session (NULL)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::dummy_distributor_t::set_session (session_t *session_)
|
void zmq::dummy_distributor_t::set_session (session_t *session_)
|
||||||
{
|
{
|
||||||
zs_assert (!session);
|
zmq_assert (!session);
|
||||||
session = session_;
|
session = session_;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::dummy_distributor_t::shutdown ()
|
void zmq::dummy_distributor_t::shutdown ()
|
||||||
{
|
{
|
||||||
// No need to deallocate pipe here. It'll be deallocated during the
|
// No need to deallocate pipe here. It'll be deallocated during the
|
||||||
// shutdown of the dispatcher.
|
// shutdown of the dispatcher.
|
||||||
delete this;
|
delete this;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::dummy_distributor_t::terminate ()
|
void zmq::dummy_distributor_t::terminate ()
|
||||||
{
|
{
|
||||||
if (pipe)
|
if (pipe)
|
||||||
pipe->terminate ();
|
pipe->terminate ();
|
||||||
@ -51,33 +51,33 @@ void zs::dummy_distributor_t::terminate ()
|
|||||||
delete this;
|
delete this;
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::dummy_distributor_t::~dummy_distributor_t ()
|
zmq::dummy_distributor_t::~dummy_distributor_t ()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::dummy_distributor_t::attach_pipe (pipe_writer_t *pipe_)
|
void zmq::dummy_distributor_t::attach_pipe (pipe_writer_t *pipe_)
|
||||||
{
|
{
|
||||||
zs_assert (!pipe);
|
zmq_assert (!pipe);
|
||||||
pipe = pipe_;
|
pipe = pipe_;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::dummy_distributor_t::detach_pipe (pipe_writer_t *pipe_)
|
void zmq::dummy_distributor_t::detach_pipe (pipe_writer_t *pipe_)
|
||||||
{
|
{
|
||||||
zs_assert (pipe == pipe_);
|
zmq_assert (pipe == pipe_);
|
||||||
pipe = NULL;
|
pipe = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool zs::dummy_distributor_t::empty ()
|
bool zmq::dummy_distributor_t::empty ()
|
||||||
{
|
{
|
||||||
return pipe == NULL;
|
return pipe == NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool zs::dummy_distributor_t::send (zs_msg *msg_)
|
bool zmq::dummy_distributor_t::send (zmq_msg *msg_)
|
||||||
{
|
{
|
||||||
return pipe && pipe->write (msg_);
|
return pipe && pipe->write (msg_);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::dummy_distributor_t::flush ()
|
void zmq::dummy_distributor_t::flush ()
|
||||||
{
|
{
|
||||||
if (pipe)
|
if (pipe)
|
||||||
pipe->flush ();
|
pipe->flush ();
|
||||||
|
@ -17,14 +17,14 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_DUMMY_DISTRIBUTOR_HPP_INCLUDED__
|
#ifndef __ZMQ_DUMMY_DISTRIBUTOR_HPP_INCLUDED__
|
||||||
#define __ZS_DUMMY_DISTRIBUTOR_HPP_INCLUDED__
|
#define __ZMQ_DUMMY_DISTRIBUTOR_HPP_INCLUDED__
|
||||||
|
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
#include <i_demux.hpp>
|
#include <i_demux.hpp>
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
// Fake message distributor. There can be only one pipe bound to it
|
// Fake message distributor. There can be only one pipe bound to it
|
||||||
@ -45,7 +45,7 @@ namespace zs
|
|||||||
void attach_pipe (class pipe_writer_t *pipe_);
|
void attach_pipe (class pipe_writer_t *pipe_);
|
||||||
void detach_pipe (class pipe_writer_t *pipe_);
|
void detach_pipe (class pipe_writer_t *pipe_);
|
||||||
bool empty ();
|
bool empty ();
|
||||||
bool send (struct zs_msg *msg_);
|
bool send (struct zmq_msg *msg_);
|
||||||
void flush ();
|
void flush ();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@ -17,14 +17,14 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_ENCODER_HPP_INCLUDED__
|
#ifndef __ZMQ_ENCODER_HPP_INCLUDED__
|
||||||
#define __ZS_ENCODER_HPP_INCLUDED__
|
#define __ZMQ_ENCODER_HPP_INCLUDED__
|
||||||
|
|
||||||
#include <stddef.h>
|
#include <stddef.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
// Helper base class for encoders. It implements the state machine that
|
// Helper base class for encoders. It implements the state machine that
|
||||||
|
@ -19,7 +19,7 @@
|
|||||||
|
|
||||||
#include "platform.hpp"
|
#include "platform.hpp"
|
||||||
|
|
||||||
#ifdef ZS_HAVE_LINUX
|
#ifdef ZMQ_HAVE_LINUX
|
||||||
|
|
||||||
#include <sys/epoll.h>
|
#include <sys/epoll.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
@ -32,14 +32,14 @@
|
|||||||
#include "config.hpp"
|
#include "config.hpp"
|
||||||
#include "i_poll_events.hpp"
|
#include "i_poll_events.hpp"
|
||||||
|
|
||||||
zs::epoll_t::epoll_t () :
|
zmq::epoll_t::epoll_t () :
|
||||||
stopping (false)
|
stopping (false)
|
||||||
{
|
{
|
||||||
epoll_fd = epoll_create (1);
|
epoll_fd = epoll_create (1);
|
||||||
errno_assert (epoll_fd != -1);
|
errno_assert (epoll_fd != -1);
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::epoll_t::~epoll_t ()
|
zmq::epoll_t::~epoll_t ()
|
||||||
{
|
{
|
||||||
close (epoll_fd);
|
close (epoll_fd);
|
||||||
|
|
||||||
@ -47,10 +47,10 @@ zs::epoll_t::~epoll_t ()
|
|||||||
delete *it;
|
delete *it;
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::handle_t zs::epoll_t::add_fd (fd_t fd_, i_poll_events *events_)
|
zmq::handle_t zmq::epoll_t::add_fd (fd_t fd_, i_poll_events *events_)
|
||||||
{
|
{
|
||||||
poll_entry_t *pe = new poll_entry_t;
|
poll_entry_t *pe = new poll_entry_t;
|
||||||
zs_assert (pe != NULL);
|
zmq_assert (pe != NULL);
|
||||||
|
|
||||||
// The memset is not actually needed. It's here to prevent debugging
|
// The memset is not actually needed. It's here to prevent debugging
|
||||||
// tools to complain about using uninitialised memory.
|
// tools to complain about using uninitialised memory.
|
||||||
@ -72,7 +72,7 @@ zs::handle_t zs::epoll_t::add_fd (fd_t fd_, i_poll_events *events_)
|
|||||||
return handle;
|
return handle;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::epoll_t::rm_fd (handle_t handle_)
|
void zmq::epoll_t::rm_fd (handle_t handle_)
|
||||||
{
|
{
|
||||||
poll_entry_t *pe = (poll_entry_t*) handle_.ptr;
|
poll_entry_t *pe = (poll_entry_t*) handle_.ptr;
|
||||||
int rc = epoll_ctl (epoll_fd, EPOLL_CTL_DEL, pe->fd, &pe->ev);
|
int rc = epoll_ctl (epoll_fd, EPOLL_CTL_DEL, pe->fd, &pe->ev);
|
||||||
@ -84,7 +84,7 @@ void zs::epoll_t::rm_fd (handle_t handle_)
|
|||||||
load.sub (1);
|
load.sub (1);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::epoll_t::set_pollin (handle_t handle_)
|
void zmq::epoll_t::set_pollin (handle_t handle_)
|
||||||
{
|
{
|
||||||
poll_entry_t *pe = (poll_entry_t*) handle_.ptr;
|
poll_entry_t *pe = (poll_entry_t*) handle_.ptr;
|
||||||
pe->ev.events |= EPOLLIN;
|
pe->ev.events |= EPOLLIN;
|
||||||
@ -92,7 +92,7 @@ void zs::epoll_t::set_pollin (handle_t handle_)
|
|||||||
errno_assert (rc != -1);
|
errno_assert (rc != -1);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::epoll_t::reset_pollin (handle_t handle_)
|
void zmq::epoll_t::reset_pollin (handle_t handle_)
|
||||||
{
|
{
|
||||||
poll_entry_t *pe = (poll_entry_t*) handle_.ptr;
|
poll_entry_t *pe = (poll_entry_t*) handle_.ptr;
|
||||||
pe->ev.events &= ~((short) EPOLLIN);
|
pe->ev.events &= ~((short) EPOLLIN);
|
||||||
@ -100,7 +100,7 @@ void zs::epoll_t::reset_pollin (handle_t handle_)
|
|||||||
errno_assert (rc != -1);
|
errno_assert (rc != -1);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::epoll_t::set_pollout (handle_t handle_)
|
void zmq::epoll_t::set_pollout (handle_t handle_)
|
||||||
{
|
{
|
||||||
poll_entry_t *pe = (poll_entry_t*) handle_.ptr;
|
poll_entry_t *pe = (poll_entry_t*) handle_.ptr;
|
||||||
pe->ev.events |= EPOLLOUT;
|
pe->ev.events |= EPOLLOUT;
|
||||||
@ -108,7 +108,7 @@ void zs::epoll_t::set_pollout (handle_t handle_)
|
|||||||
errno_assert (rc != -1);
|
errno_assert (rc != -1);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::epoll_t::reset_pollout (handle_t handle_)
|
void zmq::epoll_t::reset_pollout (handle_t handle_)
|
||||||
{
|
{
|
||||||
poll_entry_t *pe = (poll_entry_t*) handle_.ptr;
|
poll_entry_t *pe = (poll_entry_t*) handle_.ptr;
|
||||||
pe->ev.events &= ~((short) EPOLLOUT);
|
pe->ev.events &= ~((short) EPOLLOUT);
|
||||||
@ -116,12 +116,12 @@ void zs::epoll_t::reset_pollout (handle_t handle_)
|
|||||||
errno_assert (rc != -1);
|
errno_assert (rc != -1);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::epoll_t::add_timer (i_poll_events *events_)
|
void zmq::epoll_t::add_timer (i_poll_events *events_)
|
||||||
{
|
{
|
||||||
timers.push_back (events_);
|
timers.push_back (events_);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::epoll_t::cancel_timer (i_poll_events *events_)
|
void zmq::epoll_t::cancel_timer (i_poll_events *events_)
|
||||||
{
|
{
|
||||||
timers_t::iterator it = std::find (timers.begin (), timers.end (), events_);
|
timers_t::iterator it = std::find (timers.begin (), timers.end (), events_);
|
||||||
if (it == timers.end ())
|
if (it == timers.end ())
|
||||||
@ -129,27 +129,27 @@ void zs::epoll_t::cancel_timer (i_poll_events *events_)
|
|||||||
timers.erase (it);
|
timers.erase (it);
|
||||||
}
|
}
|
||||||
|
|
||||||
int zs::epoll_t::get_load ()
|
int zmq::epoll_t::get_load ()
|
||||||
{
|
{
|
||||||
return load.get ();
|
return load.get ();
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::epoll_t::start ()
|
void zmq::epoll_t::start ()
|
||||||
{
|
{
|
||||||
worker.start (worker_routine, this);
|
worker.start (worker_routine, this);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::epoll_t::stop ()
|
void zmq::epoll_t::stop ()
|
||||||
{
|
{
|
||||||
stopping = true;
|
stopping = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::epoll_t::join ()
|
void zmq::epoll_t::join ()
|
||||||
{
|
{
|
||||||
worker.stop ();
|
worker.stop ();
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::epoll_t::loop ()
|
void zmq::epoll_t::loop ()
|
||||||
{
|
{
|
||||||
epoll_event ev_buf [max_io_events];
|
epoll_event ev_buf [max_io_events];
|
||||||
|
|
||||||
@ -206,7 +206,7 @@ void zs::epoll_t::loop ()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::epoll_t::worker_routine (void *arg_)
|
void zmq::epoll_t::worker_routine (void *arg_)
|
||||||
{
|
{
|
||||||
((epoll_t*) arg_)->loop ();
|
((epoll_t*) arg_)->loop ();
|
||||||
}
|
}
|
||||||
|
@ -17,12 +17,12 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_EPOLL_HPP_INCLUDED__
|
#ifndef __ZMQ_EPOLL_HPP_INCLUDED__
|
||||||
#define __ZS_EPOLL_HPP_INCLUDED__
|
#define __ZMQ_EPOLL_HPP_INCLUDED__
|
||||||
|
|
||||||
#include "platform.hpp"
|
#include "platform.hpp"
|
||||||
|
|
||||||
#ifdef ZS_HAVE_LINUX
|
#ifdef ZMQ_HAVE_LINUX
|
||||||
|
|
||||||
#include <vector>
|
#include <vector>
|
||||||
#include <sys/epoll.h>
|
#include <sys/epoll.h>
|
||||||
@ -33,7 +33,7 @@
|
|||||||
#include "thread.hpp"
|
#include "thread.hpp"
|
||||||
#include "atomic_counter.hpp"
|
#include "atomic_counter.hpp"
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
// This class implements socket polling mechanism using the Linux-specific
|
// This class implements socket polling mechanism using the Linux-specific
|
||||||
|
@ -20,9 +20,9 @@
|
|||||||
#include "err.hpp"
|
#include "err.hpp"
|
||||||
#include "platform.hpp"
|
#include "platform.hpp"
|
||||||
|
|
||||||
#ifdef ZS_HAVE_WINDOWS
|
#ifdef ZMQ_HAVE_WINDOWS
|
||||||
|
|
||||||
const char *zs::wsa_error()
|
const char *zmq::wsa_error()
|
||||||
{
|
{
|
||||||
int errcode = WSAGetLastError ();
|
int errcode = WSAGetLastError ();
|
||||||
// TODO: This is not a generic way to handle this...
|
// TODO: This is not a generic way to handle this...
|
||||||
@ -134,13 +134,13 @@ const char *zs::wsa_error()
|
|||||||
"Valid name no data record of requested" :
|
"Valid name no data record of requested" :
|
||||||
"error not defined";
|
"error not defined";
|
||||||
}
|
}
|
||||||
void zs::win_error (char *buffer_, size_t buffer_size_)
|
void zmq::win_error (char *buffer_, size_t buffer_size_)
|
||||||
{
|
{
|
||||||
DWORD errcode = GetLastError ();
|
DWORD errcode = GetLastError ();
|
||||||
DWORD rc = FormatMessageA (FORMAT_MESSAGE_FROM_SYSTEM |
|
DWORD rc = FormatMessageA (FORMAT_MESSAGE_FROM_SYSTEM |
|
||||||
FORMAT_MESSAGE_IGNORE_INSERTS, NULL, errcode, MAKELANGID(LANG_NEUTRAL,
|
FORMAT_MESSAGE_IGNORE_INSERTS, NULL, errcode, MAKELANGID(LANG_NEUTRAL,
|
||||||
SUBLANG_DEFAULT), buffer_, buffer_size_, NULL );
|
SUBLANG_DEFAULT), buffer_, buffer_size_, NULL );
|
||||||
zs_assert (rc);
|
zmq_assert (rc);
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
16
src/err.hpp
16
src/err.hpp
@ -17,8 +17,8 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_ERR_HPP_INCLUDED__
|
#ifndef __ZMQ_ERR_HPP_INCLUDED__
|
||||||
#define __ZS_ERR_HPP_INCLUDED__
|
#define __ZMQ_ERR_HPP_INCLUDED__
|
||||||
|
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
@ -27,15 +27,15 @@
|
|||||||
|
|
||||||
#include "platform.hpp"
|
#include "platform.hpp"
|
||||||
|
|
||||||
#ifdef ZS_HAVE_WINDOWS
|
#ifdef ZMQ_HAVE_WINDOWS
|
||||||
#include "windows.hpp"
|
#include "windows.hpp"
|
||||||
#else
|
#else
|
||||||
#include <netdb.h>
|
#include <netdb.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef ZS_HAVE_WINDOWS
|
#ifdef ZMQ_HAVE_WINDOWS
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
const char *wsa_error ();
|
const char *wsa_error ();
|
||||||
@ -45,7 +45,7 @@ namespace zs
|
|||||||
|
|
||||||
// Provides convenient way to check WSA-style errors on Windows.
|
// Provides convenient way to check WSA-style errors on Windows.
|
||||||
#define wsa_assert(x) do { if (!(x)){\
|
#define wsa_assert(x) do { if (!(x)){\
|
||||||
const char *errstr = zs::wsa_error ();\
|
const char *errstr = zmq::wsa_error ();\
|
||||||
if (errstr != NULL) {\
|
if (errstr != NULL) {\
|
||||||
fprintf (stderr, "Assertion failed: %s (%s:%d)\n", errstr, \
|
fprintf (stderr, "Assertion failed: %s (%s:%d)\n", errstr, \
|
||||||
__FILE__, __LINE__);\
|
__FILE__, __LINE__);\
|
||||||
@ -56,7 +56,7 @@ namespace zs
|
|||||||
// Provides convenient way to check GetLastError-style errors on Windows.
|
// Provides convenient way to check GetLastError-style errors on Windows.
|
||||||
#define win_assert(x) do { if (!(x)) {\
|
#define win_assert(x) do { if (!(x)) {\
|
||||||
char errstr [256];\
|
char errstr [256];\
|
||||||
zs::win_error (errstr, 256);\
|
zmq::win_error (errstr, 256);\
|
||||||
fprintf (stderr, "Assertion failed: %s (%s:%d)\n", errstr, \
|
fprintf (stderr, "Assertion failed: %s (%s:%d)\n", errstr, \
|
||||||
__FILE__, __LINE__);\
|
__FILE__, __LINE__);\
|
||||||
abort ();\
|
abort ();\
|
||||||
@ -67,7 +67,7 @@ namespace zs
|
|||||||
// This macro works in exactly the same way as the normal assert. It is used
|
// This macro works in exactly the same way as the normal assert. It is used
|
||||||
// in its stead because standard assert on Win32 in broken - it prints nothing
|
// in its stead because standard assert on Win32 in broken - it prints nothing
|
||||||
// when used within the scope of JNI library.
|
// when used within the scope of JNI library.
|
||||||
#define zs_assert(x) do { if (!(x)){\
|
#define zmq_assert(x) do { if (!(x)){\
|
||||||
fprintf (stderr, "Assertion failed: %s (%s:%d)\n", #x, \
|
fprintf (stderr, "Assertion failed: %s (%s:%d)\n", #x, \
|
||||||
__FILE__, __LINE__);\
|
__FILE__, __LINE__);\
|
||||||
abort ();\
|
abort ();\
|
||||||
|
@ -17,7 +17,7 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "../include/zs.h"
|
#include "../include/zmq.h"
|
||||||
|
|
||||||
#include "fair_aggregator.hpp"
|
#include "fair_aggregator.hpp"
|
||||||
#include "err.hpp"
|
#include "err.hpp"
|
||||||
@ -30,27 +30,27 @@
|
|||||||
pipes [i1_]->set_index (i1_);\
|
pipes [i1_]->set_index (i1_);\
|
||||||
pipes [i2_]->set_index (i2_);
|
pipes [i2_]->set_index (i2_);
|
||||||
|
|
||||||
zs::fair_aggregator_t::fair_aggregator_t () :
|
zmq::fair_aggregator_t::fair_aggregator_t () :
|
||||||
session (NULL),
|
session (NULL),
|
||||||
active (0),
|
active (0),
|
||||||
current (0)
|
current (0)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::fair_aggregator_t::set_session (session_t *session_)
|
void zmq::fair_aggregator_t::set_session (session_t *session_)
|
||||||
{
|
{
|
||||||
zs_assert (!session);
|
zmq_assert (!session);
|
||||||
session = session_;
|
session = session_;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::fair_aggregator_t::shutdown ()
|
void zmq::fair_aggregator_t::shutdown ()
|
||||||
{
|
{
|
||||||
// No need to deallocate pipes here. They'll be deallocated during the
|
// No need to deallocate pipes here. They'll be deallocated during the
|
||||||
// shutdown of the dispatcher.
|
// shutdown of the dispatcher.
|
||||||
delete this;
|
delete this;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::fair_aggregator_t::terminate ()
|
void zmq::fair_aggregator_t::terminate ()
|
||||||
{
|
{
|
||||||
// Pipe unregisters itself during the call to terminate, so the pipes
|
// Pipe unregisters itself during the call to terminate, so the pipes
|
||||||
// list shinks by one in each iteration.
|
// list shinks by one in each iteration.
|
||||||
@ -60,11 +60,11 @@ void zs::fair_aggregator_t::terminate ()
|
|||||||
delete this;
|
delete this;
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::fair_aggregator_t::~fair_aggregator_t ()
|
zmq::fair_aggregator_t::~fair_aggregator_t ()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::fair_aggregator_t::attach_pipe (pipe_reader_t *pipe_)
|
void zmq::fair_aggregator_t::attach_pipe (pipe_reader_t *pipe_)
|
||||||
{
|
{
|
||||||
// Associate new pipe with the mux object.
|
// Associate new pipe with the mux object.
|
||||||
pipe_->set_mux (this);
|
pipe_->set_mux (this);
|
||||||
@ -76,7 +76,7 @@ void zs::fair_aggregator_t::attach_pipe (pipe_reader_t *pipe_)
|
|||||||
session->revive ();
|
session->revive ();
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::fair_aggregator_t::detach_pipe (pipe_reader_t *pipe_)
|
void zmq::fair_aggregator_t::detach_pipe (pipe_reader_t *pipe_)
|
||||||
{
|
{
|
||||||
// Move the pipe from the list of active pipes to the list of idle pipes.
|
// Move the pipe from the list of active pipes to the list of idle pipes.
|
||||||
deactivate (pipe_);
|
deactivate (pipe_);
|
||||||
@ -86,15 +86,15 @@ void zs::fair_aggregator_t::detach_pipe (pipe_reader_t *pipe_)
|
|||||||
pipes.pop_back ();
|
pipes.pop_back ();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool zs::fair_aggregator_t::empty ()
|
bool zmq::fair_aggregator_t::empty ()
|
||||||
{
|
{
|
||||||
return pipes.empty ();
|
return pipes.empty ();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool zs::fair_aggregator_t::recv (zs_msg *msg_)
|
bool zmq::fair_aggregator_t::recv (zmq_msg *msg_)
|
||||||
{
|
{
|
||||||
// Deallocate old content of the message.
|
// Deallocate old content of the message.
|
||||||
zs_msg_close (msg_);
|
zmq_msg_close (msg_);
|
||||||
|
|
||||||
// O(1) fair queueing. Round-robin over the active pipes to get
|
// O(1) fair queueing. Round-robin over the active pipes to get
|
||||||
// next message.
|
// next message.
|
||||||
@ -110,11 +110,11 @@ bool zs::fair_aggregator_t::recv (zs_msg *msg_)
|
|||||||
|
|
||||||
// No message is available. Initialise the output parameter
|
// No message is available. Initialise the output parameter
|
||||||
// to be a 0-byte message.
|
// to be a 0-byte message.
|
||||||
zs_msg_init (msg_);
|
zmq_msg_init (msg_);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::fair_aggregator_t::deactivate (pipe_reader_t *pipe_)
|
void zmq::fair_aggregator_t::deactivate (pipe_reader_t *pipe_)
|
||||||
{
|
{
|
||||||
int index = pipe_->get_index ();
|
int index = pipe_->get_index ();
|
||||||
|
|
||||||
@ -133,7 +133,7 @@ void zs::fair_aggregator_t::deactivate (pipe_reader_t *pipe_)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::fair_aggregator_t::reactivate (pipe_reader_t *pipe_)
|
void zmq::fair_aggregator_t::reactivate (pipe_reader_t *pipe_)
|
||||||
{
|
{
|
||||||
// Revive an idle pipe.
|
// Revive an idle pipe.
|
||||||
swap_pipes (pipe_->get_index (), active);
|
swap_pipes (pipe_->get_index (), active);
|
||||||
|
@ -17,14 +17,14 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_FAIR_AGGREGATOR_HPP_INCLUDED__
|
#ifndef __ZMQ_FAIR_AGGREGATOR_HPP_INCLUDED__
|
||||||
#define __ZS_FAIR_AGGREGATOR_HPP_INCLUDED__
|
#define __ZMQ_FAIR_AGGREGATOR_HPP_INCLUDED__
|
||||||
|
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
#include "i_mux.hpp"
|
#include "i_mux.hpp"
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
// Object to aggregate messages from inbound pipes.
|
// Object to aggregate messages from inbound pipes.
|
||||||
@ -44,7 +44,7 @@ namespace zs
|
|||||||
bool empty ();
|
bool empty ();
|
||||||
void deactivate (class pipe_reader_t *pipe_);
|
void deactivate (class pipe_reader_t *pipe_);
|
||||||
void reactivate (class pipe_reader_t *pipe_);
|
void reactivate (class pipe_reader_t *pipe_);
|
||||||
bool recv (struct zs_msg *msg_);
|
bool recv (struct zmq_msg *msg_);
|
||||||
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@ -17,16 +17,16 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_FD_HPP_INCLUDED__
|
#ifndef __ZMQ_FD_HPP_INCLUDED__
|
||||||
#define __ZS_FD_HPP_INCLUDED__
|
#define __ZMQ_FD_HPP_INCLUDED__
|
||||||
|
|
||||||
#include "platform.hpp"
|
#include "platform.hpp"
|
||||||
|
|
||||||
#ifdef ZS_HAVE_WINDOWS
|
#ifdef ZMQ_HAVE_WINDOWS
|
||||||
#include "windows.hpp"
|
#include "windows.hpp"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
#ifdef _MSC_VER
|
#ifdef _MSC_VER
|
||||||
#if (_MSC_VER <= 1400)
|
#if (_MSC_VER <= 1400)
|
||||||
|
@ -22,20 +22,20 @@
|
|||||||
#include "err.hpp"
|
#include "err.hpp"
|
||||||
#include "fd.hpp"
|
#include "fd.hpp"
|
||||||
|
|
||||||
#if defined ZS_HAVE_OPENVMS
|
#if defined ZMQ_HAVE_OPENVMS
|
||||||
#include <netinet/tcp.h>
|
#include <netinet/tcp.h>
|
||||||
#elif defined ZS_HAVE_WINDOWS
|
#elif defined ZMQ_HAVE_WINDOWS
|
||||||
#include "windows.hpp"
|
#include "windows.hpp"
|
||||||
#else
|
#else
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <fcntl.h>
|
#include <fcntl.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined ZS_HAVE_EVENTFD
|
#if defined ZMQ_HAVE_EVENTFD
|
||||||
|
|
||||||
#include <sys/eventfd.h>
|
#include <sys/eventfd.h>
|
||||||
|
|
||||||
zs::fd_signaler_t::fd_signaler_t ()
|
zmq::fd_signaler_t::fd_signaler_t ()
|
||||||
{
|
{
|
||||||
// Create eventfd object.
|
// Create eventfd object.
|
||||||
fd = eventfd (0, 0);
|
fd = eventfd (0, 0);
|
||||||
@ -49,22 +49,22 @@ zs::fd_signaler_t::fd_signaler_t ()
|
|||||||
errno_assert (rc != -1);
|
errno_assert (rc != -1);
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::fd_signaler_t::~fd_signaler_t ()
|
zmq::fd_signaler_t::~fd_signaler_t ()
|
||||||
{
|
{
|
||||||
int rc = close (fd);
|
int rc = close (fd);
|
||||||
errno_assert (rc != -1);
|
errno_assert (rc != -1);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::fd_signaler_t::signal (int signal_)
|
void zmq::fd_signaler_t::signal (int signal_)
|
||||||
{
|
{
|
||||||
zs_assert (signal_ >= 0 && signal_ < 64);
|
zmq_assert (signal_ >= 0 && signal_ < 64);
|
||||||
signals_t inc = 1;
|
signals_t inc = 1;
|
||||||
inc <<= signal_;
|
inc <<= signal_;
|
||||||
ssize_t sz = write (fd, &inc, sizeof (signals_t));
|
ssize_t sz = write (fd, &inc, sizeof (signals_t));
|
||||||
errno_assert (sz == sizeof (signals_t));
|
errno_assert (sz == sizeof (signals_t));
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::fd_signaler_t::signals_t zs::fd_signaler_t::check ()
|
zmq::fd_signaler_t::signals_t zmq::fd_signaler_t::check ()
|
||||||
{
|
{
|
||||||
signals_t val;
|
signals_t val;
|
||||||
ssize_t sz = read (fd, &val, sizeof (signals_t));
|
ssize_t sz = read (fd, &val, sizeof (signals_t));
|
||||||
@ -75,14 +75,14 @@ zs::fd_signaler_t::signals_t zs::fd_signaler_t::check ()
|
|||||||
return val;
|
return val;
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::fd_t zs::fd_signaler_t::get_fd ()
|
zmq::fd_t zmq::fd_signaler_t::get_fd ()
|
||||||
{
|
{
|
||||||
return fd;
|
return fd;
|
||||||
}
|
}
|
||||||
|
|
||||||
#elif defined ZS_HAVE_WINDOWS
|
#elif defined ZMQ_HAVE_WINDOWS
|
||||||
|
|
||||||
zs::fd_signaler_t::fd_signaler_t ()
|
zmq::fd_signaler_t::fd_signaler_t ()
|
||||||
{
|
{
|
||||||
struct sockaddr_in addr;
|
struct sockaddr_in addr;
|
||||||
SOCKET listener;
|
SOCKET listener;
|
||||||
@ -124,7 +124,7 @@ zs::fd_signaler_t::fd_signaler_t ()
|
|||||||
wsa_assert (rc != SOCKET_ERROR);
|
wsa_assert (rc != SOCKET_ERROR);
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::fd_signaler_t::~fd_signaler_t ()
|
zmq::fd_signaler_t::~fd_signaler_t ()
|
||||||
{
|
{
|
||||||
int rc = closesocket (w);
|
int rc = closesocket (w);
|
||||||
wsa_assert (rc != SOCKET_ERROR);
|
wsa_assert (rc != SOCKET_ERROR);
|
||||||
@ -133,15 +133,15 @@ zs::fd_signaler_t::~fd_signaler_t ()
|
|||||||
wsa_assert (rc != SOCKET_ERROR);
|
wsa_assert (rc != SOCKET_ERROR);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::fd_signaler_t::signal (int signal_)
|
void zmq::fd_signaler_t::signal (int signal_)
|
||||||
{
|
{
|
||||||
zs_assert (signal_ >= 0 && signal_ < 64);
|
zmq_assert (signal_ >= 0 && signal_ < 64);
|
||||||
char c = (char) signal_;
|
char c = (char) signal_;
|
||||||
int rc = send (w, &c, 1, 0);
|
int rc = send (w, &c, 1, 0);
|
||||||
win_assert (rc != SOCKET_ERROR);
|
win_assert (rc != SOCKET_ERROR);
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::fd_signaler_t::signals_t zs::fd_signaler_t::check ()
|
zmq::fd_signaler_t::signals_t zmq::fd_signaler_t::check ()
|
||||||
{
|
{
|
||||||
char buffer [32];
|
char buffer [32];
|
||||||
int nbytes = recv (r, buffer, 32, 0);
|
int nbytes = recv (r, buffer, 32, 0);
|
||||||
@ -149,13 +149,13 @@ zs::fd_signaler_t::signals_t zs::fd_signaler_t::check ()
|
|||||||
|
|
||||||
signals_t signals = 0;
|
signals_t signals = 0;
|
||||||
for (int pos = 0; pos != nbytes; pos++) {
|
for (int pos = 0; pos != nbytes; pos++) {
|
||||||
zs_assert (buffer [pos] < 64);
|
zmq_assert (buffer [pos] < 64);
|
||||||
signals |= (1 << (buffer [pos]));
|
signals |= (1 << (buffer [pos]));
|
||||||
}
|
}
|
||||||
return signals;
|
return signals;
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::fd_t zs::fd_signaler_t::get_fd ()
|
zmq::fd_t zmq::fd_signaler_t::get_fd ()
|
||||||
{
|
{
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
@ -165,7 +165,7 @@ zs::fd_t zs::fd_signaler_t::get_fd ()
|
|||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <sys/socket.h>
|
#include <sys/socket.h>
|
||||||
|
|
||||||
zs::fd_signaler_t::fd_signaler_t ()
|
zmq::fd_signaler_t::fd_signaler_t ()
|
||||||
{
|
{
|
||||||
int sv [2];
|
int sv [2];
|
||||||
int rc = socketpair (AF_UNIX, SOCK_STREAM, 0, sv);
|
int rc = socketpair (AF_UNIX, SOCK_STREAM, 0, sv);
|
||||||
@ -181,43 +181,43 @@ zs::fd_signaler_t::fd_signaler_t ()
|
|||||||
errno_assert (rc != -1);
|
errno_assert (rc != -1);
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::fd_signaler_t::~fd_signaler_t ()
|
zmq::fd_signaler_t::~fd_signaler_t ()
|
||||||
{
|
{
|
||||||
close (w);
|
close (w);
|
||||||
close (r);
|
close (r);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::fd_signaler_t::signal (int signal_)
|
void zmq::fd_signaler_t::signal (int signal_)
|
||||||
{
|
{
|
||||||
zs_assert (signal_ >= 0 && signal_ < 64);
|
zmq_assert (signal_ >= 0 && signal_ < 64);
|
||||||
unsigned char c = (unsigned char) signal_;
|
unsigned char c = (unsigned char) signal_;
|
||||||
ssize_t nbytes = send (w, &c, 1, 0);
|
ssize_t nbytes = send (w, &c, 1, 0);
|
||||||
errno_assert (nbytes == 1);
|
errno_assert (nbytes == 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::fd_signaler_t::signals_t zs::fd_signaler_t::check ()
|
zmq::fd_signaler_t::signals_t zmq::fd_signaler_t::check ()
|
||||||
{
|
{
|
||||||
unsigned char buffer [32];
|
unsigned char buffer [32];
|
||||||
ssize_t nbytes = recv (r, buffer, 32, 0);
|
ssize_t nbytes = recv (r, buffer, 32, 0);
|
||||||
errno_assert (nbytes != -1);
|
errno_assert (nbytes != -1);
|
||||||
signals_t signals = 0;
|
signals_t signals = 0;
|
||||||
for (int pos = 0; pos != nbytes; pos ++) {
|
for (int pos = 0; pos != nbytes; pos ++) {
|
||||||
zs_assert (buffer [pos] < 64);
|
zmq_assert (buffer [pos] < 64);
|
||||||
signals |= (1 << (buffer [pos]));
|
signals |= (1 << (buffer [pos]));
|
||||||
}
|
}
|
||||||
return signals;
|
return signals;
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::fd_t zs::fd_signaler_t::get_fd ()
|
zmq::fd_t zmq::fd_signaler_t::get_fd ()
|
||||||
{
|
{
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined ZS_HAVE_OPENVMS
|
#if defined ZMQ_HAVE_OPENVMS
|
||||||
|
|
||||||
int zs::fd_signaler_t::socketpair (int domain_, int type_, int protocol_,
|
int zmq::fd_signaler_t::socketpair (int domain_, int type_, int protocol_,
|
||||||
int sv_ [2])
|
int sv_ [2])
|
||||||
{
|
{
|
||||||
int listener;
|
int listener;
|
||||||
@ -226,7 +226,7 @@ int zs::fd_signaler_t::socketpair (int domain_, int type_, int protocol_,
|
|||||||
int rc;
|
int rc;
|
||||||
int on = 1;
|
int on = 1;
|
||||||
|
|
||||||
zs_assert (type_ == SOCK_STREAM);
|
zmq_assert (type_ == SOCK_STREAM);
|
||||||
|
|
||||||
// Fill in the localhost address (127.0.0.1).
|
// Fill in the localhost address (127.0.0.1).
|
||||||
memset (&lcladdr, 0, sizeof (lcladdr));
|
memset (&lcladdr, 0, sizeof (lcladdr));
|
||||||
|
@ -17,15 +17,15 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_FD_SIGNALER_HPP_INCLUDED__
|
#ifndef __ZMQ_FD_SIGNALER_HPP_INCLUDED__
|
||||||
#define __ZS_FD_SIGNALER_HPP_INCLUDED__
|
#define __ZMQ_FD_SIGNALER_HPP_INCLUDED__
|
||||||
|
|
||||||
#include "platform.hpp"
|
#include "platform.hpp"
|
||||||
#include "i_signaler.hpp"
|
#include "i_signaler.hpp"
|
||||||
#include "fd.hpp"
|
#include "fd.hpp"
|
||||||
#include "stdint.hpp"
|
#include "stdint.hpp"
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
// This object can be used to send individual signals from one thread to
|
// This object can be used to send individual signals from one thread to
|
||||||
@ -73,7 +73,7 @@ namespace zs
|
|||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined ZS_HAVE_EVENTFD
|
#if defined ZMQ_HAVE_EVENTFD
|
||||||
// Eventfd descriptor.
|
// Eventfd descriptor.
|
||||||
fd_t fd;
|
fd_t fd;
|
||||||
#else
|
#else
|
||||||
|
@ -17,20 +17,20 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_I_API_HPP_INCLUDED__
|
#ifndef __ZMQ_I_API_HPP_INCLUDED__
|
||||||
#define __ZS_I_API_HPP_INCLUDED__
|
#define __ZMQ_I_API_HPP_INCLUDED__
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
struct i_api
|
struct i_api
|
||||||
{
|
{
|
||||||
virtual int bind (const char *addr_, struct zs_opts *opts_) = 0;
|
virtual int bind (const char *addr_, struct zmq_opts *opts_) = 0;
|
||||||
virtual int connect (const char *addr_, struct zs_opts *opts_) = 0;
|
virtual int connect (const char *addr_, struct zmq_opts *opts_) = 0;
|
||||||
virtual int subscribe (const char *criteria_) = 0;
|
virtual int subscribe (const char *criteria_) = 0;
|
||||||
virtual int send (struct zs_msg *msg_, int flags_) = 0;
|
virtual int send (struct zmq_msg *msg_, int flags_) = 0;
|
||||||
virtual int flush () = 0;
|
virtual int flush () = 0;
|
||||||
virtual int recv (struct zs_msg *msg_, int flags_) = 0;
|
virtual int recv (struct zmq_msg *msg_, int flags_) = 0;
|
||||||
virtual int close () = 0;
|
virtual int close () = 0;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -17,10 +17,10 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_I_DEMUX_HPP_INCLUDED__
|
#ifndef __ZMQ_I_DEMUX_HPP_INCLUDED__
|
||||||
#define __ZS_I_DEMUX_HPP_INCLUDED__
|
#define __ZMQ_I_DEMUX_HPP_INCLUDED__
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
struct i_demux
|
struct i_demux
|
||||||
@ -28,7 +28,8 @@ namespace zs
|
|||||||
// Attaches mux to a particular session.
|
// Attaches mux to a particular session.
|
||||||
virtual void set_session (class session_t *session_) = 0;
|
virtual void set_session (class session_t *session_) = 0;
|
||||||
|
|
||||||
// To be called when the whole infrastrucure is being closed (zs_term).
|
// To be called when the whole infrastrucure
|
||||||
|
// is being closed (zmq_term).
|
||||||
virtual void shutdown () = 0;
|
virtual void shutdown () = 0;
|
||||||
|
|
||||||
// To be called when session is being closed.
|
// To be called when session is being closed.
|
||||||
@ -45,7 +46,7 @@ namespace zs
|
|||||||
|
|
||||||
// Sends the message. Returns false if the message cannot be sent
|
// Sends the message. Returns false if the message cannot be sent
|
||||||
// because the pipes are full.
|
// because the pipes are full.
|
||||||
virtual bool send (struct zs_msg *msg_) = 0;
|
virtual bool send (struct zmq_msg *msg_) = 0;
|
||||||
|
|
||||||
// Flushes messages downstream.
|
// Flushes messages downstream.
|
||||||
virtual void flush () = 0;
|
virtual void flush () = 0;
|
||||||
|
@ -17,10 +17,10 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_I_ENGINE_HPP_INCLUDED__
|
#ifndef __ZMQ_I_ENGINE_HPP_INCLUDED__
|
||||||
#define __ZS_I_ENGINE_HPP_INCLUDED__
|
#define __ZMQ_I_ENGINE_HPP_INCLUDED__
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
// Generic interface to access engines from MD objects.
|
// Generic interface to access engines from MD objects.
|
||||||
@ -44,7 +44,7 @@ namespace zs
|
|||||||
// Called by normal object termination process.
|
// Called by normal object termination process.
|
||||||
virtual void terminate () = 0;
|
virtual void terminate () = 0;
|
||||||
|
|
||||||
// To be called by MD when terminal shutdown (zs_term) is in progress.
|
// To be called by MD when terminal shutdown (zmq_term) is in progress.
|
||||||
virtual void shutdown () = 0;
|
virtual void shutdown () = 0;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -17,10 +17,10 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_I_MUX_HPP_INCLUDED__
|
#ifndef __ZMQ_I_MUX_HPP_INCLUDED__
|
||||||
#define __ZS_I_MUX_HPP_INCLUDED__
|
#define __ZMQ_I_MUX_HPP_INCLUDED__
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
struct i_mux
|
struct i_mux
|
||||||
@ -28,7 +28,8 @@ namespace zs
|
|||||||
// Attaches mux to a particular session.
|
// Attaches mux to a particular session.
|
||||||
virtual void set_session (class session_t *session_) = 0;
|
virtual void set_session (class session_t *session_) = 0;
|
||||||
|
|
||||||
// To be called when the whole infrastrucure is being closed (zs_term).
|
// To be called when the whole infrastrucure
|
||||||
|
// is being closed (zmq_term).
|
||||||
virtual void shutdown () = 0;
|
virtual void shutdown () = 0;
|
||||||
|
|
||||||
// To be called when session is being closed.
|
// To be called when session is being closed.
|
||||||
@ -51,7 +52,7 @@ namespace zs
|
|||||||
|
|
||||||
// Receives a message. Returns false when there is no message
|
// Receives a message. Returns false when there is no message
|
||||||
// to receive.
|
// to receive.
|
||||||
virtual bool recv (struct zs_msg *msg_) = 0;
|
virtual bool recv (struct zmq_msg *msg_) = 0;
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -17,10 +17,10 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_I_POLL_EVENTS_HPP_INCLUDED__
|
#ifndef __ZMQ_I_POLL_EVENTS_HPP_INCLUDED__
|
||||||
#define __ZS_I_POLL_EVENTS_HPP_INCLUDED__
|
#define __ZMQ_I_POLL_EVENTS_HPP_INCLUDED__
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
// Virtual interface to be exposed by object that want to be notified
|
// Virtual interface to be exposed by object that want to be notified
|
||||||
|
@ -17,12 +17,12 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_I_POLLER_HPP_INCLUDED__
|
#ifndef __ZMQ_I_POLLER_HPP_INCLUDED__
|
||||||
#define __ZS_I_POLLER_HPP_INCLUDED__
|
#define __ZMQ_I_POLLER_HPP_INCLUDED__
|
||||||
|
|
||||||
#include "fd.hpp"
|
#include "fd.hpp"
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
union handle_t
|
union handle_t
|
||||||
|
@ -17,18 +17,18 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_I_SESSION_HPP_INCLUDED__
|
#ifndef __ZMQ_I_SESSION_HPP_INCLUDED__
|
||||||
#define __ZS_I_SESSION_HPP_INCLUDED__
|
#define __ZMQ_I_SESSION_HPP_INCLUDED__
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
struct i_session
|
struct i_session
|
||||||
{
|
{
|
||||||
virtual void set_engine (struct i_engine *engine_) = 0;
|
virtual void set_engine (struct i_engine *engine_) = 0;
|
||||||
virtual void shutdown () = 0;
|
virtual void shutdown () = 0;
|
||||||
virtual bool read (struct zs_msg *msg_) = 0;
|
virtual bool read (struct zmq_msg *msg_) = 0;
|
||||||
virtual bool write (struct zs_msg *msg_) = 0;
|
virtual bool write (struct zmq_msg *msg_) = 0;
|
||||||
virtual void flush () = 0;
|
virtual void flush () = 0;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -17,10 +17,10 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_I_SIGNALER_HPP_INCLUDED__
|
#ifndef __ZMQ_I_SIGNALER_HPP_INCLUDED__
|
||||||
#define __ZS_I_SIGNALER_HPP_INCLUDED__
|
#define __ZMQ_I_SIGNALER_HPP_INCLUDED__
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
// Virtual interface used to send signals. Individual implementations
|
// Virtual interface used to send signals. Individual implementations
|
||||||
// may restrict the number of possible signal types to send.
|
// may restrict the number of possible signal types to send.
|
||||||
|
@ -17,10 +17,10 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_I_THREAD_HPP_INCLUDED__
|
#ifndef __ZMQ_I_THREAD_HPP_INCLUDED__
|
||||||
#define __ZS_I_THREAD_HPP_INCLUDED__
|
#define __ZMQ_I_THREAD_HPP_INCLUDED__
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
// Interface used by session object to communicate with the thread
|
// Interface used by session object to communicate with the thread
|
||||||
|
@ -21,17 +21,17 @@
|
|||||||
#include "io_thread.hpp"
|
#include "io_thread.hpp"
|
||||||
#include "i_poller.hpp"
|
#include "i_poller.hpp"
|
||||||
|
|
||||||
zs::io_object_t::io_object_t (io_thread_t *thread_) :
|
zmq::io_object_t::io_object_t (io_thread_t *thread_) :
|
||||||
object_t (thread_),
|
object_t (thread_),
|
||||||
thread (thread_)
|
thread (thread_)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::io_object_t::~io_object_t ()
|
zmq::io_object_t::~io_object_t ()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::i_poller *zs::io_object_t::get_poller ()
|
zmq::i_poller *zmq::io_object_t::get_poller ()
|
||||||
{
|
{
|
||||||
return thread->get_poller ();
|
return thread->get_poller ();
|
||||||
}
|
}
|
||||||
|
@ -17,12 +17,12 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_IO_OBJECT_HPP_INCLUDED__
|
#ifndef __ZMQ_IO_OBJECT_HPP_INCLUDED__
|
||||||
#define __ZS_IO_OBJECT_HPP_INCLUDED__
|
#define __ZMQ_IO_OBJECT_HPP_INCLUDED__
|
||||||
|
|
||||||
#include "object.hpp"
|
#include "object.hpp"
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
// All objects running within the context of an I/O thread should be
|
// All objects running within the context of an I/O thread should be
|
||||||
|
@ -17,7 +17,7 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "../include/zs.h"
|
#include "../include/zmq.h"
|
||||||
|
|
||||||
#include "io_thread.hpp"
|
#include "io_thread.hpp"
|
||||||
#include "command.hpp"
|
#include "command.hpp"
|
||||||
@ -34,49 +34,49 @@
|
|||||||
#include "simple_semaphore.hpp"
|
#include "simple_semaphore.hpp"
|
||||||
#include "session.hpp"
|
#include "session.hpp"
|
||||||
|
|
||||||
zs::io_thread_t::io_thread_t (dispatcher_t *dispatcher_, int thread_slot_) :
|
zmq::io_thread_t::io_thread_t (dispatcher_t *dispatcher_, int thread_slot_) :
|
||||||
object_t (dispatcher_, thread_slot_)
|
object_t (dispatcher_, thread_slot_)
|
||||||
{
|
{
|
||||||
#if defined ZS_FORCE_SELECT
|
#if defined ZMQ_FORCE_SELECT
|
||||||
poller = new select_t;
|
poller = new select_t;
|
||||||
#elif defined ZS_FORCE_POLL
|
#elif defined ZMQ_FORCE_POLL
|
||||||
poller = new poll_t;
|
poller = new poll_t;
|
||||||
#elif defined ZS_FORCE_EPOLL
|
#elif defined ZMQ_FORCE_EPOLL
|
||||||
poller = new epoll_t;
|
poller = new epoll_t;
|
||||||
#elif defined ZS_FORCE_DEVPOLL
|
#elif defined ZMQ_FORCE_DEVPOLL
|
||||||
poller = new devpoll_t;
|
poller = new devpoll_t;
|
||||||
#elif defined ZS_FORCE_KQUEUE
|
#elif defined ZMQ_FORCE_KQUEUE
|
||||||
poller = new kqueue_t;
|
poller = new kqueue_t;
|
||||||
#elif defined ZS_HAVE_LINUX
|
#elif defined ZMQ_HAVE_LINUX
|
||||||
poller = new epoll_t;
|
poller = new epoll_t;
|
||||||
#elif defined ZS_HAVE_WINDOWS
|
#elif defined ZMQ_HAVE_WINDOWS
|
||||||
poller = new select_t;
|
poller = new select_t;
|
||||||
#elif defined ZS_HAVE_FREEBSD
|
#elif defined ZMQ_HAVE_FREEBSD
|
||||||
poller = new kqueue_t;
|
poller = new kqueue_t;
|
||||||
#elif defined ZS_HAVE_OPENBSD
|
#elif defined ZMQ_HAVE_OPENBSD
|
||||||
poller = new kqueue_t;
|
poller = new kqueue_t;
|
||||||
#elif defined ZS_HAVE_SOLARIS
|
#elif defined ZMQ_HAVE_SOLARIS
|
||||||
poller = new devpoll_t;
|
poller = new devpoll_t;
|
||||||
#elif defined ZS_HAVE_OSX
|
#elif defined ZMQ_HAVE_OSX
|
||||||
poller = new kqueue_t;
|
poller = new kqueue_t;
|
||||||
#elif defined ZS_HAVE_QNXNTO
|
#elif defined ZMQ_HAVE_QNXNTO
|
||||||
poller = new poll_t;
|
poller = new poll_t;
|
||||||
#elif defined ZS_HAVE_AIX
|
#elif defined ZMQ_HAVE_AIX
|
||||||
poller = new poll_t;
|
poller = new poll_t;
|
||||||
#elif defined ZS_HAVE_HPUX
|
#elif defined ZMQ_HAVE_HPUX
|
||||||
poller = new devpoll_t;
|
poller = new devpoll_t;
|
||||||
#elif defined ZS_HAVE_OPENVMS
|
#elif defined ZMQ_HAVE_OPENVMS
|
||||||
poller = new select_t;
|
poller = new select_t;
|
||||||
#else
|
#else
|
||||||
#error Unsupported platform
|
#error Unsupported platform
|
||||||
#endif
|
#endif
|
||||||
zs_assert (poller);
|
zmq_assert (poller);
|
||||||
|
|
||||||
signaler_handle = poller->add_fd (signaler.get_fd (), this);
|
signaler_handle = poller->add_fd (signaler.get_fd (), this);
|
||||||
poller->set_pollin (signaler_handle);
|
poller->set_pollin (signaler_handle);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::io_thread_t::shutdown ()
|
void zmq::io_thread_t::shutdown ()
|
||||||
{
|
{
|
||||||
// Deallocate all the sessions associated with the thread.
|
// Deallocate all the sessions associated with the thread.
|
||||||
while (!sessions.empty ())
|
while (!sessions.empty ())
|
||||||
@ -85,42 +85,42 @@ void zs::io_thread_t::shutdown ()
|
|||||||
delete this;
|
delete this;
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::io_thread_t::~io_thread_t ()
|
zmq::io_thread_t::~io_thread_t ()
|
||||||
{
|
{
|
||||||
delete poller;
|
delete poller;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::io_thread_t::start ()
|
void zmq::io_thread_t::start ()
|
||||||
{
|
{
|
||||||
// Start the underlying I/O thread.
|
// Start the underlying I/O thread.
|
||||||
poller->start ();
|
poller->start ();
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::io_thread_t::stop ()
|
void zmq::io_thread_t::stop ()
|
||||||
{
|
{
|
||||||
send_stop ();
|
send_stop ();
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::io_thread_t::join ()
|
void zmq::io_thread_t::join ()
|
||||||
{
|
{
|
||||||
poller->join ();
|
poller->join ();
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::i_signaler *zs::io_thread_t::get_signaler ()
|
zmq::i_signaler *zmq::io_thread_t::get_signaler ()
|
||||||
{
|
{
|
||||||
return &signaler;
|
return &signaler;
|
||||||
}
|
}
|
||||||
|
|
||||||
int zs::io_thread_t::get_load ()
|
int zmq::io_thread_t::get_load ()
|
||||||
{
|
{
|
||||||
return poller->get_load ();
|
return poller->get_load ();
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::io_thread_t::in_event ()
|
void zmq::io_thread_t::in_event ()
|
||||||
{
|
{
|
||||||
// Find out which threads are sending us commands.
|
// Find out which threads are sending us commands.
|
||||||
fd_signaler_t::signals_t signals = signaler.check ();
|
fd_signaler_t::signals_t signals = signaler.check ();
|
||||||
zs_assert (signals);
|
zmq_assert (signals);
|
||||||
|
|
||||||
// Iterate through all the threads in the process and find out
|
// Iterate through all the threads in the process and find out
|
||||||
// which of them sent us commands.
|
// which of them sent us commands.
|
||||||
@ -137,25 +137,25 @@ void zs::io_thread_t::in_event ()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::io_thread_t::out_event ()
|
void zmq::io_thread_t::out_event ()
|
||||||
{
|
{
|
||||||
// We are never polling for POLLOUT here. This function is never called.
|
// We are never polling for POLLOUT here. This function is never called.
|
||||||
zs_assert (false);
|
zmq_assert (false);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::io_thread_t::timer_event ()
|
void zmq::io_thread_t::timer_event ()
|
||||||
{
|
{
|
||||||
// No timers here. This function is never called.
|
// No timers here. This function is never called.
|
||||||
zs_assert (false);
|
zmq_assert (false);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::io_thread_t::attach_session (session_t *session_)
|
void zmq::io_thread_t::attach_session (session_t *session_)
|
||||||
{
|
{
|
||||||
session_->set_index (sessions.size ());
|
session_->set_index (sessions.size ());
|
||||||
sessions.push_back (session_);
|
sessions.push_back (session_);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::io_thread_t::detach_session (session_t *session_)
|
void zmq::io_thread_t::detach_session (session_t *session_)
|
||||||
{
|
{
|
||||||
// O(1) removal of the session from the list.
|
// O(1) removal of the session from the list.
|
||||||
sessions_t::size_type i = session_->get_index ();
|
sessions_t::size_type i = session_->get_index ();
|
||||||
@ -164,13 +164,13 @@ void zs::io_thread_t::detach_session (session_t *session_)
|
|||||||
sessions.pop_back ();
|
sessions.pop_back ();
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::i_poller *zs::io_thread_t::get_poller ()
|
zmq::i_poller *zmq::io_thread_t::get_poller ()
|
||||||
{
|
{
|
||||||
zs_assert (poller);
|
zmq_assert (poller);
|
||||||
return poller;
|
return poller;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::io_thread_t::process_stop ()
|
void zmq::io_thread_t::process_stop ()
|
||||||
{
|
{
|
||||||
poller->rm_fd (signaler_handle);
|
poller->rm_fd (signaler_handle);
|
||||||
poller->stop ();
|
poller->stop ();
|
||||||
|
@ -17,8 +17,8 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_IO_THREAD_HPP_INCLUDED__
|
#ifndef __ZMQ_IO_THREAD_HPP_INCLUDED__
|
||||||
#define __ZS_IO_THREAD_HPP_INCLUDED__
|
#define __ZMQ_IO_THREAD_HPP_INCLUDED__
|
||||||
|
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
@ -28,7 +28,7 @@
|
|||||||
#include "i_poll_events.hpp"
|
#include "i_poll_events.hpp"
|
||||||
#include "fd_signaler.hpp"
|
#include "fd_signaler.hpp"
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
// Generic part of the I/O thread. Polling-mechanism-specific features
|
// Generic part of the I/O thread. Polling-mechanism-specific features
|
||||||
@ -49,7 +49,7 @@ namespace zs
|
|||||||
// Wait till undelying thread terminates.
|
// Wait till undelying thread terminates.
|
||||||
void join ();
|
void join ();
|
||||||
|
|
||||||
// To be called when the whole infrastrucure is being closed (zs_term).
|
// To be called when the whole infrastrucure is being closed (zmq_term).
|
||||||
// It's vital to call the individual commands in this sequence:
|
// It's vital to call the individual commands in this sequence:
|
||||||
// stop, join, shutdown.
|
// stop, join, shutdown.
|
||||||
void shutdown ();
|
void shutdown ();
|
||||||
|
36
src/ip.cpp
36
src/ip.cpp
@ -27,7 +27,7 @@
|
|||||||
#include "err.hpp"
|
#include "err.hpp"
|
||||||
#include "stdint.hpp"
|
#include "stdint.hpp"
|
||||||
|
|
||||||
#if defined ZS_HAVE_SOLARIS
|
#if defined ZMQ_HAVE_SOLARIS
|
||||||
|
|
||||||
#include <sys/sockio.h>
|
#include <sys/sockio.h>
|
||||||
#include <net/if.h>
|
#include <net/if.h>
|
||||||
@ -44,14 +44,14 @@ static int resolve_nic_name (in_addr* addr_, char const *interface_)
|
|||||||
|
|
||||||
// Create a socket.
|
// Create a socket.
|
||||||
int fd = socket (AF_INET, SOCK_DGRAM, 0);
|
int fd = socket (AF_INET, SOCK_DGRAM, 0);
|
||||||
zs_assert (fd != -1);
|
zmq_assert (fd != -1);
|
||||||
|
|
||||||
// Retrieve number of interfaces.
|
// Retrieve number of interfaces.
|
||||||
lifnum ifn;
|
lifnum ifn;
|
||||||
ifn.lifn_family = AF_UNSPEC;
|
ifn.lifn_family = AF_UNSPEC;
|
||||||
ifn.lifn_flags = 0;
|
ifn.lifn_flags = 0;
|
||||||
int rc = ioctl (fd, SIOCGLIFNUM, (char*) &ifn);
|
int rc = ioctl (fd, SIOCGLIFNUM, (char*) &ifn);
|
||||||
zs_assert (rc != -1);
|
zmq_assert (rc != -1);
|
||||||
|
|
||||||
// Allocate memory to get interface names.
|
// Allocate memory to get interface names.
|
||||||
size_t ifr_size = sizeof (struct lifreq) * ifn.lifn_count;
|
size_t ifr_size = sizeof (struct lifreq) * ifn.lifn_count;
|
||||||
@ -65,7 +65,7 @@ static int resolve_nic_name (in_addr* addr_, char const *interface_)
|
|||||||
ifc.lifc_len = ifr_size;
|
ifc.lifc_len = ifr_size;
|
||||||
ifc.lifc_buf = ifr;
|
ifc.lifc_buf = ifr;
|
||||||
rc = ioctl (fd, SIOCGLIFCONF, (char*) &ifc);
|
rc = ioctl (fd, SIOCGLIFCONF, (char*) &ifc);
|
||||||
zs_assert (rc != -1);
|
zmq_assert (rc != -1);
|
||||||
|
|
||||||
// Find the interface with the specified name and AF_INET family.
|
// Find the interface with the specified name and AF_INET family.
|
||||||
bool found = false;
|
bool found = false;
|
||||||
@ -74,7 +74,7 @@ static int resolve_nic_name (in_addr* addr_, char const *interface_)
|
|||||||
n ++, ifrp ++) {
|
n ++, ifrp ++) {
|
||||||
if (!strcmp (interface_, ifrp->lifr_name)) {
|
if (!strcmp (interface_, ifrp->lifr_name)) {
|
||||||
rc = ioctl (fd, SIOCGLIFADDR, (char*) ifrp);
|
rc = ioctl (fd, SIOCGLIFADDR, (char*) ifrp);
|
||||||
zs_assert (rc != -1);
|
zmq_assert (rc != -1);
|
||||||
if (ifrp->lifr_addr.ss_family == AF_INET) {
|
if (ifrp->lifr_addr.ss_family == AF_INET) {
|
||||||
*addr_ = ((sockaddr_in*) &ifrp->lifr_addr)->sin_addr;
|
*addr_ = ((sockaddr_in*) &ifrp->lifr_addr)->sin_addr;
|
||||||
found = true;
|
found = true;
|
||||||
@ -100,7 +100,7 @@ static int resolve_nic_name (in_addr* addr_, char const *interface_)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
#elif defined ZS_HAVE_AIX || ZS_HAVE_HPUX
|
#elif defined ZMQ_HAVE_AIX || ZMQ_HAVE_HPUX
|
||||||
|
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
@ -119,12 +119,12 @@ static int resolve_nic_name (in_addr* addr_, char const *interface_)
|
|||||||
|
|
||||||
// Create a socket.
|
// Create a socket.
|
||||||
int sd = socket (AF_INET, SOCK_DGRAM, 0);
|
int sd = socket (AF_INET, SOCK_DGRAM, 0);
|
||||||
zs_assert (sd != -1);
|
zmq_assert (sd != -1);
|
||||||
|
|
||||||
struct ifreq ifr;
|
struct ifreq ifr;
|
||||||
|
|
||||||
// Copy interface name for ioctl get.
|
// Copy interface name for ioctl get.
|
||||||
zs_strncpy (ifr.ifr_name, interface_, sizeof (ifr.ifr_name));
|
zmq_strncpy (ifr.ifr_name, interface_, sizeof (ifr.ifr_name));
|
||||||
|
|
||||||
// Fetch interface address.
|
// Fetch interface address.
|
||||||
int rc = ioctl (sd, SIOCGIFADDR, (caddr_t) &ifr, sizeof (struct ifreq));
|
int rc = ioctl (sd, SIOCGIFADDR, (caddr_t) &ifr, sizeof (struct ifreq));
|
||||||
@ -149,7 +149,7 @@ static int resolve_nic_name (in_addr* addr_, char const *interface_)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
#elif defined ZS_HAVE_WINDOWS
|
#elif defined ZMQ_HAVE_WINDOWS
|
||||||
|
|
||||||
static int resolve_nic_name (in_addr* addr_, char const *interface_)
|
static int resolve_nic_name (in_addr* addr_, char const *interface_)
|
||||||
{
|
{
|
||||||
@ -173,9 +173,9 @@ static int resolve_nic_name (in_addr* addr_, char const *interface_)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
#elif ((defined ZS_HAVE_LINUX || defined ZS_HAVE_FREEBSD ||\
|
#elif ((defined ZMQ_HAVE_LINUX || defined ZMQ_HAVE_FREEBSD ||\
|
||||||
defined ZS_HAVE_OSX || defined ZS_HAVE_OPENBSD ||\
|
defined ZMQ_HAVE_OSX || defined ZMQ_HAVE_OPENBSD ||\
|
||||||
defined ZS_HAVE_QNXNTO) && defined ZS_HAVE_IFADDRS)
|
defined ZMQ_HAVE_QNXNTO) && defined ZMQ_HAVE_IFADDRS)
|
||||||
|
|
||||||
#include <ifaddrs.h>
|
#include <ifaddrs.h>
|
||||||
|
|
||||||
@ -195,8 +195,8 @@ static int resolve_nic_name (in_addr* addr_, char const *interface_)
|
|||||||
// Get the addresses.
|
// Get the addresses.
|
||||||
ifaddrs* ifa = NULL;
|
ifaddrs* ifa = NULL;
|
||||||
int rc = getifaddrs (&ifa);
|
int rc = getifaddrs (&ifa);
|
||||||
zs_assert (rc == 0);
|
zmq_assert (rc == 0);
|
||||||
zs_assert (ifa != NULL);
|
zmq_assert (ifa != NULL);
|
||||||
|
|
||||||
// Find the corresponding network interface.
|
// Find the corresponding network interface.
|
||||||
bool found = false;
|
bool found = false;
|
||||||
@ -237,7 +237,7 @@ static int resolve_nic_name (in_addr* addr_, char const *interface_)
|
|||||||
|
|
||||||
// Convert IP address into sockaddr_in structure.
|
// Convert IP address into sockaddr_in structure.
|
||||||
int rc = inet_pton (AF_INET, interface_, addr_);
|
int rc = inet_pton (AF_INET, interface_, addr_);
|
||||||
zs_assert (rc != 0);
|
zmq_assert (rc != 0);
|
||||||
errno_assert (rc == 1);
|
errno_assert (rc == 1);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
@ -245,7 +245,7 @@ static int resolve_nic_name (in_addr* addr_, char const *interface_)
|
|||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
int zs::resolve_ip_interface (sockaddr_in* addr_, char const *interface_)
|
int zmq::resolve_ip_interface (sockaddr_in* addr_, char const *interface_)
|
||||||
{
|
{
|
||||||
// Find the ':' that separates NIC name from port.
|
// Find the ':' that separates NIC name from port.
|
||||||
const char *delimiter = strchr (interface_, ':');
|
const char *delimiter = strchr (interface_, ':');
|
||||||
@ -273,7 +273,7 @@ int zs::resolve_ip_interface (sockaddr_in* addr_, char const *interface_)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int zs::resolve_ip_hostname (sockaddr_in *addr_, const char *hostname_)
|
int zmq::resolve_ip_hostname (sockaddr_in *addr_, const char *hostname_)
|
||||||
{
|
{
|
||||||
// Find the ':' that separates hostname name from port.
|
// Find the ':' that separates hostname name from port.
|
||||||
const char *delimiter = strchr (hostname_, ':');
|
const char *delimiter = strchr (hostname_, ':');
|
||||||
@ -295,7 +295,7 @@ int zs::resolve_ip_hostname (sockaddr_in *addr_, const char *hostname_)
|
|||||||
errno = EINVAL;
|
errno = EINVAL;
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
zs_assert (res->ai_addr->sa_family == AF_INET);
|
zmq_assert (res->ai_addr->sa_family == AF_INET);
|
||||||
memcpy (addr_, res->ai_addr, sizeof (sockaddr_in));
|
memcpy (addr_, res->ai_addr, sizeof (sockaddr_in));
|
||||||
freeaddrinfo (res);
|
freeaddrinfo (res);
|
||||||
|
|
||||||
|
@ -17,12 +17,12 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_IP_HPP_INCLUDED__
|
#ifndef __ZMQ_IP_HPP_INCLUDED__
|
||||||
#define __ZS_IP_HPP_INCLUDED__
|
#define __ZMQ_IP_HPP_INCLUDED__
|
||||||
|
|
||||||
#include "platform.hpp"
|
#include "platform.hpp"
|
||||||
|
|
||||||
#ifdef ZS_HAVE_WINDOWS
|
#ifdef ZMQ_HAVE_WINDOWS
|
||||||
#include "windows.hpp"
|
#include "windows.hpp"
|
||||||
#else
|
#else
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
@ -32,7 +32,7 @@
|
|||||||
#include <netdb.h>
|
#include <netdb.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
// Resolves network interface name in <nic-name>:<port> format. Symbol "*"
|
// Resolves network interface name in <nic-name>:<port> format. Symbol "*"
|
||||||
|
@ -19,7 +19,7 @@
|
|||||||
|
|
||||||
#include "platform.hpp"
|
#include "platform.hpp"
|
||||||
|
|
||||||
#if defined ZS_HAVE_FREEBSD || defined ZS_HAVE_OPENBSD || defined ZS_HAVE_OSX
|
#if defined ZMQ_HAVE_FREEBSD || defined ZMQ_HAVE_OPENBSD || defined ZMQ_HAVE_OSX
|
||||||
|
|
||||||
#include <sys/time.h>
|
#include <sys/time.h>
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
@ -33,19 +33,19 @@
|
|||||||
#include "config.hpp"
|
#include "config.hpp"
|
||||||
#include "i_poll_events.hpp"
|
#include "i_poll_events.hpp"
|
||||||
|
|
||||||
zs::kqueue_t::kqueue_t ()
|
zmq::kqueue_t::kqueue_t ()
|
||||||
{
|
{
|
||||||
// Create event queue
|
// Create event queue
|
||||||
kqueue_fd = kqueue ();
|
kqueue_fd = kqueue ();
|
||||||
errno_assert (kqueue_fd != -1);
|
errno_assert (kqueue_fd != -1);
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::kqueue_t::~kqueue_t ()
|
zmq::kqueue_t::~kqueue_t ()
|
||||||
{
|
{
|
||||||
close (kqueue_fd);
|
close (kqueue_fd);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::kqueue_t::kevent_add (fd_t fd_, short filter_, void *udata_)
|
void zmq::kqueue_t::kevent_add (fd_t fd_, short filter_, void *udata_)
|
||||||
{
|
{
|
||||||
struct kevent ev;
|
struct kevent ev;
|
||||||
|
|
||||||
@ -54,7 +54,7 @@ void zs::kqueue_t::kevent_add (fd_t fd_, short filter_, void *udata_)
|
|||||||
errno_assert (rc != -1);
|
errno_assert (rc != -1);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::kqueue_t::kevent_delete (fd_t fd_, short filter_)
|
void zmq::kqueue_t::kevent_delete (fd_t fd_, short filter_)
|
||||||
{
|
{
|
||||||
struct kevent ev;
|
struct kevent ev;
|
||||||
|
|
||||||
@ -63,10 +63,10 @@ void zs::kqueue_t::kevent_delete (fd_t fd_, short filter_)
|
|||||||
errno_assert (rc != -1);
|
errno_assert (rc != -1);
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::handle_t zs::kqueue_t::add_fd (fd_t fd_, i_poll_events *reactor_)
|
zmq::handle_t zmq::kqueue_t::add_fd (fd_t fd_, i_poll_events *reactor_)
|
||||||
{
|
{
|
||||||
poll_entry_t *pe = new poll_entry_t;
|
poll_entry_t *pe = new poll_entry_t;
|
||||||
zs_assert (pe != NULL);
|
zmq_assert (pe != NULL);
|
||||||
|
|
||||||
pe->fd = fd_;
|
pe->fd = fd_;
|
||||||
pe->flag_pollin = 0;
|
pe->flag_pollin = 0;
|
||||||
@ -78,7 +78,7 @@ zs::handle_t zs::kqueue_t::add_fd (fd_t fd_, i_poll_events *reactor_)
|
|||||||
return handle;
|
return handle;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::kqueue_t::rm_fd (handle_t handle_)
|
void zmq::kqueue_t::rm_fd (handle_t handle_)
|
||||||
{
|
{
|
||||||
poll_entry_t *pe = (poll_entry_t*) handle_.ptr;
|
poll_entry_t *pe = (poll_entry_t*) handle_.ptr;
|
||||||
if (pe->flag_pollin)
|
if (pe->flag_pollin)
|
||||||
@ -89,67 +89,67 @@ void zs::kqueue_t::rm_fd (handle_t handle_)
|
|||||||
retired.push_back (pe);
|
retired.push_back (pe);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::kqueue_t::set_pollin (handle_t handle_)
|
void zmq::kqueue_t::set_pollin (handle_t handle_)
|
||||||
{
|
{
|
||||||
poll_entry_t *pe = (poll_entry_t*) handle_.ptr;
|
poll_entry_t *pe = (poll_entry_t*) handle_.ptr;
|
||||||
pe->flag_pollin = true;
|
pe->flag_pollin = true;
|
||||||
kevent_add (pe->fd, EVFILT_READ, pe);
|
kevent_add (pe->fd, EVFILT_READ, pe);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::kqueue_t::reset_pollin (handle_t handle_)
|
void zmq::kqueue_t::reset_pollin (handle_t handle_)
|
||||||
{
|
{
|
||||||
poll_entry_t *pe = (poll_entry_t*) handle_.ptr;
|
poll_entry_t *pe = (poll_entry_t*) handle_.ptr;
|
||||||
pe->flag_pollin = false;
|
pe->flag_pollin = false;
|
||||||
kevent_delete (pe->fd, EVFILT_READ);
|
kevent_delete (pe->fd, EVFILT_READ);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::kqueue_t::set_pollout (handle_t handle_)
|
void zmq::kqueue_t::set_pollout (handle_t handle_)
|
||||||
{
|
{
|
||||||
poll_entry_t *pe = (poll_entry_t*) handle_.ptr;
|
poll_entry_t *pe = (poll_entry_t*) handle_.ptr;
|
||||||
pe->flag_pollout = true;
|
pe->flag_pollout = true;
|
||||||
kevent_add (pe->fd, EVFILT_WRITE, pe);
|
kevent_add (pe->fd, EVFILT_WRITE, pe);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::kqueue_t::reset_pollout (handle_t handle_)
|
void zmq::kqueue_t::reset_pollout (handle_t handle_)
|
||||||
{
|
{
|
||||||
poll_entry_t *pe = (poll_entry_t*) handle_.ptr;
|
poll_entry_t *pe = (poll_entry_t*) handle_.ptr;
|
||||||
pe->flag_pollout = false;
|
pe->flag_pollout = false;
|
||||||
kevent_delete (pe->fd, EVFILT_WRITE);
|
kevent_delete (pe->fd, EVFILT_WRITE);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::kqueue_t::add_timer (i_poll_events *events_)
|
void zmq::kqueue_t::add_timer (i_poll_events *events_)
|
||||||
{
|
{
|
||||||
timers.push_back (events_);
|
timers.push_back (events_);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::kqueue_t::cancel_timer (i_poll_events *events_)
|
void zmq::kqueue_t::cancel_timer (i_poll_events *events_)
|
||||||
{
|
{
|
||||||
timers_t::iterator it = std::find (timers.begin (), timers.end (), events_);
|
timers_t::iterator it = std::find (timers.begin (), timers.end (), events_);
|
||||||
if (it != timers.end ())
|
if (it != timers.end ())
|
||||||
timers.erase (it);
|
timers.erase (it);
|
||||||
}
|
}
|
||||||
|
|
||||||
int zs::kqueue_t::get_load ()
|
int zmq::kqueue_t::get_load ()
|
||||||
{
|
{
|
||||||
return load.get ();
|
return load.get ();
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::kqueue_t::start ()
|
void zmq::kqueue_t::start ()
|
||||||
{
|
{
|
||||||
worker.start (worker_routine, this);
|
worker.start (worker_routine, this);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::kqueue_t::stop ()
|
void zmq::kqueue_t::stop ()
|
||||||
{
|
{
|
||||||
stopping = true;
|
stopping = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::kqueue_t::join ()
|
void zmq::kqueue_t::join ()
|
||||||
{
|
{
|
||||||
worker.stop ();
|
worker.stop ();
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::kqueue_t::loop ()
|
void zmq::kqueue_t::loop ()
|
||||||
{
|
{
|
||||||
while (!stopping) {
|
while (!stopping) {
|
||||||
|
|
||||||
@ -206,7 +206,7 @@ void zs::kqueue_t::loop ()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::kqueue_t::worker_routine (void *arg_)
|
void zmq::kqueue_t::worker_routine (void *arg_)
|
||||||
{
|
{
|
||||||
((kqueue_t*) arg_)->loop ();
|
((kqueue_t*) arg_)->loop ();
|
||||||
}
|
}
|
||||||
|
@ -17,12 +17,12 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_KQUEUE_HPP_INCLUDED__
|
#ifndef __ZMQ_KQUEUE_HPP_INCLUDED__
|
||||||
#define __ZS_KQUEUE_HPP_INCLUDED__
|
#define __ZMQ_KQUEUE_HPP_INCLUDED__
|
||||||
|
|
||||||
#include "platform.hpp"
|
#include "platform.hpp"
|
||||||
|
|
||||||
#if defined ZS_HAVE_FREEBSD || defined ZS_HAVE_OPENBSD || defined ZS_HAVE_OSX
|
#if defined ZMQ_HAVE_FREEBSD || defined ZMQ_HAVE_OPENBSD || defined ZMQ_HAVE_OSX
|
||||||
|
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
@ -31,7 +31,7 @@
|
|||||||
#include "thread.hpp"
|
#include "thread.hpp"
|
||||||
#include "atomic_counter.hpp"
|
#include "atomic_counter.hpp"
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
// Implements socket polling mechanism using the BSD-specific
|
// Implements socket polling mechanism using the BSD-specific
|
||||||
|
@ -27,7 +27,7 @@
|
|||||||
#include "dummy_aggregator.hpp"
|
#include "dummy_aggregator.hpp"
|
||||||
#include "dummy_distributor.hpp"
|
#include "dummy_distributor.hpp"
|
||||||
|
|
||||||
zs::listener_t::listener_t (io_thread_t *thread_, const char *addr_,
|
zmq::listener_t::listener_t (io_thread_t *thread_, const char *addr_,
|
||||||
session_t *peer_, bool has_in_, bool has_out_, uint64_t taskset_) :
|
session_t *peer_, bool has_in_, bool has_out_, uint64_t taskset_) :
|
||||||
io_object_t (thread_),
|
io_object_t (thread_),
|
||||||
poller (NULL),
|
poller (NULL),
|
||||||
@ -39,30 +39,30 @@ zs::listener_t::listener_t (io_thread_t *thread_, const char *addr_,
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::listener_t::terminate ()
|
void zmq::listener_t::terminate ()
|
||||||
{
|
{
|
||||||
for (session_stubs_t::size_type i = 0; i != session_stubs.size (); i++)
|
for (session_stubs_t::size_type i = 0; i != session_stubs.size (); i++)
|
||||||
session_stubs [i]->terminate ();
|
session_stubs [i]->terminate ();
|
||||||
delete this;
|
delete this;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::listener_t::shutdown ()
|
void zmq::listener_t::shutdown ()
|
||||||
{
|
{
|
||||||
for (session_stubs_t::size_type i = 0; i != session_stubs.size (); i++)
|
for (session_stubs_t::size_type i = 0; i != session_stubs.size (); i++)
|
||||||
session_stubs [i]->shutdown ();
|
session_stubs [i]->shutdown ();
|
||||||
delete this;
|
delete this;
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::listener_t::~listener_t ()
|
zmq::listener_t::~listener_t ()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::listener_t::got_identity (session_stub_t *session_stub_,
|
void zmq::listener_t::got_identity (session_stub_t *session_stub_,
|
||||||
const char *identity_)
|
const char *identity_)
|
||||||
{
|
{
|
||||||
// Get the engine allready disconnected from the stub and poller.
|
// Get the engine allready disconnected from the stub and poller.
|
||||||
i_engine *engine = session_stub_->detach_engine ();
|
i_engine *engine = session_stub_->detach_engine ();
|
||||||
zs_assert (engine);
|
zmq_assert (engine);
|
||||||
|
|
||||||
// Find the corresponding session.
|
// Find the corresponding session.
|
||||||
session_t *session;
|
session_t *session;
|
||||||
@ -89,11 +89,11 @@ void zs::listener_t::got_identity (session_stub_t *session_stub_,
|
|||||||
// sure that the peer session won't get deallocated till it processes
|
// sure that the peer session won't get deallocated till it processes
|
||||||
// the subsequent bind command.
|
// the subsequent bind command.
|
||||||
i_mux *mux = new dummy_aggregator_t;
|
i_mux *mux = new dummy_aggregator_t;
|
||||||
zs_assert (mux);
|
zmq_assert (mux);
|
||||||
i_demux *demux = new dummy_distributor_t;
|
i_demux *demux = new dummy_distributor_t;
|
||||||
zs_assert (demux);
|
zmq_assert (demux);
|
||||||
session = new session_t (io_thread, io_thread, mux, demux, false, true);
|
session = new session_t (io_thread, io_thread, mux, demux, false, true);
|
||||||
zs_assert (session);
|
zmq_assert (session);
|
||||||
session->inc_seqnum ();
|
session->inc_seqnum ();
|
||||||
session->inc_seqnum ();
|
session->inc_seqnum ();
|
||||||
peer->inc_seqnum ();
|
peer->inc_seqnum ();
|
||||||
@ -104,14 +104,14 @@ void zs::listener_t::got_identity (session_stub_t *session_stub_,
|
|||||||
send_engine (session, engine);
|
send_engine (session, engine);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::listener_t::process_reg (simple_semaphore_t *smph_)
|
void zmq::listener_t::process_reg (simple_semaphore_t *smph_)
|
||||||
{
|
{
|
||||||
zs_assert (!poller);
|
zmq_assert (!poller);
|
||||||
poller = get_poller ();
|
poller = get_poller ();
|
||||||
|
|
||||||
// Open the listening socket.
|
// Open the listening socket.
|
||||||
int rc = tcp_listener.open (addr.c_str ());
|
int rc = tcp_listener.open (addr.c_str ());
|
||||||
zs_assert (rc == 0);
|
zmq_assert (rc == 0);
|
||||||
|
|
||||||
// Unlock the application thread that created the listener.
|
// Unlock the application thread that created the listener.
|
||||||
if (smph_)
|
if (smph_)
|
||||||
@ -122,10 +122,10 @@ void zs::listener_t::process_reg (simple_semaphore_t *smph_)
|
|||||||
poller->set_pollin (handle);
|
poller->set_pollin (handle);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::listener_t::process_unreg (simple_semaphore_t *smph_)
|
void zmq::listener_t::process_unreg (simple_semaphore_t *smph_)
|
||||||
{
|
{
|
||||||
// Disassociate listener from the poller.
|
// Disassociate listener from the poller.
|
||||||
zs_assert (poller);
|
zmq_assert (poller);
|
||||||
poller->rm_fd (handle);
|
poller->rm_fd (handle);
|
||||||
poller = NULL;
|
poller = NULL;
|
||||||
|
|
||||||
@ -134,7 +134,7 @@ void zs::listener_t::process_unreg (simple_semaphore_t *smph_)
|
|||||||
smph_->post ();
|
smph_->post ();
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::listener_t::in_event ()
|
void zmq::listener_t::in_event ()
|
||||||
{
|
{
|
||||||
fd_t fd = tcp_listener.accept ();
|
fd_t fd = tcp_listener.accept ();
|
||||||
|
|
||||||
@ -146,25 +146,25 @@ void zs::listener_t::in_event ()
|
|||||||
// Create an session stub for the engine to take care for it till its
|
// Create an session stub for the engine to take care for it till its
|
||||||
// identity is retreived.
|
// identity is retreived.
|
||||||
session_stub_t *session_stub = new session_stub_t (this);
|
session_stub_t *session_stub = new session_stub_t (this);
|
||||||
zs_assert (session_stub);
|
zmq_assert (session_stub);
|
||||||
session_stub->set_index (session_stubs.size ());
|
session_stub->set_index (session_stubs.size ());
|
||||||
session_stubs.push_back (session_stub);
|
session_stubs.push_back (session_stub);
|
||||||
|
|
||||||
// Create an engine to encaspulate the socket. Engine will register itself
|
// Create an engine to encaspulate the socket. Engine will register itself
|
||||||
// with the stub so the stub will be able to free it in case of shutdown.
|
// with the stub so the stub will be able to free it in case of shutdown.
|
||||||
zmq_tcp_engine_t *engine = new zmq_tcp_engine_t (fd);
|
zmq_tcp_engine_t *engine = new zmq_tcp_engine_t (fd);
|
||||||
zs_assert (engine);
|
zmq_assert (engine);
|
||||||
engine->attach (poller, session_stub);
|
engine->attach (poller, session_stub);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::listener_t::out_event ()
|
void zmq::listener_t::out_event ()
|
||||||
{
|
{
|
||||||
zs_assert (false);
|
zmq_assert (false);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::listener_t::timer_event ()
|
void zmq::listener_t::timer_event ()
|
||||||
{
|
{
|
||||||
zs_assert (false);
|
zmq_assert (false);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -17,8 +17,8 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_LISTENER_HPP_INCLUDED__
|
#ifndef __ZMQ_LISTENER_HPP_INCLUDED__
|
||||||
#define __ZS_LISTENER_HPP_INCLUDED__
|
#define __ZMQ_LISTENER_HPP_INCLUDED__
|
||||||
|
|
||||||
#include <map>
|
#include <map>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
@ -30,7 +30,7 @@
|
|||||||
#include "i_poll_events.hpp"
|
#include "i_poll_events.hpp"
|
||||||
#include "stdint.hpp"
|
#include "stdint.hpp"
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
class listener_t : public io_object_t, public i_poll_events
|
class listener_t : public io_object_t, public i_poll_events
|
||||||
|
@ -17,7 +17,7 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "../include/zs.h"
|
#include "../include/zmq.h"
|
||||||
|
|
||||||
#include "load_balancer.hpp"
|
#include "load_balancer.hpp"
|
||||||
#include "pipe_writer.hpp"
|
#include "pipe_writer.hpp"
|
||||||
@ -25,26 +25,26 @@
|
|||||||
#include "session.hpp"
|
#include "session.hpp"
|
||||||
#include "msg.hpp"
|
#include "msg.hpp"
|
||||||
|
|
||||||
zs::load_balancer_t::load_balancer_t () :
|
zmq::load_balancer_t::load_balancer_t () :
|
||||||
session (NULL),
|
session (NULL),
|
||||||
current (0)
|
current (0)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::load_balancer_t::set_session (session_t *session_)
|
void zmq::load_balancer_t::set_session (session_t *session_)
|
||||||
{
|
{
|
||||||
zs_assert (!session);
|
zmq_assert (!session);
|
||||||
session = session_;
|
session = session_;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::load_balancer_t::shutdown ()
|
void zmq::load_balancer_t::shutdown ()
|
||||||
{
|
{
|
||||||
// No need to deallocate pipes here. They'll be deallocated during the
|
// No need to deallocate pipes here. They'll be deallocated during the
|
||||||
// shutdown of the dispatcher.
|
// shutdown of the dispatcher.
|
||||||
delete this;
|
delete this;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::load_balancer_t::terminate ()
|
void zmq::load_balancer_t::terminate ()
|
||||||
{
|
{
|
||||||
// Pipe unregisters itself during the call to terminate, so the pipes
|
// Pipe unregisters itself during the call to terminate, so the pipes
|
||||||
// list shinks by one in each iteration.
|
// list shinks by one in each iteration.
|
||||||
@ -54,11 +54,11 @@ void zs::load_balancer_t::terminate ()
|
|||||||
delete this;
|
delete this;
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::load_balancer_t::~load_balancer_t ()
|
zmq::load_balancer_t::~load_balancer_t ()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::load_balancer_t::attach_pipe (pipe_writer_t *pipe_)
|
void zmq::load_balancer_t::attach_pipe (pipe_writer_t *pipe_)
|
||||||
{
|
{
|
||||||
// Associate demux with a new pipe.
|
// Associate demux with a new pipe.
|
||||||
pipe_->set_demux (this);
|
pipe_->set_demux (this);
|
||||||
@ -66,7 +66,7 @@ void zs::load_balancer_t::attach_pipe (pipe_writer_t *pipe_)
|
|||||||
pipes.push_back (pipe_);
|
pipes.push_back (pipe_);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::load_balancer_t::detach_pipe (pipe_writer_t *pipe_)
|
void zmq::load_balancer_t::detach_pipe (pipe_writer_t *pipe_)
|
||||||
{
|
{
|
||||||
// Release the reference to the pipe.
|
// Release the reference to the pipe.
|
||||||
int index = pipe_->get_index ();
|
int index = pipe_->get_index ();
|
||||||
@ -76,12 +76,12 @@ void zs::load_balancer_t::detach_pipe (pipe_writer_t *pipe_)
|
|||||||
pipes.pop_back ();
|
pipes.pop_back ();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool zs::load_balancer_t::empty ()
|
bool zmq::load_balancer_t::empty ()
|
||||||
{
|
{
|
||||||
return pipes.empty ();
|
return pipes.empty ();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool zs::load_balancer_t::send (zs_msg *msg_)
|
bool zmq::load_balancer_t::send (zmq_msg *msg_)
|
||||||
{
|
{
|
||||||
// If there are no pipes, message cannot be sent.
|
// If there are no pipes, message cannot be sent.
|
||||||
if (pipes.size () == 0)
|
if (pipes.size () == 0)
|
||||||
@ -105,12 +105,12 @@ bool zs::load_balancer_t::send (zs_msg *msg_)
|
|||||||
current = (current + 1) % pipes.size ();
|
current = (current + 1) % pipes.size ();
|
||||||
|
|
||||||
// Detach the original message from the data buffer.
|
// Detach the original message from the data buffer.
|
||||||
zs_msg_init (msg_);
|
zmq_msg_init (msg_);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::load_balancer_t::flush ()
|
void zmq::load_balancer_t::flush ()
|
||||||
{
|
{
|
||||||
// Flush all pipes. If there's large number of pipes, it can be pretty
|
// Flush all pipes. If there's large number of pipes, it can be pretty
|
||||||
// inefficient (especially if there's new message only in a single pipe).
|
// inefficient (especially if there's new message only in a single pipe).
|
||||||
@ -119,12 +119,12 @@ void zs::load_balancer_t::flush ()
|
|||||||
(*it)->flush ();
|
(*it)->flush ();
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::load_balancer_t::write_to_pipe (class pipe_writer_t *pipe_,
|
void zmq::load_balancer_t::write_to_pipe (class pipe_writer_t *pipe_,
|
||||||
struct zs_msg *msg_)
|
struct zmq_msg *msg_)
|
||||||
{
|
{
|
||||||
if (!pipe_->write (msg_)) {
|
if (!pipe_->write (msg_)) {
|
||||||
// TODO: Push gap notification to the pipe.
|
// TODO: Push gap notification to the pipe.
|
||||||
zs_assert (false);
|
zmq_assert (false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -17,14 +17,14 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_LOAD_BALANCER_HPP_INCLUDED__
|
#ifndef __ZMQ_LOAD_BALANCER_HPP_INCLUDED__
|
||||||
#define __ZS_LOAD_BALANCER_HPP_INCLUDED__
|
#define __ZMQ_LOAD_BALANCER_HPP_INCLUDED__
|
||||||
|
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
#include <i_demux.hpp>
|
#include <i_demux.hpp>
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
// Object to distribute messages to outbound pipes.
|
// Object to distribute messages to outbound pipes.
|
||||||
@ -42,7 +42,7 @@ namespace zs
|
|||||||
void attach_pipe (class pipe_writer_t *pipe_);
|
void attach_pipe (class pipe_writer_t *pipe_);
|
||||||
void detach_pipe (class pipe_writer_t *pipe_);
|
void detach_pipe (class pipe_writer_t *pipe_);
|
||||||
bool empty ();
|
bool empty ();
|
||||||
bool send (struct zs_msg *msg_);
|
bool send (struct zmq_msg *msg_);
|
||||||
void flush ();
|
void flush ();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
@ -55,7 +55,7 @@ namespace zs
|
|||||||
|
|
||||||
// Writes the message to the pipe if possible. If it isn't, writes
|
// Writes the message to the pipe if possible. If it isn't, writes
|
||||||
// a gap notification to the pipe.
|
// a gap notification to the pipe.
|
||||||
void write_to_pipe (class pipe_writer_t *pipe_, struct zs_msg *msg_);
|
void write_to_pipe (class pipe_writer_t *pipe_, struct zmq_msg *msg_);
|
||||||
|
|
||||||
// The list of outbound pipes.
|
// The list of outbound pipes.
|
||||||
typedef std::vector <class pipe_writer_t*> pipes_t;
|
typedef std::vector <class pipe_writer_t*> pipes_t;
|
||||||
|
16
src/msg.hpp
16
src/msg.hpp
@ -17,31 +17,31 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_MSG_HPP_INCLUDE__
|
#ifndef __ZMQ_MSG_HPP_INCLUDE__
|
||||||
#define __ZS_MSG_HPP_INCLUDE__
|
#define __ZMQ_MSG_HPP_INCLUDE__
|
||||||
|
|
||||||
#include <stddef.h>
|
#include <stddef.h>
|
||||||
|
|
||||||
#include "../include/zs.h"
|
#include "../include/zmq.h"
|
||||||
|
|
||||||
#include "atomic_counter.hpp"
|
#include "atomic_counter.hpp"
|
||||||
|
|
||||||
//namespace zs
|
//namespace zmq
|
||||||
//{
|
//{
|
||||||
|
|
||||||
// Shared message buffer. Message data are either allocated in one
|
// Shared message buffer. Message data are either allocated in one
|
||||||
// continguous block along with this structure - thus avoiding one
|
// continuous block along with this structure - thus avoiding one
|
||||||
// malloc/free pair or they are stored in used-supplied memory.
|
// malloc/free pair or they are stored in used-supplied memory.
|
||||||
// In the latter case, ffn member stores pointer to the function to be
|
// In the latter case, ffn member stores pointer to the function to be
|
||||||
// used to deallocate the data. If the buffer is actually shared (there
|
// used to deallocate the data. If the buffer is actually shared (there
|
||||||
// are at least 2 references to it) refcount member contains number of
|
// are at least 2 references to it) refcount member contains number of
|
||||||
// references.
|
// references.
|
||||||
struct zs_msg_content
|
struct zmq_msg_content
|
||||||
{
|
{
|
||||||
void *data;
|
void *data;
|
||||||
size_t size;
|
size_t size;
|
||||||
zs_free_fn *ffn;
|
zmq_free_fn *ffn;
|
||||||
zs::atomic_counter_t refcnt;
|
zmq::atomic_counter_t refcnt;
|
||||||
};
|
};
|
||||||
|
|
||||||
//}
|
//}
|
||||||
|
@ -17,19 +17,19 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_MUTEX_HPP_INCLUDED__
|
#ifndef __ZMQ_MUTEX_HPP_INCLUDED__
|
||||||
#define __ZS_MUTEX_HPP_INCLUDED__
|
#define __ZMQ_MUTEX_HPP_INCLUDED__
|
||||||
|
|
||||||
#include "platform.hpp"
|
#include "platform.hpp"
|
||||||
#include "err.hpp"
|
#include "err.hpp"
|
||||||
|
|
||||||
// Mutex class encapsulates OS mutex in a platform-independent way.
|
// Mutex class encapsulates OS mutex in a platform-independent way.
|
||||||
|
|
||||||
#ifdef ZS_HAVE_WINDOWS
|
#ifdef ZMQ_HAVE_WINDOWS
|
||||||
|
|
||||||
#include "windows.hpp"
|
#include "windows.hpp"
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
class mutex_t
|
class mutex_t
|
||||||
@ -70,7 +70,7 @@ namespace zs
|
|||||||
|
|
||||||
#include <pthread.h>
|
#include <pthread.h>
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
class mutex_t
|
class mutex_t
|
||||||
|
@ -27,33 +27,33 @@
|
|||||||
#include "simple_semaphore.hpp"
|
#include "simple_semaphore.hpp"
|
||||||
#include "i_engine.hpp"
|
#include "i_engine.hpp"
|
||||||
|
|
||||||
zs::object_t::object_t (dispatcher_t *dispatcher_, int thread_slot_) :
|
zmq::object_t::object_t (dispatcher_t *dispatcher_, int thread_slot_) :
|
||||||
dispatcher (dispatcher_),
|
dispatcher (dispatcher_),
|
||||||
thread_slot (thread_slot_)
|
thread_slot (thread_slot_)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::object_t::object_t (object_t *parent_) :
|
zmq::object_t::object_t (object_t *parent_) :
|
||||||
dispatcher (parent_->dispatcher),
|
dispatcher (parent_->dispatcher),
|
||||||
thread_slot (parent_->thread_slot)
|
thread_slot (parent_->thread_slot)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::object_t::~object_t ()
|
zmq::object_t::~object_t ()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
int zs::object_t::thread_slot_count ()
|
int zmq::object_t::thread_slot_count ()
|
||||||
{
|
{
|
||||||
return dispatcher->thread_slot_count ();
|
return dispatcher->thread_slot_count ();
|
||||||
}
|
}
|
||||||
|
|
||||||
int zs::object_t::get_thread_slot ()
|
int zmq::object_t::get_thread_slot ()
|
||||||
{
|
{
|
||||||
return thread_slot;
|
return thread_slot;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::object_t::process_command (command_t &cmd_)
|
void zmq::object_t::process_command (command_t &cmd_)
|
||||||
{
|
{
|
||||||
switch (cmd_.type) {
|
switch (cmd_.type) {
|
||||||
|
|
||||||
@ -99,11 +99,11 @@ void zs::object_t::process_command (command_t &cmd_)
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
zs_assert (false);
|
zmq_assert (false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::object_t::create_pipe (object_t *reader_parent_,
|
void zmq::object_t::create_pipe (object_t *reader_parent_,
|
||||||
object_t *writer_parent_, uint64_t hwm_, uint64_t lwm_,
|
object_t *writer_parent_, uint64_t hwm_, uint64_t lwm_,
|
||||||
pipe_reader_t **reader_, pipe_writer_t **writer_)
|
pipe_reader_t **reader_, pipe_writer_t **writer_)
|
||||||
{
|
{
|
||||||
@ -111,33 +111,33 @@ void zs::object_t::create_pipe (object_t *reader_parent_,
|
|||||||
reader_, writer_);
|
reader_, writer_);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::object_t::destroy_pipe (pipe_t *pipe_)
|
void zmq::object_t::destroy_pipe (pipe_t *pipe_)
|
||||||
{
|
{
|
||||||
dispatcher->destroy_pipe (pipe_);
|
dispatcher->destroy_pipe (pipe_);
|
||||||
}
|
}
|
||||||
|
|
||||||
int zs::object_t::register_inproc_endpoint (const char *endpoint_,
|
int zmq::object_t::register_inproc_endpoint (const char *endpoint_,
|
||||||
session_t *session_)
|
session_t *session_)
|
||||||
{
|
{
|
||||||
return dispatcher->register_inproc_endpoint (endpoint_, session_);
|
return dispatcher->register_inproc_endpoint (endpoint_, session_);
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::object_t *zs::object_t::get_inproc_endpoint (const char *endpoint_)
|
zmq::object_t *zmq::object_t::get_inproc_endpoint (const char *endpoint_)
|
||||||
{
|
{
|
||||||
return dispatcher->get_inproc_endpoint (endpoint_);
|
return dispatcher->get_inproc_endpoint (endpoint_);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::object_t::unregister_inproc_endpoints (session_t *session_)
|
void zmq::object_t::unregister_inproc_endpoints (session_t *session_)
|
||||||
{
|
{
|
||||||
dispatcher->unregister_inproc_endpoints (session_);
|
dispatcher->unregister_inproc_endpoints (session_);
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::io_thread_t *zs::object_t::choose_io_thread (uint64_t taskset_)
|
zmq::io_thread_t *zmq::object_t::choose_io_thread (uint64_t taskset_)
|
||||||
{
|
{
|
||||||
return dispatcher->choose_io_thread (taskset_);
|
return dispatcher->choose_io_thread (taskset_);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::object_t::send_stop ()
|
void zmq::object_t::send_stop ()
|
||||||
{
|
{
|
||||||
// Send command goes always to the current object. To-self pipe is
|
// Send command goes always to the current object. To-self pipe is
|
||||||
// used exclusively for sending this command.
|
// used exclusively for sending this command.
|
||||||
@ -147,7 +147,7 @@ void zs::object_t::send_stop ()
|
|||||||
dispatcher->write (thread_slot, thread_slot, cmd);
|
dispatcher->write (thread_slot, thread_slot, cmd);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::object_t::send_bind (object_t *destination_, pipe_reader_t *reader_,
|
void zmq::object_t::send_bind (object_t *destination_, pipe_reader_t *reader_,
|
||||||
session_t *peer_)
|
session_t *peer_)
|
||||||
{
|
{
|
||||||
command_t cmd;
|
command_t cmd;
|
||||||
@ -158,7 +158,7 @@ void zs::object_t::send_bind (object_t *destination_, pipe_reader_t *reader_,
|
|||||||
send_command (cmd);
|
send_command (cmd);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::object_t::send_head (object_t *destination_, uint64_t bytes_)
|
void zmq::object_t::send_head (object_t *destination_, uint64_t bytes_)
|
||||||
{
|
{
|
||||||
command_t cmd;
|
command_t cmd;
|
||||||
cmd.destination = destination_;
|
cmd.destination = destination_;
|
||||||
@ -167,7 +167,7 @@ void zs::object_t::send_head (object_t *destination_, uint64_t bytes_)
|
|||||||
send_command (cmd);
|
send_command (cmd);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::object_t::send_tail (object_t *destination_, uint64_t bytes_)
|
void zmq::object_t::send_tail (object_t *destination_, uint64_t bytes_)
|
||||||
{
|
{
|
||||||
command_t cmd;
|
command_t cmd;
|
||||||
cmd.destination = destination_;
|
cmd.destination = destination_;
|
||||||
@ -176,7 +176,7 @@ void zs::object_t::send_tail (object_t *destination_, uint64_t bytes_)
|
|||||||
send_command (cmd);
|
send_command (cmd);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::object_t::send_reg (object_t *destination_, simple_semaphore_t *smph_)
|
void zmq::object_t::send_reg (object_t *destination_, simple_semaphore_t *smph_)
|
||||||
{
|
{
|
||||||
command_t cmd;
|
command_t cmd;
|
||||||
cmd.destination = destination_;
|
cmd.destination = destination_;
|
||||||
@ -185,7 +185,7 @@ void zs::object_t::send_reg (object_t *destination_, simple_semaphore_t *smph_)
|
|||||||
send_command (cmd);
|
send_command (cmd);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::object_t::send_reg_and_bind (object_t *destination_,
|
void zmq::object_t::send_reg_and_bind (object_t *destination_,
|
||||||
session_t *peer_, bool flow_in_, bool flow_out_)
|
session_t *peer_, bool flow_in_, bool flow_out_)
|
||||||
{
|
{
|
||||||
command_t cmd;
|
command_t cmd;
|
||||||
@ -197,7 +197,7 @@ void zs::object_t::send_reg_and_bind (object_t *destination_,
|
|||||||
send_command (cmd);
|
send_command (cmd);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::object_t::send_unreg (object_t *destination_,
|
void zmq::object_t::send_unreg (object_t *destination_,
|
||||||
simple_semaphore_t *smph_)
|
simple_semaphore_t *smph_)
|
||||||
{
|
{
|
||||||
command_t cmd;
|
command_t cmd;
|
||||||
@ -207,7 +207,7 @@ void zs::object_t::send_unreg (object_t *destination_,
|
|||||||
send_command (cmd);
|
send_command (cmd);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::object_t::send_engine (object_t *destination_, i_engine *engine_)
|
void zmq::object_t::send_engine (object_t *destination_, i_engine *engine_)
|
||||||
{
|
{
|
||||||
command_t cmd;
|
command_t cmd;
|
||||||
cmd.destination = destination_;
|
cmd.destination = destination_;
|
||||||
@ -216,7 +216,7 @@ void zs::object_t::send_engine (object_t *destination_, i_engine *engine_)
|
|||||||
send_command (cmd);
|
send_command (cmd);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::object_t::send_terminate (object_t *destination_)
|
void zmq::object_t::send_terminate (object_t *destination_)
|
||||||
{
|
{
|
||||||
command_t cmd;
|
command_t cmd;
|
||||||
cmd.destination = destination_;
|
cmd.destination = destination_;
|
||||||
@ -224,7 +224,7 @@ void zs::object_t::send_terminate (object_t *destination_)
|
|||||||
send_command (cmd);
|
send_command (cmd);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::object_t::send_terminate_ack (object_t *destination_)
|
void zmq::object_t::send_terminate_ack (object_t *destination_)
|
||||||
{
|
{
|
||||||
command_t cmd;
|
command_t cmd;
|
||||||
cmd.destination = destination_;
|
cmd.destination = destination_;
|
||||||
@ -232,58 +232,58 @@ void zs::object_t::send_terminate_ack (object_t *destination_)
|
|||||||
send_command (cmd);
|
send_command (cmd);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::object_t::process_stop ()
|
void zmq::object_t::process_stop ()
|
||||||
{
|
{
|
||||||
zs_assert (false);
|
zmq_assert (false);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::object_t::process_bind (pipe_reader_t *reader_, session_t *peer_)
|
void zmq::object_t::process_bind (pipe_reader_t *reader_, session_t *peer_)
|
||||||
{
|
{
|
||||||
zs_assert (false);
|
zmq_assert (false);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::object_t::process_head (uint64_t bytes_)
|
void zmq::object_t::process_head (uint64_t bytes_)
|
||||||
{
|
{
|
||||||
zs_assert (false);
|
zmq_assert (false);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::object_t::process_tail (uint64_t bytes_)
|
void zmq::object_t::process_tail (uint64_t bytes_)
|
||||||
{
|
{
|
||||||
zs_assert (false);
|
zmq_assert (false);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::object_t::process_reg (simple_semaphore_t *smph_)
|
void zmq::object_t::process_reg (simple_semaphore_t *smph_)
|
||||||
{
|
{
|
||||||
zs_assert (false);
|
zmq_assert (false);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::object_t::process_reg_and_bind (session_t *session_,
|
void zmq::object_t::process_reg_and_bind (session_t *session_,
|
||||||
bool flow_in_, bool flow_out_)
|
bool flow_in_, bool flow_out_)
|
||||||
{
|
{
|
||||||
zs_assert (false);
|
zmq_assert (false);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::object_t::process_unreg (simple_semaphore_t *smph_)
|
void zmq::object_t::process_unreg (simple_semaphore_t *smph_)
|
||||||
{
|
{
|
||||||
zs_assert (false);
|
zmq_assert (false);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::object_t::process_engine (i_engine *engine_)
|
void zmq::object_t::process_engine (i_engine *engine_)
|
||||||
{
|
{
|
||||||
zs_assert (false);
|
zmq_assert (false);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::object_t::process_terminate ()
|
void zmq::object_t::process_terminate ()
|
||||||
{
|
{
|
||||||
zs_assert (false);
|
zmq_assert (false);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::object_t::process_terminate_ack ()
|
void zmq::object_t::process_terminate_ack ()
|
||||||
{
|
{
|
||||||
zs_assert (false);
|
zmq_assert (false);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::object_t::send_command (command_t &cmd_)
|
void zmq::object_t::send_command (command_t &cmd_)
|
||||||
{
|
{
|
||||||
int destination_thread_slot = cmd_.destination->get_thread_slot ();
|
int destination_thread_slot = cmd_.destination->get_thread_slot ();
|
||||||
if (destination_thread_slot == thread_slot)
|
if (destination_thread_slot == thread_slot)
|
||||||
|
@ -17,12 +17,12 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_OBJECT_HPP_INCLUDED__
|
#ifndef __ZMQ_OBJECT_HPP_INCLUDED__
|
||||||
#define __ZS_OBJECT_HPP_INCLUDED__
|
#define __ZMQ_OBJECT_HPP_INCLUDED__
|
||||||
|
|
||||||
#include "stdint.hpp"
|
#include "stdint.hpp"
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
// Base class for all objects that participate in inter-thread
|
// Base class for all objects that participate in inter-thread
|
||||||
|
@ -17,13 +17,13 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "../include/zs.h"
|
#include "../include/zmq.h"
|
||||||
|
|
||||||
#include "p2p.hpp"
|
#include "p2p.hpp"
|
||||||
#include "app_thread.hpp"
|
#include "app_thread.hpp"
|
||||||
#include "session.hpp"
|
#include "session.hpp"
|
||||||
|
|
||||||
zs::p2p_t::p2p_t (app_thread_t *thread_, session_t *session_) :
|
zmq::p2p_t::p2p_t (app_thread_t *thread_, session_t *session_) :
|
||||||
socket_base_t (thread_, session_)
|
socket_base_t (thread_, session_)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
@ -17,12 +17,12 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_P2P_HPP_INCLUDED__
|
#ifndef __ZMQ_P2P_HPP_INCLUDED__
|
||||||
#define __ZS_P2P_HPP_INCLUDED__
|
#define __ZMQ_P2P_HPP_INCLUDED__
|
||||||
|
|
||||||
#include "socket_base.hpp"
|
#include "socket_base.hpp"
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
class p2p_t : public socket_base_t
|
class p2p_t : public socket_base_t
|
||||||
|
14
src/pipe.cpp
14
src/pipe.cpp
@ -19,29 +19,29 @@
|
|||||||
|
|
||||||
#include "pipe.hpp"
|
#include "pipe.hpp"
|
||||||
|
|
||||||
zs::pipe_t::pipe_t () :
|
zmq::pipe_t::pipe_t () :
|
||||||
ypipe_t <zs_msg, false, message_pipe_granularity> (false),
|
ypipe_t <zmq_msg, false, message_pipe_granularity> (false),
|
||||||
index (-1)
|
index (-1)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::pipe_t::~pipe_t ()
|
zmq::pipe_t::~pipe_t ()
|
||||||
{
|
{
|
||||||
// Flush any outstanding messages to the pipe.
|
// Flush any outstanding messages to the pipe.
|
||||||
flush ();
|
flush ();
|
||||||
|
|
||||||
// Deallocate all the messages in the pipe.
|
// Deallocate all the messages in the pipe.
|
||||||
zs_msg msg;
|
zmq_msg msg;
|
||||||
while (read (&msg))
|
while (read (&msg))
|
||||||
zs_msg_close (&msg);
|
zmq_msg_close (&msg);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::pipe_t::set_index (int index_)
|
void zmq::pipe_t::set_index (int index_)
|
||||||
{
|
{
|
||||||
index = index_;
|
index = index_;
|
||||||
}
|
}
|
||||||
|
|
||||||
int zs::pipe_t::get_index ()
|
int zmq::pipe_t::get_index ()
|
||||||
{
|
{
|
||||||
return index;
|
return index;
|
||||||
}
|
}
|
||||||
|
10
src/pipe.hpp
10
src/pipe.hpp
@ -17,20 +17,20 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_PIPE_HPP_INCLUDED__
|
#ifndef __ZMQ_PIPE_HPP_INCLUDED__
|
||||||
#define __ZS_PIPE_HPP_INCLUDED__
|
#define __ZMQ_PIPE_HPP_INCLUDED__
|
||||||
|
|
||||||
#include "../include/zs.h"
|
#include "../include/zmq.h"
|
||||||
|
|
||||||
#include "ypipe.hpp"
|
#include "ypipe.hpp"
|
||||||
#include "config.hpp"
|
#include "config.hpp"
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
// Message pipe. A simple wrapper on top of ypipe.
|
// Message pipe. A simple wrapper on top of ypipe.
|
||||||
|
|
||||||
class pipe_t : public ypipe_t <zs_msg, false, message_pipe_granularity>
|
class pipe_t : public ypipe_t <zmq_msg, false, message_pipe_granularity>
|
||||||
{
|
{
|
||||||
// Dispatcher is a friend so that it can create & destroy the pipes.
|
// Dispatcher is a friend so that it can create & destroy the pipes.
|
||||||
// By making constructor & destructor private we are sure that nobody
|
// By making constructor & destructor private we are sure that nobody
|
||||||
|
@ -17,14 +17,14 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "../include/zs.h"
|
#include "../include/zmq.h"
|
||||||
|
|
||||||
#include "pipe_reader.hpp"
|
#include "pipe_reader.hpp"
|
||||||
#include "pipe.hpp"
|
#include "pipe.hpp"
|
||||||
#include "err.hpp"
|
#include "err.hpp"
|
||||||
#include "i_mux.hpp"
|
#include "i_mux.hpp"
|
||||||
|
|
||||||
zs::pipe_reader_t::pipe_reader_t (object_t *parent_, pipe_t *pipe_,
|
zmq::pipe_reader_t::pipe_reader_t (object_t *parent_, pipe_t *pipe_,
|
||||||
uint64_t hwm_, uint64_t lwm_) :
|
uint64_t hwm_, uint64_t lwm_) :
|
||||||
object_t (parent_),
|
object_t (parent_),
|
||||||
pipe (pipe_),
|
pipe (pipe_),
|
||||||
@ -39,37 +39,37 @@ zs::pipe_reader_t::pipe_reader_t (object_t *parent_, pipe_t *pipe_,
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::pipe_reader_t::set_peer (object_t *peer_)
|
void zmq::pipe_reader_t::set_peer (object_t *peer_)
|
||||||
{
|
{
|
||||||
peer = peer_;
|
peer = peer_;
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::pipe_reader_t::~pipe_reader_t ()
|
zmq::pipe_reader_t::~pipe_reader_t ()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::pipe_reader_t::set_mux (i_mux *mux_)
|
void zmq::pipe_reader_t::set_mux (i_mux *mux_)
|
||||||
{
|
{
|
||||||
mux = mux_;
|
mux = mux_;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::pipe_reader_t::set_index (int index_)
|
void zmq::pipe_reader_t::set_index (int index_)
|
||||||
{
|
{
|
||||||
index = index_;
|
index = index_;
|
||||||
}
|
}
|
||||||
|
|
||||||
int zs::pipe_reader_t::get_index ()
|
int zmq::pipe_reader_t::get_index ()
|
||||||
{
|
{
|
||||||
return index;
|
return index;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::pipe_reader_t::process_tail (uint64_t bytes_)
|
void zmq::pipe_reader_t::process_tail (uint64_t bytes_)
|
||||||
{
|
{
|
||||||
tail = bytes_;
|
tail = bytes_;
|
||||||
mux->reactivate (this);
|
mux->reactivate (this);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool zs::pipe_reader_t::read (struct zs_msg *msg_)
|
bool zmq::pipe_reader_t::read (struct zmq_msg *msg_)
|
||||||
{
|
{
|
||||||
// Read a message.
|
// Read a message.
|
||||||
if (!pipe->read (msg_)) {
|
if (!pipe->read (msg_)) {
|
||||||
@ -78,7 +78,7 @@ bool zs::pipe_reader_t::read (struct zs_msg *msg_)
|
|||||||
}
|
}
|
||||||
|
|
||||||
// If successfull, adjust the head of the pipe.
|
// If successfull, adjust the head of the pipe.
|
||||||
head += zs_msg_size (msg_);
|
head += zmq_msg_size (msg_);
|
||||||
|
|
||||||
// If pipe writer wasn't notified about the head position for long enough,
|
// If pipe writer wasn't notified about the head position for long enough,
|
||||||
// notify it.
|
// notify it.
|
||||||
@ -87,7 +87,7 @@ bool zs::pipe_reader_t::read (struct zs_msg *msg_)
|
|||||||
last_sent_head = head;
|
last_sent_head = head;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (zs_msg_type (msg_) == ZS_DELIMITER) {
|
if (zmq_msg_type (msg_) == ZMQ_DELIMITER) {
|
||||||
|
|
||||||
// Detach the pipe from the mux and send termination request to
|
// Detach the pipe from the mux and send termination request to
|
||||||
// the pipe writer.
|
// the pipe writer.
|
||||||
@ -100,7 +100,7 @@ bool zs::pipe_reader_t::read (struct zs_msg *msg_)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::pipe_reader_t::terminate ()
|
void zmq::pipe_reader_t::terminate ()
|
||||||
{
|
{
|
||||||
// Detach the pipe from the mux and send termination request to
|
// Detach the pipe from the mux and send termination request to
|
||||||
// the pipe writer.
|
// the pipe writer.
|
||||||
@ -111,7 +111,7 @@ void zs::pipe_reader_t::terminate ()
|
|||||||
send_terminate (peer);
|
send_terminate (peer);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::pipe_reader_t::process_terminate_ack ()
|
void zmq::pipe_reader_t::process_terminate_ack ()
|
||||||
{
|
{
|
||||||
// Ask dispatcher to deallocate the pipe.
|
// Ask dispatcher to deallocate the pipe.
|
||||||
destroy_pipe (pipe);
|
destroy_pipe (pipe);
|
||||||
|
@ -17,13 +17,13 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_PIPE_READER_HPP_INCLUDED__
|
#ifndef __ZMQ_PIPE_READER_HPP_INCLUDED__
|
||||||
#define __ZS_PIPE_READER_HPP_INCLUDED__
|
#define __ZMQ_PIPE_READER_HPP_INCLUDED__
|
||||||
|
|
||||||
#include "object.hpp"
|
#include "object.hpp"
|
||||||
#include "stdint.hpp"
|
#include "stdint.hpp"
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
class pipe_reader_t : public object_t
|
class pipe_reader_t : public object_t
|
||||||
@ -41,7 +41,7 @@ namespace zs
|
|||||||
int get_index ();
|
int get_index ();
|
||||||
|
|
||||||
// Reads a message to the underlying pipe.
|
// Reads a message to the underlying pipe.
|
||||||
bool read (struct zs_msg *msg_);
|
bool read (struct zmq_msg *msg_);
|
||||||
|
|
||||||
// Asks pipe to destroy itself.
|
// Asks pipe to destroy itself.
|
||||||
void terminate ();
|
void terminate ();
|
||||||
|
@ -17,13 +17,13 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "../include/zs.h"
|
#include "../include/zmq.h"
|
||||||
|
|
||||||
#include "pipe_writer.hpp"
|
#include "pipe_writer.hpp"
|
||||||
#include "pipe.hpp"
|
#include "pipe.hpp"
|
||||||
#include "i_demux.hpp"
|
#include "i_demux.hpp"
|
||||||
|
|
||||||
zs::pipe_writer_t::pipe_writer_t (object_t *parent_, pipe_t *pipe_,
|
zmq::pipe_writer_t::pipe_writer_t (object_t *parent_, pipe_t *pipe_,
|
||||||
object_t *peer_, uint64_t hwm_, uint64_t lwm_) :
|
object_t *peer_, uint64_t hwm_, uint64_t lwm_) :
|
||||||
object_t (parent_),
|
object_t (parent_),
|
||||||
pipe (pipe_),
|
pipe (pipe_),
|
||||||
@ -37,34 +37,34 @@ zs::pipe_writer_t::pipe_writer_t (object_t *parent_, pipe_t *pipe_,
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::pipe_writer_t::~pipe_writer_t ()
|
zmq::pipe_writer_t::~pipe_writer_t ()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::pipe_writer_t::set_demux (i_demux *demux_)
|
void zmq::pipe_writer_t::set_demux (i_demux *demux_)
|
||||||
{
|
{
|
||||||
demux = demux_;
|
demux = demux_;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::pipe_writer_t::set_index (int index_)
|
void zmq::pipe_writer_t::set_index (int index_)
|
||||||
{
|
{
|
||||||
index = index_;
|
index = index_;
|
||||||
}
|
}
|
||||||
|
|
||||||
int zs::pipe_writer_t::get_index ()
|
int zmq::pipe_writer_t::get_index ()
|
||||||
{
|
{
|
||||||
return index;
|
return index;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool zs::pipe_writer_t::write (zs_msg *msg_)
|
bool zmq::pipe_writer_t::write (zmq_msg *msg_)
|
||||||
{
|
{
|
||||||
size_t msg_size = zs_msg_size (msg_);
|
size_t msg_size = zmq_msg_size (msg_);
|
||||||
|
|
||||||
// If message won't fit into the in-memory pipe, there's no way
|
// If message won't fit into the in-memory pipe, there's no way
|
||||||
// to pass it further.
|
// to pass it further.
|
||||||
// TODO: It should be discarded and 'oversized' notification should be
|
// TODO: It should be discarded and 'oversized' notification should be
|
||||||
// placed into the pipe.
|
// placed into the pipe.
|
||||||
zs_assert (!hwm || msg_size <= hwm);
|
zmq_assert (!hwm || msg_size <= hwm);
|
||||||
|
|
||||||
// If there's not enough space in the pipe at the moment, return false.
|
// If there's not enough space in the pipe at the moment, return false.
|
||||||
if (hwm && tail + msg_size - head > hwm)
|
if (hwm && tail + msg_size - head > hwm)
|
||||||
@ -78,18 +78,18 @@ bool zs::pipe_writer_t::write (zs_msg *msg_)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::pipe_writer_t::flush ()
|
void zmq::pipe_writer_t::flush ()
|
||||||
{
|
{
|
||||||
if (!pipe->flush ())
|
if (!pipe->flush ())
|
||||||
send_tail (peer, tail);
|
send_tail (peer, tail);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::pipe_writer_t::process_head (uint64_t bytes_)
|
void zmq::pipe_writer_t::process_head (uint64_t bytes_)
|
||||||
{
|
{
|
||||||
head = bytes_;
|
head = bytes_;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::pipe_writer_t::terminate ()
|
void zmq::pipe_writer_t::terminate ()
|
||||||
{
|
{
|
||||||
// Disconnect from the associated demux.
|
// Disconnect from the associated demux.
|
||||||
if (demux) {
|
if (demux) {
|
||||||
@ -99,15 +99,15 @@ void zs::pipe_writer_t::terminate ()
|
|||||||
|
|
||||||
// Push the delimiter to the pipe. Delimiter is a notification for pipe
|
// Push the delimiter to the pipe. Delimiter is a notification for pipe
|
||||||
// reader that there will be no more messages in the pipe.
|
// reader that there will be no more messages in the pipe.
|
||||||
zs_msg delimiter;
|
zmq_msg delimiter;
|
||||||
delimiter.content = (zs_msg_content*) ZS_DELIMITER;
|
delimiter.content = (zmq_msg_content*) ZMQ_DELIMITER;
|
||||||
delimiter.shared = false;
|
delimiter.shared = false;
|
||||||
delimiter.vsm_size = 0;
|
delimiter.vsm_size = 0;
|
||||||
pipe->write (delimiter);
|
pipe->write (delimiter);
|
||||||
flush ();
|
flush ();
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::pipe_writer_t::process_terminate ()
|
void zmq::pipe_writer_t::process_terminate ()
|
||||||
{
|
{
|
||||||
// Disconnect from the associated demux.
|
// Disconnect from the associated demux.
|
||||||
if (demux) {
|
if (demux) {
|
||||||
|
@ -17,13 +17,13 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_PIPE_WRITER_HPP_INCLUDED__
|
#ifndef __ZMQ_PIPE_WRITER_HPP_INCLUDED__
|
||||||
#define __ZS_PIPE_WRITER_HPP_INCLUDED__
|
#define __ZMQ_PIPE_WRITER_HPP_INCLUDED__
|
||||||
|
|
||||||
#include "object.hpp"
|
#include "object.hpp"
|
||||||
#include "stdint.hpp"
|
#include "stdint.hpp"
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
class pipe_writer_t : public object_t
|
class pipe_writer_t : public object_t
|
||||||
@ -42,7 +42,7 @@ namespace zs
|
|||||||
|
|
||||||
// Writes a message to the underlying pipe. Returns false if the
|
// Writes a message to the underlying pipe. Returns false if the
|
||||||
// message cannot be written to the pipe at the moment.
|
// message cannot be written to the pipe at the moment.
|
||||||
bool write (struct zs_msg *msg_);
|
bool write (struct zmq_msg *msg_);
|
||||||
|
|
||||||
// Flush the messages downsteam.
|
// Flush the messages downsteam.
|
||||||
void flush ();
|
void flush ();
|
||||||
|
@ -140,43 +140,43 @@
|
|||||||
#undef VERSION
|
#undef VERSION
|
||||||
|
|
||||||
/* Force to use mutexes */
|
/* Force to use mutexes */
|
||||||
#undef ZS_FORCE_MUTEXES
|
#undef ZMQ_FORCE_MUTEXES
|
||||||
|
|
||||||
/* Have AIX OS */
|
/* Have AIX OS */
|
||||||
#undef ZS_HAVE_AIX
|
#undef ZMQ_HAVE_AIX
|
||||||
|
|
||||||
/* Have eventfd extension. */
|
/* Have eventfd extension. */
|
||||||
#undef ZS_HAVE_EVENTFD
|
#undef ZMQ_HAVE_EVENTFD
|
||||||
|
|
||||||
/* Have FreeBSD OS */
|
/* Have FreeBSD OS */
|
||||||
#undef ZS_HAVE_FREEBSD
|
#undef ZMQ_HAVE_FREEBSD
|
||||||
|
|
||||||
/* Have HPUX OS */
|
/* Have HPUX OS */
|
||||||
#undef ZS_HAVE_HPUX
|
#undef ZMQ_HAVE_HPUX
|
||||||
|
|
||||||
/* Have ifaddrs.h header. */
|
/* Have ifaddrs.h header. */
|
||||||
#undef ZS_HAVE_IFADDRS
|
#undef ZMQ_HAVE_IFADDRS
|
||||||
|
|
||||||
/* Have Linux OS */
|
/* Have Linux OS */
|
||||||
#undef ZS_HAVE_LINUX
|
#undef ZMQ_HAVE_LINUX
|
||||||
|
|
||||||
/* Have MinGW32 */
|
/* Have MinGW32 */
|
||||||
#undef ZS_HAVE_MINGW32
|
#undef ZMQ_HAVE_MINGW32
|
||||||
|
|
||||||
/* Have OpenBSD OS */
|
/* Have OpenBSD OS */
|
||||||
#undef ZS_HAVE_OPENBSD
|
#undef ZMQ_HAVE_OPENBSD
|
||||||
|
|
||||||
/* Have DarwinOSX OS */
|
/* Have DarwinOSX OS */
|
||||||
#undef ZS_HAVE_OSX
|
#undef ZMQ_HAVE_OSX
|
||||||
|
|
||||||
/* Have QNX Neutrino OS */
|
/* Have QNX Neutrino OS */
|
||||||
#undef ZS_HAVE_QNXNTO
|
#undef ZMQ_HAVE_QNXNTO
|
||||||
|
|
||||||
/* Have Solaris OS */
|
/* Have Solaris OS */
|
||||||
#undef ZS_HAVE_SOLARIS
|
#undef ZMQ_HAVE_SOLARIS
|
||||||
|
|
||||||
/* Have Windows OS */
|
/* Have Windows OS */
|
||||||
#undef ZS_HAVE_WINDOWS
|
#undef ZMQ_HAVE_WINDOWS
|
||||||
|
|
||||||
/* Define for Solaris 2.5.1 so the uint32_t typedef from <sys/synch.h>,
|
/* Define for Solaris 2.5.1 so the uint32_t typedef from <sys/synch.h>,
|
||||||
<pthread.h>, or <semaphore.h> is not used. If the typedef was allowed, the
|
<pthread.h>, or <semaphore.h> is not used. If the typedef was allowed, the
|
||||||
|
40
src/poll.cpp
40
src/poll.cpp
@ -19,10 +19,10 @@
|
|||||||
|
|
||||||
#include "platform.hpp"
|
#include "platform.hpp"
|
||||||
|
|
||||||
#if defined ZS_HAVE_LINUX || defined ZS_HAVE_FREEBSD ||\
|
#if defined ZMQ_HAVE_LINUX || defined ZMQ_HAVE_FREEBSD ||\
|
||||||
defined ZS_HAVE_OPENBSD || defined ZS_HAVE_SOLARIS ||\
|
defined ZMQ_HAVE_OPENBSD || defined ZMQ_HAVE_SOLARIS ||\
|
||||||
defined ZS_HAVE_OSX || defined ZS_HAVE_QNXNTO ||\
|
defined ZMQ_HAVE_OSX || defined ZMQ_HAVE_QNXNTO ||\
|
||||||
defined ZS_HAVE_HPUX || defined ZS_HAVE_AIX
|
defined ZMQ_HAVE_HPUX || defined ZMQ_HAVE_AIX
|
||||||
|
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <sys/time.h>
|
#include <sys/time.h>
|
||||||
@ -35,7 +35,7 @@
|
|||||||
#include "config.hpp"
|
#include "config.hpp"
|
||||||
#include "i_poll_events.hpp"
|
#include "i_poll_events.hpp"
|
||||||
|
|
||||||
zs::poll_t::poll_t () :
|
zmq::poll_t::poll_t () :
|
||||||
retired (false),
|
retired (false),
|
||||||
stopping (false)
|
stopping (false)
|
||||||
{
|
{
|
||||||
@ -50,7 +50,7 @@ zs::poll_t::poll_t () :
|
|||||||
fd_table [i].index = retired_fd;
|
fd_table [i].index = retired_fd;
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::handle_t zs::poll_t::add_fd (fd_t fd_, i_poll_events *events_)
|
zmq::handle_t zmq::poll_t::add_fd (fd_t fd_, i_poll_events *events_)
|
||||||
{
|
{
|
||||||
pollfd pfd = {fd_, 0, 0};
|
pollfd pfd = {fd_, 0, 0};
|
||||||
pollset.push_back (pfd);
|
pollset.push_back (pfd);
|
||||||
@ -67,7 +67,7 @@ zs::handle_t zs::poll_t::add_fd (fd_t fd_, i_poll_events *events_)
|
|||||||
return handle;
|
return handle;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::poll_t::rm_fd (handle_t handle_)
|
void zmq::poll_t::rm_fd (handle_t handle_)
|
||||||
{
|
{
|
||||||
fd_t index = fd_table [handle_.fd].index;
|
fd_t index = fd_table [handle_.fd].index;
|
||||||
assert (index != retired_fd);
|
assert (index != retired_fd);
|
||||||
@ -81,63 +81,63 @@ void zs::poll_t::rm_fd (handle_t handle_)
|
|||||||
load.sub (1);
|
load.sub (1);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::poll_t::set_pollin (handle_t handle_)
|
void zmq::poll_t::set_pollin (handle_t handle_)
|
||||||
{
|
{
|
||||||
int index = fd_table [handle_.fd].index;
|
int index = fd_table [handle_.fd].index;
|
||||||
pollset [index].events |= POLLIN;
|
pollset [index].events |= POLLIN;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::poll_t::reset_pollin (handle_t handle_)
|
void zmq::poll_t::reset_pollin (handle_t handle_)
|
||||||
{
|
{
|
||||||
int index = fd_table [handle_.fd].index;
|
int index = fd_table [handle_.fd].index;
|
||||||
pollset [index].events &= ~((short) POLLIN);
|
pollset [index].events &= ~((short) POLLIN);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::poll_t::set_pollout (handle_t handle_)
|
void zmq::poll_t::set_pollout (handle_t handle_)
|
||||||
{
|
{
|
||||||
int index = fd_table [handle_.fd].index;
|
int index = fd_table [handle_.fd].index;
|
||||||
pollset [index].events |= POLLOUT;
|
pollset [index].events |= POLLOUT;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::poll_t::reset_pollout (handle_t handle_)
|
void zmq::poll_t::reset_pollout (handle_t handle_)
|
||||||
{
|
{
|
||||||
int index = fd_table [handle_.fd].index;
|
int index = fd_table [handle_.fd].index;
|
||||||
pollset [index].events &= ~((short) POLLOUT);
|
pollset [index].events &= ~((short) POLLOUT);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::poll_t::add_timer (i_poll_events *events_)
|
void zmq::poll_t::add_timer (i_poll_events *events_)
|
||||||
{
|
{
|
||||||
timers.push_back (events_);
|
timers.push_back (events_);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::poll_t::cancel_timer (i_poll_events *events_)
|
void zmq::poll_t::cancel_timer (i_poll_events *events_)
|
||||||
{
|
{
|
||||||
timers_t::iterator it = std::find (timers.begin (), timers.end (), events_);
|
timers_t::iterator it = std::find (timers.begin (), timers.end (), events_);
|
||||||
if (it != timers.end ())
|
if (it != timers.end ())
|
||||||
timers.erase (it);
|
timers.erase (it);
|
||||||
}
|
}
|
||||||
|
|
||||||
int zs::poll_t::get_load ()
|
int zmq::poll_t::get_load ()
|
||||||
{
|
{
|
||||||
return load.get ();
|
return load.get ();
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::poll_t::start ()
|
void zmq::poll_t::start ()
|
||||||
{
|
{
|
||||||
worker.start (worker_routine, this);
|
worker.start (worker_routine, this);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::poll_t::stop ()
|
void zmq::poll_t::stop ()
|
||||||
{
|
{
|
||||||
stopping = true;
|
stopping = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::poll_t::join ()
|
void zmq::poll_t::join ()
|
||||||
{
|
{
|
||||||
worker.stop ();
|
worker.stop ();
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::poll_t::loop ()
|
void zmq::poll_t::loop ()
|
||||||
{
|
{
|
||||||
while (!stopping) {
|
while (!stopping) {
|
||||||
|
|
||||||
@ -166,7 +166,7 @@ void zs::poll_t::loop ()
|
|||||||
for (pollset_t::iterator it = pollset.begin ();
|
for (pollset_t::iterator it = pollset.begin ();
|
||||||
it != pollset.end (); it ++) {
|
it != pollset.end (); it ++) {
|
||||||
|
|
||||||
zs_assert (!(it->revents & POLLNVAL));
|
zmq_assert (!(it->revents & POLLNVAL));
|
||||||
if (it->fd == retired_fd)
|
if (it->fd == retired_fd)
|
||||||
continue;
|
continue;
|
||||||
if (it->revents & (POLLERR | POLLHUP))
|
if (it->revents & (POLLERR | POLLHUP))
|
||||||
@ -197,7 +197,7 @@ void zs::poll_t::loop ()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::poll_t::worker_routine (void *arg_)
|
void zmq::poll_t::worker_routine (void *arg_)
|
||||||
{
|
{
|
||||||
((poll_t*) arg_)->loop ();
|
((poll_t*) arg_)->loop ();
|
||||||
}
|
}
|
||||||
|
14
src/poll.hpp
14
src/poll.hpp
@ -17,15 +17,15 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_POLL_HPP_INCLUDED__
|
#ifndef __ZMQ_POLL_HPP_INCLUDED__
|
||||||
#define __ZS_POLL_HPP_INCLUDED__
|
#define __ZMQ_POLL_HPP_INCLUDED__
|
||||||
|
|
||||||
#include "platform.hpp"
|
#include "platform.hpp"
|
||||||
|
|
||||||
#if defined ZS_HAVE_LINUX || defined ZS_HAVE_FREEBSD ||\
|
#if defined ZMQ_HAVE_LINUX || defined ZMQ_HAVE_FREEBSD ||\
|
||||||
defined ZS_HAVE_OPENBSD || defined ZS_HAVE_SOLARIS ||\
|
defined ZMQ_HAVE_OPENBSD || defined ZMQ_HAVE_SOLARIS ||\
|
||||||
defined ZS_HAVE_OSX || defined ZS_HAVE_QNXNTO ||\
|
defined ZMQ_HAVE_OSX || defined ZMQ_HAVE_QNXNTO ||\
|
||||||
defined ZS_HAVE_HPUX || defined ZS_HAVE_AIX
|
defined ZMQ_HAVE_HPUX || defined ZMQ_HAVE_AIX
|
||||||
|
|
||||||
#include <poll.h>
|
#include <poll.h>
|
||||||
#include <stddef.h>
|
#include <stddef.h>
|
||||||
@ -36,7 +36,7 @@
|
|||||||
#include "thread.hpp"
|
#include "thread.hpp"
|
||||||
#include "atomic_counter.hpp"
|
#include "atomic_counter.hpp"
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
// Implements socket polling mechanism using the POSIX.1-2001
|
// Implements socket polling mechanism using the POSIX.1-2001
|
||||||
|
@ -17,20 +17,20 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "../include/zs.h"
|
#include "../include/zmq.h"
|
||||||
|
|
||||||
#include "pub.hpp"
|
#include "pub.hpp"
|
||||||
#include "app_thread.hpp"
|
#include "app_thread.hpp"
|
||||||
#include "session.hpp"
|
#include "session.hpp"
|
||||||
#include "err.hpp"
|
#include "err.hpp"
|
||||||
|
|
||||||
zs::pub_t::pub_t (app_thread_t *thread_, session_t *session_) :
|
zmq::pub_t::pub_t (app_thread_t *thread_, session_t *session_) :
|
||||||
socket_base_t (thread_, session_)
|
socket_base_t (thread_, session_)
|
||||||
{
|
{
|
||||||
disable_in ();
|
disable_in ();
|
||||||
}
|
}
|
||||||
|
|
||||||
int zs::pub_t::recv (struct zs_msg *msg_, int flags_)
|
int zmq::pub_t::recv (struct zmq_msg *msg_, int flags_)
|
||||||
{
|
{
|
||||||
// Publisher socket has no recv function.
|
// Publisher socket has no recv function.
|
||||||
errno = ENOTSUP;
|
errno = ENOTSUP;
|
||||||
|
@ -17,12 +17,12 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_PUB_HPP_INCLUDED__
|
#ifndef __ZMQ_PUB_HPP_INCLUDED__
|
||||||
#define __ZS_PUB_HPP_INCLUDED__
|
#define __ZMQ_PUB_HPP_INCLUDED__
|
||||||
|
|
||||||
#include "socket_base.hpp"
|
#include "socket_base.hpp"
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
class pub_t : public socket_base_t
|
class pub_t : public socket_base_t
|
||||||
@ -32,7 +32,7 @@ namespace zs
|
|||||||
pub_t (class app_thread_t *thread_, class session_t *session_);
|
pub_t (class app_thread_t *thread_, class session_t *session_);
|
||||||
|
|
||||||
// i_api overloads.
|
// i_api overloads.
|
||||||
int recv (struct zs_msg *msg_, int flags_);
|
int recv (struct zmq_msg *msg_, int flags_);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
|
@ -17,13 +17,13 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "../include/zs.h"
|
#include "../include/zmq.h"
|
||||||
|
|
||||||
#include "rep.hpp"
|
#include "rep.hpp"
|
||||||
#include "app_thread.hpp"
|
#include "app_thread.hpp"
|
||||||
#include "session.hpp"
|
#include "session.hpp"
|
||||||
|
|
||||||
zs::rep_t::rep_t (app_thread_t *thread_, session_t *session_) :
|
zmq::rep_t::rep_t (app_thread_t *thread_, session_t *session_) :
|
||||||
socket_base_t (thread_, session_)
|
socket_base_t (thread_, session_)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
@ -17,12 +17,12 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_REP_HPP_INCLUDED__
|
#ifndef __ZMQ_REP_HPP_INCLUDED__
|
||||||
#define __ZS_REP_HPP_INCLUDED__
|
#define __ZMQ_REP_HPP_INCLUDED__
|
||||||
|
|
||||||
#include "socket_base.hpp"
|
#include "socket_base.hpp"
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
class rep_t : public socket_base_t
|
class rep_t : public socket_base_t
|
||||||
|
@ -17,13 +17,13 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "../include/zs.h"
|
#include "../include/zmq.h"
|
||||||
|
|
||||||
#include "req.hpp"
|
#include "req.hpp"
|
||||||
#include "app_thread.hpp"
|
#include "app_thread.hpp"
|
||||||
#include "session.hpp"
|
#include "session.hpp"
|
||||||
|
|
||||||
zs::req_t::req_t (app_thread_t *thread_, session_t *session_) :
|
zmq::req_t::req_t (app_thread_t *thread_, session_t *session_) :
|
||||||
socket_base_t (thread_, session_)
|
socket_base_t (thread_, session_)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
@ -17,12 +17,12 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_REQ_HPP_INCLUDED__
|
#ifndef __ZMQ_REQ_HPP_INCLUDED__
|
||||||
#define __ZS_REQ_HPP_INCLUDED__
|
#define __ZMQ_REQ_HPP_INCLUDED__
|
||||||
|
|
||||||
#include "socket_base.hpp"
|
#include "socket_base.hpp"
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
class req_t : public socket_base_t
|
class req_t : public socket_base_t
|
||||||
|
@ -19,7 +19,7 @@
|
|||||||
|
|
||||||
#include "safe_object.hpp"
|
#include "safe_object.hpp"
|
||||||
|
|
||||||
zs::safe_object_t::safe_object_t (class dispatcher_t *dispatcher_,
|
zmq::safe_object_t::safe_object_t (class dispatcher_t *dispatcher_,
|
||||||
int thread_slot_) :
|
int thread_slot_) :
|
||||||
object_t (dispatcher_, thread_slot_),
|
object_t (dispatcher_, thread_slot_),
|
||||||
processed_seqnum (0),
|
processed_seqnum (0),
|
||||||
@ -27,14 +27,14 @@ zs::safe_object_t::safe_object_t (class dispatcher_t *dispatcher_,
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::safe_object_t::safe_object_t (object_t *parent_) :
|
zmq::safe_object_t::safe_object_t (object_t *parent_) :
|
||||||
object_t (parent_),
|
object_t (parent_),
|
||||||
processed_seqnum (0),
|
processed_seqnum (0),
|
||||||
terminating (false)
|
terminating (false)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::safe_object_t::inc_seqnum ()
|
void zmq::safe_object_t::inc_seqnum ()
|
||||||
{
|
{
|
||||||
// This function is called from the sender thread to ensure that this
|
// This function is called from the sender thread to ensure that this
|
||||||
// object will still exist when the command sent to it arrives in the
|
// object will still exist when the command sent to it arrives in the
|
||||||
@ -42,7 +42,7 @@ void zs::safe_object_t::inc_seqnum ()
|
|||||||
sent_seqnum.add (1);
|
sent_seqnum.add (1);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::safe_object_t::process_command (struct command_t &cmd_)
|
void zmq::safe_object_t::process_command (struct command_t &cmd_)
|
||||||
{
|
{
|
||||||
object_t::process_command (cmd_);
|
object_t::process_command (cmd_);
|
||||||
|
|
||||||
@ -55,7 +55,7 @@ void zs::safe_object_t::process_command (struct command_t &cmd_)
|
|||||||
delete this;
|
delete this;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::safe_object_t::terminate ()
|
void zmq::safe_object_t::terminate ()
|
||||||
{
|
{
|
||||||
// Wait till all commands sent to this session are processed.
|
// Wait till all commands sent to this session are processed.
|
||||||
terminating = true;
|
terminating = true;
|
||||||
@ -66,11 +66,11 @@ void zs::safe_object_t::terminate ()
|
|||||||
delete this;
|
delete this;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool zs::safe_object_t::is_terminating ()
|
bool zmq::safe_object_t::is_terminating ()
|
||||||
{
|
{
|
||||||
return terminating;
|
return terminating;
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::safe_object_t::~safe_object_t ()
|
zmq::safe_object_t::~safe_object_t ()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
@ -17,13 +17,13 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_SAFE_OBJECT_HPP_INCLUDED__
|
#ifndef __ZMQ_SAFE_OBJECT_HPP_INCLUDED__
|
||||||
#define __ZS_SAFE_OBJECT_HPP_INCLUDED__
|
#define __ZMQ_SAFE_OBJECT_HPP_INCLUDED__
|
||||||
|
|
||||||
#include "object.hpp"
|
#include "object.hpp"
|
||||||
#include "atomic_counter.hpp"
|
#include "atomic_counter.hpp"
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
// Same as object_t with the exception of termination mechanism. While
|
// Same as object_t with the exception of termination mechanism. While
|
||||||
|
@ -22,13 +22,13 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
|
|
||||||
#ifdef ZS_HAVE_WINDOWS
|
#ifdef ZMQ_HAVE_WINDOWS
|
||||||
#include "winsock2.h"
|
#include "winsock2.h"
|
||||||
#elif defined ZS_HAVE_HPUX
|
#elif defined ZMQ_HAVE_HPUX
|
||||||
#include <sys/param.h>
|
#include <sys/param.h>
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <sys/time.h>
|
#include <sys/time.h>
|
||||||
#elif defined ZS_HAVE_OPENVMS
|
#elif defined ZMQ_HAVE_OPENVMS
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <sys/time.h>
|
#include <sys/time.h>
|
||||||
#else
|
#else
|
||||||
@ -40,7 +40,7 @@
|
|||||||
#include "config.hpp"
|
#include "config.hpp"
|
||||||
#include "i_poll_events.hpp"
|
#include "i_poll_events.hpp"
|
||||||
|
|
||||||
zs::select_t::select_t () :
|
zmq::select_t::select_t () :
|
||||||
maxfd (retired_fd),
|
maxfd (retired_fd),
|
||||||
retired (false),
|
retired (false),
|
||||||
stopping (false)
|
stopping (false)
|
||||||
@ -51,7 +51,7 @@ zs::select_t::select_t () :
|
|||||||
FD_ZERO (&source_set_err);
|
FD_ZERO (&source_set_err);
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::handle_t zs::select_t::add_fd (fd_t fd_, i_poll_events *events_)
|
zmq::handle_t zmq::select_t::add_fd (fd_t fd_, i_poll_events *events_)
|
||||||
{
|
{
|
||||||
// Store the file descriptor.
|
// Store the file descriptor.
|
||||||
fd_entry_t entry = {fd_, events_};
|
fd_entry_t entry = {fd_, events_};
|
||||||
@ -72,7 +72,7 @@ zs::handle_t zs::select_t::add_fd (fd_t fd_, i_poll_events *events_)
|
|||||||
return handle;
|
return handle;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::select_t::rm_fd (handle_t handle_)
|
void zmq::select_t::rm_fd (handle_t handle_)
|
||||||
{
|
{
|
||||||
// Get file descriptor.
|
// Get file descriptor.
|
||||||
fd_t fd = handle_.fd;
|
fd_t fd = handle_.fd;
|
||||||
@ -82,7 +82,7 @@ void zs::select_t::rm_fd (handle_t handle_)
|
|||||||
for (it = fds.begin (); it != fds.end (); it ++)
|
for (it = fds.begin (); it != fds.end (); it ++)
|
||||||
if (it->fd == fd)
|
if (it->fd == fd)
|
||||||
break;
|
break;
|
||||||
zs_assert (it != fds.end ());
|
zmq_assert (it != fds.end ());
|
||||||
it->fd = retired_fd;
|
it->fd = retired_fd;
|
||||||
retired = true;
|
retired = true;
|
||||||
|
|
||||||
@ -109,59 +109,59 @@ void zs::select_t::rm_fd (handle_t handle_)
|
|||||||
load.sub (1);
|
load.sub (1);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::select_t::set_pollin (handle_t handle_)
|
void zmq::select_t::set_pollin (handle_t handle_)
|
||||||
{
|
{
|
||||||
FD_SET (handle_.fd, &source_set_in);
|
FD_SET (handle_.fd, &source_set_in);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::select_t::reset_pollin (handle_t handle_)
|
void zmq::select_t::reset_pollin (handle_t handle_)
|
||||||
{
|
{
|
||||||
FD_CLR (handle_.fd, &source_set_in);
|
FD_CLR (handle_.fd, &source_set_in);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::select_t::set_pollout (handle_t handle_)
|
void zmq::select_t::set_pollout (handle_t handle_)
|
||||||
{
|
{
|
||||||
FD_SET (handle_.fd, &source_set_out);
|
FD_SET (handle_.fd, &source_set_out);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::select_t::reset_pollout (handle_t handle_)
|
void zmq::select_t::reset_pollout (handle_t handle_)
|
||||||
{
|
{
|
||||||
FD_CLR (handle_.fd, &source_set_out);
|
FD_CLR (handle_.fd, &source_set_out);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::select_t::add_timer (i_poll_events *events_)
|
void zmq::select_t::add_timer (i_poll_events *events_)
|
||||||
{
|
{
|
||||||
timers.push_back (events_);
|
timers.push_back (events_);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::select_t::cancel_timer (i_poll_events *events_)
|
void zmq::select_t::cancel_timer (i_poll_events *events_)
|
||||||
{
|
{
|
||||||
timers_t::iterator it = std::find (timers.begin (), timers.end (), events_);
|
timers_t::iterator it = std::find (timers.begin (), timers.end (), events_);
|
||||||
if (it != timers.end ())
|
if (it != timers.end ())
|
||||||
timers.erase (it);
|
timers.erase (it);
|
||||||
}
|
}
|
||||||
|
|
||||||
int zs::select_t::get_load ()
|
int zmq::select_t::get_load ()
|
||||||
{
|
{
|
||||||
return load.get ();
|
return load.get ();
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::select_t::start ()
|
void zmq::select_t::start ()
|
||||||
{
|
{
|
||||||
worker.start (worker_routine, this);
|
worker.start (worker_routine, this);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::select_t::stop ()
|
void zmq::select_t::stop ()
|
||||||
{
|
{
|
||||||
stopping = true;
|
stopping = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::select_t::join ()
|
void zmq::select_t::join ()
|
||||||
{
|
{
|
||||||
worker.stop ();
|
worker.stop ();
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::select_t::loop ()
|
void zmq::select_t::loop ()
|
||||||
{
|
{
|
||||||
while (!stopping) {
|
while (!stopping) {
|
||||||
|
|
||||||
@ -179,7 +179,7 @@ void zs::select_t::loop ()
|
|||||||
int rc = select (maxfd + 1, &readfds, &writefds, &exceptfds,
|
int rc = select (maxfd + 1, &readfds, &writefds, &exceptfds,
|
||||||
timers.empty () ? NULL : &timeout);
|
timers.empty () ? NULL : &timeout);
|
||||||
|
|
||||||
#ifdef ZS_HAVE_WINDOWS
|
#ifdef ZMQ_HAVE_WINDOWS
|
||||||
wsa_assert (rc != SOCKET_ERROR);
|
wsa_assert (rc != SOCKET_ERROR);
|
||||||
#else
|
#else
|
||||||
if (rc == -1 && errno == EINTR)
|
if (rc == -1 && errno == EINTR)
|
||||||
@ -230,7 +230,7 @@ void zs::select_t::loop ()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::select_t::worker_routine (void *arg_)
|
void zmq::select_t::worker_routine (void *arg_)
|
||||||
{
|
{
|
||||||
((select_t*) arg_)->loop ();
|
((select_t*) arg_)->loop ();
|
||||||
}
|
}
|
||||||
|
@ -17,17 +17,17 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_SELECT_HPP_INCLUDED__
|
#ifndef __ZMQ_SELECT_HPP_INCLUDED__
|
||||||
#define __ZS_SELECT_HPP_INCLUDED__
|
#define __ZMQ_SELECT_HPP_INCLUDED__
|
||||||
|
|
||||||
#include "platform.hpp"
|
#include "platform.hpp"
|
||||||
|
|
||||||
#include <stddef.h>
|
#include <stddef.h>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
#ifdef ZS_HAVE_WINDOWS
|
#ifdef ZMQ_HAVE_WINDOWS
|
||||||
#include "winsock2.h"
|
#include "winsock2.h"
|
||||||
#elif defined ZS_HAVE_OPENVMS
|
#elif defined ZMQ_HAVE_OPENVMS
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <sys/time.h>
|
#include <sys/time.h>
|
||||||
#else
|
#else
|
||||||
@ -39,7 +39,7 @@
|
|||||||
#include "thread.hpp"
|
#include "thread.hpp"
|
||||||
#include "atomic_counter.hpp"
|
#include "atomic_counter.hpp"
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
// Implements socket polling mechanism using POSIX.1-2001 select()
|
// Implements socket polling mechanism using POSIX.1-2001 select()
|
||||||
|
@ -17,7 +17,7 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "../include/zs.h"
|
#include "../include/zmq.h"
|
||||||
|
|
||||||
#include "session.hpp"
|
#include "session.hpp"
|
||||||
#include "i_engine.hpp"
|
#include "i_engine.hpp"
|
||||||
@ -30,7 +30,7 @@
|
|||||||
#include "pipe_writer.hpp"
|
#include "pipe_writer.hpp"
|
||||||
#include "simple_semaphore.hpp"
|
#include "simple_semaphore.hpp"
|
||||||
|
|
||||||
zs::session_t::session_t (object_t *parent_, i_thread *thread_,
|
zmq::session_t::session_t (object_t *parent_, i_thread *thread_,
|
||||||
i_mux *mux_, i_demux *demux_,
|
i_mux *mux_, i_demux *demux_,
|
||||||
bool terminate_on_disconnect_, bool terminate_on_no_pipes_) :
|
bool terminate_on_disconnect_, bool terminate_on_no_pipes_) :
|
||||||
safe_object_t (parent_),
|
safe_object_t (parent_),
|
||||||
@ -45,7 +45,7 @@ zs::session_t::session_t (object_t *parent_, i_thread *thread_,
|
|||||||
{
|
{
|
||||||
// At least one way to terminate the session should be allowed. Otherwise
|
// At least one way to terminate the session should be allowed. Otherwise
|
||||||
// the session can be orphaned forever.
|
// the session can be orphaned forever.
|
||||||
zs_assert (terminate_on_disconnect || terminate_on_no_pipes_delayed);
|
zmq_assert (terminate_on_disconnect || terminate_on_no_pipes_delayed);
|
||||||
|
|
||||||
// Give the mux and the demux callback pointer to ourselves.
|
// Give the mux and the demux callback pointer to ourselves.
|
||||||
if (mux)
|
if (mux)
|
||||||
@ -54,7 +54,7 @@ zs::session_t::session_t (object_t *parent_, i_thread *thread_,
|
|||||||
demux->set_session (this);
|
demux->set_session (this);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::session_t::shutdown ()
|
void zmq::session_t::shutdown ()
|
||||||
{
|
{
|
||||||
// Session may live even without an associated engine, thus we have
|
// Session may live even without an associated engine, thus we have
|
||||||
// to check if for NULL value.
|
// to check if for NULL value.
|
||||||
@ -70,7 +70,7 @@ void zs::session_t::shutdown ()
|
|||||||
delete this;
|
delete this;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::session_t::disconnected ()
|
void zmq::session_t::disconnected ()
|
||||||
{
|
{
|
||||||
// It's engine who calls this function so there's no need to deallocate
|
// It's engine who calls this function so there's no need to deallocate
|
||||||
// the engine. Just drop the reference.
|
// the engine. Just drop the reference.
|
||||||
@ -84,7 +84,7 @@ void zs::session_t::disconnected ()
|
|||||||
terminate ();
|
terminate ();
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::session_t::bind (object_t *peer_, bool in_, bool out_)
|
void zmq::session_t::bind (object_t *peer_, bool in_, bool out_)
|
||||||
{
|
{
|
||||||
// Create the out pipe (if required).
|
// Create the out pipe (if required).
|
||||||
pipe_reader_t *pipe_reader = NULL;
|
pipe_reader_t *pipe_reader = NULL;
|
||||||
@ -107,13 +107,13 @@ void zs::session_t::bind (object_t *peer_, bool in_, bool out_)
|
|||||||
send_bind (peer_, pipe_reader, in_ ? this : NULL);
|
send_bind (peer_, pipe_reader, in_ ? this : NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::session_t::revive ()
|
void zmq::session_t::revive ()
|
||||||
{
|
{
|
||||||
if (engine)
|
if (engine)
|
||||||
engine->revive ();
|
engine->revive ();
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::session_t::terminate ()
|
void zmq::session_t::terminate ()
|
||||||
{
|
{
|
||||||
// Terminate is always called by engine, thus it'll terminate itself,
|
// Terminate is always called by engine, thus it'll terminate itself,
|
||||||
// we just have to drop the pointer.
|
// we just have to drop the pointer.
|
||||||
@ -138,7 +138,7 @@ void zs::session_t::terminate ()
|
|||||||
safe_object_t::terminate ();
|
safe_object_t::terminate ();
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::session_t::~session_t ()
|
zmq::session_t::~session_t ()
|
||||||
{
|
{
|
||||||
// When session is actually deallocated it unregisters from its thread.
|
// When session is actually deallocated it unregisters from its thread.
|
||||||
// Unregistration cannot be done earlier as it would result in memory
|
// Unregistration cannot be done earlier as it would result in memory
|
||||||
@ -146,44 +146,44 @@ zs::session_t::~session_t ()
|
|||||||
thread->detach_session (this);
|
thread->detach_session (this);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::session_t::set_engine (i_engine *engine_)
|
void zmq::session_t::set_engine (i_engine *engine_)
|
||||||
{
|
{
|
||||||
zs_assert (!engine || !engine_);
|
zmq_assert (!engine || !engine_);
|
||||||
engine = engine_;
|
engine = engine_;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::session_t::set_index (int index_)
|
void zmq::session_t::set_index (int index_)
|
||||||
{
|
{
|
||||||
index = index_;
|
index = index_;
|
||||||
}
|
}
|
||||||
|
|
||||||
int zs::session_t::get_index ()
|
int zmq::session_t::get_index ()
|
||||||
{
|
{
|
||||||
return index;
|
return index;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool zs::session_t::write (zs_msg *msg_)
|
bool zmq::session_t::write (zmq_msg *msg_)
|
||||||
{
|
{
|
||||||
return demux->send (msg_);
|
return demux->send (msg_);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::session_t::flush ()
|
void zmq::session_t::flush ()
|
||||||
{
|
{
|
||||||
demux->flush ();
|
demux->flush ();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool zs::session_t::read (zs_msg *msg_)
|
bool zmq::session_t::read (zmq_msg *msg_)
|
||||||
{
|
{
|
||||||
bool retrieved = mux->recv (msg_);
|
bool retrieved = mux->recv (msg_);
|
||||||
if (terminate_on_no_pipes && mux->empty () && demux->empty ()) {
|
if (terminate_on_no_pipes && mux->empty () && demux->empty ()) {
|
||||||
zs_assert (engine);
|
zmq_assert (engine);
|
||||||
engine->schedule_terminate ();
|
engine->schedule_terminate ();
|
||||||
terminate ();
|
terminate ();
|
||||||
}
|
}
|
||||||
return retrieved;
|
return retrieved;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::session_t::process_bind (pipe_reader_t *reader_, session_t *peer_)
|
void zmq::session_t::process_bind (pipe_reader_t *reader_, session_t *peer_)
|
||||||
{
|
{
|
||||||
if (is_terminating ()) {
|
if (is_terminating ()) {
|
||||||
|
|
||||||
@ -223,9 +223,9 @@ void zs::session_t::process_bind (pipe_reader_t *reader_, session_t *peer_)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::session_t::process_reg (simple_semaphore_t *smph_)
|
void zmq::session_t::process_reg (simple_semaphore_t *smph_)
|
||||||
{
|
{
|
||||||
zs_assert (!is_terminating ());
|
zmq_assert (!is_terminating ());
|
||||||
|
|
||||||
// Add the session to the list of sessions associated with this I/O thread.
|
// Add the session to the list of sessions associated with this I/O thread.
|
||||||
// This way the session will be deallocated on the terminal shutdown.
|
// This way the session will be deallocated on the terminal shutdown.
|
||||||
@ -236,10 +236,10 @@ void zs::session_t::process_reg (simple_semaphore_t *smph_)
|
|||||||
smph_->post ();
|
smph_->post ();
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::session_t::process_reg_and_bind (session_t *peer_,
|
void zmq::session_t::process_reg_and_bind (session_t *peer_,
|
||||||
bool flow_in_, bool flow_out_)
|
bool flow_in_, bool flow_out_)
|
||||||
{
|
{
|
||||||
zs_assert (!is_terminating ());
|
zmq_assert (!is_terminating ());
|
||||||
|
|
||||||
// Add the session to the list of sessions associated with this I/O thread.
|
// Add the session to the list of sessions associated with this I/O thread.
|
||||||
// This way the session will be deallocated on the terminal shutdown.
|
// This way the session will be deallocated on the terminal shutdown.
|
||||||
@ -260,7 +260,7 @@ void zs::session_t::process_reg_and_bind (session_t *peer_,
|
|||||||
send_bind (peer_, pipe_reader, flow_in_ ? this : NULL);
|
send_bind (peer_, pipe_reader, flow_in_ ? this : NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::session_t::process_engine (i_engine *engine_)
|
void zmq::session_t::process_engine (i_engine *engine_)
|
||||||
{
|
{
|
||||||
if (is_terminating ()) {
|
if (is_terminating ()) {
|
||||||
|
|
||||||
|
@ -17,15 +17,15 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_SESSION_HPP_INCLUDED__
|
#ifndef __ZMQ_SESSION_HPP_INCLUDED__
|
||||||
#define __ZS_SESSION_HPP_INCLUDED__
|
#define __ZMQ_SESSION_HPP_INCLUDED__
|
||||||
|
|
||||||
#include "i_session.hpp"
|
#include "i_session.hpp"
|
||||||
#include "safe_object.hpp"
|
#include "safe_object.hpp"
|
||||||
#include "stdint.hpp"
|
#include "stdint.hpp"
|
||||||
#include "atomic_counter.hpp"
|
#include "atomic_counter.hpp"
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
// Object that encapsulates both mux and demux.
|
// Object that encapsulates both mux and demux.
|
||||||
@ -42,8 +42,8 @@ namespace zs
|
|||||||
// i_session implementation
|
// i_session implementation
|
||||||
void set_engine (struct i_engine *engine_);
|
void set_engine (struct i_engine *engine_);
|
||||||
void shutdown ();
|
void shutdown ();
|
||||||
bool read (struct zs_msg *msg_);
|
bool read (struct zmq_msg *msg_);
|
||||||
bool write (struct zs_msg *msg_);
|
bool write (struct zmq_msg *msg_);
|
||||||
void flush ();
|
void flush ();
|
||||||
|
|
||||||
// Called by the engine when it is being closed.
|
// Called by the engine when it is being closed.
|
||||||
|
@ -19,14 +19,14 @@
|
|||||||
|
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
#include "../include/zs.h"
|
#include "../include/zmq.h"
|
||||||
|
|
||||||
#include "session_stub.hpp"
|
#include "session_stub.hpp"
|
||||||
#include "i_engine.hpp"
|
#include "i_engine.hpp"
|
||||||
#include "listener.hpp"
|
#include "listener.hpp"
|
||||||
#include "err.hpp"
|
#include "err.hpp"
|
||||||
|
|
||||||
zs::session_stub_t::session_stub_t (listener_t *listener_) :
|
zmq::session_stub_t::session_stub_t (listener_t *listener_) :
|
||||||
state (reading_identity),
|
state (reading_identity),
|
||||||
engine (NULL),
|
engine (NULL),
|
||||||
listener (listener_),
|
listener (listener_),
|
||||||
@ -34,42 +34,42 @@ zs::session_stub_t::session_stub_t (listener_t *listener_) :
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::session_stub_t::terminate ()
|
void zmq::session_stub_t::terminate ()
|
||||||
{
|
{
|
||||||
if (engine)
|
if (engine)
|
||||||
engine->terminate ();
|
engine->terminate ();
|
||||||
delete this;
|
delete this;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::session_stub_t::shutdown ()
|
void zmq::session_stub_t::shutdown ()
|
||||||
{
|
{
|
||||||
if (engine)
|
if (engine)
|
||||||
engine->shutdown ();
|
engine->shutdown ();
|
||||||
delete this;
|
delete this;
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::session_stub_t::~session_stub_t ()
|
zmq::session_stub_t::~session_stub_t ()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::session_stub_t::set_engine (i_engine *engine_)
|
void zmq::session_stub_t::set_engine (i_engine *engine_)
|
||||||
{
|
{
|
||||||
zs_assert (!engine_ || !engine);
|
zmq_assert (!engine_ || !engine);
|
||||||
engine = engine_;
|
engine = engine_;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool zs::session_stub_t::read (struct zs_msg *msg_)
|
bool zmq::session_stub_t::read (struct zmq_msg *msg_)
|
||||||
{
|
{
|
||||||
// No messages are sent to the connecting peer.
|
// No messages are sent to the connecting peer.
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool zs::session_stub_t::write (struct zs_msg *msg_)
|
bool zmq::session_stub_t::write (struct zmq_msg *msg_)
|
||||||
{
|
{
|
||||||
// The first message arrived is the connection identity.
|
// The first message arrived is the connection identity.
|
||||||
if (state == reading_identity) {
|
if (state == reading_identity) {
|
||||||
identity = std::string ((const char*) zs_msg_data (msg_),
|
identity = std::string ((const char*) zmq_msg_data (msg_),
|
||||||
zs_msg_size (msg_));
|
zmq_msg_size (msg_));
|
||||||
state = has_identity;
|
state = has_identity;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -78,7 +78,7 @@ bool zs::session_stub_t::write (struct zs_msg *msg_)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::session_stub_t::flush ()
|
void zmq::session_stub_t::flush ()
|
||||||
{
|
{
|
||||||
// We have the identity. At this point we can find the correct session and
|
// We have the identity. At this point we can find the correct session and
|
||||||
// attach it to the connection.
|
// attach it to the connection.
|
||||||
@ -91,7 +91,7 @@ void zs::session_stub_t::flush ()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::i_engine *zs::session_stub_t::detach_engine ()
|
zmq::i_engine *zmq::session_stub_t::detach_engine ()
|
||||||
{
|
{
|
||||||
// Ask engine to unregister from the poller.
|
// Ask engine to unregister from the poller.
|
||||||
i_engine *e = engine;
|
i_engine *e = engine;
|
||||||
@ -99,12 +99,12 @@ zs::i_engine *zs::session_stub_t::detach_engine ()
|
|||||||
return e;
|
return e;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::session_stub_t::set_index (int index_)
|
void zmq::session_stub_t::set_index (int index_)
|
||||||
{
|
{
|
||||||
index = index_;
|
index = index_;
|
||||||
}
|
}
|
||||||
|
|
||||||
int zs::session_stub_t::get_index ()
|
int zmq::session_stub_t::get_index ()
|
||||||
{
|
{
|
||||||
return index;
|
return index;
|
||||||
}
|
}
|
||||||
|
@ -17,14 +17,14 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_SESSION_STUB_HPP_INCLUDED__
|
#ifndef __ZMQ_SESSION_STUB_HPP_INCLUDED__
|
||||||
#define __ZS_SESSION_STUB_HPP_INCLUDED__
|
#define __ZMQ_SESSION_STUB_HPP_INCLUDED__
|
||||||
|
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
#include "i_session.hpp"
|
#include "i_session.hpp"
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
// This class is used instead of regular session till the identity of
|
// This class is used instead of regular session till the identity of
|
||||||
@ -41,8 +41,8 @@ namespace zs
|
|||||||
void set_engine (struct i_engine *engine_);
|
void set_engine (struct i_engine *engine_);
|
||||||
void terminate ();
|
void terminate ();
|
||||||
void shutdown ();
|
void shutdown ();
|
||||||
bool read (struct zs_msg *msg_);
|
bool read (struct zmq_msg *msg_);
|
||||||
bool write (struct zs_msg *msg_);
|
bool write (struct zmq_msg *msg_);
|
||||||
void flush ();
|
void flush ();
|
||||||
|
|
||||||
// Detaches engine from the stub. Returns it to the caller.
|
// Detaches engine from the stub. Returns it to the caller.
|
||||||
|
@ -17,21 +17,21 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_SIMPLE_SEMAPHORE_HPP_INCLUDED__
|
#ifndef __ZMQ_SIMPLE_SEMAPHORE_HPP_INCLUDED__
|
||||||
#define __ZS_SIMPLE_SEMAPHORE_HPP_INCLUDED__
|
#define __ZMQ_SIMPLE_SEMAPHORE_HPP_INCLUDED__
|
||||||
|
|
||||||
#include "platform.hpp"
|
#include "platform.hpp"
|
||||||
#include "err.hpp"
|
#include "err.hpp"
|
||||||
|
|
||||||
#if defined ZS_HAVE_LINUX || defined ZS_HAVE_OSX || defined ZS_HAVE_OPENVMS
|
#if defined ZMQ_HAVE_LINUX || defined ZMQ_HAVE_OSX || defined ZMQ_HAVE_OPENVMS
|
||||||
#include <pthread.h>
|
#include <pthread.h>
|
||||||
#elif defined ZS_HAVE_WINDOWS
|
#elif defined ZMQ_HAVE_WINDOWS
|
||||||
#include "windows.hpp"
|
#include "windows.hpp"
|
||||||
#else
|
#else
|
||||||
#include <semaphore.h>
|
#include <semaphore.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
// Simple semaphore. Only single thread may be waiting at any given time.
|
// Simple semaphore. Only single thread may be waiting at any given time.
|
||||||
@ -39,7 +39,7 @@ namespace zs
|
|||||||
// was matched by corresponding wait and the waiting thread was
|
// was matched by corresponding wait and the waiting thread was
|
||||||
// released.
|
// released.
|
||||||
|
|
||||||
#if defined ZS_HAVE_LINUX || defined ZS_HAVE_OSX || defined ZS_HAVE_OPENVMS
|
#if defined ZMQ_HAVE_LINUX || defined ZMQ_HAVE_OSX || defined ZMQ_HAVE_OPENVMS
|
||||||
|
|
||||||
// On platforms that allow for double locking of a mutex from the same
|
// On platforms that allow for double locking of a mutex from the same
|
||||||
// thread, simple semaphore is implemented using mutex, as it is more
|
// thread, simple semaphore is implemented using mutex, as it is more
|
||||||
|
@ -19,7 +19,7 @@
|
|||||||
|
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
#include "../include/zs.h"
|
#include "../include/zmq.h"
|
||||||
|
|
||||||
#include "socket_base.hpp"
|
#include "socket_base.hpp"
|
||||||
#include "app_thread.hpp"
|
#include "app_thread.hpp"
|
||||||
@ -33,7 +33,7 @@
|
|||||||
#include "dummy_aggregator.hpp"
|
#include "dummy_aggregator.hpp"
|
||||||
#include "dummy_distributor.hpp"
|
#include "dummy_distributor.hpp"
|
||||||
|
|
||||||
zs::socket_base_t::socket_base_t (app_thread_t *thread_, session_t *session_) :
|
zmq::socket_base_t::socket_base_t (app_thread_t *thread_, session_t *session_) :
|
||||||
object_t (thread_),
|
object_t (thread_),
|
||||||
thread (thread_),
|
thread (thread_),
|
||||||
session (session_),
|
session (session_),
|
||||||
@ -43,7 +43,7 @@ zs::socket_base_t::socket_base_t (app_thread_t *thread_, session_t *session_) :
|
|||||||
session->set_engine (this);
|
session->set_engine (this);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::socket_base_t::shutdown ()
|
void zmq::socket_base_t::shutdown ()
|
||||||
{
|
{
|
||||||
// Destroy all the I/O objects created from this socket.
|
// Destroy all the I/O objects created from this socket.
|
||||||
for (io_objects_t::size_type i = 0; i != io_objects.size (); i++)
|
for (io_objects_t::size_type i = 0; i != io_objects.size (); i++)
|
||||||
@ -52,13 +52,13 @@ void zs::socket_base_t::shutdown ()
|
|||||||
delete this;
|
delete this;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::socket_base_t::schedule_terminate ()
|
void zmq::socket_base_t::schedule_terminate ()
|
||||||
{
|
{
|
||||||
// Terminate is never scheduled on socket engines.
|
// Terminate is never scheduled on socket engines.
|
||||||
zs_assert (false);
|
zmq_assert (false);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::socket_base_t::terminate ()
|
void zmq::socket_base_t::terminate ()
|
||||||
{
|
{
|
||||||
// Destroy all the I/O objects created from this socket.
|
// Destroy all the I/O objects created from this socket.
|
||||||
// First unregister the object from I/O thread, then terminate it in
|
// First unregister the object from I/O thread, then terminate it in
|
||||||
@ -70,27 +70,27 @@ void zs::socket_base_t::terminate ()
|
|||||||
io_objects [i]->terminate ();
|
io_objects [i]->terminate ();
|
||||||
}
|
}
|
||||||
|
|
||||||
zs_assert (session);
|
zmq_assert (session);
|
||||||
session->disconnected ();
|
session->disconnected ();
|
||||||
|
|
||||||
delete this;
|
delete this;
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::socket_base_t::~socket_base_t ()
|
zmq::socket_base_t::~socket_base_t ()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::socket_base_t::disable_in ()
|
void zmq::socket_base_t::disable_in ()
|
||||||
{
|
{
|
||||||
has_in = false;
|
has_in = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::socket_base_t::disable_out ()
|
void zmq::socket_base_t::disable_out ()
|
||||||
{
|
{
|
||||||
has_out = false;
|
has_out = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
int zs::socket_base_t::bind (const char *addr_, zs_opts *opts_)
|
int zmq::socket_base_t::bind (const char *addr_, zmq_opts *opts_)
|
||||||
{
|
{
|
||||||
thread->process_commands (false);
|
thread->process_commands (false);
|
||||||
|
|
||||||
@ -136,7 +136,7 @@ int zs::socket_base_t::bind (const char *addr_, zs_opts *opts_)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int zs::socket_base_t::connect (const char *addr_, zs_opts *opts_)
|
int zmq::socket_base_t::connect (const char *addr_, zmq_opts *opts_)
|
||||||
{
|
{
|
||||||
thread->process_commands (false);
|
thread->process_commands (false);
|
||||||
|
|
||||||
@ -148,14 +148,14 @@ int zs::socket_base_t::connect (const char *addr_, zs_opts *opts_)
|
|||||||
// session.
|
// session.
|
||||||
io_thread_t *io_thread = choose_io_thread (opts_ ? opts_->taskset : 0);
|
io_thread_t *io_thread = choose_io_thread (opts_ ? opts_->taskset : 0);
|
||||||
i_mux *mux = new dummy_aggregator_t;
|
i_mux *mux = new dummy_aggregator_t;
|
||||||
zs_assert (mux);
|
zmq_assert (mux);
|
||||||
i_demux *demux = new dummy_distributor_t;
|
i_demux *demux = new dummy_distributor_t;
|
||||||
zs_assert (demux);
|
zmq_assert (demux);
|
||||||
session_t *peer = new session_t (io_thread, io_thread, mux, demux,
|
session_t *peer = new session_t (io_thread, io_thread, mux, demux,
|
||||||
false, true);
|
false, true);
|
||||||
zs_assert (peer);
|
zmq_assert (peer);
|
||||||
connecter_t *connecter = new connecter_t (io_thread, addr_, peer);
|
connecter_t *connecter = new connecter_t (io_thread, addr_, peer);
|
||||||
zs_assert (connecter);
|
zmq_assert (connecter);
|
||||||
|
|
||||||
// Increment session's command sequence number so that it won't get
|
// Increment session's command sequence number so that it won't get
|
||||||
// deallocated till the subsequent bind command arrives.
|
// deallocated till the subsequent bind command arrives.
|
||||||
@ -202,20 +202,20 @@ int zs::socket_base_t::connect (const char *addr_, zs_opts *opts_)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int zs::socket_base_t::subscribe (const char *criteria_)
|
int zmq::socket_base_t::subscribe (const char *criteria_)
|
||||||
{
|
{
|
||||||
// No implementation at the moment...
|
// No implementation at the moment...
|
||||||
errno = ENOTSUP;
|
errno = ENOTSUP;
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
int zs::socket_base_t::send (zs_msg *msg_, int flags_)
|
int zmq::socket_base_t::send (zmq_msg *msg_, int flags_)
|
||||||
{
|
{
|
||||||
thread->process_commands (false);
|
thread->process_commands (false);
|
||||||
while (true) {
|
while (true) {
|
||||||
if (session->write (msg_))
|
if (session->write (msg_))
|
||||||
return 0;
|
return 0;
|
||||||
if (flags_ & ZS_NOBLOCK) {
|
if (flags_ & ZMQ_NOBLOCK) {
|
||||||
errno = EAGAIN;
|
errno = EAGAIN;
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
@ -223,20 +223,20 @@ int zs::socket_base_t::send (zs_msg *msg_, int flags_)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int zs::socket_base_t::flush ()
|
int zmq::socket_base_t::flush ()
|
||||||
{
|
{
|
||||||
thread->process_commands (false);
|
thread->process_commands (false);
|
||||||
session->flush ();
|
session->flush ();
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int zs::socket_base_t::recv (zs_msg *msg_, int flags_)
|
int zmq::socket_base_t::recv (zmq_msg *msg_, int flags_)
|
||||||
{
|
{
|
||||||
thread->process_commands (false);
|
thread->process_commands (false);
|
||||||
while (true) {
|
while (true) {
|
||||||
if (session->read (msg_))
|
if (session->read (msg_))
|
||||||
return 0;
|
return 0;
|
||||||
if (flags_ & ZS_NOBLOCK) {
|
if (flags_ & ZMQ_NOBLOCK) {
|
||||||
errno = EAGAIN;
|
errno = EAGAIN;
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
@ -244,23 +244,23 @@ int zs::socket_base_t::recv (zs_msg *msg_, int flags_)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int zs::socket_base_t::close ()
|
int zmq::socket_base_t::close ()
|
||||||
{
|
{
|
||||||
terminate ();
|
terminate ();
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::socket_base_t::attach (struct i_poller *poller_, i_session *session_)
|
void zmq::socket_base_t::attach (struct i_poller *poller_, i_session *session_)
|
||||||
{
|
{
|
||||||
zs_assert (false);
|
zmq_assert (false);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::socket_base_t::detach ()
|
void zmq::socket_base_t::detach ()
|
||||||
{
|
{
|
||||||
zs_assert (false);
|
zmq_assert (false);
|
||||||
}
|
}
|
||||||
|
|
||||||
void zs::socket_base_t::revive ()
|
void zmq::socket_base_t::revive ()
|
||||||
{
|
{
|
||||||
// We can ignore the event safely here.
|
// We can ignore the event safely here.
|
||||||
}
|
}
|
||||||
|
@ -17,8 +17,8 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_SOCKET_BASE_HPP_INCLUDED__
|
#ifndef __ZMQ_SOCKET_BASE_HPP_INCLUDED__
|
||||||
#define __ZS_SOCKET_BASE_HPP_INCLUDED__
|
#define __ZMQ_SOCKET_BASE_HPP_INCLUDED__
|
||||||
|
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
@ -26,7 +26,7 @@
|
|||||||
#include "i_api.hpp"
|
#include "i_api.hpp"
|
||||||
#include "object.hpp"
|
#include "object.hpp"
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
class socket_base_t : public object_t, public i_engine, public i_api
|
class socket_base_t : public object_t, public i_engine, public i_api
|
||||||
@ -46,12 +46,12 @@ namespace zs
|
|||||||
void shutdown ();
|
void shutdown ();
|
||||||
|
|
||||||
// i_api interface implementation.
|
// i_api interface implementation.
|
||||||
int bind (const char *addr_, struct zs_opts *opts_);
|
int bind (const char *addr_, struct zmq_opts *opts_);
|
||||||
int connect (const char *addr_, struct zs_opts *opts_);
|
int connect (const char *addr_, struct zmq_opts *opts_);
|
||||||
int subscribe (const char *criteria_);
|
int subscribe (const char *criteria_);
|
||||||
int send (struct zs_msg *msg_, int flags_);
|
int send (struct zmq_msg *msg_, int flags_);
|
||||||
int flush ();
|
int flush ();
|
||||||
int recv (struct zs_msg *msg_, int flags_);
|
int recv (struct zmq_msg *msg_, int flags_);
|
||||||
int close ();
|
int close ();
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
@ -17,12 +17,12 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_STDINT_HPP_INCLUDED__
|
#ifndef __ZMQ_STDINT_HPP_INCLUDED__
|
||||||
#define __ZS_STDINT_HPP_INCLUDED__
|
#define __ZMQ_STDINT_HPP_INCLUDED__
|
||||||
|
|
||||||
#include "platform.hpp"
|
#include "platform.hpp"
|
||||||
|
|
||||||
#ifdef ZS_HAVE_SOLARIS
|
#ifdef ZMQ_HAVE_SOLARIS
|
||||||
|
|
||||||
#include <inttypes.h>
|
#include <inttypes.h>
|
||||||
|
|
||||||
|
@ -17,27 +17,27 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "../include/zs.h"
|
#include "../include/zmq.h"
|
||||||
|
|
||||||
#include "sub.hpp"
|
#include "sub.hpp"
|
||||||
#include "app_thread.hpp"
|
#include "app_thread.hpp"
|
||||||
#include "session.hpp"
|
#include "session.hpp"
|
||||||
#include "err.hpp"
|
#include "err.hpp"
|
||||||
|
|
||||||
zs::sub_t::sub_t (app_thread_t *thread_, session_t *session_) :
|
zmq::sub_t::sub_t (app_thread_t *thread_, session_t *session_) :
|
||||||
socket_base_t (thread_, session_)
|
socket_base_t (thread_, session_)
|
||||||
{
|
{
|
||||||
disable_out ();
|
disable_out ();
|
||||||
}
|
}
|
||||||
|
|
||||||
int zs::sub_t::send (struct zs_msg *msg_, int flags_)
|
int zmq::sub_t::send (struct zmq_msg *msg_, int flags_)
|
||||||
{
|
{
|
||||||
// Subscriber socket has no send function.
|
// Subscriber socket has no send function.
|
||||||
errno = ENOTSUP;
|
errno = ENOTSUP;
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
int zs::sub_t::flush ()
|
int zmq::sub_t::flush ()
|
||||||
{
|
{
|
||||||
// Subscriber socket has no flush function.
|
// Subscriber socket has no flush function.
|
||||||
errno = ENOTSUP;
|
errno = ENOTSUP;
|
||||||
|
@ -17,12 +17,12 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_SUB_HPP_INCLUDED__
|
#ifndef __ZMQ_SUB_HPP_INCLUDED__
|
||||||
#define __ZS_SUB_HPP_INCLUDED__
|
#define __ZMQ_SUB_HPP_INCLUDED__
|
||||||
|
|
||||||
#include "socket_base.hpp"
|
#include "socket_base.hpp"
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
class sub_t : public socket_base_t
|
class sub_t : public socket_base_t
|
||||||
@ -32,7 +32,7 @@ namespace zs
|
|||||||
sub_t (class app_thread_t *thread_, class session_t *session_);
|
sub_t (class app_thread_t *thread_, class session_t *session_);
|
||||||
|
|
||||||
// i_api overloads.
|
// i_api overloads.
|
||||||
int send (struct zs_msg *msg_, int flags_);
|
int send (struct zmq_msg *msg_, int flags_);
|
||||||
int flush ();
|
int flush ();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@ -22,7 +22,7 @@
|
|||||||
#include "ip.hpp"
|
#include "ip.hpp"
|
||||||
#include "err.hpp"
|
#include "err.hpp"
|
||||||
|
|
||||||
#ifdef ZS_HAVE_WINDOWS
|
#ifdef ZMQ_HAVE_WINDOWS
|
||||||
|
|
||||||
#include "windows.hpp"
|
#include "windows.hpp"
|
||||||
#error
|
#error
|
||||||
@ -37,20 +37,20 @@
|
|||||||
#include <netdb.h>
|
#include <netdb.h>
|
||||||
#include <fcntl.h>
|
#include <fcntl.h>
|
||||||
|
|
||||||
zs::tcp_connecter_t::tcp_connecter_t () :
|
zmq::tcp_connecter_t::tcp_connecter_t () :
|
||||||
s (retired_fd)
|
s (retired_fd)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::tcp_connecter_t::~tcp_connecter_t ()
|
zmq::tcp_connecter_t::~tcp_connecter_t ()
|
||||||
{
|
{
|
||||||
if (s != retired_fd)
|
if (s != retired_fd)
|
||||||
close ();
|
close ();
|
||||||
}
|
}
|
||||||
|
|
||||||
int zs::tcp_connecter_t::open (const char *addr_)
|
int zmq::tcp_connecter_t::open (const char *addr_)
|
||||||
{
|
{
|
||||||
zs_assert (s == retired_fd);
|
zmq_assert (s == retired_fd);
|
||||||
|
|
||||||
// Convert the hostname into sockaddr_in structure.
|
// Convert the hostname into sockaddr_in structure.
|
||||||
sockaddr_in address;
|
sockaddr_in address;
|
||||||
@ -75,7 +75,7 @@ int zs::tcp_connecter_t::open (const char *addr_)
|
|||||||
rc = setsockopt (s, IPPROTO_TCP, TCP_NODELAY, (char*) &flag, sizeof (int));
|
rc = setsockopt (s, IPPROTO_TCP, TCP_NODELAY, (char*) &flag, sizeof (int));
|
||||||
errno_assert (rc == 0);
|
errno_assert (rc == 0);
|
||||||
|
|
||||||
#ifdef ZS_HAVE_OPENVMS
|
#ifdef ZMQ_HAVE_OPENVMS
|
||||||
// Disable delayed acknowledgements.
|
// Disable delayed acknowledgements.
|
||||||
flag = 1;
|
flag = 1;
|
||||||
rc = setsockopt (s, IPPROTO_TCP, TCP_NODELACK, (char*) &flag, sizeof (int));
|
rc = setsockopt (s, IPPROTO_TCP, TCP_NODELACK, (char*) &flag, sizeof (int));
|
||||||
@ -100,9 +100,9 @@ int zs::tcp_connecter_t::open (const char *addr_)
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
int zs::tcp_connecter_t::close ()
|
int zmq::tcp_connecter_t::close ()
|
||||||
{
|
{
|
||||||
zs_assert (s != retired_fd);
|
zmq_assert (s != retired_fd);
|
||||||
int rc = ::close (s);
|
int rc = ::close (s);
|
||||||
if (rc != 0)
|
if (rc != 0)
|
||||||
return -1;
|
return -1;
|
||||||
@ -110,12 +110,12 @@ int zs::tcp_connecter_t::close ()
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::fd_t zs::tcp_connecter_t::get_fd ()
|
zmq::fd_t zmq::tcp_connecter_t::get_fd ()
|
||||||
{
|
{
|
||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::fd_t zs::tcp_connecter_t::connect ()
|
zmq::fd_t zmq::tcp_connecter_t::connect ()
|
||||||
{
|
{
|
||||||
// Following code should handle both Berkeley-derived socket
|
// Following code should handle both Berkeley-derived socket
|
||||||
// implementations and Solaris.
|
// implementations and Solaris.
|
||||||
|
@ -17,12 +17,12 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ZS_TCP_CONNECTER_HPP_INCLUDED__
|
#ifndef __ZMQ_TCP_CONNECTER_HPP_INCLUDED__
|
||||||
#define __ZS_TCP_CONNECTER_HPP_INCLUDED__
|
#define __ZMQ_TCP_CONNECTER_HPP_INCLUDED__
|
||||||
|
|
||||||
#include "fd.hpp"
|
#include "fd.hpp"
|
||||||
|
|
||||||
namespace zs
|
namespace zmq
|
||||||
{
|
{
|
||||||
|
|
||||||
// The class encapsulating simple TCP listening socket.
|
// The class encapsulating simple TCP listening socket.
|
||||||
|
@ -23,7 +23,7 @@
|
|||||||
#include "config.hpp"
|
#include "config.hpp"
|
||||||
#include "err.hpp"
|
#include "err.hpp"
|
||||||
|
|
||||||
#ifdef ZS_HAVE_WINDOWS
|
#ifdef ZMQ_HAVE_WINDOWS
|
||||||
|
|
||||||
#include "windows.hpp"
|
#include "windows.hpp"
|
||||||
#error
|
#error
|
||||||
@ -38,18 +38,18 @@
|
|||||||
#include <netdb.h>
|
#include <netdb.h>
|
||||||
#include <fcntl.h>
|
#include <fcntl.h>
|
||||||
|
|
||||||
zs::tcp_listener_t::tcp_listener_t () :
|
zmq::tcp_listener_t::tcp_listener_t () :
|
||||||
s (retired_fd)
|
s (retired_fd)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::tcp_listener_t::~tcp_listener_t ()
|
zmq::tcp_listener_t::~tcp_listener_t ()
|
||||||
{
|
{
|
||||||
if (s != retired_fd)
|
if (s != retired_fd)
|
||||||
close ();
|
close ();
|
||||||
}
|
}
|
||||||
|
|
||||||
int zs::tcp_listener_t::open (const char *addr_)
|
int zmq::tcp_listener_t::open (const char *addr_)
|
||||||
{
|
{
|
||||||
// Convert the interface into sockaddr_in structure.
|
// Convert the interface into sockaddr_in structure.
|
||||||
sockaddr_in ip_address;
|
sockaddr_in ip_address;
|
||||||
@ -91,9 +91,9 @@ int zs::tcp_listener_t::open (const char *addr_)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int zs::tcp_listener_t::close ()
|
int zmq::tcp_listener_t::close ()
|
||||||
{
|
{
|
||||||
zs_assert (s != retired_fd);
|
zmq_assert (s != retired_fd);
|
||||||
int rc = ::close (s);
|
int rc = ::close (s);
|
||||||
if (rc != 0)
|
if (rc != 0)
|
||||||
return -1;
|
return -1;
|
||||||
@ -101,14 +101,14 @@ int zs::tcp_listener_t::close ()
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::fd_t zs::tcp_listener_t::get_fd ()
|
zmq::fd_t zmq::tcp_listener_t::get_fd ()
|
||||||
{
|
{
|
||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
|
||||||
zs::fd_t zs::tcp_listener_t::accept ()
|
zmq::fd_t zmq::tcp_listener_t::accept ()
|
||||||
{
|
{
|
||||||
zs_assert (s != retired_fd);
|
zmq_assert (s != retired_fd);
|
||||||
|
|
||||||
// Accept one incoming connection.
|
// Accept one incoming connection.
|
||||||
fd_t sock = ::accept (s, NULL, NULL);
|
fd_t sock = ::accept (s, NULL, NULL);
|
||||||
@ -151,7 +151,7 @@ zs::fd_t zs::tcp_listener_t::accept ()
|
|||||||
sizeof (int));
|
sizeof (int));
|
||||||
errno_assert (rc == 0);
|
errno_assert (rc == 0);
|
||||||
|
|
||||||
#ifdef ZS_HAVE_OPENVMS
|
#ifdef ZMQ_HAVE_OPENVMS
|
||||||
// Disable delayed acknowledgements.
|
// Disable delayed acknowledgements.
|
||||||
flag = 1;
|
flag = 1;
|
||||||
rc = setsockopt (sock, IPPROTO_TCP, TCP_NODELACK, (char*) &flag,
|
rc = setsockopt (sock, IPPROTO_TCP, TCP_NODELACK, (char*) &flag,
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user