| From: |
| Herbert Xu <herbert-AT-gondor.apana.org.au> |
| To: |
| Linux Crypto Mailing List <linux-crypto-AT-vger.kernel.org> |
| Subject: |
| [PATCH 00/15] crypto: lib - Add partial block helper |
| Date: |
| Thu, 24 Apr 2025 18:46:56 +0800 |
| Message-ID: |
| <cover.1745490652.git.herbert@gondor.apana.org.au> |
| Archive-link: |
| Article |
This is based on
https://patchwork.kernel.org/project/linux-crypto/patch/2...
https://patchwork.kernel.org/project/linux-crypto/patch/2...
https://patchwork.kernel.org/project/linux-crypto/patch/2...
This series introduces a partial block helper for lib/crypto hash
algorithms based on the one from sha256_base.
It then uses it on poly1305 to eliminate duplication between
architectures. In particular, instead of having complete update
functions for each architecture, reduce it to a block function
per architecture instead. The partial block handling is handled
by the generic library layer.
The poly1305 implementation was anomalous due to the inability
to call setkey in softirq. This has since been resolved with
the addition of cloning. Add setkey to poly1305 and switch the
IPsec code (rfc7539) to use that.
Finally add a partial blocks conversion for polyval.
Herbert Xu (15):
crypto: lib/sha256 - Move partial block handling out
crypto: lib/poly1305 - Add block-only interface
crypto: arm/poly1305 - Add block-only interface
crypto: arm64/poly1305 - Add block-only interface
crypto: mips/poly1305 - Add block-only interface
crypto: powerpc/poly1305 - Add block-only interface
crypto: x86/poly1305 - Add block-only interface
crypto: poly1305 - Use API partial block handling
crypto: lib/poly1305 - Use block-only interface
crypto: chacha20poly1305 - Use setkey on poly1305
crypto: testmgr/poly1305 - Use setkey on poly1305
crypto: poly1305 - Make setkey mandatory
crypto: arm64/polyval - Use API partial block handling
crypto: x86/polyval - Use API partial block handling
crypto: polyval-generic - Use API partial block handling
arch/arm/lib/crypto/poly1305-armv4.pl | 4 +-
arch/arm/lib/crypto/poly1305-glue.c | 112 ++++---------
arch/arm64/crypto/polyval-ce-glue.c | 73 +++------
arch/arm64/lib/crypto/Makefile | 3 +-
arch/arm64/lib/crypto/poly1305-glue.c | 104 ++++--------
arch/mips/lib/crypto/poly1305-glue.c | 74 ++-------
arch/mips/lib/crypto/poly1305-mips.pl | 12 +-
arch/powerpc/lib/crypto/poly1305-p10-glue.c | 105 ++++--------
arch/x86/crypto/polyval-clmulni_glue.c | 72 +++------
arch/x86/lib/crypto/poly1305_glue.c | 168 +++++---------------
crypto/chacha20poly1305.c | 115 ++++++++------
crypto/poly1305.c | 124 ++++++++++-----
crypto/polyval-generic.c | 120 +++++---------
crypto/testmgr.h | 112 +++++++------
include/crypto/internal/blockhash.h | 52 ++++++
include/crypto/internal/poly1305.h | 28 +++-
include/crypto/poly1305.h | 60 ++-----
include/crypto/polyval.h | 8 -
include/crypto/sha2.h | 9 +-
include/crypto/sha256_base.h | 38 +----
include/linux/crypto.h | 3 +
lib/crypto/poly1305.c | 80 +++++-----
22 files changed, 595 insertions(+), 881 deletions(-)
create mode 100644 include/crypto/internal/blockhash.h
--
2.39.5