serverinfo_process_buffer: check result of realloc(ctx->cert->key->serverinfo) and...
authorJonas Maebe <jonas.maebe@elis.ugent.be>
Mon, 9 Dec 2013 15:57:04 +0000 (16:57 +0100)
committerKurt Roeckx <kurt@roeckx.be>
Wed, 10 Dec 2014 17:35:17 +0000 (18:35 +0100)
Signed-off-by: Kurt Roeckx <kurt@roeckx.be>
Reviewed-by: Matt Caswell <matt@openssl.org>
ssl/ssl_rsa.c

index 6f9337e1503228253ca19ea7842b78f8b603e7ba..006c02eb03ebf38818f50dcdd7e777a8cd6a732e 100644 (file)
@@ -948,6 +948,8 @@ static int serverinfo_process_buffer(const unsigned char *serverinfo,
 int SSL_CTX_use_serverinfo(SSL_CTX *ctx, const unsigned char *serverinfo,
                           size_t serverinfo_length)
        {
+       unsigned char *new_serverinfo;
+
        if (ctx == NULL || serverinfo == NULL || serverinfo_length == 0)
                {
                SSLerr(SSL_F_SSL_CTX_USE_SERVERINFO,ERR_R_PASSED_NULL_PARAMETER);
@@ -968,13 +970,14 @@ int SSL_CTX_use_serverinfo(SSL_CTX *ctx, const unsigned char *serverinfo,
                SSLerr(SSL_F_SSL_CTX_USE_SERVERINFO,ERR_R_INTERNAL_ERROR);
                return 0;
                }
-       ctx->cert->key->serverinfo = OPENSSL_realloc(ctx->cert->key->serverinfo,
+       new_serverinfo = OPENSSL_realloc(ctx->cert->key->serverinfo,
                                                     serverinfo_length);
-       if (ctx->cert->key->serverinfo == NULL)
+       if (new_serverinfo == NULL)
                {
                SSLerr(SSL_F_SSL_CTX_USE_SERVERINFO,ERR_R_MALLOC_FAILURE);
                return 0;
                }
+       ctx->cert->key->serverinfo = new_serverinfo;
        memcpy(ctx->cert->key->serverinfo, serverinfo, serverinfo_length);
        ctx->cert->key->serverinfo_length = serverinfo_length;