From: Pauli Date: Thu, 16 Jul 2020 01:15:42 +0000 (+1000) Subject: mac: always pass a non-NULL output size pointer to providers. X-Git-Tag: openssl-3.0.0-alpha6~107 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=a85c9021252e4ab53a15b46e773808864a63d3d1;p=thirdparty%2Fopenssl.git mac: always pass a non-NULL output size pointer to providers. The backend code varies for the different MACs and sometimes sets the output length, sometimes checks the return pointer and sometimes neither. Reviewed-by: Richard Levitte (Merged from https://github.com/openssl/openssl/pull/12458) --- diff --git a/crypto/evp/mac_lib.c b/crypto/evp/mac_lib.c index b7bfe8921fc..a5c1b44666d 100644 --- a/crypto/evp/mac_lib.c +++ b/crypto/evp/mac_lib.c @@ -120,15 +120,14 @@ int EVP_MAC_update(EVP_MAC_CTX *ctx, const unsigned char *data, size_t datalen) int EVP_MAC_final(EVP_MAC_CTX *ctx, unsigned char *out, size_t *outl, size_t outsize) { - int l = EVP_MAC_size(ctx); + size_t l = EVP_MAC_size(ctx); + int res = 1; - if (l < 0) - return 0; + if (out != NULL) + res = ctx->meth->final(ctx->data, out, &l, outsize); if (outl != NULL) *outl = l; - if (out == NULL) - return 1; - return ctx->meth->final(ctx->data, out, outl, outsize); + return res; } /*