Commit d0c58d24 authored by Ian Barber's avatar Ian Barber

Merge pull request #546 from hintjens/master

Throughput perf test was borked, fixed it
parents f4a07b39 9df7c70a
...@@ -215,8 +215,8 @@ members of the 0MQ community and pointers can be found on the 0MQ website. ...@@ -215,8 +215,8 @@ members of the 0MQ community and pointers can be found on the 0MQ website.
AUTHORS AUTHORS
------- -------
This 0MQ manual page was written by Martin Sustrik <sustrik@250bpm.com>, This page was written by the 0MQ community. To make a change please
Martin Lucina <martin@lucina.net>, and Pieter Hintjens <ph@imatix.com>. read the 0MQ Contribution Policy at <http://www.zeromq.org/docs:contributing>.
RESOURCES RESOURCES
......
...@@ -98,5 +98,5 @@ linkzmq:zmq[7] ...@@ -98,5 +98,5 @@ linkzmq:zmq[7]
AUTHORS AUTHORS
------- -------
This 0MQ manual page was written by Pieter Hintjens <ph@imatix.com>, This page was written by the 0MQ community. To make a change please
Martin Sustrik <sustrik@250bpm.com> and Martin Lucina <mato@kotelna.sk>. read the 0MQ Contribution Policy at <http://www.zeromq.org/docs:contributing>.
...@@ -48,5 +48,5 @@ linkzmq:zmq[7] ...@@ -48,5 +48,5 @@ linkzmq:zmq[7]
AUTHORS AUTHORS
------- -------
This 0MQ manual page was written by Martin Sustrik <sustrik@250bpm.com> and This page was written by the 0MQ community. To make a change please
Martin Lucina <mato@kotelna.sk>. read the 0MQ Contribution Policy at <http://www.zeromq.org/docs:contributing>.
...@@ -96,5 +96,5 @@ linkzmq:zmq[7] ...@@ -96,5 +96,5 @@ linkzmq:zmq[7]
AUTHORS AUTHORS
------- -------
This 0MQ manual page was written by Pieter Hintjens <ph@imatix.com>, This page was written by the 0MQ community. To make a change please
Martin Sustrik <sustrik@250bpm.com> and Martin Lucina <mato@kotelna.sk>. read the 0MQ Contribution Policy at <http://www.zeromq.org/docs:contributing>.
...@@ -63,4 +63,5 @@ linkzmq:zmq_setsockopt[3] ...@@ -63,4 +63,5 @@ linkzmq:zmq_setsockopt[3]
AUTHORS AUTHORS
------- -------
This 0MQ manual page was written by Pieter Hintjens <ph@imatix.com> This page was written by the 0MQ community. To make a change please
read the 0MQ Contribution Policy at <http://www.zeromq.org/docs:contributing>.
...@@ -68,4 +68,5 @@ linkzmq:zmq[7] ...@@ -68,4 +68,5 @@ linkzmq:zmq[7]
AUTHORS AUTHORS
------- -------
This 0MQ manual page was written by Pieter Hintjens <ph@imatix.com> This page was written by the 0MQ community. To make a change please
read the 0MQ Contribution Policy at <http://www.zeromq.org/docs:contributing>.
...@@ -46,4 +46,5 @@ linkzmq:zmq_ctx_term[3] ...@@ -46,4 +46,5 @@ linkzmq:zmq_ctx_term[3]
AUTHORS AUTHORS
------- -------
This 0MQ manual page was written by Pieter Hintjens <ph@imatix.com> This page was written by the 0MQ community. To make a change please
read the 0MQ Contribution Policy at <http://www.zeromq.org/docs:contributing>.
...@@ -83,4 +83,5 @@ linkzmq:zmq[7] ...@@ -83,4 +83,5 @@ linkzmq:zmq[7]
AUTHORS AUTHORS
------- -------
This 0MQ manual page was written by Pieter Hintjens <ph@imatix.com> This page was written by the 0MQ community. To make a change please
read the 0MQ Contribution Policy at <http://www.zeromq.org/docs:contributing>.
...@@ -63,4 +63,5 @@ linkzmq:zmq_setsockopt[3] ...@@ -63,4 +63,5 @@ linkzmq:zmq_setsockopt[3]
AUTHORS AUTHORS
------- -------
This 0MQ manual page was written by Pieter Hintjens <ph@imatix.com> This page was written by the 0MQ community. To make a change please
read the 0MQ Contribution Policy at <http://www.zeromq.org/docs:contributing>.
...@@ -63,5 +63,5 @@ linkzmq:zmq[7] ...@@ -63,5 +63,5 @@ linkzmq:zmq[7]
AUTHORS AUTHORS
------- -------
This 0MQ manual page was written by Martin Sustrik <sustrik@250bpm.com>, This page was written by the 0MQ community. To make a change please
Martin Lucina <mato@kotelna.sk> and Ian Barber <ian.barber@gmail.com> read the 0MQ Contribution Policy at <http://www.zeromq.org/docs:contributing>.
...@@ -46,5 +46,5 @@ linkzmq:zmq[7] ...@@ -46,5 +46,5 @@ linkzmq:zmq[7]
AUTHORS AUTHORS
------- -------
This 0MQ manual page was written by Martin Sustrik <sustrik@250bpm.com> and This page was written by the 0MQ community. To make a change please
Martin Lucina <mato@kotelna.sk>. read the 0MQ Contribution Policy at <http://www.zeromq.org/docs:contributing>.
...@@ -527,5 +527,5 @@ linkzmq:zmq[7] ...@@ -527,5 +527,5 @@ linkzmq:zmq[7]
AUTHORS AUTHORS
------- -------
This 0MQ manual page was written by Martin Sustrik <sustrik@250bpm.com> and This page was written by the 0MQ community. To make a change please
Martin Lucina <mato@kotelna.sk>. read the 0MQ Contribution Policy at <http://www.zeromq.org/docs:contributing>.
...@@ -48,5 +48,5 @@ linkzmq:zmq_term[3] ...@@ -48,5 +48,5 @@ linkzmq:zmq_term[3]
AUTHORS AUTHORS
------- -------
This 0MQ manual page was written by Martin Sustrik <sustrik@250bpm.com> and This page was written by the 0MQ community. To make a change please
Martin Lucina <mato@kotelna.sk>. read the 0MQ Contribution Policy at <http://www.zeromq.org/docs:contributing>.
...@@ -81,5 +81,5 @@ linkzmq:zmq[7] ...@@ -81,5 +81,5 @@ linkzmq:zmq[7]
AUTHORS AUTHORS
------- -------
This 0MQ manual page was written by Pieter Hintjens <ph@imatix.com>, This page was written by the 0MQ community. To make a change please
Martin Sustrik <sustrik@250bpm.com> and Martin Lucina <mato@kotelna.sk>. read the 0MQ Contribution Policy at <http://www.zeromq.org/docs:contributing>.
...@@ -86,9 +86,5 @@ linkzmq:zmq[7] ...@@ -86,9 +86,5 @@ linkzmq:zmq[7]
AUTHORS AUTHORS
------- -------
This 0MQ manual page was written by Pieter Hintjens <ph@imatix.com>, This page was written by the 0MQ community. To make a change please
Martin Sustrik <sustrik@250bpm.com> and Martin Lucina <mato@kotelna.sk>. read the 0MQ Contribution Policy at <http://www.zeromq.org/docs:contributing>.
...@@ -51,5 +51,5 @@ linkzmq:zmq[7] ...@@ -51,5 +51,5 @@ linkzmq:zmq[7]
AUTHORS AUTHORS
------- -------
This 0MQ manual page was written by Martin Sustrik <sustrik@250bpm.com> and This page was written by the 0MQ community. To make a change please
Martin Lucina <mato@kotelna.sk>. read the 0MQ Contribution Policy at <http://www.zeromq.org/docs:contributing>.
...@@ -53,5 +53,5 @@ linkzmq:zmq[7] ...@@ -53,5 +53,5 @@ linkzmq:zmq[7]
AUTHORS AUTHORS
------- -------
This 0MQ manual page was written by Martin Sustrik <sustrik@250bpm.com> and This page was written by the 0MQ community. To make a change please
Martin Lucina <mato@kotelna.sk>. read the 0MQ Contribution Policy at <http://www.zeromq.org/docs:contributing>.
...@@ -44,5 +44,5 @@ linkzmq:zmq[7] ...@@ -44,5 +44,5 @@ linkzmq:zmq[7]
AUTHORS AUTHORS
------- -------
This 0MQ manual page was written by Martin Sustrik <sustrik@250bpm.com> and This page was written by the 0MQ community. To make a change please
Martin Lucina <mato@kotelna.sk>. read the 0MQ Contribution Policy at <http://www.zeromq.org/docs:contributing>.
...@@ -68,5 +68,5 @@ linkzmq:zmq[7] ...@@ -68,5 +68,5 @@ linkzmq:zmq[7]
AUTHORS AUTHORS
------- -------
This 0MQ manual page was written by Chuck Remes <cremes@mac.com> and Pieter This page was written by the 0MQ community. To make a change please
Hintjens <ph@imatix.com>. read the 0MQ Contribution Policy at <http://www.zeromq.org/docs:contributing>.
...@@ -61,5 +61,5 @@ linkzmq:zmq[7] ...@@ -61,5 +61,5 @@ linkzmq:zmq[7]
AUTHORS AUTHORS
------- -------
This 0MQ manual page was written by Martin Sustrik <sustrik@250bpm.com> and This page was written by the 0MQ community. To make a change please
Martin Lucina <mato@kotelna.sk>. read the 0MQ Contribution Policy at <http://www.zeromq.org/docs:contributing>.
...@@ -81,5 +81,5 @@ linkzmq:zmq[7] ...@@ -81,5 +81,5 @@ linkzmq:zmq[7]
AUTHORS AUTHORS
------- -------
This 0MQ manual page was written by Martin Sustrik <sustrik@250bpm.com> and This page was written by the 0MQ community. To make a change please
Martin Lucina <mato@kotelna.sk>. read the 0MQ Contribution Policy at <http://www.zeromq.org/docs:contributing>.
...@@ -54,5 +54,5 @@ linkzmq:zmq[7] ...@@ -54,5 +54,5 @@ linkzmq:zmq[7]
AUTHORS AUTHORS
------- -------
This 0MQ manual page was written by Martin Sustrik <sustrik@250bpm.com> and This page was written by the 0MQ community. To make a change please
Martin Lucina <mato@kotelna.sk>. read the 0MQ Contribution Policy at <http://www.zeromq.org/docs:contributing>.
...@@ -61,5 +61,5 @@ linkzmq:zmq[7] ...@@ -61,5 +61,5 @@ linkzmq:zmq[7]
AUTHORS AUTHORS
------- -------
This 0MQ manual page was written by Chuck Remes <cremes@mac.com> and Pieter This page was written by the 0MQ community. To make a change please
Hintjens <ph@imatix.com>. read the 0MQ Contribution Policy at <http://www.zeromq.org/docs:contributing>.
...@@ -48,5 +48,5 @@ linkzmq:zmq[7] ...@@ -48,5 +48,5 @@ linkzmq:zmq[7]
AUTHORS AUTHORS
------- -------
This 0MQ manual page was written by Martin Sustrik <sustrik@250bpm.com> and This page was written by the 0MQ community. To make a change please
Martin Lucina <mato@kotelna.sk>. read the 0MQ Contribution Policy at <http://www.zeromq.org/docs:contributing>.
...@@ -120,6 +120,5 @@ linkzmq:zmq[7] ...@@ -120,6 +120,5 @@ linkzmq:zmq[7]
AUTHORS AUTHORS
------- -------
This man page was written by Martin Sustrik <sustrik@250bpm.com>, Martin This page was written by the 0MQ community. To make a change please
Lucina <martin@lucina.net>, and Pieter Hintjens <ph@imatix.com>. read the 0MQ Contribution Policy at <http://www.zeromq.org/docs:contributing>.
...@@ -117,6 +117,5 @@ linkzmq:zmq[7] ...@@ -117,6 +117,5 @@ linkzmq:zmq[7]
AUTHORS AUTHORS
------- -------
This 0MQ manual page was written by Martin Sustrik <sustrik@250bpm.com> and This page was written by the 0MQ community. To make a change please
Martin Lucina <mato@kotelna.sk>, and Pieter Hintjens <ph@imatix.com>. read the 0MQ Contribution Policy at <http://www.zeromq.org/docs:contributing>.
...@@ -42,4 +42,5 @@ linkzmq:zmq[7] ...@@ -42,4 +42,5 @@ linkzmq:zmq[7]
AUTHORS AUTHORS
------- -------
This 0MQ manual page was written by Pieter Hintjens <ph@imatix.com>. This page was written by the 0MQ community. To make a change please
read the 0MQ Contribution Policy at <http://www.zeromq.org/docs:contributing>.
...@@ -44,5 +44,5 @@ linkzmq:zmq[7] ...@@ -44,5 +44,5 @@ linkzmq:zmq[7]
AUTHORS AUTHORS
------- -------
This 0MQ manual page was written by Martin Sustrik <sustrik@250bpm.com>, This page was written by the 0MQ community. To make a change please
Martin Lucina <mato@kotelna.sk>, and Pieter Hintjens <ph@imatix.com>. read the 0MQ Contribution Policy at <http://www.zeromq.org/docs:contributing>.
...@@ -156,7 +156,8 @@ linkzmq:zmq_ipc[7] ...@@ -156,7 +156,8 @@ linkzmq:zmq_ipc[7]
linkzmq:zmq_inproc[7] linkzmq:zmq_inproc[7]
linkzmq:zmq[7] linkzmq:zmq[7]
AUTHORS AUTHORS
------- -------
This 0MQ manual page was written by Pieter Hintjens <ph@imatix.com>, This page was written by the 0MQ community. To make a change please
Martin Sustrik <sustrik@250bpm.com> and Martin Lucina <mato@kotelna.sk>. read the 0MQ Contribution Policy at <http://www.zeromq.org/docs:contributing>.
...@@ -128,5 +128,5 @@ Your operating system documentation for the _poll()_ system call. ...@@ -128,5 +128,5 @@ Your operating system documentation for the _poll()_ system call.
AUTHORS AUTHORS
------- -------
This 0MQ manual page was written by Martin Sustrik <sustrik@250bpm.com> and This page was written by the 0MQ community. To make a change please
Martin Lucina <mato@kotelna.sk>. read the 0MQ Contribution Policy at <http://www.zeromq.org/docs:contributing>.
...@@ -94,4 +94,5 @@ linkzmq:zmq[7] ...@@ -94,4 +94,5 @@ linkzmq:zmq[7]
AUTHORS AUTHORS
------- -------
This 0MQ manual page was written by Pieter Hintjens <ph@imatix.com> This page was written by the 0MQ community. To make a change please
read the 0MQ Contribution Policy at <http://www.zeromq.org/docs:contributing>.
...@@ -86,6 +86,5 @@ linkzmq:zmq[7] ...@@ -86,6 +86,5 @@ linkzmq:zmq[7]
AUTHORS AUTHORS
------- -------
This 0MQ manual page was written by Martin Sustrik <sustrik@250bpm.com> and This page was written by the 0MQ community. To make a change please
Martin Lucina <mato@kotelna.sk>, and Pieter Hintjens <ph@imatix.com>. read the 0MQ Contribution Policy at <http://www.zeromq.org/docs:contributing>.
...@@ -117,6 +117,5 @@ linkzmq:zmq[7] ...@@ -117,6 +117,5 @@ linkzmq:zmq[7]
AUTHORS AUTHORS
------- -------
This man page was written by Martin Sustrik <sustrik@250bpm.com>, Martin This page was written by the 0MQ community. To make a change please
Lucina <martin@lucina.net> and Pieter Hintjens <ph@imatix.com>. read the 0MQ Contribution Policy at <http://www.zeromq.org/docs:contributing>.
...@@ -94,5 +94,5 @@ linkzmq:zmq[7] ...@@ -94,5 +94,5 @@ linkzmq:zmq[7]
AUTHORS AUTHORS
------- -------
This 0MQ manual page was written by Martin Sustrik <sustrik@250bpm.com> and This page was written by the 0MQ community. To make a change please
Martin Lucina <mato@kotelna.sk>, and Pieter Hintjens <ph@imatix.com>. read the 0MQ Contribution Policy at <http://www.zeromq.org/docs:contributing>.
...@@ -112,6 +112,5 @@ linkzmq:zmq[7] ...@@ -112,6 +112,5 @@ linkzmq:zmq[7]
AUTHORS AUTHORS
------- -------
This 0MQ manual page was written by Martin Sustrik <sustrik@250bpm.com> and This page was written by the 0MQ community. To make a change please
Martin Lucina <mato@kotelna.sk>, and Pieter Hintjens <ph@imatix.com>. read the 0MQ Contribution Policy at <http://www.zeromq.org/docs:contributing>.
...@@ -555,5 +555,7 @@ linkzmq:zmq[7] ...@@ -555,5 +555,7 @@ linkzmq:zmq[7]
AUTHORS AUTHORS
------- -------
This 0MQ manual page was written by Martin Sustrik <sustrik@250bpm.com> and This page was written by the 0MQ community. To make a change please
Martin Lucina <mato@kotelna.sk>. read the 0MQ Contribution Policy at <http://www.zeromq.org/docs:contributing>.
...@@ -367,5 +367,7 @@ linkzmq:zmq[7] ...@@ -367,5 +367,7 @@ linkzmq:zmq[7]
AUTHORS AUTHORS
------- -------
This 0MQ manual page was written by Martin Sustrik <sustrik@250bpm.com>, This page was written by the 0MQ community. To make a change please
Martin Lucina <mato@kotelna.sk>, and Pieter Hintjens <ph@imatix.com>. read the 0MQ Contribution Policy at <http://www.zeromq.org/docs:contributing>.
...@@ -255,5 +255,5 @@ linkzmq:zmq[7] ...@@ -255,5 +255,5 @@ linkzmq:zmq[7]
AUTHORS AUTHORS
------- -------
This 0MQ manual page was written by Lourens Naudé <lourens@methodmissing.com> This page was written by the 0MQ community. To make a change please
Changes by Guido Goldstein <github@a-nugget.de> read the 0MQ Contribution Policy at <http://www.zeromq.org/docs:contributing>.
...@@ -51,5 +51,6 @@ linkzmq:zmq[7] ...@@ -51,5 +51,6 @@ linkzmq:zmq[7]
AUTHORS AUTHORS
------- -------
This 0MQ manual page was written by Martin Sustrik <sustrik@250bpm.com> and This page was written by the 0MQ community. To make a change please
Martin Lucina <mato@kotelna.sk>. read the 0MQ Contribution Policy at <http://www.zeromq.org/docs:contributing>.
...@@ -99,5 +99,5 @@ linkzmq:zmq[7] ...@@ -99,5 +99,5 @@ linkzmq:zmq[7]
AUTHORS AUTHORS
------- -------
This 0MQ manual page was written by Pieter Hintjens <ph@imatix.com>, This page was written by the 0MQ community. To make a change please
Martin Sustrik <sustrik@250bpm.com> and Martin Lucina <mato@kotelna.sk>. read the 0MQ Contribution Policy at <http://www.zeromq.org/docs:contributing>.
...@@ -62,5 +62,5 @@ linkzmq:zmq_setsockopt[3] ...@@ -62,5 +62,5 @@ linkzmq:zmq_setsockopt[3]
AUTHORS AUTHORS
------- -------
This 0MQ manual page was written by Martin Sustrik <sustrik@250bpm.com> and This page was written by the 0MQ community. To make a change please
Martin Lucina <mato@kotelna.sk>. read the 0MQ Contribution Policy at <http://www.zeromq.org/docs:contributing>.
...@@ -61,5 +61,5 @@ linkzmq:zmq[7] ...@@ -61,5 +61,5 @@ linkzmq:zmq[7]
AUTHORS AUTHORS
------- -------
This 0MQ manual page was written by Martin Sustrik <sustrik@250bpm.com>, This page was written by the 0MQ community. To make a change please
Martin Lucina <mato@kotelna.sk> and Ian Barber <ian.barber@gmail.com> read the 0MQ Contribution Policy at <http://www.zeromq.org/docs:contributing>.
...@@ -47,7 +47,8 @@ SEE ALSO ...@@ -47,7 +47,8 @@ SEE ALSO
-------- --------
linkzmq:zmq[7] linkzmq:zmq[7]
AUTHORS AUTHORS
------- -------
This 0MQ manual page was written by Martin Sustrik <sustrik@250bpm.com> and This page was written by the 0MQ community. To make a change please
Martin Lucina <mato@kotelna.sk>. read the 0MQ Contribution Policy at <http://www.zeromq.org/docs:contributing>.
/* /*
Copyright (c) 2007-2012 iMatix Corporation Copyright (c) 2007-2013 Contributors as noted in the AUTHORS file
Copyright (c) 2009-2011 250bpm s.r.o.
Copyright (c) 2007-2011 Other contributors as noted in the AUTHORS file
This file is part of 0MQ. This file is part of 0MQ.
......
/* /*
Copyright (c) 2007-2012 iMatix Corporation Copyright (c) 2007-2013 Contributors as noted in the AUTHORS file
Copyright (c) 2009-2011 250bpm s.r.o.
Copyright (c) 2007-2011 Other contributors as noted in the AUTHORS file
This file is part of 0MQ. This file is part of 0MQ.
......
/* /*
Copyright (c) 2007-2012 iMatix Corporation Copyright (c) 2007-2013 Contributors as noted in the AUTHORS file
Copyright (c) 2009-2011 250bpm s.r.o.
Copyright (c) 2007-2011 Other contributors as noted in the AUTHORS file
This file is part of 0MQ. This file is part of 0MQ.
...@@ -23,143 +21,37 @@ ...@@ -23,143 +21,37 @@
#include "../include/zmq_utils.h" #include "../include/zmq_utils.h"
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#include <string.h>
#include <time.h>
#include <limits.h>
#include "platform.hpp"
#ifndef ZMQ_HAVE_WINDOWS
#include <sys/time.h>
#endif
#define ZMSG 1
#define DATA 0
typedef struct US_TIMER US_TIMER;
struct US_TIMER{
struct timeval time_was;
struct timeval time_now;
};
/* Records the current timer state
*/
void tm_init( US_TIMER *t){
#if defined ZMQ_HAVE_WINDOWS
// Get the high resolution counter's accuracy.
LARGE_INTEGER ticksPerSecond;
QueryPerformanceFrequency (&ticksPerSecond);
// What time is it?
LARGE_INTEGER tick;
if ( !QueryPerformanceCounter (&tick) ) { perror( "tm_init()" ); }
// Seconds
t->time_now.tv_sec = (long)( tick.QuadPart / ticksPerSecond.QuadPart );
// Microseconds
t->time_now.tv_usec = (long)( ( tick.QuadPart - t->time_now.tv_sec * ticksPerSecond.QuadPart ) * 1000000 / ticksPerSecond.QuadPart );
#else
if( gettimeofday( &t->time_now, NULL) < 0){ perror( "tm_init()");}
#endif
t->time_was = t->time_now;
}
/* Returns the time passed in microsecond precision in seconds since last init
of timer.
*/
float tm_secs( US_TIMER *t){
register float seconds;
#if defined ZMQ_HAVE_WINDOWS
// Get the high resolution counter's accuracy.
LARGE_INTEGER ticksPerSecond;
QueryPerformanceFrequency (&ticksPerSecond);
// What time is it?
LARGE_INTEGER tick;
if ( !QueryPerformanceCounter (&tick) ) { perror( "tm_secs()" ); }
// Seconds
t->time_now.tv_sec = (long)( tick.QuadPart / ticksPerSecond.QuadPart );
// Microseconds
t->time_now.tv_usec = (long)( ( tick.QuadPart - t->time_now.tv_sec * ticksPerSecond.QuadPart ) * 1000000 / ticksPerSecond.QuadPart );
#else
if( gettimeofday( &t->time_now, NULL) < 0){ perror( "tm_secs()");}
#endif
seconds = ( ((float)( t->time_now.tv_sec - t->time_was.tv_sec)) +
(((float)( t->time_now.tv_usec - t->time_was.tv_usec)) / 1000000.0));
t->time_was = t->time_now;
return( seconds);
}
const char *bind_to;
int message_count = 1000;
int message_size = 1024;
int threads = 1;
int workers = 1;
int sndbuflen = 128*256;
int rcvbuflen = 128*256;
int flow = ZMQ_PULL;
int rec = DATA;
void my_free (void *data, void *hint)
{
// free (data);
}
int main (int argc, char *argv []) int main (int argc, char *argv [])
{ {
US_TIMER timer; const char *bind_to;
int message_count;
size_t message_size;
void *ctx; void *ctx;
void *s; void *s;
int rc; int rc;
int i; int i;
void *buf = NULL; zmq_msg_t msg;
void *watch;
unsigned long elapsed;
unsigned long throughput;
double megabits;
if (argc != 9) { if (argc != 4) {
printf ("usage: local_thr <bind-to> <message-size> <message-count> <SND buffer> <RCV buffer> <flow (PUSH/PULL)> <rec (ZMSG/DATA)> <zmq-threads>\n"); printf ("usage: local_thr <bind-to> <message-size> <message-count>\n");
return 1; return 1;
} }
bind_to = argv [1]; bind_to = argv [1];
message_size = atoi (argv [2]); message_size = atoi (argv [2]);
message_count = atoi (argv [3]); message_count = atoi (argv [3]);
sndbuflen = atoi (argv [4]);
rcvbuflen = atoi (argv [5]);
if( !strcmp( argv [6], "PUSH")){
flow = ZMQ_PUSH;
}
if( !strcmp( argv [6], "PULL")){
flow = ZMQ_PULL;
}
if( !strcmp( argv [7], "ZMSG")){
rec = ZMSG;
}
if( !strcmp( argv [7], "DATA")){
rec = DATA;
}
threads = atoi (argv [8]);
if( !(buf = malloc( message_size))){ perror("malloc"); return -1;} ctx = zmq_init (1);
ctx = zmq_ctx_new ();
if (!ctx) { if (!ctx) {
printf ("error in zmq_ctx_new: %s\n", zmq_strerror (errno)); printf ("error in zmq_init: %s\n", zmq_strerror (errno));
return -1;
}
rc = zmq_ctx_set ( ctx, ZMQ_IO_THREADS, threads);
if (rc) {
printf ("error in zmq_ctx_set: %s\n", zmq_strerror (errno));
return -1; return -1;
} }
s = zmq_socket (ctx, flow); s = zmq_socket (ctx, ZMQ_PULL);
if (!s) { if (!s) {
printf ("error in zmq_socket: %s\n", zmq_strerror (errno)); printf ("error in zmq_socket: %s\n", zmq_strerror (errno));
return -1; return -1;
...@@ -168,141 +60,60 @@ int main (int argc, char *argv []) ...@@ -168,141 +60,60 @@ int main (int argc, char *argv [])
// Add your socket options here. // Add your socket options here.
// For example ZMQ_RATE, ZMQ_RECOVERY_IVL and ZMQ_MCAST_LOOP for PGM. // For example ZMQ_RATE, ZMQ_RECOVERY_IVL and ZMQ_MCAST_LOOP for PGM.
size_t rcvbuflenlen = (size_t)sizeof rcvbuflen;
size_t sndbuflenlen = (size_t)sizeof sndbuflen;
rc = zmq_setsockopt (s, ZMQ_RCVBUF, &rcvbuflen, rcvbuflenlen);
if (rc != 0) {
printf ("error in zmq_setsockopt: %s\n", zmq_strerror (errno));
return -1;
}
rc = zmq_setsockopt (s, ZMQ_SNDBUF, &sndbuflen, sndbuflenlen);
if (rc != 0) {
printf ("error in zmq_setsockopt: %s\n", zmq_strerror (errno));
return -1;
}
sndbuflen = 1;
rc = zmq_setsockopt (s, ZMQ_DELAY_ATTACH_ON_CONNECT, &sndbuflen, sndbuflenlen);
if (rc != 0) {
printf ("error in zmq_setsockopt: %s\n", zmq_strerror (errno));
return -1;
}
sndbuflen = 2;
rc = zmq_setsockopt (s, ZMQ_SNDHWM, &sndbuflen, sndbuflenlen);
if (rc != 0) {
printf ("error in zmq_setsockopt: %s\n", zmq_strerror (errno));
return -1;
}
sndbuflen = 2;
rc = zmq_setsockopt (s, ZMQ_RCVHWM, &sndbuflen, sndbuflenlen);
if (rc != 0) {
printf ("error in zmq_setsockopt: %s\n", zmq_strerror (errno));
return -1;
}
rc = zmq_getsockopt (s, ZMQ_RCVBUF, &rcvbuflen, &rcvbuflenlen);
if (rc != 0) {
printf ("error in zmq_getsockopt: %s\n", zmq_strerror (errno));
return -1;
}
rc = zmq_getsockopt (s, ZMQ_SNDBUF, &sndbuflen, &sndbuflenlen);
if (rc != 0) {
printf ("error in zmq_getsockopt: %s\n", zmq_strerror (errno));
return -1;
}
printf("RCVBUF=%d KB SNDBUF=%d KB adjusted\n", rcvbuflen/1024, sndbuflen/1024);
printf("Threads: %d\n", zmq_ctx_get( ctx, ZMQ_IO_THREADS));
rc = zmq_bind (s, bind_to); rc = zmq_bind (s, bind_to);
if (rc != 0) { if (rc != 0) {
printf ("error in zmq_bind: %s\n", zmq_strerror (errno)); printf ("error in zmq_bind: %s\n", zmq_strerror (errno));
return -1; return -1;
} }
if( !(buf = malloc( message_size))){ perror("malloc"); return -1;}
printf("%sING %s...\n", flow == ZMQ_PUSH ? "PUSH":"PULL", rec ? "ZMQ_MSG":"DATA");
tm_init( &timer);
if( flow == ZMQ_PULL){
if( rec == ZMSG){
zmq_msg_t msg;
rc = zmq_msg_init (&msg); rc = zmq_msg_init (&msg);
if (rc != 0) { if (rc != 0) {
printf ("error in zmq_msg_init: %s\n", zmq_strerror (errno)); printf ("error in zmq_msg_init: %s\n", zmq_strerror (errno));
return -1; return -1;
} }
for (i = 0; i != message_count; i++) {
rc = zmq_msg_recv (&msg, s, 0); rc = zmq_recvmsg (s, &msg, 0);
if (rc < 0) { if (rc < 0) {
printf ("error in zmq_recv: %s\n", zmq_strerror (errno)); printf ("error in zmq_recvmsg: %s\n", zmq_strerror (errno));
return -1; return -1;
} }
} if (zmq_msg_size (&msg) != message_size) {
rc = zmq_msg_close (&msg); printf ("message of incorrect size received\n");
if (rc != 0) {
printf ("error in zmq_msg_close: %s\n", zmq_strerror (errno));
return -1; return -1;
}} }
else{ watch = zmq_stopwatch_start ();
for (i = 0; i != message_count; i++) { for (i = 0; i != message_count - 1; i++) {
rc = zmq_recv( s, buf, message_size, 0); rc = zmq_recvmsg (s, &msg, 0);
if (rc < 0) { if (rc < 0) {
printf ("error in zmq_recv: %s\n", zmq_strerror (errno)); printf ("error in zmq_recvmsg: %s\n", zmq_strerror (errno));
return -1; return -1;
} }
}} if (zmq_msg_size (&msg) != message_size) {
} printf ("message of incorrect size received\n");
else{
if( rec == ZMSG){
zmq_msg_t msg;
for (i = 0; i != message_count; i++) {
rc = zmq_msg_init_data (&msg, buf, message_size, NULL, NULL);
if (rc != 0) {
printf ("error in zmq_msg_init_data: %s\n", zmq_strerror (errno));
return -1; return -1;
} }
rc = zmq_msg_send( &msg, s, 0);
if (rc < 0) {
printf ("error in zmq_send: %s\n", zmq_strerror (errno));
return -1;
} }
}}
elapsed = zmq_stopwatch_stop (watch);
if (elapsed == 0)
elapsed = 1;
else{ rc = zmq_msg_close (&msg);
for (i = 0; i != message_count; i++){ if (rc != 0) {
rc = zmq_send( s, buf, message_size, 0); printf ("error in zmq_msg_close: %s\n", zmq_strerror (errno));
if (rc < 0) {
printf ("error in zmq_send: %s\n", zmq_strerror (errno));
return -1; return -1;
} }
}}
}
float secs = tm_secs( &timer); throughput = (unsigned long)
float total = (((float) message_count) * ((float) message_size)) / (1024.0*1024.0*1024.0); ((double) message_count / (double) elapsed * 1000000);
megabits = (double) (throughput * message_size * 8) / 1000000;
printf ("Message size: %d KBytes, time: %f secs\n", (int) message_size/1024, secs);
printf ("%sed %.3f GB @ %.3f GB/s\n", (flow == ZMQ_PULL) ? "Pull":"Push", total, total/secs);
printf ("message size: %d [B]\n", (int) message_size);
printf ("message count: %d\n", (int) message_count);
printf ("mean throughput: %d [msg/s]\n", (int) throughput);
printf ("mean throughput: %.3f [Mb/s]\n", (double) megabits);
rc = zmq_close (s); rc = zmq_close (s);
if (rc != 0) { if (rc != 0) {
...@@ -316,7 +127,5 @@ int main (int argc, char *argv []) ...@@ -316,7 +127,5 @@ int main (int argc, char *argv [])
return -1; return -1;
} }
if( buf) free( buf);
return 0; return 0;
} }
/* /*
Copyright (c) 2007-2012 iMatix Corporation Copyright (c) 2007-2013 Contributors as noted in the AUTHORS file
Copyright (c) 2009-2011 250bpm s.r.o.
Copyright (c) 2007-2011 Other contributors as noted in the AUTHORS file
This file is part of 0MQ. This file is part of 0MQ.
......
/* /*
Copyright (c) 2009-2011 250bpm s.r.o. Copyright (c) 2007-2013 Contributors as noted in the AUTHORS file
Copyright (c) 2007-2009 iMatix Corporation
Copyright (c) 2007-2011 Other contributors as noted in the AUTHORS file
This file is part of 0MQ. This file is part of 0MQ.
...@@ -24,337 +22,72 @@ ...@@ -24,337 +22,72 @@
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#include <string.h> #include <string.h>
#include <time.h>
#include <limits.h>
#include "platform.hpp" int main (int argc, char *argv [])
#if defined ZMQ_HAVE_WINDOWS
#include <windows.h>
#include <process.h>
#else
#include <unistd.h>
#include <sys/time.h>
#include <pthread.h>
#endif
#define ZMSG 1
#define DATA 0
const char *connect_to;
int message_count = 1000;
int message_size = 1024;
int threads = 1;
int workers = 1;
int sndbuflen = 128*256;
int rcvbuflen = 128*256;
int flow = ZMQ_PUSH;
int rec = DATA;
typedef struct US_TIMER US_TIMER;
struct US_TIMER{
struct timeval time_was;
struct timeval time_now;
};
/* Records the current timer state
*/
void tm_init( US_TIMER *t){
#if defined ZMQ_HAVE_WINDOWS
// Get the high resolution counter's accuracy.
LARGE_INTEGER ticksPerSecond;
QueryPerformanceFrequency (&ticksPerSecond);
// What time is it?
LARGE_INTEGER tick;
if ( !QueryPerformanceCounter (&tick) ) { perror( "tm_init()" ); }
// Seconds
t->time_now.tv_sec = (long)( tick.QuadPart / ticksPerSecond.QuadPart );
// Microseconds
t->time_now.tv_usec = (long)( ( tick.QuadPart - t->time_now.tv_sec * ticksPerSecond.QuadPart ) * 1000000 / ticksPerSecond.QuadPart );
#else
if( gettimeofday( &t->time_now, NULL) < 0){ perror( "tm_init()");}
#endif
t->time_was = t->time_now;
}
/* Returns the time passed in microsecond precision in seconds since last init
of timer.
*/
float tm_secs( US_TIMER *t){
register float seconds;
#if defined ZMQ_HAVE_WINDOWS
// Get the high resolution counter's accuracy.
LARGE_INTEGER ticksPerSecond;
QueryPerformanceFrequency (&ticksPerSecond);
// What time is it?
LARGE_INTEGER tick;
if ( !QueryPerformanceCounter (&tick) ) { perror( "tm_secs()" ); }
// Seconds
t->time_now.tv_sec = (long)( tick.QuadPart / ticksPerSecond.QuadPart );
// Microseconds
t->time_now.tv_usec = (long)( ( tick.QuadPart - t->time_now.tv_sec * ticksPerSecond.QuadPart ) * 1000000 / ticksPerSecond.QuadPart );
#else
if( gettimeofday( &t->time_now, NULL) < 0){ perror( "tm_secs()");}
#endif
seconds = ( ((float)( t->time_now.tv_sec - t->time_was.tv_sec)) +
(((float)( t->time_now.tv_usec - t->time_was.tv_usec)) / 1000000.0));
t->time_was = t->time_now;
return seconds;
}
void my_free (void *data, void *hint)
{
//free (data);
}
#if defined ZMQ_HAVE_WINDOWS
static unsigned int __stdcall worker_routine (void *ctx)
#else
static void *worker_routine (void *ctx)
#endif
{ {
int rc,i; const char *connect_to;
void *buf = NULL; int message_count;
int message_size;
void *ctx;
void *s;
int rc;
int i;
zmq_msg_t msg;
if( !(buf = malloc( message_size))){ perror("malloc"); return 0;} if (argc != 4) {
printf ("usage: remote_thr <connect-to> <message-size> "
"<message-count>\n");
return 1;
}
connect_to = argv [1];
message_size = atoi (argv [2]);
message_count = atoi (argv [3]);
void *s = zmq_socket (ctx, flow); ctx = zmq_init (1);
if (!ctx) {
printf ("error in zmq_init: %s\n", zmq_strerror (errno));
return -1;
}
s = zmq_socket (ctx, ZMQ_PUSH);
if (!s) { if (!s) {
printf ("error in zmq_socket: %s\n", zmq_strerror (errno)); printf ("error in zmq_socket: %s\n", zmq_strerror (errno));
return 0; return -1;
} }
// Add your socket options here. // Add your socket options here.
// For example ZMQ_RATE, ZMQ_RECOVERY_IVL and ZMQ_MCAST_LOOP for PGM. // For example ZMQ_RATE, ZMQ_RECOVERY_IVL and ZMQ_MCAST_LOOP for PGM.
size_t rcvbuflenlen = (size_t)sizeof rcvbuflen;
size_t sndbuflenlen = (size_t)sizeof sndbuflen;
rc = zmq_setsockopt (s, ZMQ_RCVBUF, &rcvbuflen, rcvbuflenlen);
if (rc != 0) {
printf ("error in zmq_setsockopt: %s\n", zmq_strerror (errno));
return 0;
}
rc = zmq_setsockopt (s, ZMQ_SNDBUF, &sndbuflen, sndbuflenlen);
if (rc != 0) {
printf ("error in zmq_setsockopt: %s\n", zmq_strerror (errno));
return 0;
}
sndbuflen = 1;
rc = zmq_setsockopt (s, ZMQ_DELAY_ATTACH_ON_CONNECT, &sndbuflen, sndbuflenlen);
if (rc != 0) {
printf ("error in zmq_setsockopt: %s\n", zmq_strerror (errno));
return 0;
}
sndbuflen = 2;
rc = zmq_setsockopt (s, ZMQ_SNDHWM, &sndbuflen, sndbuflenlen);
if (rc != 0) {
printf ("error in zmq_setsockopt: %s\n", zmq_strerror (errno));
return 0;
}
sndbuflen = 2;
rc = zmq_setsockopt (s, ZMQ_RCVHWM, &sndbuflen, sndbuflenlen);
if (rc != 0) {
printf ("error in zmq_setsockopt: %s\n", zmq_strerror (errno));
return 0;
}
rc = zmq_getsockopt (s, ZMQ_RCVBUF, &rcvbuflen, &rcvbuflenlen);
if (rc != 0) {
printf ("error in zmq_getsockopt: %s\n", zmq_strerror (errno));
return 0;
}
rc = zmq_getsockopt (s, ZMQ_SNDBUF, &sndbuflen, &sndbuflenlen);
if (rc != 0) {
printf ("error in zmq_getsockopt: %s\n", zmq_strerror (errno));
return 0;
}
printf("RCVBUF=%d KB SNDBUF=%d KB adjusted\n", rcvbuflen/1024, sndbuflen/1024);
rc = zmq_connect (s, connect_to); rc = zmq_connect (s, connect_to);
if (rc != 0) { if (rc != 0) {
printf ("error in zmq_connect: %s\n", zmq_strerror (errno)); printf ("error in zmq_connect: %s\n", zmq_strerror (errno));
return 0; return -1;
} }
printf("%sING %s...\n", flow == ZMQ_PUSH ? "PUSH":"PULL", rec ? "ZMQ_MSG":"DATA");
if( flow == ZMQ_PUSH){
if( rec == ZMSG){
zmq_msg_t msg;
for (i = 0; i != message_count; i++) { for (i = 0; i != message_count; i++) {
rc = zmq_msg_init_size (&msg, message_size);
rc = zmq_msg_init_data (&msg, buf, message_size, NULL, NULL);
if (rc != 0) { if (rc != 0) {
printf ("error in zmq_msg_init_data: %s\n", zmq_strerror (errno)); printf ("error in zmq_msg_init_size: %s\n", zmq_strerror (errno));
return 0; return -1;
} }
rc = zmq_sendmsg (s, &msg, 0);
rc = zmq_msg_send( &msg, s, 0);
if (rc < 0) { if (rc < 0) {
printf ("error in zmq_send: %s\n", zmq_strerror (errno)); printf ("error in zmq_sendmsg: %s\n", zmq_strerror (errno));
return 0; return -1;
} }
rc = zmq_msg_close (&msg); rc = zmq_msg_close (&msg);
if (rc != 0) { if (rc != 0) {
printf ("error in zmq_msg_close: %s\n", zmq_strerror (errno)); printf ("error in zmq_msg_close: %s\n", zmq_strerror (errno));
exit (1); return -1;
}
}}
else{
for (i = 0; i != message_count; i++) {
rc = zmq_send( s, buf, message_size, 0);
if (rc < 0) {
printf ("error in zmq_send: %s\n", zmq_strerror (errno));
return 0;
}
}}
}
else{
if( rec == ZMSG){
zmq_msg_t msg;
rc = zmq_msg_init (&msg);
if (rc != 0) {
printf ("error in zmq_msg_init: %s\n", zmq_strerror (errno));
return 0;
}
for (i = 0; i != message_count; i++) {
rc = zmq_msg_recv (&msg, s, 0);
if (rc < 0) {
printf ("error in zmq_recv: %s\n", zmq_strerror (errno));
return 0;
}
}}
else{
for (i = 0; i != message_count; i++) {
rc = zmq_recv( s, buf, message_size, 0);
if (rc < 0) {
printf ("error in zmq_recv: %s\n", zmq_strerror (errno));
return 0;
} }
}}
} }
rc = zmq_close (s); rc = zmq_close (s);
if (rc != 0) { if (rc != 0) {
printf ("error in zmq_close: %s\n", zmq_strerror (errno)); printf ("error in zmq_close: %s\n", zmq_strerror (errno));
return 0;
}
free( buf);
return 0;
}
int main (int argc, char *argv [])
{
void *ctx;
int rc;
int i;
if (argc != 10) {
printf ("usage: remote_thr <connect-to> <message-size> <message-count> <SND buffer> <RCV buffer> <flow (PUSH/PULL)> <records (ZMSG/DATA)> <zmq-threads> <workers>\n");
return 1;
}
connect_to = argv [1];
message_size = atoi (argv [2]);
message_count = atoi (argv [3]);
sndbuflen = atoi (argv [4]);
rcvbuflen = atoi (argv [5]);
if( !strcmp( argv [6], "PUSH")){
flow = ZMQ_PUSH;
}
if( !strcmp( argv [6], "PULL")){
flow = ZMQ_PULL;
}
if( !strcmp( argv [7], "ZMSG")){
rec = ZMSG;
}
if( !strcmp( argv [7], "DATA")){
rec = DATA;
}
threads = atoi (argv [8]);
workers = atoi (argv [9]);
ctx = zmq_ctx_new ();
if (!ctx) {
printf ("error in zmq_ctx_new: %s\n", zmq_strerror (errno));
return -1; return -1;
} }
rc = zmq_ctx_set ( ctx, ZMQ_IO_THREADS, threads);
if (rc) {
printf ("error in zmq_ctx_set: %s\n", zmq_strerror (errno));
return -1;
}
printf("Threads: %d, workers %d\n", zmq_ctx_get( ctx, ZMQ_IO_THREADS), workers);
#if defined ZMQ_HAVE_WINDOWS
HANDLE worker[128];
#else
pthread_t worker[128];
#endif
US_TIMER timer;
tm_init( &timer);
for (i = 0; i < workers; i++) {
#if defined ZMQ_HAVE_WINDOWS
worker[i] = (HANDLE) _beginthreadex (NULL, 0, worker_routine, ctx, 0 , NULL);
#else
pthread_create (&worker[i], NULL, worker_routine, ctx);
#endif
printf("Worker %d spawned\n", i);
}
for (i = 0; i < workers; i++) {
#if defined ZMQ_HAVE_WINDOWS
WaitForSingleObject (worker[i], INFINITE);
CloseHandle (worker[i]);
#else
pthread_join( worker[i], NULL);
#endif
printf("Worker %d joined\n", i);
}
float secs = tm_secs( &timer);
float total = ( (float)workers)*(((float) message_count) * ((float) message_size)) / (1024.0*1024.0*1024.0);
printf ("Message: size: %d KBytes, count: %d/workers(%d), time: %f secs\n", (int) message_size/1024, message_count, workers, secs);
printf ("%sed %.3f GB @ %.3f GB/s\n", (flow == ZMQ_PULL) ? "Pull":"Push", total, total/secs);
rc = zmq_term (ctx); rc = zmq_term (ctx);
if (rc != 0) { if (rc != 0) {
printf ("error in zmq_term: %s\n", zmq_strerror (errno)); printf ("error in zmq_term: %s\n", zmq_strerror (errno));
...@@ -363,4 +96,3 @@ int main (int argc, char *argv []) ...@@ -363,4 +96,3 @@ int main (int argc, char *argv [])
return 0; return 0;
} }
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment