Fix a ssl session leak due to OOM in lh_SSL_SESSION_insert
authorBernd Edlinger <bernd.edlinger@hotmail.de>
Thu, 22 Dec 2016 19:17:29 +0000 (20:17 +0100)
committerRichard Levitte <levitte@openssl.org>
Tue, 24 Jan 2017 14:06:43 +0000 (15:06 +0100)
- 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)
(cherry picked from commit 38088ce9934a90d4aea486edbff864f3935342e6)

ssl/ssl_sess.c

index eee1ca1f5bcc59be8db7cce5251489989804fc47..43cb1d371b98c7018d83a63b7a5f5fe5efd8f4d0 100644 (file)
@@ -660,6 +660,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 */