2019-05-27 06:55:01 +00:00
|
|
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
2015-04-03 10:03:40 +00:00
|
|
|
/*
|
|
|
|
* Glue code for the SHA256 Secure Hash Algorithm assembly implementation
|
|
|
|
* using optimized ARM assembler and NEON instructions.
|
|
|
|
*
|
2018-08-24 00:01:26 +00:00
|
|
|
* Copyright © 2015 Google Inc.
|
2015-04-03 10:03:40 +00:00
|
|
|
*
|
|
|
|
* This file is based on sha256_ssse3_glue.c:
|
|
|
|
* Copyright (C) 2013 Intel Corporation
|
|
|
|
* Author: Tim Chen <tim.c.chen@linux.intel.com>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <crypto/internal/hash.h>
|
|
|
|
#include <linux/crypto.h>
|
|
|
|
#include <linux/init.h>
|
|
|
|
#include <linux/module.h>
|
|
|
|
#include <linux/mm.h>
|
|
|
|
#include <linux/types.h>
|
|
|
|
#include <linux/string.h>
|
2020-11-13 05:20:21 +00:00
|
|
|
#include <crypto/sha2.h>
|
2015-04-09 10:55:42 +00:00
|
|
|
#include <crypto/sha256_base.h>
|
2015-04-03 10:03:40 +00:00
|
|
|
#include <asm/simd.h>
|
|
|
|
#include <asm/neon.h>
|
2015-04-09 10:55:42 +00:00
|
|
|
|
2015-04-03 10:03:40 +00:00
|
|
|
#include "sha256_glue.h"
|
|
|
|
|
crypto: arm/sha - fix function cast warnings
clang-16 warns about casting between incompatible function types:
arch/arm/crypto/sha256_glue.c:37:5: error: cast from 'void (*)(u32 *, const void *, unsigned int)' (aka 'void (*)(unsigned int *, const void *, unsigned int)') to 'sha256_block_fn *' (aka 'void (*)(struct sha256_state *, const unsigned char *, int)') converts to incompatible function type [-Werror,-Wcast-function-type-strict]
37 | (sha256_block_fn *)sha256_block_data_order);
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
arch/arm/crypto/sha512-glue.c:34:3: error: cast from 'void (*)(u64 *, const u8 *, int)' (aka 'void (*)(unsigned long long *, const unsigned char *, int)') to 'sha512_block_fn *' (aka 'void (*)(struct sha512_state *, const unsigned char *, int)') converts to incompatible function type [-Werror,-Wcast-function-type-strict]
34 | (sha512_block_fn *)sha512_block_data_order);
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Fix the prototypes for the assembler functions to match the typedef.
The code already relies on the digest being the first part of the
state structure, so there is no change in behavior.
Fixes: c80ae7ca3726 ("crypto: arm/sha512 - accelerated SHA-512 using ARM generic ASM and NEON")
Fixes: b59e2ae3690c ("crypto: arm/sha256 - move SHA-224/256 ASM/NEON implementation to base layer")
Signed-off-by: Arnd Bergmann <arnd@arndb.de>
Reviewed-by: Ard Biesheuvel <ardb@kernel.org>
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
2024-02-13 13:49:46 +00:00
|
|
|
asmlinkage void sha256_block_data_order(struct sha256_state *state,
|
|
|
|
const u8 *data, int num_blks);
|
2015-04-03 10:03:40 +00:00
|
|
|
|
2015-04-09 10:55:42 +00:00
|
|
|
int crypto_sha256_arm_update(struct shash_desc *desc, const u8 *data,
|
|
|
|
unsigned int len)
|
2015-04-03 10:03:40 +00:00
|
|
|
{
|
2015-04-09 10:55:42 +00:00
|
|
|
/* make sure casting to sha256_block_fn() is safe */
|
|
|
|
BUILD_BUG_ON(offsetof(struct sha256_state, state) != 0);
|
2015-04-03 10:03:40 +00:00
|
|
|
|
crypto: arm/sha - fix function cast warnings
clang-16 warns about casting between incompatible function types:
arch/arm/crypto/sha256_glue.c:37:5: error: cast from 'void (*)(u32 *, const void *, unsigned int)' (aka 'void (*)(unsigned int *, const void *, unsigned int)') to 'sha256_block_fn *' (aka 'void (*)(struct sha256_state *, const unsigned char *, int)') converts to incompatible function type [-Werror,-Wcast-function-type-strict]
37 | (sha256_block_fn *)sha256_block_data_order);
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
arch/arm/crypto/sha512-glue.c:34:3: error: cast from 'void (*)(u64 *, const u8 *, int)' (aka 'void (*)(unsigned long long *, const unsigned char *, int)') to 'sha512_block_fn *' (aka 'void (*)(struct sha512_state *, const unsigned char *, int)') converts to incompatible function type [-Werror,-Wcast-function-type-strict]
34 | (sha512_block_fn *)sha512_block_data_order);
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Fix the prototypes for the assembler functions to match the typedef.
The code already relies on the digest being the first part of the
state structure, so there is no change in behavior.
Fixes: c80ae7ca3726 ("crypto: arm/sha512 - accelerated SHA-512 using ARM generic ASM and NEON")
Fixes: b59e2ae3690c ("crypto: arm/sha256 - move SHA-224/256 ASM/NEON implementation to base layer")
Signed-off-by: Arnd Bergmann <arnd@arndb.de>
Reviewed-by: Ard Biesheuvel <ardb@kernel.org>
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
2024-02-13 13:49:46 +00:00
|
|
|
return sha256_base_do_update(desc, data, len, sha256_block_data_order);
|
2015-04-03 10:03:40 +00:00
|
|
|
}
|
2015-04-09 10:55:42 +00:00
|
|
|
EXPORT_SYMBOL(crypto_sha256_arm_update);
|
2015-04-03 10:03:40 +00:00
|
|
|
|
2019-09-01 20:35:24 +00:00
|
|
|
static int crypto_sha256_arm_final(struct shash_desc *desc, u8 *out)
|
2015-04-03 10:03:40 +00:00
|
|
|
{
|
crypto: arm/sha - fix function cast warnings
clang-16 warns about casting between incompatible function types:
arch/arm/crypto/sha256_glue.c:37:5: error: cast from 'void (*)(u32 *, const void *, unsigned int)' (aka 'void (*)(unsigned int *, const void *, unsigned int)') to 'sha256_block_fn *' (aka 'void (*)(struct sha256_state *, const unsigned char *, int)') converts to incompatible function type [-Werror,-Wcast-function-type-strict]
37 | (sha256_block_fn *)sha256_block_data_order);
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
arch/arm/crypto/sha512-glue.c:34:3: error: cast from 'void (*)(u64 *, const u8 *, int)' (aka 'void (*)(unsigned long long *, const unsigned char *, int)') to 'sha512_block_fn *' (aka 'void (*)(struct sha512_state *, const unsigned char *, int)') converts to incompatible function type [-Werror,-Wcast-function-type-strict]
34 | (sha512_block_fn *)sha512_block_data_order);
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Fix the prototypes for the assembler functions to match the typedef.
The code already relies on the digest being the first part of the
state structure, so there is no change in behavior.
Fixes: c80ae7ca3726 ("crypto: arm/sha512 - accelerated SHA-512 using ARM generic ASM and NEON")
Fixes: b59e2ae3690c ("crypto: arm/sha256 - move SHA-224/256 ASM/NEON implementation to base layer")
Signed-off-by: Arnd Bergmann <arnd@arndb.de>
Reviewed-by: Ard Biesheuvel <ardb@kernel.org>
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
2024-02-13 13:49:46 +00:00
|
|
|
sha256_base_do_finalize(desc, sha256_block_data_order);
|
2015-04-09 10:55:42 +00:00
|
|
|
return sha256_base_finish(desc, out);
|
2015-04-03 10:03:40 +00:00
|
|
|
}
|
|
|
|
|
2015-04-09 10:55:42 +00:00
|
|
|
int crypto_sha256_arm_finup(struct shash_desc *desc, const u8 *data,
|
|
|
|
unsigned int len, u8 *out)
|
2015-04-03 10:03:40 +00:00
|
|
|
{
|
crypto: arm/sha - fix function cast warnings
clang-16 warns about casting between incompatible function types:
arch/arm/crypto/sha256_glue.c:37:5: error: cast from 'void (*)(u32 *, const void *, unsigned int)' (aka 'void (*)(unsigned int *, const void *, unsigned int)') to 'sha256_block_fn *' (aka 'void (*)(struct sha256_state *, const unsigned char *, int)') converts to incompatible function type [-Werror,-Wcast-function-type-strict]
37 | (sha256_block_fn *)sha256_block_data_order);
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
arch/arm/crypto/sha512-glue.c:34:3: error: cast from 'void (*)(u64 *, const u8 *, int)' (aka 'void (*)(unsigned long long *, const unsigned char *, int)') to 'sha512_block_fn *' (aka 'void (*)(struct sha512_state *, const unsigned char *, int)') converts to incompatible function type [-Werror,-Wcast-function-type-strict]
34 | (sha512_block_fn *)sha512_block_data_order);
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Fix the prototypes for the assembler functions to match the typedef.
The code already relies on the digest being the first part of the
state structure, so there is no change in behavior.
Fixes: c80ae7ca3726 ("crypto: arm/sha512 - accelerated SHA-512 using ARM generic ASM and NEON")
Fixes: b59e2ae3690c ("crypto: arm/sha256 - move SHA-224/256 ASM/NEON implementation to base layer")
Signed-off-by: Arnd Bergmann <arnd@arndb.de>
Reviewed-by: Ard Biesheuvel <ardb@kernel.org>
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
2024-02-13 13:49:46 +00:00
|
|
|
sha256_base_do_update(desc, data, len, sha256_block_data_order);
|
2019-09-01 20:35:24 +00:00
|
|
|
return crypto_sha256_arm_final(desc, out);
|
2015-04-03 10:03:40 +00:00
|
|
|
}
|
2015-04-09 10:55:42 +00:00
|
|
|
EXPORT_SYMBOL(crypto_sha256_arm_finup);
|
2015-04-03 10:03:40 +00:00
|
|
|
|
|
|
|
static struct shash_alg algs[] = { {
|
|
|
|
.digestsize = SHA256_DIGEST_SIZE,
|
2015-04-09 10:55:42 +00:00
|
|
|
.init = sha256_base_init,
|
|
|
|
.update = crypto_sha256_arm_update,
|
2019-09-01 20:35:24 +00:00
|
|
|
.final = crypto_sha256_arm_final,
|
2015-04-09 10:55:42 +00:00
|
|
|
.finup = crypto_sha256_arm_finup,
|
2015-04-03 10:03:40 +00:00
|
|
|
.descsize = sizeof(struct sha256_state),
|
|
|
|
.base = {
|
|
|
|
.cra_name = "sha256",
|
|
|
|
.cra_driver_name = "sha256-asm",
|
|
|
|
.cra_priority = 150,
|
|
|
|
.cra_blocksize = SHA256_BLOCK_SIZE,
|
|
|
|
.cra_module = THIS_MODULE,
|
|
|
|
}
|
|
|
|
}, {
|
|
|
|
.digestsize = SHA224_DIGEST_SIZE,
|
2015-04-09 10:55:42 +00:00
|
|
|
.init = sha224_base_init,
|
|
|
|
.update = crypto_sha256_arm_update,
|
2019-09-01 20:35:24 +00:00
|
|
|
.final = crypto_sha256_arm_final,
|
2015-04-09 10:55:42 +00:00
|
|
|
.finup = crypto_sha256_arm_finup,
|
2015-04-03 10:03:40 +00:00
|
|
|
.descsize = sizeof(struct sha256_state),
|
|
|
|
.base = {
|
|
|
|
.cra_name = "sha224",
|
|
|
|
.cra_driver_name = "sha224-asm",
|
|
|
|
.cra_priority = 150,
|
|
|
|
.cra_blocksize = SHA224_BLOCK_SIZE,
|
|
|
|
.cra_module = THIS_MODULE,
|
|
|
|
}
|
|
|
|
} };
|
|
|
|
|
|
|
|
static int __init sha256_mod_init(void)
|
|
|
|
{
|
|
|
|
int res = crypto_register_shashes(algs, ARRAY_SIZE(algs));
|
|
|
|
|
|
|
|
if (res < 0)
|
|
|
|
return res;
|
|
|
|
|
|
|
|
if (IS_ENABLED(CONFIG_KERNEL_MODE_NEON) && cpu_has_neon()) {
|
|
|
|
res = crypto_register_shashes(sha256_neon_algs,
|
|
|
|
ARRAY_SIZE(sha256_neon_algs));
|
|
|
|
|
|
|
|
if (res < 0)
|
|
|
|
crypto_unregister_shashes(algs, ARRAY_SIZE(algs));
|
|
|
|
}
|
|
|
|
|
|
|
|
return res;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void __exit sha256_mod_fini(void)
|
|
|
|
{
|
|
|
|
crypto_unregister_shashes(algs, ARRAY_SIZE(algs));
|
|
|
|
|
|
|
|
if (IS_ENABLED(CONFIG_KERNEL_MODE_NEON) && cpu_has_neon())
|
|
|
|
crypto_unregister_shashes(sha256_neon_algs,
|
|
|
|
ARRAY_SIZE(sha256_neon_algs));
|
|
|
|
}
|
|
|
|
|
|
|
|
module_init(sha256_mod_init);
|
|
|
|
module_exit(sha256_mod_fini);
|
|
|
|
|
|
|
|
MODULE_LICENSE("GPL");
|
|
|
|
MODULE_DESCRIPTION("SHA256 Secure Hash Algorithm (ARM), including NEON");
|
|
|
|
|
|
|
|
MODULE_ALIAS_CRYPTO("sha256");
|