diff options
author | Pauli <pauli@openssl.org> | 2021-06-15 10:48:35 +0200 |
---|---|---|
committer | Pauli <pauli@openssl.org> | 2021-06-16 10:30:28 +0200 |
commit | 987d7da3277423b580b66232985a21af38ae4f79 (patch) | |
tree | 5481c88ddc7ff9f2f23360a9133c7f1ccaa97507 /crypto/sha | |
parent | Correct processing of AES-SHA stitched ciphers (diff) | |
download | openssl-987d7da3277423b580b66232985a21af38ae4f79.tar.xz openssl-987d7da3277423b580b66232985a21af38ae4f79.zip |
Include a local static buffer for the SHA helper functions
This functionality existed in 1.1.1 but was lost.
Fixes #15718
Reviewed-by: Tomas Mraz <tomas@openssl.org>
(Merged from https://github.com/openssl/openssl/pull/15752)
Diffstat (limited to 'crypto/sha')
-rw-r--r-- | crypto/sha/sha1_one.c | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/crypto/sha/sha1_one.c b/crypto/sha/sha1_one.c index d6f5d1ecce..d1fa3d84f1 100644 --- a/crypto/sha/sha1_one.c +++ b/crypto/sha/sha1_one.c @@ -37,25 +37,45 @@ unsigned char *ossl_sha1(const unsigned char *d, size_t n, unsigned char *md) unsigned char *SHA1(const unsigned char *d, size_t n, unsigned char *md) { + static unsigned char m[SHA_DIGEST_LENGTH]; + + if (md == NULL) + md = m; return EVP_Q_digest(NULL, "SHA1", NULL, d, n, md, NULL) ? md : NULL; } unsigned char *SHA224(const unsigned char *d, size_t n, unsigned char *md) { + static unsigned char m[SHA224_DIGEST_LENGTH]; + + if (md == NULL) + md = m; return EVP_Q_digest(NULL, "SHA224", NULL, d, n, md, NULL) ? md : NULL; } unsigned char *SHA256(const unsigned char *d, size_t n, unsigned char *md) { + static unsigned char m[SHA256_DIGEST_LENGTH]; + + if (md == NULL) + md = m; return EVP_Q_digest(NULL, "SHA256", NULL, d, n, md, NULL) ? md : NULL; } unsigned char *SHA384(const unsigned char *d, size_t n, unsigned char *md) { + static unsigned char m[SHA384_DIGEST_LENGTH]; + + if (md == NULL) + md = m; return EVP_Q_digest(NULL, "SHA384", NULL, d, n, md, NULL) ? md : NULL; } unsigned char *SHA512(const unsigned char *d, size_t n, unsigned char *md) { + static unsigned char m[SHA512_DIGEST_LENGTH]; + + if (md == NULL) + md = m; return EVP_Q_digest(NULL, "SHA512", NULL, d, n, md, NULL) ? md : NULL; } |