mirror of
https://github.com/zeromq/libzmq.git
synced 2025-10-23 08:31:46 +02:00
Problem: read-after-free when closing socket
Solution: use socket object's mutex before the send_reap() call that might deallocate it
This commit is contained in:
@@ -1290,12 +1290,13 @@ int zmq::socket_base_t::close ()
|
|||||||
// Mark the socket as dead
|
// Mark the socket as dead
|
||||||
tag = 0xdeadbeef;
|
tag = 0xdeadbeef;
|
||||||
|
|
||||||
|
EXIT_MUTEX ();
|
||||||
|
|
||||||
// Transfer the ownership of the socket from this application thread
|
// Transfer the ownership of the socket from this application thread
|
||||||
// to the reaper thread which will take care of the rest of shutdown
|
// to the reaper thread which will take care of the rest of shutdown
|
||||||
// process.
|
// process.
|
||||||
send_reap (this);
|
send_reap (this);
|
||||||
|
|
||||||
EXIT_MUTEX ();
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user