mirror of
https://github.com/zeromq/libzmq.git
synced 2025-01-21 15:12:03 +08:00
56ead84490
1) VSM - you cannot hand out the 'data' address as it was not allocated on the heap 2) for other messages the 'data' address cannot be handed out either, as it not the address originally returned by malloc and hence cannot be passed to 'free'. see msg.cpp u.lmsg.content = (content_t*) malloc (sizeof (content_t) + size_); .... u.lmsg.content->data = u.lmsg.content + 1; So the function is changed to always malloc a data buffer and copy the data into it. There is a possible optimisation using memmove for the non-VSM case but that is not done yet.
112 lines
2.5 KiB
C++
112 lines
2.5 KiB
C++
/*
|
|
Copyright (c) 2007-2013 Contributors as noted in the AUTHORS file
|
|
|
|
This file is part of 0MQ.
|
|
|
|
0MQ is free software; you can redistribute it and/or modify it under
|
|
the terms of the GNU Lesser General Public License as published by
|
|
the Free Software Foundation; either version 3 of the License, or
|
|
(at your option) any later version.
|
|
|
|
0MQ is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU Lesser General Public License for more details.
|
|
|
|
You should have received a copy of the GNU Lesser General Public License
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#include "../include/zmq.h"
|
|
#include <stdio.h>
|
|
#include <unistd.h>
|
|
#include <stdlib.h>
|
|
#include <string.h>
|
|
#undef NDEBUG
|
|
#include <assert.h>
|
|
|
|
// XSI vector I/O
|
|
#if defined ZMQ_HAVE_UIO
|
|
#include <sys/uio.h>
|
|
#else
|
|
struct iovec {
|
|
void *iov_base;
|
|
size_t iov_len;
|
|
};
|
|
#endif
|
|
|
|
void do_check(void* sb, void* sc, unsigned int msgsz)
|
|
{
|
|
int rc;
|
|
int sum =0;
|
|
for (int i = 0; i < 10; i++)
|
|
{
|
|
zmq_msg_t msg;
|
|
zmq_msg_init_size(&msg, msgsz);
|
|
void * data = zmq_msg_data(&msg);
|
|
memcpy(data,&i, sizeof(int));
|
|
rc = zmq_msg_send(&msg,sc,i==9 ? 0 :ZMQ_SNDMORE);
|
|
assert (rc == (int)msgsz);
|
|
zmq_msg_close(&msg);
|
|
sum += i;
|
|
}
|
|
|
|
struct iovec ibuffer[32] ;
|
|
memset(&ibuffer[0], 0, sizeof(ibuffer));
|
|
|
|
size_t count = 10;
|
|
rc = zmq_recviov(sb,&ibuffer[0],&count,0);
|
|
assert (rc == 10);
|
|
|
|
int rsum=0;
|
|
for(;count;--count)
|
|
{
|
|
int v;
|
|
memcpy(&v,ibuffer[count-1].iov_base,sizeof(int));
|
|
rsum += v;
|
|
assert(ibuffer[count-1].iov_len == msgsz);
|
|
// free up the memory
|
|
free(ibuffer[count-1].iov_base);
|
|
}
|
|
|
|
assert ( sum == rsum );
|
|
|
|
}
|
|
|
|
int main (void)
|
|
{
|
|
void *ctx = zmq_ctx_new ();
|
|
assert (ctx);
|
|
int rc;
|
|
|
|
void *sb = zmq_socket (ctx, ZMQ_PULL);
|
|
assert (sb);
|
|
|
|
rc = zmq_bind (sb, "inproc://a");
|
|
assert (rc == 0);
|
|
|
|
::sleep(1);
|
|
void *sc = zmq_socket (ctx, ZMQ_PUSH);
|
|
|
|
rc = zmq_connect (sc, "inproc://a");
|
|
assert (rc == 0);
|
|
|
|
|
|
// message bigger than vsm max
|
|
do_check(sb,sc,100);
|
|
|
|
// message smaller than vsm max
|
|
do_check(sb,sc,10);
|
|
|
|
rc = zmq_close (sc);
|
|
assert (rc == 0);
|
|
|
|
rc = zmq_close (sb);
|
|
assert (rc == 0);
|
|
|
|
rc = zmq_ctx_term (ctx);
|
|
assert (rc == 0);
|
|
|
|
return 0;
|
|
}
|