serverinfo_process_buffer: check result of realloc(ctx->cert->key->serverinfo) and don't leak memory if it fails
Signed-off-by: Kurt Roeckx <kurt@roeckx.be> Reviewed-by: Matt Caswell <matt@openssl.org>
This commit is contained in:
parent
bf8e7047aa
commit
e9e688effb
@ -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,
|
int SSL_CTX_use_serverinfo(SSL_CTX *ctx, const unsigned char *serverinfo,
|
||||||
size_t serverinfo_length)
|
size_t serverinfo_length)
|
||||||
{
|
{
|
||||||
|
unsigned char *new_serverinfo;
|
||||||
|
|
||||||
if (ctx == NULL || serverinfo == NULL || serverinfo_length == 0)
|
if (ctx == NULL || serverinfo == NULL || serverinfo_length == 0)
|
||||||
{
|
{
|
||||||
SSLerr(SSL_F_SSL_CTX_USE_SERVERINFO,ERR_R_PASSED_NULL_PARAMETER);
|
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);
|
SSLerr(SSL_F_SSL_CTX_USE_SERVERINFO,ERR_R_INTERNAL_ERROR);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
ctx->cert->key->serverinfo = OPENSSL_realloc(ctx->cert->key->serverinfo,
|
new_serverinfo = OPENSSL_realloc(ctx->cert->key->serverinfo,
|
||||||
serverinfo_length);
|
serverinfo_length);
|
||||||
if (ctx->cert->key->serverinfo == NULL)
|
if (new_serverinfo == NULL)
|
||||||
{
|
{
|
||||||
SSLerr(SSL_F_SSL_CTX_USE_SERVERINFO,ERR_R_MALLOC_FAILURE);
|
SSLerr(SSL_F_SSL_CTX_USE_SERVERINFO,ERR_R_MALLOC_FAILURE);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
ctx->cert->key->serverinfo = new_serverinfo;
|
||||||
memcpy(ctx->cert->key->serverinfo, serverinfo, serverinfo_length);
|
memcpy(ctx->cert->key->serverinfo, serverinfo, serverinfo_length);
|
||||||
ctx->cert->key->serverinfo_length = serverinfo_length;
|
ctx->cert->key->serverinfo_length = serverinfo_length;
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user