v3 modifies the block helper so that arrays can be used as state. This is based on https://patchwork.kernel.org/project/linux-crypto/list/?series=955753 https://patchwork.kernel.org/project/linux-crypto/list/?series=957401 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. It also has just a single user, which is chacha20poly1305 that is hard-coded to use poly1305. Replace the gratuitous use of ahash in chacha20poly1305 with the lib/crypto poly1305 instead. This then allows the shash poly1305 to be removed. Herbert Xu (11): 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: chacha20poly1305 - Use lib/crypto poly1305 crypto: testmgr - Remove poly1305 crypto: poly1305 - Remove algorithm crypto: lib/poly1305 - Use block-only interface arch/arm/lib/crypto/poly1305-armv4.pl | 4 +- arch/arm/lib/crypto/poly1305-glue.c | 113 ++---- arch/arm64/lib/crypto/Makefile | 3 +- arch/arm64/lib/crypto/poly1305-glue.c | 105 ++---- arch/mips/lib/crypto/poly1305-glue.c | 75 +--- arch/mips/lib/crypto/poly1305-mips.pl | 12 +- arch/powerpc/lib/crypto/poly1305-p10-glue.c | 109 ++---- .../lib/crypto/poly1305-x86_64-cryptogams.pl | 33 +- arch/x86/lib/crypto/poly1305_glue.c | 169 +++------ crypto/Kconfig | 14 +- crypto/Makefile | 2 - crypto/chacha20poly1305.c | 323 ++++-------------- crypto/poly1305.c | 152 --------- crypto/testmgr.c | 6 - crypto/testmgr.h | 288 ---------------- include/crypto/internal/blockhash.h | 49 +++ include/crypto/internal/poly1305.h | 28 +- include/crypto/poly1305.h | 60 +--- include/crypto/sha2.h | 9 +- include/crypto/sha256_base.h | 38 +-- lib/crypto/poly1305.c | 83 ++--- 21 files changed, 393 insertions(+), 1282 deletions(-) delete mode 100644 crypto/poly1305.c create mode 100644 include/crypto/internal/blockhash.h -- 2.39.5