Commit 74d3d842 authored by Simon Giesecke's avatar Simon Giesecke

Problem: huge stack allocation with select on Windows in socket_poller_t::wait

Solution: use optimized_fd_set_t
parent 3d39bb9c
...@@ -618,7 +618,9 @@ int zmq::socket_poller_t::wait (zmq::socket_poller_t::event_t *events_, ...@@ -618,7 +618,9 @@ int zmq::socket_poller_t::wait (zmq::socket_poller_t::event_t *events_,
bool first_pass = true; bool first_pass = true;
fd_set inset, outset, errset; optimized_fd_set_t inset (_pollset_size);
optimized_fd_set_t outset (_pollset_size);
optimized_fd_set_t errset (_pollset_size);
while (true) { while (true) {
// Compute the timeout for the subsequent poll. // Compute the timeout for the subsequent poll.
...@@ -638,11 +640,14 @@ int zmq::socket_poller_t::wait (zmq::socket_poller_t::event_t *events_, ...@@ -638,11 +640,14 @@ int zmq::socket_poller_t::wait (zmq::socket_poller_t::event_t *events_,
// Wait for events. Ignore interrupts if there's infinite timeout. // Wait for events. Ignore interrupts if there's infinite timeout.
while (true) { while (true) {
memcpy (&inset, &_pollset_in, valid_pollset_bytes (_pollset_in)); memcpy (inset.get (), &_pollset_in,
memcpy (&outset, &_pollset_out, valid_pollset_bytes (_pollset_out)); valid_pollset_bytes (_pollset_in));
memcpy (&errset, &_pollset_err, valid_pollset_bytes (_pollset_err)); memcpy (outset.get (), &_pollset_out,
const int rc = select (static_cast<int> (_max_fd + 1), &inset, valid_pollset_bytes (_pollset_out));
&outset, &errset, ptimeout); memcpy (errset.get (), &_pollset_err,
valid_pollset_bytes (_pollset_err));
const int rc = select (static_cast<int> (_max_fd + 1), inset.get (),
outset.get (), errset.get (), ptimeout);
#if defined ZMQ_HAVE_WINDOWS #if defined ZMQ_HAVE_WINDOWS
if (unlikely (rc == SOCKET_ERROR)) { if (unlikely (rc == SOCKET_ERROR)) {
errno = wsa_error_to_errno (WSAGetLastError ()); errno = wsa_error_to_errno (WSAGetLastError ());
...@@ -662,8 +667,8 @@ int zmq::socket_poller_t::wait (zmq::socket_poller_t::event_t *events_, ...@@ -662,8 +667,8 @@ int zmq::socket_poller_t::wait (zmq::socket_poller_t::event_t *events_,
_signaler->recv (); _signaler->recv ();
// Check for the events. // Check for the events.
const int found = const int found = check_events (events_, n_events_, *inset.get (),
check_events (events_, n_events_, inset, outset, errset); *outset.get (), *errset.get ());
if (found) { if (found) {
if (found > 0) if (found > 0)
zero_trail_events (events_, n_events_, found); zero_trail_events (events_, n_events_, found);
......
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