summaryrefslogtreecommitdiffstats
path: root/ssl
diff options
context:
space:
mode:
authorBernd Edlinger <bernd.edlinger@hotmail.de>2016-12-22 20:17:29 +0100
committerRichard Levitte <levitte@openssl.org>2017-01-24 15:05:12 +0100
commit38088ce9934a90d4aea486edbff864f3935342e6 (patch)
treef64492188cd38ec53fb40888227981255ae93bf8 /ssl
parentRAND_egd_bytes: No need to check RAND_status on connection error. (diff)
downloadopenssl-38088ce9934a90d4aea486edbff864f3935342e6.tar.xz
openssl-38088ce9934a90d4aea486edbff864f3935342e6.zip
Fix a ssl session leak due to OOM in lh_SSL_SESSION_insert
- s == NULL can mean c is a new session *or* lh_insert was unable to create a hash entry. - use lh_SSL_SESSION_retrieve to check for this error condition. - If it happens simply remove the extra reference again. Reviewed-by: Rich Salz <rsalz@openssl.org> Reviewed-by: Richard Levitte <levitte@openssl.org> (Merged from https://github.com/openssl/openssl/pull/2138)
Diffstat (limited to 'ssl')
-rw-r--r--ssl/ssl_sess.c9
1 files changed, 9 insertions, 0 deletions
diff --git a/ssl/ssl_sess.c b/ssl/ssl_sess.c
index 0ea74389c2..c6d5c1247f 100644
--- a/ssl/ssl_sess.c
+++ b/ssl/ssl_sess.c
@@ -678,6 +678,15 @@ int SSL_CTX_add_session(SSL_CTX *ctx, SSL_SESSION *c)
* obtain the same session from an external cache)
*/
s = NULL;
+ } else if (s == NULL &&
+ lh_SSL_SESSION_retrieve(ctx->sessions, c) == NULL) {
+ /* s == NULL can also mean OOM error in lh_SSL_SESSION_insert ... */
+
+ /*
+ * ... so take back the extra reference and also don't add
+ * the session to the SSL_SESSION_list at this time
+ */
+ s = c;
}
/* Put at the head of the queue unless it is already in the cache */