From: Bernd Edlinger Date: Wed, 15 Feb 2017 18:11:05 +0000 (+0100) Subject: Fix possible memory leak in cryptodev_digest_update. X-Git-Tag: OpenSSL_1_0_2l~90 X-Git-Url: https://git.librecmc.org/?a=commitdiff_plain;h=62cd6a8389128ec4dc5500bdd13889633c4a5ae0;p=oweals%2Fopenssl.git Fix possible memory leak in cryptodev_digest_update. Reviewed-by: Richard Levitte Reviewed-by: Rich Salz (Merged from https://github.com/openssl/openssl/pull/2639) --- diff --git a/crypto/engine/eng_cryptodev.c b/crypto/engine/eng_cryptodev.c index 2a2b95ce83..af59471c47 100644 --- a/crypto/engine/eng_cryptodev.c +++ b/crypto/engine/eng_cryptodev.c @@ -810,14 +810,15 @@ static int cryptodev_digest_update(EVP_MD_CTX *ctx, const void *data, if (!(ctx->flags & EVP_MD_CTX_FLAG_ONESHOT)) { /* if application doesn't support one buffer */ - state->mac_data = + char *mac_data = OPENSSL_realloc(state->mac_data, state->mac_len + count); - if (!state->mac_data) { + if (mac_data == NULL) { printf("cryptodev_digest_update: realloc failed\n"); return (0); } + state->mac_data = mac_data; memcpy(state->mac_data + state->mac_len, data, count); state->mac_len += count;