summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorEric Biggers <ebiggers@google.com>2023-10-09 00:32:14 -0700
committerHerbert Xu <herbert@gondor.apana.org.au>2023-10-20 13:39:25 +0800
commit8a3684881087d6030988a99bea8b3299e88aaf17 (patch)
tree2ea31cd0ab78fb9595808cac332b74d10e3a4b06
parente5dcb2c03a0cecf042e52ca1c84f7c6595723fe5 (diff)
downloadlinux-crypto-8a3684881087d6030988a99bea8b3299e88aaf17.tar.gz
linux-crypto-8a3684881087d6030988a99bea8b3299e88aaf17.zip
crypto: shash - fold shash_digest_unaligned() into crypto_shash_digest()
Fold shash_digest_unaligned() into its only remaining caller. Also, avoid a redundant check of CRYPTO_TFM_NEED_KEY by replacing the call to crypto_shash_init() with shash->init(desc). Finally, replace shash_update_unaligned() + shash_final_unaligned() with shash_finup_unaligned() which does exactly that. Signed-off-by: Eric Biggers <ebiggers@google.com> Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
-rw-r--r--crypto/shash.c11
1 files changed, 2 insertions, 9 deletions
diff --git a/crypto/shash.c b/crypto/shash.c
index d99dc2f9..15fee57c 100644
--- a/crypto/shash.c
+++ b/crypto/shash.c
@@ -225,14 +225,6 @@ int crypto_shash_finup(struct shash_desc *desc, const u8 *data,
}
EXPORT_SYMBOL_GPL(crypto_shash_finup);
-static int shash_digest_unaligned(struct shash_desc *desc, const u8 *data,
- unsigned int len, u8 *out)
-{
- return crypto_shash_init(desc) ?:
- shash_update_unaligned(desc, data, len) ?:
- shash_final_unaligned(desc, out);
-}
-
static int shash_default_digest(struct shash_desc *desc, const u8 *data,
unsigned int len, u8 *out)
{
@@ -260,7 +252,8 @@ int crypto_shash_digest(struct shash_desc *desc, const u8 *data,
if (crypto_shash_get_flags(tfm) & CRYPTO_TFM_NEED_KEY)
err = -ENOKEY;
else if (((unsigned long)data | (unsigned long)out) & alignmask)
- err = shash_digest_unaligned(desc, data, len, out);
+ err = shash->init(desc) ?:
+ shash_finup_unaligned(desc, data, len, out);
else
err = shash->digest(desc, data, len, out);