This series of patches uses different instruction sets to optimize the SM3 and SM4 algorithms, as well as the optimization of different modes of SM4. patch 1-2: NEON instruction set optimization for SM3 patch 3: Refactored and streamlined SM4 NEON instruction implementation patch 4-5: support test for new SM4 mode patch 6-8: Refactored and streamlined SM4 CE instruction implementation patch 9-12: CE accelerated implementation of SM4 CTS/XTS/ESSIV patch 13: CE accelerated implementation of SM4 CMAC/XCBC/CBCMAC patch 14-15: CE accelerated implementation of SM4 CCM/GCM patch 16: SM4 ARMv9 SVE cryptography acceleration implementation Tianjia Zhang (16): crypto: arm64/sm3 - raise the priority of the CE implementation crypto: arm64/sm3 - add NEON assembly implementation crypto: arm64/sm4 - refactor and simplify NEON implementation crypto: testmgr - add SM4 cts-cbc/essiv/xts/xcbc test vectors crypto: tcrypt - add SM4 cts-cbc/essiv/xts/xcbc test crypto: arm64/sm4 - refactor and simplify CE implementation crypto: arm64/sm4 - simplify sm4_ce_expand_key() of CE implementation crypto: arm64/sm4 - export reusable CE acceleration functions crypto: arm64/sm4 - add CE implementation for CTS-CBC mode crypto: arm64/sm4 - add CE implementation for XTS mode crypto: essiv - allow digestsize to be greater than keysize crypto: arm64/sm4 - add CE implementation for ESSIV mode crypto: arm64/sm4 - add CE implementation for cmac/xcbc/cbcmac crypto: arm64/sm4 - add CE implementation for CCM mode crypto: arm64/sm4 - add CE implementation for GCM mode crypto: arm64/sm4 - add ARMv9 SVE cryptography acceleration implementation arch/arm64/crypto/Kconfig | 66 +- arch/arm64/crypto/Makefile | 12 + arch/arm64/crypto/sm3-ce-glue.c | 2 +- arch/arm64/crypto/sm3-neon-core.S | 600 +++++++++++++ arch/arm64/crypto/sm3-neon-glue.c | 103 +++ arch/arm64/crypto/sm4-ce-asm.h | 209 +++++ arch/arm64/crypto/sm4-ce-ccm-core.S | 328 +++++++ arch/arm64/crypto/sm4-ce-ccm-glue.c | 303 +++++++ arch/arm64/crypto/sm4-ce-core.S | 1247 ++++++++++++++++++--------- arch/arm64/crypto/sm4-ce-gcm-core.S | 741 ++++++++++++++++ arch/arm64/crypto/sm4-ce-gcm-glue.c | 286 ++++++ arch/arm64/crypto/sm4-ce-glue.c | 703 ++++++++++++++- arch/arm64/crypto/sm4-ce.h | 16 + arch/arm64/crypto/sm4-neon-core.S | 630 +++++++++----- arch/arm64/crypto/sm4-neon-glue.c | 172 +--- arch/arm64/crypto/sm4-sve-ce-core.S | 1028 ++++++++++++++++++++++ arch/arm64/crypto/sm4-sve-ce-glue.c | 332 +++++++ crypto/essiv.c | 11 +- crypto/tcrypt.c | 28 + crypto/testmgr.c | 25 + crypto/testmgr.h | 1161 +++++++++++++++++++++++++ 21 files changed, 7234 insertions(+), 769 deletions(-) create mode 100644 arch/arm64/crypto/sm3-neon-core.S create mode 100644 arch/arm64/crypto/sm3-neon-glue.c create mode 100644 arch/arm64/crypto/sm4-ce-asm.h create mode 100644 arch/arm64/crypto/sm4-ce-ccm-core.S create mode 100644 arch/arm64/crypto/sm4-ce-ccm-glue.c create mode 100644 arch/arm64/crypto/sm4-ce-gcm-core.S create mode 100644 arch/arm64/crypto/sm4-ce-gcm-glue.c create mode 100644 arch/arm64/crypto/sm4-ce.h create mode 100644 arch/arm64/crypto/sm4-sve-ce-core.S create mode 100644 arch/arm64/crypto/sm4-sve-ce-glue.c -- 2.24.3 (Apple Git-128)