linux/include/crypto/internal
Eric Biggers e96cb9507f lib/crypto: sha256: Consolidate into single module
Consolidate the CPU-based SHA-256 code into a single module, following
what I did with SHA-512:

- Each arch now provides a header file lib/crypto/$(SRCARCH)/sha256.h,
  replacing lib/crypto/$(SRCARCH)/sha256.c.  The header defines
  sha256_blocks() and optionally sha256_mod_init_arch().  It is included
  by lib/crypto/sha256.c, and thus the code gets built into the single
  libsha256 module, with proper inlining and dead code elimination.

- sha256_blocks_generic() is moved from lib/crypto/sha256-generic.c into
  lib/crypto/sha256.c.  It's now a static function marked with
  __maybe_unused, so the compiler automatically eliminates it in any
  cases where it's not used.

- Whether arch-optimized SHA-256 is buildable is now controlled
  centrally by lib/crypto/Kconfig instead of by
  lib/crypto/$(SRCARCH)/Kconfig.  The conditions for enabling it remain
  the same as before, and it remains enabled by default.

- Any additional arch-specific translation units for the optimized
  SHA-256 code (such as assembly files) are now compiled by
  lib/crypto/Makefile instead of lib/crypto/$(SRCARCH)/Makefile.

Acked-by: Ard Biesheuvel <ardb@kernel.org>
Link: https://lore.kernel.org/r/20250630160645.3198-13-ebiggers@kernel.org
Signed-off-by: Eric Biggers <ebiggers@kernel.org>
2025-07-04 10:23:11 -07:00
..
acompress.h crypto: api - Rename CRYPTO_ALG_REQ_CHAIN to CRYPTO_ALG_REQ_VIRT 2025-05-05 18:20:45 +08:00
aead.h
akcipher.h crypto: akcipher - Drop sign/verify operations 2024-10-05 13:22:04 +08:00
blake2b.h crypto: arm/blake2b - Use API partial block handling 2025-04-23 11:33:46 +08:00
blake2s.h
blockhash.h crypto: lib/sha256 - Move partial block handling out 2025-05-05 13:32:01 +08:00
cipher.h
des.h
ecc.h This update includes the following changes: 2024-11-19 10:28:41 -08:00
engine.h crypto: engine - Realign struct crypto_engine to save 8 bytes 2025-04-23 11:33:46 +08:00
geniv.h crypto: geniv - use memcpy_sglist() instead of null skcipher 2025-05-12 13:32:53 +08:00
hash.h Revert "crypto: testmgr - Add hash export format testing" 2025-05-23 17:20:59 +08:00
kdf_selftest.h
kpp.h
poly1305.h crypto: lib/poly1305 - Add block-only interface 2025-05-05 13:32:50 +08:00
rng.h
rsa.h crypto: rsassa-pkcs1 - Migrate to sig_alg backend 2024-10-05 13:22:04 +08:00
scompress.h crypto: acomp - Move scomp stream allocation code into acomp 2025-04-07 13:22:25 +08:00
sig.h crypto: sig - Introduce sig_alg backend 2024-10-05 13:22:04 +08:00
simd.h crypto: testmgr - reinstate kconfig control over full self-tests 2025-06-13 17:24:21 +08:00
skcipher.h crypto: scatterwalk - Move skcipher walk and use it for memcpy_sglist 2025-04-28 19:45:26 +08:00