bug #2785173 pointed out that we really must call _libssh2_transport_read()

in loops until it returns < 0 when we call it, as if we just call it once we
may drain the socket for data and then leave unused in-memory data that we
won't detect because the socket is back to idle...
This commit is contained in:
Daniel Stenberg 2009-05-01 19:07:20 +00:00
parent 9f104cd883
commit 9412588373

View File

@ -1758,29 +1758,19 @@ static ssize_t channel_read(LIBSSH2_CHANNEL *channel, int stream_id,
"stream #%d",
(int) buflen, channel->local.id, channel->remote.id,
stream_id);
channel->read_state = libssh2_NB_state_created;
}
rc = 1; /* set to >0 to let the while loop start */
/* process all pending incoming packets */
/* Process all pending incoming packets in all states in order to "even
out" the network readings. Tests prove that this way produces faster
transfers. */
while (rc > 0)
rc = _libssh2_transport_read(session);
if ((rc < 0) && (rc != PACKET_EAGAIN))
return -1;
channel->read_state = libssh2_NB_state_created;
}
else {
/* We're not in the idle state, but in order to "even out" the network
readings we do a single shot read here as well. Tests prove that
this way produces faster transfers. */
rc = _libssh2_transport_read(session);
/* ignore PACKET_EAGAIN but return failure for the rest */
if ((rc < 0) && (rc != PACKET_EAGAIN))
return -1;
}
/*
* =============================== NOTE ===============================
* I know this is very ugly and not a really good use of "goto", but