Loop on recv and send operations for non-blocking sockets with OpenSSL.

This commit is contained in:
Vincent Richard 2013-12-17 22:10:08 +01:00
parent 73eded2f97
commit 2b62c675fa

View File

@ -319,6 +319,8 @@ void TLSSocket_OpenSSL::handleError(int rc)
{ {
if (rc > 0) return; if (rc > 0) return;
internalThrow();
int sslError = SSL_get_error(m_ssl, rc); int sslError = SSL_get_error(m_ssl, rc);
long lastError = ERR_get_error(); long lastError = ERR_get_error();
@ -401,21 +403,17 @@ int TLSSocket_OpenSSL::bio_write(BIO* bio, const char* buf, int len)
try try
{ {
BIO_clear_retry_flags(bio); while (true)
{
const size_t n = sok->m_wrapped->sendRawNonBlocking const size_t n = sok->m_wrapped->sendRawNonBlocking
(reinterpret_cast <const byte_t*>(buf), len); (reinterpret_cast <const byte_t*>(buf), len);
BIO_clear_retry_flags(bio);
if (n == 0 && sok->m_wrapped->getStatus() & socket::STATUS_WOULDBLOCK) if (n == 0 && sok->m_wrapped->getStatus() & socket::STATUS_WOULDBLOCK)
{ continue;
BIO_set_retry_write(bio);
return -1;
}
return static_cast <int>(len); return static_cast <int>(len);
} }
}
catch (exception& e) catch (exception& e)
{ {
// Workaround for passing C++ exceptions from C BIO functions // Workaround for passing C++ exceptions from C BIO functions
@ -434,20 +432,18 @@ int TLSSocket_OpenSSL::bio_read(BIO* bio, char* buf, int len)
TLSSocket_OpenSSL *sok = reinterpret_cast <TLSSocket_OpenSSL*>(bio->ptr); TLSSocket_OpenSSL *sok = reinterpret_cast <TLSSocket_OpenSSL*>(bio->ptr);
try try
{
while (true)
{ {
const size_t n = sok->m_wrapped->receiveRaw const size_t n = sok->m_wrapped->receiveRaw
(reinterpret_cast <byte_t*>(buf), len); (reinterpret_cast <byte_t*>(buf), len);
BIO_clear_retry_flags(bio); if (n == 0 && sok->m_wrapped->getStatus() & socket::STATUS_WOULDBLOCK)
continue;
if (sok->m_wrapped->getStatus() & socket::STATUS_WOULDBLOCK)
{
BIO_set_retry_read(bio);
return -1;
}
return static_cast <int>(n); return static_cast <int>(n);
} }
}
catch (exception& e) catch (exception& e)
{ {
// Workaround for passing C++ exceptions from C BIO functions // Workaround for passing C++ exceptions from C BIO functions