diff options
Diffstat (limited to '')
| -rw-r--r-- | src/lib/libssl/ssl_asn1.c | 11 |
1 files changed, 9 insertions, 2 deletions
diff --git a/src/lib/libssl/ssl_asn1.c b/src/lib/libssl/ssl_asn1.c index 23bfe44e21..d8ff8fc4a3 100644 --- a/src/lib/libssl/ssl_asn1.c +++ b/src/lib/libssl/ssl_asn1.c | |||
| @@ -298,6 +298,7 @@ SSL_SESSION *d2i_SSL_SESSION(SSL_SESSION **a, unsigned char **pp, | |||
| 298 | os.length = sizeof ret->session_id; | 298 | os.length = sizeof ret->session_id; |
| 299 | 299 | ||
| 300 | ret->session_id_length=os.length; | 300 | ret->session_id_length=os.length; |
| 301 | OPENSSL_assert(os.length <= sizeof ret->session_id); | ||
| 301 | memcpy(ret->session_id,os.data,os.length); | 302 | memcpy(ret->session_id,os.data,os.length); |
| 302 | 303 | ||
| 303 | M_ASN1_D2I_get(osp,d2i_ASN1_OCTET_STRING); | 304 | M_ASN1_D2I_get(osp,d2i_ASN1_OCTET_STRING); |
| @@ -369,9 +370,15 @@ SSL_SESSION *d2i_SSL_SESSION(SSL_SESSION **a, unsigned char **pp, | |||
| 369 | if(os.data != NULL) | 370 | if(os.data != NULL) |
| 370 | { | 371 | { |
| 371 | if (os.length > SSL_MAX_SID_CTX_LENGTH) | 372 | if (os.length > SSL_MAX_SID_CTX_LENGTH) |
| 373 | { | ||
| 374 | ret->sid_ctx_length=os.length; | ||
| 372 | SSLerr(SSL_F_D2I_SSL_SESSION,SSL_R_BAD_LENGTH); | 375 | SSLerr(SSL_F_D2I_SSL_SESSION,SSL_R_BAD_LENGTH); |
| 373 | ret->sid_ctx_length=os.length; | 376 | } |
| 374 | memcpy(ret->sid_ctx,os.data,os.length); | 377 | else |
| 378 | { | ||
| 379 | ret->sid_ctx_length=os.length; | ||
| 380 | memcpy(ret->sid_ctx,os.data,os.length); | ||
| 381 | } | ||
| 375 | OPENSSL_free(os.data); os.data=NULL; os.length=0; | 382 | OPENSSL_free(os.data); os.data=NULL; os.length=0; |
| 376 | } | 383 | } |
| 377 | else | 384 | else |
