0
0
mirror of https://github.com/zeromq/libzmq.git synced 2025-01-21 15:12:03 +08:00

Merge pull request #294 from pieterh/master

Fixed issue LIBZMQ-348 - Valgrind support
This commit is contained in:
Ian Barber 2012-03-26 14:41:12 -07:00
commit 19f364e202
3 changed files with 15 additions and 48 deletions

View File

@ -0,0 +1,14 @@
{
<socketcall_sendto>
Memcheck:Param
socketcall.sendto(msg)
fun:send
...
}
{
<socketcall_sendto>
Memcheck:Param
socketcall.send(msg)
fun:send
...
}

1
builds/valgrind/vg Executable file
View File

@ -0,0 +1 @@
valgrind --tool=memcheck --leak-check=full --suppressions=valgrind.supp $*

View File

@ -159,9 +159,6 @@ void zmq::object_t::send_stop ()
// 'stop' command goes always from administrative thread to // 'stop' command goes always from administrative thread to
// the current object. // the current object.
command_t cmd; command_t cmd;
#if defined ZMQ_MAKE_VALGRIND_HAPPY
memset (&cmd, 0, sizeof (cmd));
#endif
cmd.destination = this; cmd.destination = this;
cmd.type = command_t::stop; cmd.type = command_t::stop;
ctx->send_command (tid, cmd); ctx->send_command (tid, cmd);
@ -173,9 +170,6 @@ void zmq::object_t::send_plug (own_t *destination_, bool inc_seqnum_)
destination_->inc_seqnum (); destination_->inc_seqnum ();
command_t cmd; command_t cmd;
#if defined ZMQ_MAKE_VALGRIND_HAPPY
memset (&cmd, 0, sizeof (cmd));
#endif
cmd.destination = destination_; cmd.destination = destination_;
cmd.type = command_t::plug; cmd.type = command_t::plug;
send_command (cmd); send_command (cmd);
@ -185,9 +179,6 @@ void zmq::object_t::send_own (own_t *destination_, own_t *object_)
{ {
destination_->inc_seqnum (); destination_->inc_seqnum ();
command_t cmd; command_t cmd;
#if defined ZMQ_MAKE_VALGRIND_HAPPY
memset (&cmd, 0, sizeof (cmd));
#endif
cmd.destination = destination_; cmd.destination = destination_;
cmd.type = command_t::own; cmd.type = command_t::own;
cmd.args.own.object = object_; cmd.args.own.object = object_;
@ -201,9 +192,6 @@ void zmq::object_t::send_attach (session_base_t *destination_,
destination_->inc_seqnum (); destination_->inc_seqnum ();
command_t cmd; command_t cmd;
#if defined ZMQ_MAKE_VALGRIND_HAPPY
memset (&cmd, 0, sizeof (cmd));
#endif
cmd.destination = destination_; cmd.destination = destination_;
cmd.type = command_t::attach; cmd.type = command_t::attach;
cmd.args.attach.engine = engine_; cmd.args.attach.engine = engine_;
@ -217,9 +205,6 @@ void zmq::object_t::send_bind (own_t *destination_, pipe_t *pipe_,
destination_->inc_seqnum (); destination_->inc_seqnum ();
command_t cmd; command_t cmd;
#if defined ZMQ_MAKE_VALGRIND_HAPPY
memset (&cmd, 0, sizeof (cmd));
#endif
cmd.destination = destination_; cmd.destination = destination_;
cmd.type = command_t::bind; cmd.type = command_t::bind;
cmd.args.bind.pipe = pipe_; cmd.args.bind.pipe = pipe_;
@ -229,9 +214,6 @@ void zmq::object_t::send_bind (own_t *destination_, pipe_t *pipe_,
void zmq::object_t::send_activate_read (pipe_t *destination_) void zmq::object_t::send_activate_read (pipe_t *destination_)
{ {
command_t cmd; command_t cmd;
#if defined ZMQ_MAKE_VALGRIND_HAPPY
memset (&cmd, 0, sizeof (cmd));
#endif
cmd.destination = destination_; cmd.destination = destination_;
cmd.type = command_t::activate_read; cmd.type = command_t::activate_read;
send_command (cmd); send_command (cmd);
@ -241,9 +223,6 @@ void zmq::object_t::send_activate_write (pipe_t *destination_,
uint64_t msgs_read_) uint64_t msgs_read_)
{ {
command_t cmd; command_t cmd;
#if defined ZMQ_MAKE_VALGRIND_HAPPY
memset (&cmd, 0, sizeof (cmd));
#endif
cmd.destination = destination_; cmd.destination = destination_;
cmd.type = command_t::activate_write; cmd.type = command_t::activate_write;
cmd.args.activate_write.msgs_read = msgs_read_; cmd.args.activate_write.msgs_read = msgs_read_;
@ -253,9 +232,6 @@ void zmq::object_t::send_activate_write (pipe_t *destination_,
void zmq::object_t::send_hiccup (pipe_t *destination_, void *pipe_) void zmq::object_t::send_hiccup (pipe_t *destination_, void *pipe_)
{ {
command_t cmd; command_t cmd;
#if defined ZMQ_MAKE_VALGRIND_HAPPY
memset (&cmd, 0, sizeof (cmd));
#endif
cmd.destination = destination_; cmd.destination = destination_;
cmd.type = command_t::hiccup; cmd.type = command_t::hiccup;
cmd.args.hiccup.pipe = pipe_; cmd.args.hiccup.pipe = pipe_;
@ -265,9 +241,6 @@ void zmq::object_t::send_hiccup (pipe_t *destination_, void *pipe_)
void zmq::object_t::send_pipe_term (pipe_t *destination_) void zmq::object_t::send_pipe_term (pipe_t *destination_)
{ {
command_t cmd; command_t cmd;
#if defined ZMQ_MAKE_VALGRIND_HAPPY
memset (&cmd, 0, sizeof (cmd));
#endif
cmd.destination = destination_; cmd.destination = destination_;
cmd.type = command_t::pipe_term; cmd.type = command_t::pipe_term;
send_command (cmd); send_command (cmd);
@ -276,9 +249,6 @@ void zmq::object_t::send_pipe_term (pipe_t *destination_)
void zmq::object_t::send_pipe_term_ack (pipe_t *destination_) void zmq::object_t::send_pipe_term_ack (pipe_t *destination_)
{ {
command_t cmd; command_t cmd;
#if defined ZMQ_MAKE_VALGRIND_HAPPY
memset (&cmd, 0, sizeof (cmd));
#endif
cmd.destination = destination_; cmd.destination = destination_;
cmd.type = command_t::pipe_term_ack; cmd.type = command_t::pipe_term_ack;
send_command (cmd); send_command (cmd);
@ -288,9 +258,6 @@ void zmq::object_t::send_term_req (own_t *destination_,
own_t *object_) own_t *object_)
{ {
command_t cmd; command_t cmd;
#if defined ZMQ_MAKE_VALGRIND_HAPPY
memset (&cmd, 0, sizeof (cmd));
#endif
cmd.destination = destination_; cmd.destination = destination_;
cmd.type = command_t::term_req; cmd.type = command_t::term_req;
cmd.args.term_req.object = object_; cmd.args.term_req.object = object_;
@ -300,9 +267,6 @@ void zmq::object_t::send_term_req (own_t *destination_,
void zmq::object_t::send_term (own_t *destination_, int linger_) void zmq::object_t::send_term (own_t *destination_, int linger_)
{ {
command_t cmd; command_t cmd;
#if defined ZMQ_MAKE_VALGRIND_HAPPY
memset (&cmd, 0, sizeof (cmd));
#endif
cmd.destination = destination_; cmd.destination = destination_;
cmd.type = command_t::term; cmd.type = command_t::term;
cmd.args.term.linger = linger_; cmd.args.term.linger = linger_;
@ -312,9 +276,6 @@ void zmq::object_t::send_term (own_t *destination_, int linger_)
void zmq::object_t::send_term_ack (own_t *destination_) void zmq::object_t::send_term_ack (own_t *destination_)
{ {
command_t cmd; command_t cmd;
#if defined ZMQ_MAKE_VALGRIND_HAPPY
memset (&cmd, 0, sizeof (cmd));
#endif
cmd.destination = destination_; cmd.destination = destination_;
cmd.type = command_t::term_ack; cmd.type = command_t::term_ack;
send_command (cmd); send_command (cmd);
@ -323,9 +284,6 @@ void zmq::object_t::send_term_ack (own_t *destination_)
void zmq::object_t::send_reap (class socket_base_t *socket_) void zmq::object_t::send_reap (class socket_base_t *socket_)
{ {
command_t cmd; command_t cmd;
#if defined ZMQ_MAKE_VALGRIND_HAPPY
memset (&cmd, 0, sizeof (cmd));
#endif
cmd.destination = ctx->get_reaper (); cmd.destination = ctx->get_reaper ();
cmd.type = command_t::reap; cmd.type = command_t::reap;
cmd.args.reap.socket = socket_; cmd.args.reap.socket = socket_;
@ -335,9 +293,6 @@ void zmq::object_t::send_reap (class socket_base_t *socket_)
void zmq::object_t::send_reaped () void zmq::object_t::send_reaped ()
{ {
command_t cmd; command_t cmd;
#if defined ZMQ_MAKE_VALGRIND_HAPPY
memset (&cmd, 0, sizeof (cmd));
#endif
cmd.destination = ctx->get_reaper (); cmd.destination = ctx->get_reaper ();
cmd.type = command_t::reaped; cmd.type = command_t::reaped;
send_command (cmd); send_command (cmd);
@ -346,9 +301,6 @@ void zmq::object_t::send_reaped ()
void zmq::object_t::send_done () void zmq::object_t::send_done ()
{ {
command_t cmd; command_t cmd;
#if defined ZMQ_MAKE_VALGRIND_HAPPY
memset (&cmd, 0, sizeof (cmd));
#endif
cmd.destination = NULL; cmd.destination = NULL;
cmd.type = command_t::done; cmd.type = command_t::done;
ctx->send_command (ctx_t::term_tid, cmd); ctx->send_command (ctx_t::term_tid, cmd);