mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-07 13:43:51 +00:00
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: Ard Biesheuvel <ardb@kernel.org> Tested-by: Hans de Goede <hdegoede@redhat.com> Signed-off-by: Eric Biggers <ebiggers@google.com> Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
This commit is contained in:
parent
6e8f972fc3
commit
9ea9c58b40
@ -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_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)
|
||||
{
|
||||
|
@ -280,4 +280,14 @@ void sha224_final(struct sha256_state *sctx, u8 *out)
|
||||
}
|
||||
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");
|
||||
|
Loading…
Reference in New Issue
Block a user