New SSL API mode 'SSL_MODE_AUTO_RETRY', which disables the default
behaviour that SSL_read may result in SSL_ERROR_WANT_READ.
This commit is contained in:
parent
fb1cba063d
commit
54f10e6adc
9
CHANGES
9
CHANGES
@ -4,6 +4,15 @@
|
|||||||
|
|
||||||
Changes between 0.9.5a and 0.9.6 [xx XXX 2000]
|
Changes between 0.9.5a and 0.9.6 [xx XXX 2000]
|
||||||
|
|
||||||
|
*) New SSL API mode 'SSL_MODE_AUTO_RETRY'. This disables the default
|
||||||
|
behaviour that SSL_read may result in SSL_ERROR_WANT_READ (even if
|
||||||
|
the underlying transport is blocking) if a handshake took place.
|
||||||
|
(The default behaviour is needed by applications such as s_client
|
||||||
|
and s_server that use select() to determine when to use SSL_read;
|
||||||
|
but for applications that know in advance when to expect data, it
|
||||||
|
just makes things more complicated.)
|
||||||
|
[Bodo Moeller]
|
||||||
|
|
||||||
*) Add RAND_egd_bytes(), which gives control over the number of bytes read
|
*) Add RAND_egd_bytes(), which gives control over the number of bytes read
|
||||||
from EGD.
|
from EGD.
|
||||||
[Ben Laurie]
|
[Ben Laurie]
|
||||||
|
24
ssl/s3_pkt.c
24
ssl/s3_pkt.c
@ -899,14 +899,15 @@ start:
|
|||||||
return(-1);
|
return(-1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!(s->mode & SSL_MODE_AUTO_RETRY))
|
||||||
|
{
|
||||||
if (s->s3->rbuf.left == 0) /* no read-ahead left? */
|
if (s->s3->rbuf.left == 0) /* no read-ahead left? */
|
||||||
{
|
{
|
||||||
BIO *bio;
|
BIO *bio;
|
||||||
/* In the case where we try to read application data
|
/* In the case where we try to read application data,
|
||||||
* the first time, but we trigger an SSL handshake, we
|
* but we trigger an SSL handshake, we return -1 with
|
||||||
* return -1 with the retry option set. I do this
|
* the retry option set. Otherwise renegotiation may
|
||||||
* otherwise renegotiation can cause nasty problems
|
* cause nasty problems in the blocking world */
|
||||||
* in the blocking world */ /* ? */
|
|
||||||
s->rwstate=SSL_READING;
|
s->rwstate=SSL_READING;
|
||||||
bio=SSL_get_rbio(s);
|
bio=SSL_get_rbio(s);
|
||||||
BIO_clear_retry_flags(bio);
|
BIO_clear_retry_flags(bio);
|
||||||
@ -915,6 +916,7 @@ start:
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
/* we either finished a handshake or ignored the request,
|
/* we either finished a handshake or ignored the request,
|
||||||
* now try again to obtain the (application) data we were asked for */
|
* now try again to obtain the (application) data we were asked for */
|
||||||
goto start;
|
goto start;
|
||||||
@ -1022,20 +1024,22 @@ start:
|
|||||||
return(-1);
|
return(-1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!(s->mode & SSL_MODE_AUTO_RETRY))
|
||||||
|
{
|
||||||
if (s->s3->rbuf.left == 0) /* no read-ahead left? */
|
if (s->s3->rbuf.left == 0) /* no read-ahead left? */
|
||||||
{
|
{
|
||||||
BIO *bio;
|
BIO *bio;
|
||||||
/* In the case where we try to read application data
|
/* In the case where we try to read application data,
|
||||||
* the first time, but we trigger an SSL handshake, we
|
* but we trigger an SSL handshake, we return -1 with
|
||||||
* return -1 with the retry option set. I do this
|
* the retry option set. Otherwise renegotiation may
|
||||||
* otherwise renegotiation can cause nasty problems
|
* cause nasty problems in the blocking world */
|
||||||
* in the blocking world */ /* ? */
|
|
||||||
s->rwstate=SSL_READING;
|
s->rwstate=SSL_READING;
|
||||||
bio=SSL_get_rbio(s);
|
bio=SSL_get_rbio(s);
|
||||||
BIO_clear_retry_flags(bio);
|
BIO_clear_retry_flags(bio);
|
||||||
BIO_set_retry_read(bio);
|
BIO_set_retry_read(bio);
|
||||||
return(-1);
|
return(-1);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
goto start;
|
goto start;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -335,6 +335,9 @@ typedef struct ssl_session_st
|
|||||||
* the misconception that non-blocking SSL_write() behaves like
|
* the misconception that non-blocking SSL_write() behaves like
|
||||||
* non-blocking write(): */
|
* non-blocking write(): */
|
||||||
#define SSL_MODE_ACCEPT_MOVING_WRITE_BUFFER 0x00000002L
|
#define SSL_MODE_ACCEPT_MOVING_WRITE_BUFFER 0x00000002L
|
||||||
|
/* Never bother the application with retries if the transport
|
||||||
|
* is blocking: */
|
||||||
|
#define SSL_MODE_AUTO_RETRY 0x00000004L
|
||||||
|
|
||||||
/* Note: SSL[_CTX]_set_{options,mode} use |= op on the previous value,
|
/* Note: SSL[_CTX]_set_{options,mode} use |= op on the previous value,
|
||||||
* they cannot be used to clear bits. */
|
* they cannot be used to clear bits. */
|
||||||
|
Loading…
Reference in New Issue
Block a user