forked from Minki/linux
lib/crypto: blake2s: include as built-in
In preparation for using blake2s in the RNG, we change the way that it is wired-in to the build system. Instead of using ifdefs to select the right symbol, we use weak symbols. And because ARM doesn't need the generic implementation, we make the generic one default only if an arch library doesn't need it already, and then have arch libraries that do need it opt-in. So that the arch libraries can remain tristate rather than bool, we then split the shash part from the glue code. Acked-by: Herbert Xu <herbert@gondor.apana.org.au> Acked-by: Ard Biesheuvel <ardb@kernel.org> Acked-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org> Cc: Masahiro Yamada <masahiroy@kernel.org> Cc: linux-kbuild@vger.kernel.org Cc: linux-crypto@vger.kernel.org Signed-off-by: Jason A. Donenfeld <Jason@zx2c4.com>
This commit is contained in:
parent
009ba8568b
commit
6048fdcc5f
@ -10,6 +10,7 @@ obj-$(CONFIG_CRYPTO_SHA1_ARM_NEON) += sha1-arm-neon.o
|
|||||||
obj-$(CONFIG_CRYPTO_SHA256_ARM) += sha256-arm.o
|
obj-$(CONFIG_CRYPTO_SHA256_ARM) += sha256-arm.o
|
||||||
obj-$(CONFIG_CRYPTO_SHA512_ARM) += sha512-arm.o
|
obj-$(CONFIG_CRYPTO_SHA512_ARM) += sha512-arm.o
|
||||||
obj-$(CONFIG_CRYPTO_BLAKE2S_ARM) += blake2s-arm.o
|
obj-$(CONFIG_CRYPTO_BLAKE2S_ARM) += blake2s-arm.o
|
||||||
|
obj-$(if $(CONFIG_CRYPTO_BLAKE2S_ARM),y) += libblake2s-arm.o
|
||||||
obj-$(CONFIG_CRYPTO_BLAKE2B_NEON) += blake2b-neon.o
|
obj-$(CONFIG_CRYPTO_BLAKE2B_NEON) += blake2b-neon.o
|
||||||
obj-$(CONFIG_CRYPTO_CHACHA20_NEON) += chacha-neon.o
|
obj-$(CONFIG_CRYPTO_CHACHA20_NEON) += chacha-neon.o
|
||||||
obj-$(CONFIG_CRYPTO_POLY1305_ARM) += poly1305-arm.o
|
obj-$(CONFIG_CRYPTO_POLY1305_ARM) += poly1305-arm.o
|
||||||
@ -31,7 +32,8 @@ sha256-arm-neon-$(CONFIG_KERNEL_MODE_NEON) := sha256_neon_glue.o
|
|||||||
sha256-arm-y := sha256-core.o sha256_glue.o $(sha256-arm-neon-y)
|
sha256-arm-y := sha256-core.o sha256_glue.o $(sha256-arm-neon-y)
|
||||||
sha512-arm-neon-$(CONFIG_KERNEL_MODE_NEON) := sha512-neon-glue.o
|
sha512-arm-neon-$(CONFIG_KERNEL_MODE_NEON) := sha512-neon-glue.o
|
||||||
sha512-arm-y := sha512-core.o sha512-glue.o $(sha512-arm-neon-y)
|
sha512-arm-y := sha512-core.o sha512-glue.o $(sha512-arm-neon-y)
|
||||||
blake2s-arm-y := blake2s-core.o blake2s-glue.o
|
blake2s-arm-y := blake2s-shash.o
|
||||||
|
libblake2s-arm-y:= blake2s-core.o blake2s-glue.o
|
||||||
blake2b-neon-y := blake2b-neon-core.o blake2b-neon-glue.o
|
blake2b-neon-y := blake2b-neon-core.o blake2b-neon-glue.o
|
||||||
sha1-arm-ce-y := sha1-ce-core.o sha1-ce-glue.o
|
sha1-arm-ce-y := sha1-ce-core.o sha1-ce-glue.o
|
||||||
sha2-arm-ce-y := sha2-ce-core.o sha2-ce-glue.o
|
sha2-arm-ce-y := sha2-ce-core.o sha2-ce-glue.o
|
||||||
|
@ -167,8 +167,8 @@
|
|||||||
.endm
|
.endm
|
||||||
|
|
||||||
//
|
//
|
||||||
// void blake2s_compress_arch(struct blake2s_state *state,
|
// void blake2s_compress(struct blake2s_state *state,
|
||||||
// const u8 *block, size_t nblocks, u32 inc);
|
// const u8 *block, size_t nblocks, u32 inc);
|
||||||
//
|
//
|
||||||
// Only the first three fields of struct blake2s_state are used:
|
// Only the first three fields of struct blake2s_state are used:
|
||||||
// u32 h[8]; (inout)
|
// u32 h[8]; (inout)
|
||||||
@ -176,7 +176,7 @@
|
|||||||
// u32 f[2]; (in)
|
// u32 f[2]; (in)
|
||||||
//
|
//
|
||||||
.align 5
|
.align 5
|
||||||
ENTRY(blake2s_compress_arch)
|
ENTRY(blake2s_compress)
|
||||||
push {r0-r2,r4-r11,lr} // keep this an even number
|
push {r0-r2,r4-r11,lr} // keep this an even number
|
||||||
|
|
||||||
.Lnext_block:
|
.Lnext_block:
|
||||||
@ -303,4 +303,4 @@ ENTRY(blake2s_compress_arch)
|
|||||||
str r3, [r12], #4
|
str r3, [r12], #4
|
||||||
bne 1b
|
bne 1b
|
||||||
b .Lcopy_block_done
|
b .Lcopy_block_done
|
||||||
ENDPROC(blake2s_compress_arch)
|
ENDPROC(blake2s_compress)
|
||||||
|
@ -1,78 +1,7 @@
|
|||||||
// SPDX-License-Identifier: GPL-2.0-or-later
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
||||||
/*
|
|
||||||
* BLAKE2s digest algorithm, ARM scalar implementation
|
|
||||||
*
|
|
||||||
* Copyright 2020 Google LLC
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include <crypto/internal/blake2s.h>
|
#include <crypto/internal/blake2s.h>
|
||||||
#include <crypto/internal/hash.h>
|
|
||||||
|
|
||||||
#include <linux/module.h>
|
#include <linux/module.h>
|
||||||
|
|
||||||
/* defined in blake2s-core.S */
|
/* defined in blake2s-core.S */
|
||||||
EXPORT_SYMBOL(blake2s_compress_arch);
|
EXPORT_SYMBOL(blake2s_compress);
|
||||||
|
|
||||||
static int crypto_blake2s_update_arm(struct shash_desc *desc,
|
|
||||||
const u8 *in, unsigned int inlen)
|
|
||||||
{
|
|
||||||
return crypto_blake2s_update(desc, in, inlen, blake2s_compress_arch);
|
|
||||||
}
|
|
||||||
|
|
||||||
static int crypto_blake2s_final_arm(struct shash_desc *desc, u8 *out)
|
|
||||||
{
|
|
||||||
return crypto_blake2s_final(desc, out, blake2s_compress_arch);
|
|
||||||
}
|
|
||||||
|
|
||||||
#define BLAKE2S_ALG(name, driver_name, digest_size) \
|
|
||||||
{ \
|
|
||||||
.base.cra_name = name, \
|
|
||||||
.base.cra_driver_name = driver_name, \
|
|
||||||
.base.cra_priority = 200, \
|
|
||||||
.base.cra_flags = CRYPTO_ALG_OPTIONAL_KEY, \
|
|
||||||
.base.cra_blocksize = BLAKE2S_BLOCK_SIZE, \
|
|
||||||
.base.cra_ctxsize = sizeof(struct blake2s_tfm_ctx), \
|
|
||||||
.base.cra_module = THIS_MODULE, \
|
|
||||||
.digestsize = digest_size, \
|
|
||||||
.setkey = crypto_blake2s_setkey, \
|
|
||||||
.init = crypto_blake2s_init, \
|
|
||||||
.update = crypto_blake2s_update_arm, \
|
|
||||||
.final = crypto_blake2s_final_arm, \
|
|
||||||
.descsize = sizeof(struct blake2s_state), \
|
|
||||||
}
|
|
||||||
|
|
||||||
static struct shash_alg blake2s_arm_algs[] = {
|
|
||||||
BLAKE2S_ALG("blake2s-128", "blake2s-128-arm", BLAKE2S_128_HASH_SIZE),
|
|
||||||
BLAKE2S_ALG("blake2s-160", "blake2s-160-arm", BLAKE2S_160_HASH_SIZE),
|
|
||||||
BLAKE2S_ALG("blake2s-224", "blake2s-224-arm", BLAKE2S_224_HASH_SIZE),
|
|
||||||
BLAKE2S_ALG("blake2s-256", "blake2s-256-arm", BLAKE2S_256_HASH_SIZE),
|
|
||||||
};
|
|
||||||
|
|
||||||
static int __init blake2s_arm_mod_init(void)
|
|
||||||
{
|
|
||||||
return IS_REACHABLE(CONFIG_CRYPTO_HASH) ?
|
|
||||||
crypto_register_shashes(blake2s_arm_algs,
|
|
||||||
ARRAY_SIZE(blake2s_arm_algs)) : 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void __exit blake2s_arm_mod_exit(void)
|
|
||||||
{
|
|
||||||
if (IS_REACHABLE(CONFIG_CRYPTO_HASH))
|
|
||||||
crypto_unregister_shashes(blake2s_arm_algs,
|
|
||||||
ARRAY_SIZE(blake2s_arm_algs));
|
|
||||||
}
|
|
||||||
|
|
||||||
module_init(blake2s_arm_mod_init);
|
|
||||||
module_exit(blake2s_arm_mod_exit);
|
|
||||||
|
|
||||||
MODULE_DESCRIPTION("BLAKE2s digest algorithm, ARM scalar implementation");
|
|
||||||
MODULE_LICENSE("GPL");
|
|
||||||
MODULE_AUTHOR("Eric Biggers <ebiggers@google.com>");
|
|
||||||
MODULE_ALIAS_CRYPTO("blake2s-128");
|
|
||||||
MODULE_ALIAS_CRYPTO("blake2s-128-arm");
|
|
||||||
MODULE_ALIAS_CRYPTO("blake2s-160");
|
|
||||||
MODULE_ALIAS_CRYPTO("blake2s-160-arm");
|
|
||||||
MODULE_ALIAS_CRYPTO("blake2s-224");
|
|
||||||
MODULE_ALIAS_CRYPTO("blake2s-224-arm");
|
|
||||||
MODULE_ALIAS_CRYPTO("blake2s-256");
|
|
||||||
MODULE_ALIAS_CRYPTO("blake2s-256-arm");
|
|
||||||
|
75
arch/arm/crypto/blake2s-shash.c
Normal file
75
arch/arm/crypto/blake2s-shash.c
Normal file
@ -0,0 +1,75 @@
|
|||||||
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
||||||
|
/*
|
||||||
|
* BLAKE2s digest algorithm, ARM scalar implementation
|
||||||
|
*
|
||||||
|
* Copyright 2020 Google LLC
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <crypto/internal/blake2s.h>
|
||||||
|
#include <crypto/internal/hash.h>
|
||||||
|
|
||||||
|
#include <linux/module.h>
|
||||||
|
|
||||||
|
static int crypto_blake2s_update_arm(struct shash_desc *desc,
|
||||||
|
const u8 *in, unsigned int inlen)
|
||||||
|
{
|
||||||
|
return crypto_blake2s_update(desc, in, inlen, blake2s_compress);
|
||||||
|
}
|
||||||
|
|
||||||
|
static int crypto_blake2s_final_arm(struct shash_desc *desc, u8 *out)
|
||||||
|
{
|
||||||
|
return crypto_blake2s_final(desc, out, blake2s_compress);
|
||||||
|
}
|
||||||
|
|
||||||
|
#define BLAKE2S_ALG(name, driver_name, digest_size) \
|
||||||
|
{ \
|
||||||
|
.base.cra_name = name, \
|
||||||
|
.base.cra_driver_name = driver_name, \
|
||||||
|
.base.cra_priority = 200, \
|
||||||
|
.base.cra_flags = CRYPTO_ALG_OPTIONAL_KEY, \
|
||||||
|
.base.cra_blocksize = BLAKE2S_BLOCK_SIZE, \
|
||||||
|
.base.cra_ctxsize = sizeof(struct blake2s_tfm_ctx), \
|
||||||
|
.base.cra_module = THIS_MODULE, \
|
||||||
|
.digestsize = digest_size, \
|
||||||
|
.setkey = crypto_blake2s_setkey, \
|
||||||
|
.init = crypto_blake2s_init, \
|
||||||
|
.update = crypto_blake2s_update_arm, \
|
||||||
|
.final = crypto_blake2s_final_arm, \
|
||||||
|
.descsize = sizeof(struct blake2s_state), \
|
||||||
|
}
|
||||||
|
|
||||||
|
static struct shash_alg blake2s_arm_algs[] = {
|
||||||
|
BLAKE2S_ALG("blake2s-128", "blake2s-128-arm", BLAKE2S_128_HASH_SIZE),
|
||||||
|
BLAKE2S_ALG("blake2s-160", "blake2s-160-arm", BLAKE2S_160_HASH_SIZE),
|
||||||
|
BLAKE2S_ALG("blake2s-224", "blake2s-224-arm", BLAKE2S_224_HASH_SIZE),
|
||||||
|
BLAKE2S_ALG("blake2s-256", "blake2s-256-arm", BLAKE2S_256_HASH_SIZE),
|
||||||
|
};
|
||||||
|
|
||||||
|
static int __init blake2s_arm_mod_init(void)
|
||||||
|
{
|
||||||
|
return IS_REACHABLE(CONFIG_CRYPTO_HASH) ?
|
||||||
|
crypto_register_shashes(blake2s_arm_algs,
|
||||||
|
ARRAY_SIZE(blake2s_arm_algs)) : 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void __exit blake2s_arm_mod_exit(void)
|
||||||
|
{
|
||||||
|
if (IS_REACHABLE(CONFIG_CRYPTO_HASH))
|
||||||
|
crypto_unregister_shashes(blake2s_arm_algs,
|
||||||
|
ARRAY_SIZE(blake2s_arm_algs));
|
||||||
|
}
|
||||||
|
|
||||||
|
module_init(blake2s_arm_mod_init);
|
||||||
|
module_exit(blake2s_arm_mod_exit);
|
||||||
|
|
||||||
|
MODULE_DESCRIPTION("BLAKE2s digest algorithm, ARM scalar implementation");
|
||||||
|
MODULE_LICENSE("GPL");
|
||||||
|
MODULE_AUTHOR("Eric Biggers <ebiggers@google.com>");
|
||||||
|
MODULE_ALIAS_CRYPTO("blake2s-128");
|
||||||
|
MODULE_ALIAS_CRYPTO("blake2s-128-arm");
|
||||||
|
MODULE_ALIAS_CRYPTO("blake2s-160");
|
||||||
|
MODULE_ALIAS_CRYPTO("blake2s-160-arm");
|
||||||
|
MODULE_ALIAS_CRYPTO("blake2s-224");
|
||||||
|
MODULE_ALIAS_CRYPTO("blake2s-224-arm");
|
||||||
|
MODULE_ALIAS_CRYPTO("blake2s-256");
|
||||||
|
MODULE_ALIAS_CRYPTO("blake2s-256-arm");
|
@ -62,7 +62,9 @@ obj-$(CONFIG_CRYPTO_SHA512_SSSE3) += sha512-ssse3.o
|
|||||||
sha512-ssse3-y := sha512-ssse3-asm.o sha512-avx-asm.o sha512-avx2-asm.o sha512_ssse3_glue.o
|
sha512-ssse3-y := sha512-ssse3-asm.o sha512-avx-asm.o sha512-avx2-asm.o sha512_ssse3_glue.o
|
||||||
|
|
||||||
obj-$(CONFIG_CRYPTO_BLAKE2S_X86) += blake2s-x86_64.o
|
obj-$(CONFIG_CRYPTO_BLAKE2S_X86) += blake2s-x86_64.o
|
||||||
blake2s-x86_64-y := blake2s-core.o blake2s-glue.o
|
blake2s-x86_64-y := blake2s-shash.o
|
||||||
|
obj-$(if $(CONFIG_CRYPTO_BLAKE2S_X86),y) += libblake2s-x86_64.o
|
||||||
|
libblake2s-x86_64-y := blake2s-core.o blake2s-glue.o
|
||||||
|
|
||||||
obj-$(CONFIG_CRYPTO_GHASH_CLMUL_NI_INTEL) += ghash-clmulni-intel.o
|
obj-$(CONFIG_CRYPTO_GHASH_CLMUL_NI_INTEL) += ghash-clmulni-intel.o
|
||||||
ghash-clmulni-intel-y := ghash-clmulni-intel_asm.o ghash-clmulni-intel_glue.o
|
ghash-clmulni-intel-y := ghash-clmulni-intel_asm.o ghash-clmulni-intel_glue.o
|
||||||
|
@ -5,7 +5,6 @@
|
|||||||
|
|
||||||
#include <crypto/internal/blake2s.h>
|
#include <crypto/internal/blake2s.h>
|
||||||
#include <crypto/internal/simd.h>
|
#include <crypto/internal/simd.h>
|
||||||
#include <crypto/internal/hash.h>
|
|
||||||
|
|
||||||
#include <linux/types.h>
|
#include <linux/types.h>
|
||||||
#include <linux/jump_label.h>
|
#include <linux/jump_label.h>
|
||||||
@ -28,9 +27,8 @@ asmlinkage void blake2s_compress_avx512(struct blake2s_state *state,
|
|||||||
static __ro_after_init DEFINE_STATIC_KEY_FALSE(blake2s_use_ssse3);
|
static __ro_after_init DEFINE_STATIC_KEY_FALSE(blake2s_use_ssse3);
|
||||||
static __ro_after_init DEFINE_STATIC_KEY_FALSE(blake2s_use_avx512);
|
static __ro_after_init DEFINE_STATIC_KEY_FALSE(blake2s_use_avx512);
|
||||||
|
|
||||||
void blake2s_compress_arch(struct blake2s_state *state,
|
void blake2s_compress(struct blake2s_state *state, const u8 *block,
|
||||||
const u8 *block, size_t nblocks,
|
size_t nblocks, const u32 inc)
|
||||||
const u32 inc)
|
|
||||||
{
|
{
|
||||||
/* SIMD disables preemption, so relax after processing each page. */
|
/* SIMD disables preemption, so relax after processing each page. */
|
||||||
BUILD_BUG_ON(SZ_4K / BLAKE2S_BLOCK_SIZE < 8);
|
BUILD_BUG_ON(SZ_4K / BLAKE2S_BLOCK_SIZE < 8);
|
||||||
@ -56,49 +54,12 @@ void blake2s_compress_arch(struct blake2s_state *state,
|
|||||||
block += blocks * BLAKE2S_BLOCK_SIZE;
|
block += blocks * BLAKE2S_BLOCK_SIZE;
|
||||||
} while (nblocks);
|
} while (nblocks);
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(blake2s_compress_arch);
|
EXPORT_SYMBOL(blake2s_compress);
|
||||||
|
|
||||||
static int crypto_blake2s_update_x86(struct shash_desc *desc,
|
|
||||||
const u8 *in, unsigned int inlen)
|
|
||||||
{
|
|
||||||
return crypto_blake2s_update(desc, in, inlen, blake2s_compress_arch);
|
|
||||||
}
|
|
||||||
|
|
||||||
static int crypto_blake2s_final_x86(struct shash_desc *desc, u8 *out)
|
|
||||||
{
|
|
||||||
return crypto_blake2s_final(desc, out, blake2s_compress_arch);
|
|
||||||
}
|
|
||||||
|
|
||||||
#define BLAKE2S_ALG(name, driver_name, digest_size) \
|
|
||||||
{ \
|
|
||||||
.base.cra_name = name, \
|
|
||||||
.base.cra_driver_name = driver_name, \
|
|
||||||
.base.cra_priority = 200, \
|
|
||||||
.base.cra_flags = CRYPTO_ALG_OPTIONAL_KEY, \
|
|
||||||
.base.cra_blocksize = BLAKE2S_BLOCK_SIZE, \
|
|
||||||
.base.cra_ctxsize = sizeof(struct blake2s_tfm_ctx), \
|
|
||||||
.base.cra_module = THIS_MODULE, \
|
|
||||||
.digestsize = digest_size, \
|
|
||||||
.setkey = crypto_blake2s_setkey, \
|
|
||||||
.init = crypto_blake2s_init, \
|
|
||||||
.update = crypto_blake2s_update_x86, \
|
|
||||||
.final = crypto_blake2s_final_x86, \
|
|
||||||
.descsize = sizeof(struct blake2s_state), \
|
|
||||||
}
|
|
||||||
|
|
||||||
static struct shash_alg blake2s_algs[] = {
|
|
||||||
BLAKE2S_ALG("blake2s-128", "blake2s-128-x86", BLAKE2S_128_HASH_SIZE),
|
|
||||||
BLAKE2S_ALG("blake2s-160", "blake2s-160-x86", BLAKE2S_160_HASH_SIZE),
|
|
||||||
BLAKE2S_ALG("blake2s-224", "blake2s-224-x86", BLAKE2S_224_HASH_SIZE),
|
|
||||||
BLAKE2S_ALG("blake2s-256", "blake2s-256-x86", BLAKE2S_256_HASH_SIZE),
|
|
||||||
};
|
|
||||||
|
|
||||||
static int __init blake2s_mod_init(void)
|
static int __init blake2s_mod_init(void)
|
||||||
{
|
{
|
||||||
if (!boot_cpu_has(X86_FEATURE_SSSE3))
|
if (boot_cpu_has(X86_FEATURE_SSSE3))
|
||||||
return 0;
|
static_branch_enable(&blake2s_use_ssse3);
|
||||||
|
|
||||||
static_branch_enable(&blake2s_use_ssse3);
|
|
||||||
|
|
||||||
if (IS_ENABLED(CONFIG_AS_AVX512) &&
|
if (IS_ENABLED(CONFIG_AS_AVX512) &&
|
||||||
boot_cpu_has(X86_FEATURE_AVX) &&
|
boot_cpu_has(X86_FEATURE_AVX) &&
|
||||||
@ -109,26 +70,9 @@ static int __init blake2s_mod_init(void)
|
|||||||
XFEATURE_MASK_AVX512, NULL))
|
XFEATURE_MASK_AVX512, NULL))
|
||||||
static_branch_enable(&blake2s_use_avx512);
|
static_branch_enable(&blake2s_use_avx512);
|
||||||
|
|
||||||
return IS_REACHABLE(CONFIG_CRYPTO_HASH) ?
|
return 0;
|
||||||
crypto_register_shashes(blake2s_algs,
|
|
||||||
ARRAY_SIZE(blake2s_algs)) : 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void __exit blake2s_mod_exit(void)
|
|
||||||
{
|
|
||||||
if (IS_REACHABLE(CONFIG_CRYPTO_HASH) && boot_cpu_has(X86_FEATURE_SSSE3))
|
|
||||||
crypto_unregister_shashes(blake2s_algs, ARRAY_SIZE(blake2s_algs));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
module_init(blake2s_mod_init);
|
module_init(blake2s_mod_init);
|
||||||
module_exit(blake2s_mod_exit);
|
|
||||||
|
|
||||||
MODULE_ALIAS_CRYPTO("blake2s-128");
|
|
||||||
MODULE_ALIAS_CRYPTO("blake2s-128-x86");
|
|
||||||
MODULE_ALIAS_CRYPTO("blake2s-160");
|
|
||||||
MODULE_ALIAS_CRYPTO("blake2s-160-x86");
|
|
||||||
MODULE_ALIAS_CRYPTO("blake2s-224");
|
|
||||||
MODULE_ALIAS_CRYPTO("blake2s-224-x86");
|
|
||||||
MODULE_ALIAS_CRYPTO("blake2s-256");
|
|
||||||
MODULE_ALIAS_CRYPTO("blake2s-256-x86");
|
|
||||||
MODULE_LICENSE("GPL v2");
|
MODULE_LICENSE("GPL v2");
|
||||||
|
77
arch/x86/crypto/blake2s-shash.c
Normal file
77
arch/x86/crypto/blake2s-shash.c
Normal file
@ -0,0 +1,77 @@
|
|||||||
|
// SPDX-License-Identifier: GPL-2.0 OR MIT
|
||||||
|
/*
|
||||||
|
* Copyright (C) 2015-2019 Jason A. Donenfeld <Jason@zx2c4.com>. All Rights Reserved.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <crypto/internal/blake2s.h>
|
||||||
|
#include <crypto/internal/simd.h>
|
||||||
|
#include <crypto/internal/hash.h>
|
||||||
|
|
||||||
|
#include <linux/types.h>
|
||||||
|
#include <linux/kernel.h>
|
||||||
|
#include <linux/module.h>
|
||||||
|
#include <linux/sizes.h>
|
||||||
|
|
||||||
|
#include <asm/cpufeature.h>
|
||||||
|
#include <asm/processor.h>
|
||||||
|
|
||||||
|
static int crypto_blake2s_update_x86(struct shash_desc *desc,
|
||||||
|
const u8 *in, unsigned int inlen)
|
||||||
|
{
|
||||||
|
return crypto_blake2s_update(desc, in, inlen, blake2s_compress);
|
||||||
|
}
|
||||||
|
|
||||||
|
static int crypto_blake2s_final_x86(struct shash_desc *desc, u8 *out)
|
||||||
|
{
|
||||||
|
return crypto_blake2s_final(desc, out, blake2s_compress);
|
||||||
|
}
|
||||||
|
|
||||||
|
#define BLAKE2S_ALG(name, driver_name, digest_size) \
|
||||||
|
{ \
|
||||||
|
.base.cra_name = name, \
|
||||||
|
.base.cra_driver_name = driver_name, \
|
||||||
|
.base.cra_priority = 200, \
|
||||||
|
.base.cra_flags = CRYPTO_ALG_OPTIONAL_KEY, \
|
||||||
|
.base.cra_blocksize = BLAKE2S_BLOCK_SIZE, \
|
||||||
|
.base.cra_ctxsize = sizeof(struct blake2s_tfm_ctx), \
|
||||||
|
.base.cra_module = THIS_MODULE, \
|
||||||
|
.digestsize = digest_size, \
|
||||||
|
.setkey = crypto_blake2s_setkey, \
|
||||||
|
.init = crypto_blake2s_init, \
|
||||||
|
.update = crypto_blake2s_update_x86, \
|
||||||
|
.final = crypto_blake2s_final_x86, \
|
||||||
|
.descsize = sizeof(struct blake2s_state), \
|
||||||
|
}
|
||||||
|
|
||||||
|
static struct shash_alg blake2s_algs[] = {
|
||||||
|
BLAKE2S_ALG("blake2s-128", "blake2s-128-x86", BLAKE2S_128_HASH_SIZE),
|
||||||
|
BLAKE2S_ALG("blake2s-160", "blake2s-160-x86", BLAKE2S_160_HASH_SIZE),
|
||||||
|
BLAKE2S_ALG("blake2s-224", "blake2s-224-x86", BLAKE2S_224_HASH_SIZE),
|
||||||
|
BLAKE2S_ALG("blake2s-256", "blake2s-256-x86", BLAKE2S_256_HASH_SIZE),
|
||||||
|
};
|
||||||
|
|
||||||
|
static int __init blake2s_mod_init(void)
|
||||||
|
{
|
||||||
|
if (IS_REACHABLE(CONFIG_CRYPTO_HASH) && boot_cpu_has(X86_FEATURE_SSSE3))
|
||||||
|
return crypto_register_shashes(blake2s_algs, ARRAY_SIZE(blake2s_algs));
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void __exit blake2s_mod_exit(void)
|
||||||
|
{
|
||||||
|
if (IS_REACHABLE(CONFIG_CRYPTO_HASH) && boot_cpu_has(X86_FEATURE_SSSE3))
|
||||||
|
crypto_unregister_shashes(blake2s_algs, ARRAY_SIZE(blake2s_algs));
|
||||||
|
}
|
||||||
|
|
||||||
|
module_init(blake2s_mod_init);
|
||||||
|
module_exit(blake2s_mod_exit);
|
||||||
|
|
||||||
|
MODULE_ALIAS_CRYPTO("blake2s-128");
|
||||||
|
MODULE_ALIAS_CRYPTO("blake2s-128-x86");
|
||||||
|
MODULE_ALIAS_CRYPTO("blake2s-160");
|
||||||
|
MODULE_ALIAS_CRYPTO("blake2s-160-x86");
|
||||||
|
MODULE_ALIAS_CRYPTO("blake2s-224");
|
||||||
|
MODULE_ALIAS_CRYPTO("blake2s-224-x86");
|
||||||
|
MODULE_ALIAS_CRYPTO("blake2s-256");
|
||||||
|
MODULE_ALIAS_CRYPTO("blake2s-256-x86");
|
||||||
|
MODULE_LICENSE("GPL v2");
|
@ -1919,9 +1919,10 @@ config CRYPTO_STATS
|
|||||||
config CRYPTO_HASH_INFO
|
config CRYPTO_HASH_INFO
|
||||||
bool
|
bool
|
||||||
|
|
||||||
source "lib/crypto/Kconfig"
|
|
||||||
source "drivers/crypto/Kconfig"
|
source "drivers/crypto/Kconfig"
|
||||||
source "crypto/asymmetric_keys/Kconfig"
|
source "crypto/asymmetric_keys/Kconfig"
|
||||||
source "certs/Kconfig"
|
source "certs/Kconfig"
|
||||||
|
|
||||||
endif # if CRYPTO
|
endif # if CRYPTO
|
||||||
|
|
||||||
|
source "lib/crypto/Kconfig"
|
||||||
|
@ -81,7 +81,6 @@ config WIREGUARD
|
|||||||
select CRYPTO
|
select CRYPTO
|
||||||
select CRYPTO_LIB_CURVE25519
|
select CRYPTO_LIB_CURVE25519
|
||||||
select CRYPTO_LIB_CHACHA20POLY1305
|
select CRYPTO_LIB_CHACHA20POLY1305
|
||||||
select CRYPTO_LIB_BLAKE2S
|
|
||||||
select CRYPTO_CHACHA20_X86_64 if X86 && 64BIT
|
select CRYPTO_CHACHA20_X86_64 if X86 && 64BIT
|
||||||
select CRYPTO_POLY1305_X86_64 if X86 && 64BIT
|
select CRYPTO_POLY1305_X86_64 if X86 && 64BIT
|
||||||
select CRYPTO_BLAKE2S_X86 if X86 && 64BIT
|
select CRYPTO_BLAKE2S_X86 if X86 && 64BIT
|
||||||
|
@ -11,11 +11,11 @@
|
|||||||
#include <crypto/internal/hash.h>
|
#include <crypto/internal/hash.h>
|
||||||
#include <linux/string.h>
|
#include <linux/string.h>
|
||||||
|
|
||||||
void blake2s_compress_generic(struct blake2s_state *state,const u8 *block,
|
void blake2s_compress_generic(struct blake2s_state *state, const u8 *block,
|
||||||
size_t nblocks, const u32 inc);
|
size_t nblocks, const u32 inc);
|
||||||
|
|
||||||
void blake2s_compress_arch(struct blake2s_state *state,const u8 *block,
|
void blake2s_compress(struct blake2s_state *state, const u8 *block,
|
||||||
size_t nblocks, const u32 inc);
|
size_t nblocks, const u32 inc);
|
||||||
|
|
||||||
bool blake2s_selftest(void);
|
bool blake2s_selftest(void);
|
||||||
|
|
||||||
|
@ -1,7 +1,5 @@
|
|||||||
# SPDX-License-Identifier: GPL-2.0
|
# SPDX-License-Identifier: GPL-2.0
|
||||||
|
|
||||||
comment "Crypto library routines"
|
|
||||||
|
|
||||||
config CRYPTO_LIB_AES
|
config CRYPTO_LIB_AES
|
||||||
tristate
|
tristate
|
||||||
|
|
||||||
@ -9,14 +7,14 @@ config CRYPTO_LIB_ARC4
|
|||||||
tristate
|
tristate
|
||||||
|
|
||||||
config CRYPTO_ARCH_HAVE_LIB_BLAKE2S
|
config CRYPTO_ARCH_HAVE_LIB_BLAKE2S
|
||||||
tristate
|
bool
|
||||||
help
|
help
|
||||||
Declares whether the architecture provides an arch-specific
|
Declares whether the architecture provides an arch-specific
|
||||||
accelerated implementation of the Blake2s library interface,
|
accelerated implementation of the Blake2s library interface,
|
||||||
either builtin or as a module.
|
either builtin or as a module.
|
||||||
|
|
||||||
config CRYPTO_LIB_BLAKE2S_GENERIC
|
config CRYPTO_LIB_BLAKE2S_GENERIC
|
||||||
tristate
|
def_bool !CRYPTO_ARCH_HAVE_LIB_BLAKE2S
|
||||||
help
|
help
|
||||||
This symbol can be depended upon by arch implementations of the
|
This symbol can be depended upon by arch implementations of the
|
||||||
Blake2s library interface that require the generic code as a
|
Blake2s library interface that require the generic code as a
|
||||||
@ -24,15 +22,6 @@ config CRYPTO_LIB_BLAKE2S_GENERIC
|
|||||||
implementation is enabled, this implementation serves the users
|
implementation is enabled, this implementation serves the users
|
||||||
of CRYPTO_LIB_BLAKE2S.
|
of CRYPTO_LIB_BLAKE2S.
|
||||||
|
|
||||||
config CRYPTO_LIB_BLAKE2S
|
|
||||||
tristate "BLAKE2s hash function library"
|
|
||||||
depends on CRYPTO_ARCH_HAVE_LIB_BLAKE2S || !CRYPTO_ARCH_HAVE_LIB_BLAKE2S
|
|
||||||
select CRYPTO_LIB_BLAKE2S_GENERIC if CRYPTO_ARCH_HAVE_LIB_BLAKE2S=n
|
|
||||||
help
|
|
||||||
Enable the Blake2s library interface. This interface may be fulfilled
|
|
||||||
by either the generic implementation or an arch-specific one, if one
|
|
||||||
is available and enabled.
|
|
||||||
|
|
||||||
config CRYPTO_ARCH_HAVE_LIB_CHACHA
|
config CRYPTO_ARCH_HAVE_LIB_CHACHA
|
||||||
tristate
|
tristate
|
||||||
help
|
help
|
||||||
@ -51,7 +40,7 @@ config CRYPTO_LIB_CHACHA_GENERIC
|
|||||||
of CRYPTO_LIB_CHACHA.
|
of CRYPTO_LIB_CHACHA.
|
||||||
|
|
||||||
config CRYPTO_LIB_CHACHA
|
config CRYPTO_LIB_CHACHA
|
||||||
tristate "ChaCha library interface"
|
tristate
|
||||||
depends on CRYPTO_ARCH_HAVE_LIB_CHACHA || !CRYPTO_ARCH_HAVE_LIB_CHACHA
|
depends on CRYPTO_ARCH_HAVE_LIB_CHACHA || !CRYPTO_ARCH_HAVE_LIB_CHACHA
|
||||||
select CRYPTO_LIB_CHACHA_GENERIC if CRYPTO_ARCH_HAVE_LIB_CHACHA=n
|
select CRYPTO_LIB_CHACHA_GENERIC if CRYPTO_ARCH_HAVE_LIB_CHACHA=n
|
||||||
help
|
help
|
||||||
@ -76,7 +65,7 @@ config CRYPTO_LIB_CURVE25519_GENERIC
|
|||||||
of CRYPTO_LIB_CURVE25519.
|
of CRYPTO_LIB_CURVE25519.
|
||||||
|
|
||||||
config CRYPTO_LIB_CURVE25519
|
config CRYPTO_LIB_CURVE25519
|
||||||
tristate "Curve25519 scalar multiplication library"
|
tristate
|
||||||
depends on CRYPTO_ARCH_HAVE_LIB_CURVE25519 || !CRYPTO_ARCH_HAVE_LIB_CURVE25519
|
depends on CRYPTO_ARCH_HAVE_LIB_CURVE25519 || !CRYPTO_ARCH_HAVE_LIB_CURVE25519
|
||||||
select CRYPTO_LIB_CURVE25519_GENERIC if CRYPTO_ARCH_HAVE_LIB_CURVE25519=n
|
select CRYPTO_LIB_CURVE25519_GENERIC if CRYPTO_ARCH_HAVE_LIB_CURVE25519=n
|
||||||
help
|
help
|
||||||
@ -111,7 +100,7 @@ config CRYPTO_LIB_POLY1305_GENERIC
|
|||||||
of CRYPTO_LIB_POLY1305.
|
of CRYPTO_LIB_POLY1305.
|
||||||
|
|
||||||
config CRYPTO_LIB_POLY1305
|
config CRYPTO_LIB_POLY1305
|
||||||
tristate "Poly1305 library interface"
|
tristate
|
||||||
depends on CRYPTO_ARCH_HAVE_LIB_POLY1305 || !CRYPTO_ARCH_HAVE_LIB_POLY1305
|
depends on CRYPTO_ARCH_HAVE_LIB_POLY1305 || !CRYPTO_ARCH_HAVE_LIB_POLY1305
|
||||||
select CRYPTO_LIB_POLY1305_GENERIC if CRYPTO_ARCH_HAVE_LIB_POLY1305=n
|
select CRYPTO_LIB_POLY1305_GENERIC if CRYPTO_ARCH_HAVE_LIB_POLY1305=n
|
||||||
help
|
help
|
||||||
@ -120,7 +109,7 @@ config CRYPTO_LIB_POLY1305
|
|||||||
is available and enabled.
|
is available and enabled.
|
||||||
|
|
||||||
config CRYPTO_LIB_CHACHA20POLY1305
|
config CRYPTO_LIB_CHACHA20POLY1305
|
||||||
tristate "ChaCha20-Poly1305 AEAD support (8-byte nonce library version)"
|
tristate
|
||||||
depends on CRYPTO_ARCH_HAVE_LIB_CHACHA || !CRYPTO_ARCH_HAVE_LIB_CHACHA
|
depends on CRYPTO_ARCH_HAVE_LIB_CHACHA || !CRYPTO_ARCH_HAVE_LIB_CHACHA
|
||||||
depends on CRYPTO_ARCH_HAVE_LIB_POLY1305 || !CRYPTO_ARCH_HAVE_LIB_POLY1305
|
depends on CRYPTO_ARCH_HAVE_LIB_POLY1305 || !CRYPTO_ARCH_HAVE_LIB_POLY1305
|
||||||
select CRYPTO_LIB_CHACHA
|
select CRYPTO_LIB_CHACHA
|
||||||
|
@ -10,11 +10,10 @@ libaes-y := aes.o
|
|||||||
obj-$(CONFIG_CRYPTO_LIB_ARC4) += libarc4.o
|
obj-$(CONFIG_CRYPTO_LIB_ARC4) += libarc4.o
|
||||||
libarc4-y := arc4.o
|
libarc4-y := arc4.o
|
||||||
|
|
||||||
obj-$(CONFIG_CRYPTO_LIB_BLAKE2S_GENERIC) += libblake2s-generic.o
|
# blake2s is used by the /dev/random driver which is always builtin
|
||||||
libblake2s-generic-y += blake2s-generic.o
|
obj-y += libblake2s.o
|
||||||
|
libblake2s-y := blake2s.o
|
||||||
obj-$(CONFIG_CRYPTO_LIB_BLAKE2S) += libblake2s.o
|
libblake2s-$(CONFIG_CRYPTO_LIB_BLAKE2S_GENERIC) += blake2s-generic.o
|
||||||
libblake2s-y += blake2s.o
|
|
||||||
|
|
||||||
obj-$(CONFIG_CRYPTO_LIB_CHACHA20POLY1305) += libchacha20poly1305.o
|
obj-$(CONFIG_CRYPTO_LIB_CHACHA20POLY1305) += libchacha20poly1305.o
|
||||||
libchacha20poly1305-y += chacha20poly1305.o
|
libchacha20poly1305-y += chacha20poly1305.o
|
||||||
|
@ -37,7 +37,11 @@ static inline void blake2s_increment_counter(struct blake2s_state *state,
|
|||||||
state->t[1] += (state->t[0] < inc);
|
state->t[1] += (state->t[0] < inc);
|
||||||
}
|
}
|
||||||
|
|
||||||
void blake2s_compress_generic(struct blake2s_state *state,const u8 *block,
|
void blake2s_compress(struct blake2s_state *state, const u8 *block,
|
||||||
|
size_t nblocks, const u32 inc)
|
||||||
|
__weak __alias(blake2s_compress_generic);
|
||||||
|
|
||||||
|
void blake2s_compress_generic(struct blake2s_state *state, const u8 *block,
|
||||||
size_t nblocks, const u32 inc)
|
size_t nblocks, const u32 inc)
|
||||||
{
|
{
|
||||||
u32 m[16];
|
u32 m[16];
|
||||||
|
@ -16,12 +16,6 @@
|
|||||||
#include <linux/init.h>
|
#include <linux/init.h>
|
||||||
#include <linux/bug.h>
|
#include <linux/bug.h>
|
||||||
|
|
||||||
#if IS_ENABLED(CONFIG_CRYPTO_ARCH_HAVE_LIB_BLAKE2S)
|
|
||||||
# define blake2s_compress blake2s_compress_arch
|
|
||||||
#else
|
|
||||||
# define blake2s_compress blake2s_compress_generic
|
|
||||||
#endif
|
|
||||||
|
|
||||||
void blake2s_update(struct blake2s_state *state, const u8 *in, size_t inlen)
|
void blake2s_update(struct blake2s_state *state, const u8 *in, size_t inlen)
|
||||||
{
|
{
|
||||||
__blake2s_update(state, in, inlen, blake2s_compress);
|
__blake2s_update(state, in, inlen, blake2s_compress);
|
||||||
|
Loading…
Reference in New Issue
Block a user