diff options
Diffstat (limited to 'src/lib/libssl/ssl_sess.c')
-rw-r--r-- | src/lib/libssl/ssl_sess.c | 7 |
1 files changed, 6 insertions, 1 deletions
diff --git a/src/lib/libssl/ssl_sess.c b/src/lib/libssl/ssl_sess.c index a0c3100b29..664f8c2230 100644 --- a/src/lib/libssl/ssl_sess.c +++ b/src/lib/libssl/ssl_sess.c | |||
@@ -250,7 +250,12 @@ int ssl_get_new_session(SSL *s, int session) | |||
250 | ss->session_id_length=0; | 250 | ss->session_id_length=0; |
251 | } | 251 | } |
252 | 252 | ||
253 | die(s->sid_ctx_length <= sizeof ss->sid_ctx); | 253 | if (s->sid_ctx_length > sizeof ss->sid_ctx) |
254 | { | ||
255 | SSLerr(SSL_F_SSL_GET_NEW_SESSION, ERR_R_INTERNAL_ERROR); | ||
256 | SSL_SESSION_free(ss); | ||
257 | return 0; | ||
258 | } | ||
254 | memcpy(ss->sid_ctx,s->sid_ctx,s->sid_ctx_length); | 259 | memcpy(ss->sid_ctx,s->sid_ctx,s->sid_ctx_length); |
255 | ss->sid_ctx_length=s->sid_ctx_length; | 260 | ss->sid_ctx_length=s->sid_ctx_length; |
256 | s->session=ss; | 261 | s->session=ss; |