Commit 9ea9c58b authored by Eric Biggers's avatar Eric Biggers Committed by Herbert Xu

crypto: lib/sha256 - add sha256() function

Add a function sha256() which computes a SHA-256 digest in one step,
combining sha256_init() + sha256_update() + sha256_final().

This is similar to how we also have blake2s().
Reviewed-by: default avatarArd Biesheuvel <ardb@kernel.org>
Tested-by: default avatarHans de Goede <hdegoede@redhat.com>
Signed-off-by: default avatarEric Biggers <ebiggers@google.com>
Signed-off-by: default avatarHerbert Xu <herbert@gondor.apana.org.au>
parent 6e8f972f
...@@ -147,6 +147,7 @@ static inline void sha256_init(struct sha256_state *sctx) ...@@ -147,6 +147,7 @@ static inline void sha256_init(struct sha256_state *sctx)
} }
void sha256_update(struct sha256_state *sctx, const u8 *data, unsigned int len); void sha256_update(struct sha256_state *sctx, const u8 *data, unsigned int len);
void sha256_final(struct sha256_state *sctx, u8 *out); void sha256_final(struct sha256_state *sctx, u8 *out);
void sha256(const u8 *data, unsigned int len, u8 *out);
static inline void sha224_init(struct sha256_state *sctx) static inline void sha224_init(struct sha256_state *sctx)
{ {
......
...@@ -280,4 +280,14 @@ void sha224_final(struct sha256_state *sctx, u8 *out) ...@@ -280,4 +280,14 @@ void sha224_final(struct sha256_state *sctx, u8 *out)
} }
EXPORT_SYMBOL(sha224_final); EXPORT_SYMBOL(sha224_final);
void sha256(const u8 *data, unsigned int len, u8 *out)
{
struct sha256_state sctx;
sha256_init(&sctx);
sha256_update(&sctx, data, len);
sha256_final(&sctx, out);
}
EXPORT_SYMBOL(sha256);
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment