mirror of
git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-08-05 16:54:27 +00:00

While the HMAC library functions support both incremental and one-shot computation and both prepared and raw keys, the combination of raw key + incremental was missing. It turns out that several potential users of the HMAC library functions (tpm2-sessions.c, smb2transport.c, trusted_tpm1.c) want exactly that. Therefore, add the missing functions hmac_sha*_init_usingrawkey(). Implement them in an optimized way that directly initializes the HMAC context without a separate key preparation step. Reimplement the one-shot raw key functions hmac_sha*_usingrawkey() on top of the new functions, which makes them a bit more efficient. Reviewed-by: Ard Biesheuvel <ardb@kernel.org> Link: https://lore.kernel.org/r/20250711215844.41715-1-ebiggers@kernel.org Signed-off-by: Eric Biggers <ebiggers@kernel.org>
876 lines
25 KiB
C
876 lines
25 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
/*
|
|
* Common values for SHA-2 algorithms
|
|
*/
|
|
|
|
#ifndef _CRYPTO_SHA2_H
|
|
#define _CRYPTO_SHA2_H
|
|
|
|
#include <linux/types.h>
|
|
|
|
#define SHA224_DIGEST_SIZE 28
|
|
#define SHA224_BLOCK_SIZE 64
|
|
|
|
#define SHA256_DIGEST_SIZE 32
|
|
#define SHA256_BLOCK_SIZE 64
|
|
#define SHA256_STATE_WORDS 8
|
|
|
|
#define SHA384_DIGEST_SIZE 48
|
|
#define SHA384_BLOCK_SIZE 128
|
|
|
|
#define SHA512_DIGEST_SIZE 64
|
|
#define SHA512_BLOCK_SIZE 128
|
|
#define SHA512_STATE_SIZE 80
|
|
|
|
#define SHA224_H0 0xc1059ed8UL
|
|
#define SHA224_H1 0x367cd507UL
|
|
#define SHA224_H2 0x3070dd17UL
|
|
#define SHA224_H3 0xf70e5939UL
|
|
#define SHA224_H4 0xffc00b31UL
|
|
#define SHA224_H5 0x68581511UL
|
|
#define SHA224_H6 0x64f98fa7UL
|
|
#define SHA224_H7 0xbefa4fa4UL
|
|
|
|
#define SHA256_H0 0x6a09e667UL
|
|
#define SHA256_H1 0xbb67ae85UL
|
|
#define SHA256_H2 0x3c6ef372UL
|
|
#define SHA256_H3 0xa54ff53aUL
|
|
#define SHA256_H4 0x510e527fUL
|
|
#define SHA256_H5 0x9b05688cUL
|
|
#define SHA256_H6 0x1f83d9abUL
|
|
#define SHA256_H7 0x5be0cd19UL
|
|
|
|
#define SHA384_H0 0xcbbb9d5dc1059ed8ULL
|
|
#define SHA384_H1 0x629a292a367cd507ULL
|
|
#define SHA384_H2 0x9159015a3070dd17ULL
|
|
#define SHA384_H3 0x152fecd8f70e5939ULL
|
|
#define SHA384_H4 0x67332667ffc00b31ULL
|
|
#define SHA384_H5 0x8eb44a8768581511ULL
|
|
#define SHA384_H6 0xdb0c2e0d64f98fa7ULL
|
|
#define SHA384_H7 0x47b5481dbefa4fa4ULL
|
|
|
|
#define SHA512_H0 0x6a09e667f3bcc908ULL
|
|
#define SHA512_H1 0xbb67ae8584caa73bULL
|
|
#define SHA512_H2 0x3c6ef372fe94f82bULL
|
|
#define SHA512_H3 0xa54ff53a5f1d36f1ULL
|
|
#define SHA512_H4 0x510e527fade682d1ULL
|
|
#define SHA512_H5 0x9b05688c2b3e6c1fULL
|
|
#define SHA512_H6 0x1f83d9abfb41bd6bULL
|
|
#define SHA512_H7 0x5be0cd19137e2179ULL
|
|
|
|
extern const u8 sha224_zero_message_hash[SHA224_DIGEST_SIZE];
|
|
|
|
extern const u8 sha256_zero_message_hash[SHA256_DIGEST_SIZE];
|
|
|
|
extern const u8 sha384_zero_message_hash[SHA384_DIGEST_SIZE];
|
|
|
|
extern const u8 sha512_zero_message_hash[SHA512_DIGEST_SIZE];
|
|
|
|
struct crypto_sha256_state {
|
|
u32 state[SHA256_STATE_WORDS];
|
|
u64 count;
|
|
};
|
|
|
|
static inline void sha224_block_init(struct crypto_sha256_state *sctx)
|
|
{
|
|
sctx->state[0] = SHA224_H0;
|
|
sctx->state[1] = SHA224_H1;
|
|
sctx->state[2] = SHA224_H2;
|
|
sctx->state[3] = SHA224_H3;
|
|
sctx->state[4] = SHA224_H4;
|
|
sctx->state[5] = SHA224_H5;
|
|
sctx->state[6] = SHA224_H6;
|
|
sctx->state[7] = SHA224_H7;
|
|
sctx->count = 0;
|
|
}
|
|
|
|
static inline void sha256_block_init(struct crypto_sha256_state *sctx)
|
|
{
|
|
sctx->state[0] = SHA256_H0;
|
|
sctx->state[1] = SHA256_H1;
|
|
sctx->state[2] = SHA256_H2;
|
|
sctx->state[3] = SHA256_H3;
|
|
sctx->state[4] = SHA256_H4;
|
|
sctx->state[5] = SHA256_H5;
|
|
sctx->state[6] = SHA256_H6;
|
|
sctx->state[7] = SHA256_H7;
|
|
sctx->count = 0;
|
|
}
|
|
|
|
struct sha256_state {
|
|
union {
|
|
struct crypto_sha256_state ctx;
|
|
struct {
|
|
u32 state[SHA256_STATE_WORDS];
|
|
u64 count;
|
|
};
|
|
};
|
|
u8 buf[SHA256_BLOCK_SIZE];
|
|
};
|
|
|
|
struct sha512_state {
|
|
u64 state[SHA512_DIGEST_SIZE / 8];
|
|
u64 count[2];
|
|
u8 buf[SHA512_BLOCK_SIZE];
|
|
};
|
|
|
|
/* State for the SHA-256 (and SHA-224) compression function */
|
|
struct sha256_block_state {
|
|
u32 h[SHA256_STATE_WORDS];
|
|
};
|
|
|
|
/*
|
|
* Context structure, shared by SHA-224 and SHA-256. The sha224_ctx and
|
|
* sha256_ctx structs wrap this one so that the API has proper typing and
|
|
* doesn't allow mixing the SHA-224 and SHA-256 functions arbitrarily.
|
|
*/
|
|
struct __sha256_ctx {
|
|
struct sha256_block_state state;
|
|
u64 bytecount;
|
|
u8 buf[SHA256_BLOCK_SIZE] __aligned(__alignof__(__be64));
|
|
};
|
|
void __sha256_update(struct __sha256_ctx *ctx, const u8 *data, size_t len);
|
|
|
|
/*
|
|
* HMAC key and message context structs, shared by HMAC-SHA224 and HMAC-SHA256.
|
|
* The hmac_sha224_* and hmac_sha256_* structs wrap this one so that the API has
|
|
* proper typing and doesn't allow mixing the functions arbitrarily.
|
|
*/
|
|
struct __hmac_sha256_key {
|
|
struct sha256_block_state istate;
|
|
struct sha256_block_state ostate;
|
|
};
|
|
struct __hmac_sha256_ctx {
|
|
struct __sha256_ctx sha_ctx;
|
|
struct sha256_block_state ostate;
|
|
};
|
|
void __hmac_sha256_init(struct __hmac_sha256_ctx *ctx,
|
|
const struct __hmac_sha256_key *key);
|
|
|
|
/**
|
|
* struct sha224_ctx - Context for hashing a message with SHA-224
|
|
* @ctx: private
|
|
*/
|
|
struct sha224_ctx {
|
|
struct __sha256_ctx ctx;
|
|
};
|
|
|
|
/**
|
|
* sha224_init() - Initialize a SHA-224 context for a new message
|
|
* @ctx: the context to initialize
|
|
*
|
|
* If you don't need incremental computation, consider sha224() instead.
|
|
*
|
|
* Context: Any context.
|
|
*/
|
|
void sha224_init(struct sha224_ctx *ctx);
|
|
|
|
/**
|
|
* sha224_update() - Update a SHA-224 context with message data
|
|
* @ctx: the context to update; must have been initialized
|
|
* @data: the message data
|
|
* @len: the data length in bytes
|
|
*
|
|
* This can be called any number of times.
|
|
*
|
|
* Context: Any context.
|
|
*/
|
|
static inline void sha224_update(struct sha224_ctx *ctx,
|
|
const u8 *data, size_t len)
|
|
{
|
|
__sha256_update(&ctx->ctx, data, len);
|
|
}
|
|
|
|
/**
|
|
* sha224_final() - Finish computing a SHA-224 message digest
|
|
* @ctx: the context to finalize; must have been initialized
|
|
* @out: (output) the resulting SHA-224 message digest
|
|
*
|
|
* After finishing, this zeroizes @ctx. So the caller does not need to do it.
|
|
*
|
|
* Context: Any context.
|
|
*/
|
|
void sha224_final(struct sha224_ctx *ctx, u8 out[SHA224_DIGEST_SIZE]);
|
|
|
|
/**
|
|
* sha224() - Compute SHA-224 message digest in one shot
|
|
* @data: the message data
|
|
* @len: the data length in bytes
|
|
* @out: (output) the resulting SHA-224 message digest
|
|
*
|
|
* Context: Any context.
|
|
*/
|
|
void sha224(const u8 *data, size_t len, u8 out[SHA224_DIGEST_SIZE]);
|
|
|
|
/**
|
|
* struct hmac_sha224_key - Prepared key for HMAC-SHA224
|
|
* @key: private
|
|
*/
|
|
struct hmac_sha224_key {
|
|
struct __hmac_sha256_key key;
|
|
};
|
|
|
|
/**
|
|
* struct hmac_sha224_ctx - Context for computing HMAC-SHA224 of a message
|
|
* @ctx: private
|
|
*/
|
|
struct hmac_sha224_ctx {
|
|
struct __hmac_sha256_ctx ctx;
|
|
};
|
|
|
|
/**
|
|
* hmac_sha224_preparekey() - Prepare a key for HMAC-SHA224
|
|
* @key: (output) the key structure to initialize
|
|
* @raw_key: the raw HMAC-SHA224 key
|
|
* @raw_key_len: the key length in bytes. All key lengths are supported.
|
|
*
|
|
* Note: the caller is responsible for zeroizing both the struct hmac_sha224_key
|
|
* and the raw key once they are no longer needed.
|
|
*
|
|
* Context: Any context.
|
|
*/
|
|
void hmac_sha224_preparekey(struct hmac_sha224_key *key,
|
|
const u8 *raw_key, size_t raw_key_len);
|
|
|
|
/**
|
|
* hmac_sha224_init() - Initialize an HMAC-SHA224 context for a new message
|
|
* @ctx: (output) the HMAC context to initialize
|
|
* @key: the prepared HMAC key
|
|
*
|
|
* If you don't need incremental computation, consider hmac_sha224() instead.
|
|
*
|
|
* Context: Any context.
|
|
*/
|
|
static inline void hmac_sha224_init(struct hmac_sha224_ctx *ctx,
|
|
const struct hmac_sha224_key *key)
|
|
{
|
|
__hmac_sha256_init(&ctx->ctx, &key->key);
|
|
}
|
|
|
|
/**
|
|
* hmac_sha224_init_usingrawkey() - Initialize an HMAC-SHA224 context for a new
|
|
* message, using a raw key
|
|
* @ctx: (output) the HMAC context to initialize
|
|
* @raw_key: the raw HMAC-SHA224 key
|
|
* @raw_key_len: the key length in bytes. All key lengths are supported.
|
|
*
|
|
* If you don't need incremental computation, consider hmac_sha224_usingrawkey()
|
|
* instead.
|
|
*
|
|
* Context: Any context.
|
|
*/
|
|
void hmac_sha224_init_usingrawkey(struct hmac_sha224_ctx *ctx,
|
|
const u8 *raw_key, size_t raw_key_len);
|
|
|
|
/**
|
|
* hmac_sha224_update() - Update an HMAC-SHA224 context with message data
|
|
* @ctx: the HMAC context to update; must have been initialized
|
|
* @data: the message data
|
|
* @data_len: the data length in bytes
|
|
*
|
|
* This can be called any number of times.
|
|
*
|
|
* Context: Any context.
|
|
*/
|
|
static inline void hmac_sha224_update(struct hmac_sha224_ctx *ctx,
|
|
const u8 *data, size_t data_len)
|
|
{
|
|
__sha256_update(&ctx->ctx.sha_ctx, data, data_len);
|
|
}
|
|
|
|
/**
|
|
* hmac_sha224_final() - Finish computing an HMAC-SHA224 value
|
|
* @ctx: the HMAC context to finalize; must have been initialized
|
|
* @out: (output) the resulting HMAC-SHA224 value
|
|
*
|
|
* After finishing, this zeroizes @ctx. So the caller does not need to do it.
|
|
*
|
|
* Context: Any context.
|
|
*/
|
|
void hmac_sha224_final(struct hmac_sha224_ctx *ctx, u8 out[SHA224_DIGEST_SIZE]);
|
|
|
|
/**
|
|
* hmac_sha224() - Compute HMAC-SHA224 in one shot, using a prepared key
|
|
* @key: the prepared HMAC key
|
|
* @data: the message data
|
|
* @data_len: the data length in bytes
|
|
* @out: (output) the resulting HMAC-SHA224 value
|
|
*
|
|
* If you're using the key only once, consider using hmac_sha224_usingrawkey().
|
|
*
|
|
* Context: Any context.
|
|
*/
|
|
void hmac_sha224(const struct hmac_sha224_key *key,
|
|
const u8 *data, size_t data_len, u8 out[SHA224_DIGEST_SIZE]);
|
|
|
|
/**
|
|
* hmac_sha224_usingrawkey() - Compute HMAC-SHA224 in one shot, using a raw key
|
|
* @raw_key: the raw HMAC-SHA224 key
|
|
* @raw_key_len: the key length in bytes. All key lengths are supported.
|
|
* @data: the message data
|
|
* @data_len: the data length in bytes
|
|
* @out: (output) the resulting HMAC-SHA224 value
|
|
*
|
|
* If you're using the key multiple times, prefer to use
|
|
* hmac_sha224_preparekey() followed by multiple calls to hmac_sha224() instead.
|
|
*
|
|
* Context: Any context.
|
|
*/
|
|
void hmac_sha224_usingrawkey(const u8 *raw_key, size_t raw_key_len,
|
|
const u8 *data, size_t data_len,
|
|
u8 out[SHA224_DIGEST_SIZE]);
|
|
|
|
/**
|
|
* struct sha256_ctx - Context for hashing a message with SHA-256
|
|
* @ctx: private
|
|
*/
|
|
struct sha256_ctx {
|
|
struct __sha256_ctx ctx;
|
|
};
|
|
|
|
/**
|
|
* sha256_init() - Initialize a SHA-256 context for a new message
|
|
* @ctx: the context to initialize
|
|
*
|
|
* If you don't need incremental computation, consider sha256() instead.
|
|
*
|
|
* Context: Any context.
|
|
*/
|
|
void sha256_init(struct sha256_ctx *ctx);
|
|
|
|
/**
|
|
* sha256_update() - Update a SHA-256 context with message data
|
|
* @ctx: the context to update; must have been initialized
|
|
* @data: the message data
|
|
* @len: the data length in bytes
|
|
*
|
|
* This can be called any number of times.
|
|
*
|
|
* Context: Any context.
|
|
*/
|
|
static inline void sha256_update(struct sha256_ctx *ctx,
|
|
const u8 *data, size_t len)
|
|
{
|
|
__sha256_update(&ctx->ctx, data, len);
|
|
}
|
|
|
|
/**
|
|
* sha256_final() - Finish computing a SHA-256 message digest
|
|
* @ctx: the context to finalize; must have been initialized
|
|
* @out: (output) the resulting SHA-256 message digest
|
|
*
|
|
* After finishing, this zeroizes @ctx. So the caller does not need to do it.
|
|
*
|
|
* Context: Any context.
|
|
*/
|
|
void sha256_final(struct sha256_ctx *ctx, u8 out[SHA256_DIGEST_SIZE]);
|
|
|
|
/**
|
|
* sha256() - Compute SHA-256 message digest in one shot
|
|
* @data: the message data
|
|
* @len: the data length in bytes
|
|
* @out: (output) the resulting SHA-256 message digest
|
|
*
|
|
* Context: Any context.
|
|
*/
|
|
void sha256(const u8 *data, size_t len, u8 out[SHA256_DIGEST_SIZE]);
|
|
|
|
/**
|
|
* struct hmac_sha256_key - Prepared key for HMAC-SHA256
|
|
* @key: private
|
|
*/
|
|
struct hmac_sha256_key {
|
|
struct __hmac_sha256_key key;
|
|
};
|
|
|
|
/**
|
|
* struct hmac_sha256_ctx - Context for computing HMAC-SHA256 of a message
|
|
* @ctx: private
|
|
*/
|
|
struct hmac_sha256_ctx {
|
|
struct __hmac_sha256_ctx ctx;
|
|
};
|
|
|
|
/**
|
|
* hmac_sha256_preparekey() - Prepare a key for HMAC-SHA256
|
|
* @key: (output) the key structure to initialize
|
|
* @raw_key: the raw HMAC-SHA256 key
|
|
* @raw_key_len: the key length in bytes. All key lengths are supported.
|
|
*
|
|
* Note: the caller is responsible for zeroizing both the struct hmac_sha256_key
|
|
* and the raw key once they are no longer needed.
|
|
*
|
|
* Context: Any context.
|
|
*/
|
|
void hmac_sha256_preparekey(struct hmac_sha256_key *key,
|
|
const u8 *raw_key, size_t raw_key_len);
|
|
|
|
/**
|
|
* hmac_sha256_init() - Initialize an HMAC-SHA256 context for a new message
|
|
* @ctx: (output) the HMAC context to initialize
|
|
* @key: the prepared HMAC key
|
|
*
|
|
* If you don't need incremental computation, consider hmac_sha256() instead.
|
|
*
|
|
* Context: Any context.
|
|
*/
|
|
static inline void hmac_sha256_init(struct hmac_sha256_ctx *ctx,
|
|
const struct hmac_sha256_key *key)
|
|
{
|
|
__hmac_sha256_init(&ctx->ctx, &key->key);
|
|
}
|
|
|
|
/**
|
|
* hmac_sha256_init_usingrawkey() - Initialize an HMAC-SHA256 context for a new
|
|
* message, using a raw key
|
|
* @ctx: (output) the HMAC context to initialize
|
|
* @raw_key: the raw HMAC-SHA256 key
|
|
* @raw_key_len: the key length in bytes. All key lengths are supported.
|
|
*
|
|
* If you don't need incremental computation, consider hmac_sha256_usingrawkey()
|
|
* instead.
|
|
*
|
|
* Context: Any context.
|
|
*/
|
|
void hmac_sha256_init_usingrawkey(struct hmac_sha256_ctx *ctx,
|
|
const u8 *raw_key, size_t raw_key_len);
|
|
|
|
/**
|
|
* hmac_sha256_update() - Update an HMAC-SHA256 context with message data
|
|
* @ctx: the HMAC context to update; must have been initialized
|
|
* @data: the message data
|
|
* @data_len: the data length in bytes
|
|
*
|
|
* This can be called any number of times.
|
|
*
|
|
* Context: Any context.
|
|
*/
|
|
static inline void hmac_sha256_update(struct hmac_sha256_ctx *ctx,
|
|
const u8 *data, size_t data_len)
|
|
{
|
|
__sha256_update(&ctx->ctx.sha_ctx, data, data_len);
|
|
}
|
|
|
|
/**
|
|
* hmac_sha256_final() - Finish computing an HMAC-SHA256 value
|
|
* @ctx: the HMAC context to finalize; must have been initialized
|
|
* @out: (output) the resulting HMAC-SHA256 value
|
|
*
|
|
* After finishing, this zeroizes @ctx. So the caller does not need to do it.
|
|
*
|
|
* Context: Any context.
|
|
*/
|
|
void hmac_sha256_final(struct hmac_sha256_ctx *ctx, u8 out[SHA256_DIGEST_SIZE]);
|
|
|
|
/**
|
|
* hmac_sha256() - Compute HMAC-SHA256 in one shot, using a prepared key
|
|
* @key: the prepared HMAC key
|
|
* @data: the message data
|
|
* @data_len: the data length in bytes
|
|
* @out: (output) the resulting HMAC-SHA256 value
|
|
*
|
|
* If you're using the key only once, consider using hmac_sha256_usingrawkey().
|
|
*
|
|
* Context: Any context.
|
|
*/
|
|
void hmac_sha256(const struct hmac_sha256_key *key,
|
|
const u8 *data, size_t data_len, u8 out[SHA256_DIGEST_SIZE]);
|
|
|
|
/**
|
|
* hmac_sha256_usingrawkey() - Compute HMAC-SHA256 in one shot, using a raw key
|
|
* @raw_key: the raw HMAC-SHA256 key
|
|
* @raw_key_len: the key length in bytes. All key lengths are supported.
|
|
* @data: the message data
|
|
* @data_len: the data length in bytes
|
|
* @out: (output) the resulting HMAC-SHA256 value
|
|
*
|
|
* If you're using the key multiple times, prefer to use
|
|
* hmac_sha256_preparekey() followed by multiple calls to hmac_sha256() instead.
|
|
*
|
|
* Context: Any context.
|
|
*/
|
|
void hmac_sha256_usingrawkey(const u8 *raw_key, size_t raw_key_len,
|
|
const u8 *data, size_t data_len,
|
|
u8 out[SHA256_DIGEST_SIZE]);
|
|
|
|
/* State for the SHA-512 (and SHA-384) compression function */
|
|
struct sha512_block_state {
|
|
u64 h[8];
|
|
};
|
|
|
|
/*
|
|
* Context structure, shared by SHA-384 and SHA-512. The sha384_ctx and
|
|
* sha512_ctx structs wrap this one so that the API has proper typing and
|
|
* doesn't allow mixing the SHA-384 and SHA-512 functions arbitrarily.
|
|
*/
|
|
struct __sha512_ctx {
|
|
struct sha512_block_state state;
|
|
u64 bytecount_lo;
|
|
u64 bytecount_hi;
|
|
u8 buf[SHA512_BLOCK_SIZE] __aligned(__alignof__(__be64));
|
|
};
|
|
void __sha512_update(struct __sha512_ctx *ctx, const u8 *data, size_t len);
|
|
|
|
/*
|
|
* HMAC key and message context structs, shared by HMAC-SHA384 and HMAC-SHA512.
|
|
* The hmac_sha384_* and hmac_sha512_* structs wrap this one so that the API has
|
|
* proper typing and doesn't allow mixing the functions arbitrarily.
|
|
*/
|
|
struct __hmac_sha512_key {
|
|
struct sha512_block_state istate;
|
|
struct sha512_block_state ostate;
|
|
};
|
|
struct __hmac_sha512_ctx {
|
|
struct __sha512_ctx sha_ctx;
|
|
struct sha512_block_state ostate;
|
|
};
|
|
void __hmac_sha512_init(struct __hmac_sha512_ctx *ctx,
|
|
const struct __hmac_sha512_key *key);
|
|
|
|
/**
|
|
* struct sha384_ctx - Context for hashing a message with SHA-384
|
|
* @ctx: private
|
|
*/
|
|
struct sha384_ctx {
|
|
struct __sha512_ctx ctx;
|
|
};
|
|
|
|
/**
|
|
* sha384_init() - Initialize a SHA-384 context for a new message
|
|
* @ctx: the context to initialize
|
|
*
|
|
* If you don't need incremental computation, consider sha384() instead.
|
|
*
|
|
* Context: Any context.
|
|
*/
|
|
void sha384_init(struct sha384_ctx *ctx);
|
|
|
|
/**
|
|
* sha384_update() - Update a SHA-384 context with message data
|
|
* @ctx: the context to update; must have been initialized
|
|
* @data: the message data
|
|
* @len: the data length in bytes
|
|
*
|
|
* This can be called any number of times.
|
|
*
|
|
* Context: Any context.
|
|
*/
|
|
static inline void sha384_update(struct sha384_ctx *ctx,
|
|
const u8 *data, size_t len)
|
|
{
|
|
__sha512_update(&ctx->ctx, data, len);
|
|
}
|
|
|
|
/**
|
|
* sha384_final() - Finish computing a SHA-384 message digest
|
|
* @ctx: the context to finalize; must have been initialized
|
|
* @out: (output) the resulting SHA-384 message digest
|
|
*
|
|
* After finishing, this zeroizes @ctx. So the caller does not need to do it.
|
|
*
|
|
* Context: Any context.
|
|
*/
|
|
void sha384_final(struct sha384_ctx *ctx, u8 out[SHA384_DIGEST_SIZE]);
|
|
|
|
/**
|
|
* sha384() - Compute SHA-384 message digest in one shot
|
|
* @data: the message data
|
|
* @len: the data length in bytes
|
|
* @out: (output) the resulting SHA-384 message digest
|
|
*
|
|
* Context: Any context.
|
|
*/
|
|
void sha384(const u8 *data, size_t len, u8 out[SHA384_DIGEST_SIZE]);
|
|
|
|
/**
|
|
* struct hmac_sha384_key - Prepared key for HMAC-SHA384
|
|
* @key: private
|
|
*/
|
|
struct hmac_sha384_key {
|
|
struct __hmac_sha512_key key;
|
|
};
|
|
|
|
/**
|
|
* struct hmac_sha384_ctx - Context for computing HMAC-SHA384 of a message
|
|
* @ctx: private
|
|
*/
|
|
struct hmac_sha384_ctx {
|
|
struct __hmac_sha512_ctx ctx;
|
|
};
|
|
|
|
/**
|
|
* hmac_sha384_preparekey() - Prepare a key for HMAC-SHA384
|
|
* @key: (output) the key structure to initialize
|
|
* @raw_key: the raw HMAC-SHA384 key
|
|
* @raw_key_len: the key length in bytes. All key lengths are supported.
|
|
*
|
|
* Note: the caller is responsible for zeroizing both the struct hmac_sha384_key
|
|
* and the raw key once they are no longer needed.
|
|
*
|
|
* Context: Any context.
|
|
*/
|
|
void hmac_sha384_preparekey(struct hmac_sha384_key *key,
|
|
const u8 *raw_key, size_t raw_key_len);
|
|
|
|
/**
|
|
* hmac_sha384_init() - Initialize an HMAC-SHA384 context for a new message
|
|
* @ctx: (output) the HMAC context to initialize
|
|
* @key: the prepared HMAC key
|
|
*
|
|
* If you don't need incremental computation, consider hmac_sha384() instead.
|
|
*
|
|
* Context: Any context.
|
|
*/
|
|
static inline void hmac_sha384_init(struct hmac_sha384_ctx *ctx,
|
|
const struct hmac_sha384_key *key)
|
|
{
|
|
__hmac_sha512_init(&ctx->ctx, &key->key);
|
|
}
|
|
|
|
/**
|
|
* hmac_sha384_init_usingrawkey() - Initialize an HMAC-SHA384 context for a new
|
|
* message, using a raw key
|
|
* @ctx: (output) the HMAC context to initialize
|
|
* @raw_key: the raw HMAC-SHA384 key
|
|
* @raw_key_len: the key length in bytes. All key lengths are supported.
|
|
*
|
|
* If you don't need incremental computation, consider hmac_sha384_usingrawkey()
|
|
* instead.
|
|
*
|
|
* Context: Any context.
|
|
*/
|
|
void hmac_sha384_init_usingrawkey(struct hmac_sha384_ctx *ctx,
|
|
const u8 *raw_key, size_t raw_key_len);
|
|
|
|
/**
|
|
* hmac_sha384_update() - Update an HMAC-SHA384 context with message data
|
|
* @ctx: the HMAC context to update; must have been initialized
|
|
* @data: the message data
|
|
* @data_len: the data length in bytes
|
|
*
|
|
* This can be called any number of times.
|
|
*
|
|
* Context: Any context.
|
|
*/
|
|
static inline void hmac_sha384_update(struct hmac_sha384_ctx *ctx,
|
|
const u8 *data, size_t data_len)
|
|
{
|
|
__sha512_update(&ctx->ctx.sha_ctx, data, data_len);
|
|
}
|
|
|
|
/**
|
|
* hmac_sha384_final() - Finish computing an HMAC-SHA384 value
|
|
* @ctx: the HMAC context to finalize; must have been initialized
|
|
* @out: (output) the resulting HMAC-SHA384 value
|
|
*
|
|
* After finishing, this zeroizes @ctx. So the caller does not need to do it.
|
|
*
|
|
* Context: Any context.
|
|
*/
|
|
void hmac_sha384_final(struct hmac_sha384_ctx *ctx, u8 out[SHA384_DIGEST_SIZE]);
|
|
|
|
/**
|
|
* hmac_sha384() - Compute HMAC-SHA384 in one shot, using a prepared key
|
|
* @key: the prepared HMAC key
|
|
* @data: the message data
|
|
* @data_len: the data length in bytes
|
|
* @out: (output) the resulting HMAC-SHA384 value
|
|
*
|
|
* If you're using the key only once, consider using hmac_sha384_usingrawkey().
|
|
*
|
|
* Context: Any context.
|
|
*/
|
|
void hmac_sha384(const struct hmac_sha384_key *key,
|
|
const u8 *data, size_t data_len, u8 out[SHA384_DIGEST_SIZE]);
|
|
|
|
/**
|
|
* hmac_sha384_usingrawkey() - Compute HMAC-SHA384 in one shot, using a raw key
|
|
* @raw_key: the raw HMAC-SHA384 key
|
|
* @raw_key_len: the key length in bytes. All key lengths are supported.
|
|
* @data: the message data
|
|
* @data_len: the data length in bytes
|
|
* @out: (output) the resulting HMAC-SHA384 value
|
|
*
|
|
* If you're using the key multiple times, prefer to use
|
|
* hmac_sha384_preparekey() followed by multiple calls to hmac_sha384() instead.
|
|
*
|
|
* Context: Any context.
|
|
*/
|
|
void hmac_sha384_usingrawkey(const u8 *raw_key, size_t raw_key_len,
|
|
const u8 *data, size_t data_len,
|
|
u8 out[SHA384_DIGEST_SIZE]);
|
|
|
|
/**
|
|
* struct sha512_ctx - Context for hashing a message with SHA-512
|
|
* @ctx: private
|
|
*/
|
|
struct sha512_ctx {
|
|
struct __sha512_ctx ctx;
|
|
};
|
|
|
|
/**
|
|
* sha512_init() - Initialize a SHA-512 context for a new message
|
|
* @ctx: the context to initialize
|
|
*
|
|
* If you don't need incremental computation, consider sha512() instead.
|
|
*
|
|
* Context: Any context.
|
|
*/
|
|
void sha512_init(struct sha512_ctx *ctx);
|
|
|
|
/**
|
|
* sha512_update() - Update a SHA-512 context with message data
|
|
* @ctx: the context to update; must have been initialized
|
|
* @data: the message data
|
|
* @len: the data length in bytes
|
|
*
|
|
* This can be called any number of times.
|
|
*
|
|
* Context: Any context.
|
|
*/
|
|
static inline void sha512_update(struct sha512_ctx *ctx,
|
|
const u8 *data, size_t len)
|
|
{
|
|
__sha512_update(&ctx->ctx, data, len);
|
|
}
|
|
|
|
/**
|
|
* sha512_final() - Finish computing a SHA-512 message digest
|
|
* @ctx: the context to finalize; must have been initialized
|
|
* @out: (output) the resulting SHA-512 message digest
|
|
*
|
|
* After finishing, this zeroizes @ctx. So the caller does not need to do it.
|
|
*
|
|
* Context: Any context.
|
|
*/
|
|
void sha512_final(struct sha512_ctx *ctx, u8 out[SHA512_DIGEST_SIZE]);
|
|
|
|
/**
|
|
* sha512() - Compute SHA-512 message digest in one shot
|
|
* @data: the message data
|
|
* @len: the data length in bytes
|
|
* @out: (output) the resulting SHA-512 message digest
|
|
*
|
|
* Context: Any context.
|
|
*/
|
|
void sha512(const u8 *data, size_t len, u8 out[SHA512_DIGEST_SIZE]);
|
|
|
|
/**
|
|
* struct hmac_sha512_key - Prepared key for HMAC-SHA512
|
|
* @key: private
|
|
*/
|
|
struct hmac_sha512_key {
|
|
struct __hmac_sha512_key key;
|
|
};
|
|
|
|
/**
|
|
* struct hmac_sha512_ctx - Context for computing HMAC-SHA512 of a message
|
|
* @ctx: private
|
|
*/
|
|
struct hmac_sha512_ctx {
|
|
struct __hmac_sha512_ctx ctx;
|
|
};
|
|
|
|
/**
|
|
* hmac_sha512_preparekey() - Prepare a key for HMAC-SHA512
|
|
* @key: (output) the key structure to initialize
|
|
* @raw_key: the raw HMAC-SHA512 key
|
|
* @raw_key_len: the key length in bytes. All key lengths are supported.
|
|
*
|
|
* Note: the caller is responsible for zeroizing both the struct hmac_sha512_key
|
|
* and the raw key once they are no longer needed.
|
|
*
|
|
* Context: Any context.
|
|
*/
|
|
void hmac_sha512_preparekey(struct hmac_sha512_key *key,
|
|
const u8 *raw_key, size_t raw_key_len);
|
|
|
|
/**
|
|
* hmac_sha512_init() - Initialize an HMAC-SHA512 context for a new message
|
|
* @ctx: (output) the HMAC context to initialize
|
|
* @key: the prepared HMAC key
|
|
*
|
|
* If you don't need incremental computation, consider hmac_sha512() instead.
|
|
*
|
|
* Context: Any context.
|
|
*/
|
|
static inline void hmac_sha512_init(struct hmac_sha512_ctx *ctx,
|
|
const struct hmac_sha512_key *key)
|
|
{
|
|
__hmac_sha512_init(&ctx->ctx, &key->key);
|
|
}
|
|
|
|
/**
|
|
* hmac_sha512_init_usingrawkey() - Initialize an HMAC-SHA512 context for a new
|
|
* message, using a raw key
|
|
* @ctx: (output) the HMAC context to initialize
|
|
* @raw_key: the raw HMAC-SHA512 key
|
|
* @raw_key_len: the key length in bytes. All key lengths are supported.
|
|
*
|
|
* If you don't need incremental computation, consider hmac_sha512_usingrawkey()
|
|
* instead.
|
|
*
|
|
* Context: Any context.
|
|
*/
|
|
void hmac_sha512_init_usingrawkey(struct hmac_sha512_ctx *ctx,
|
|
const u8 *raw_key, size_t raw_key_len);
|
|
|
|
/**
|
|
* hmac_sha512_update() - Update an HMAC-SHA512 context with message data
|
|
* @ctx: the HMAC context to update; must have been initialized
|
|
* @data: the message data
|
|
* @data_len: the data length in bytes
|
|
*
|
|
* This can be called any number of times.
|
|
*
|
|
* Context: Any context.
|
|
*/
|
|
static inline void hmac_sha512_update(struct hmac_sha512_ctx *ctx,
|
|
const u8 *data, size_t data_len)
|
|
{
|
|
__sha512_update(&ctx->ctx.sha_ctx, data, data_len);
|
|
}
|
|
|
|
/**
|
|
* hmac_sha512_final() - Finish computing an HMAC-SHA512 value
|
|
* @ctx: the HMAC context to finalize; must have been initialized
|
|
* @out: (output) the resulting HMAC-SHA512 value
|
|
*
|
|
* After finishing, this zeroizes @ctx. So the caller does not need to do it.
|
|
*
|
|
* Context: Any context.
|
|
*/
|
|
void hmac_sha512_final(struct hmac_sha512_ctx *ctx, u8 out[SHA512_DIGEST_SIZE]);
|
|
|
|
/**
|
|
* hmac_sha512() - Compute HMAC-SHA512 in one shot, using a prepared key
|
|
* @key: the prepared HMAC key
|
|
* @data: the message data
|
|
* @data_len: the data length in bytes
|
|
* @out: (output) the resulting HMAC-SHA512 value
|
|
*
|
|
* If you're using the key only once, consider using hmac_sha512_usingrawkey().
|
|
*
|
|
* Context: Any context.
|
|
*/
|
|
void hmac_sha512(const struct hmac_sha512_key *key,
|
|
const u8 *data, size_t data_len, u8 out[SHA512_DIGEST_SIZE]);
|
|
|
|
/**
|
|
* hmac_sha512_usingrawkey() - Compute HMAC-SHA512 in one shot, using a raw key
|
|
* @raw_key: the raw HMAC-SHA512 key
|
|
* @raw_key_len: the key length in bytes. All key lengths are supported.
|
|
* @data: the message data
|
|
* @data_len: the data length in bytes
|
|
* @out: (output) the resulting HMAC-SHA512 value
|
|
*
|
|
* If you're using the key multiple times, prefer to use
|
|
* hmac_sha512_preparekey() followed by multiple calls to hmac_sha512() instead.
|
|
*
|
|
* Context: Any context.
|
|
*/
|
|
void hmac_sha512_usingrawkey(const u8 *raw_key, size_t raw_key_len,
|
|
const u8 *data, size_t data_len,
|
|
u8 out[SHA512_DIGEST_SIZE]);
|
|
|
|
#endif /* _CRYPTO_SHA2_H */
|