123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293 |
- # SPDX-License-Identifier: GPL-2.0
- menu "Accelerated Cryptographic Algorithms for CPU (arm64)"
- config CRYPTO_GHASH_ARM64_CE
- tristate "Hash functions: GHASH (ARMv8 Crypto Extensions)"
- depends on KERNEL_MODE_NEON
- select CRYPTO_HASH
- select CRYPTO_GF128MUL
- select CRYPTO_LIB_AES
- select CRYPTO_AEAD
- help
- GCM GHASH function (NIST SP800-38D)
- Architecture: arm64 using:
- - ARMv8 Crypto Extensions
- config CRYPTO_NHPOLY1305_NEON
- tristate "Hash functions: NHPoly1305 (NEON)"
- depends on KERNEL_MODE_NEON
- select CRYPTO_NHPOLY1305
- help
- NHPoly1305 hash function (Adiantum)
- Architecture: arm64 using:
- - NEON (Advanced SIMD) extensions
- config CRYPTO_POLY1305_NEON
- tristate "Hash functions: Poly1305 (NEON)"
- depends on KERNEL_MODE_NEON
- select CRYPTO_HASH
- select CRYPTO_ARCH_HAVE_LIB_POLY1305
- help
- Poly1305 authenticator algorithm (RFC7539)
- Architecture: arm64 using:
- - NEON (Advanced SIMD) extensions
- config CRYPTO_SHA1_ARM64_CE
- tristate "Hash functions: SHA-1 (ARMv8 Crypto Extensions)"
- depends on KERNEL_MODE_NEON
- select CRYPTO_HASH
- select CRYPTO_SHA1
- help
- SHA-1 secure hash algorithm (FIPS 180)
- Architecture: arm64 using:
- - ARMv8 Crypto Extensions
- config CRYPTO_SHA256_ARM64
- tristate "Hash functions: SHA-224 and SHA-256"
- select CRYPTO_HASH
- help
- SHA-224 and SHA-256 secure hash algorithms (FIPS 180)
- Architecture: arm64
- config CRYPTO_SHA2_ARM64_CE
- tristate "Hash functions: SHA-224 and SHA-256 (ARMv8 Crypto Extensions)"
- depends on KERNEL_MODE_NEON
- select CRYPTO_HASH
- select CRYPTO_SHA256_ARM64
- help
- SHA-224 and SHA-256 secure hash algorithms (FIPS 180)
- Architecture: arm64 using:
- - ARMv8 Crypto Extensions
- config CRYPTO_SHA512_ARM64
- tristate "Hash functions: SHA-384 and SHA-512"
- select CRYPTO_HASH
- help
- SHA-384 and SHA-512 secure hash algorithms (FIPS 180)
- Architecture: arm64
- config CRYPTO_SHA512_ARM64_CE
- tristate "Hash functions: SHA-384 and SHA-512 (ARMv8 Crypto Extensions)"
- depends on KERNEL_MODE_NEON
- select CRYPTO_HASH
- select CRYPTO_SHA512_ARM64
- help
- SHA-384 and SHA-512 secure hash algorithms (FIPS 180)
- Architecture: arm64 using:
- - ARMv8 Crypto Extensions
- config CRYPTO_SHA3_ARM64
- tristate "Hash functions: SHA-3 (ARMv8.2 Crypto Extensions)"
- depends on KERNEL_MODE_NEON
- select CRYPTO_HASH
- select CRYPTO_SHA3
- help
- SHA-3 secure hash algorithms (FIPS 202)
- Architecture: arm64 using:
- - ARMv8.2 Crypto Extensions
- config CRYPTO_SM3_NEON
- tristate "Hash functions: SM3 (NEON)"
- depends on KERNEL_MODE_NEON
- select CRYPTO_HASH
- select CRYPTO_SM3
- help
- SM3 (ShangMi 3) secure hash function (OSCCA GM/T 0004-2012)
- Architecture: arm64 using:
- - NEON (Advanced SIMD) extensions
- config CRYPTO_SM3_ARM64_CE
- tristate "Hash functions: SM3 (ARMv8.2 Crypto Extensions)"
- depends on KERNEL_MODE_NEON
- select CRYPTO_HASH
- select CRYPTO_SM3
- help
- SM3 (ShangMi 3) secure hash function (OSCCA GM/T 0004-2012)
- Architecture: arm64 using:
- - ARMv8.2 Crypto Extensions
- config CRYPTO_POLYVAL_ARM64_CE
- tristate "Hash functions: POLYVAL (ARMv8 Crypto Extensions)"
- depends on KERNEL_MODE_NEON
- select CRYPTO_POLYVAL
- help
- POLYVAL hash function for HCTR2
- Architecture: arm64 using:
- - ARMv8 Crypto Extensions
- config CRYPTO_AES_ARM64
- tristate "Ciphers: AES, modes: ECB, CBC, CTR, CTS, XCTR, XTS"
- select CRYPTO_AES
- help
- Block ciphers: AES cipher algorithms (FIPS-197)
- Length-preserving ciphers: AES with ECB, CBC, CTR, CTS,
- XCTR, and XTS modes
- AEAD cipher: AES with CBC, ESSIV, and SHA-256
- for fscrypt and dm-crypt
- Architecture: arm64
- config CRYPTO_AES_ARM64_CE
- tristate "Ciphers: AES (ARMv8 Crypto Extensions)"
- depends on ARM64 && KERNEL_MODE_NEON
- select CRYPTO_ALGAPI
- select CRYPTO_LIB_AES
- help
- Block ciphers: AES cipher algorithms (FIPS-197)
- Architecture: arm64 using:
- - ARMv8 Crypto Extensions
- config CRYPTO_AES_ARM64_CE_BLK
- tristate "Ciphers: AES, modes: ECB/CBC/CTR/XTS (ARMv8 Crypto Extensions)"
- depends on KERNEL_MODE_NEON
- select CRYPTO_SKCIPHER
- select CRYPTO_AES_ARM64_CE
- help
- Length-preserving ciphers: AES cipher algorithms (FIPS-197)
- with block cipher modes:
- - ECB (Electronic Codebook) mode (NIST SP800-38A)
- - CBC (Cipher Block Chaining) mode (NIST SP800-38A)
- - CTR (Counter) mode (NIST SP800-38A)
- - XTS (XOR Encrypt XOR with ciphertext stealing) mode (NIST SP800-38E
- and IEEE 1619)
- Architecture: arm64 using:
- - ARMv8 Crypto Extensions
- config CRYPTO_AES_ARM64_NEON_BLK
- tristate "Ciphers: AES, modes: ECB/CBC/CTR/XTS (NEON)"
- depends on KERNEL_MODE_NEON
- select CRYPTO_SKCIPHER
- select CRYPTO_LIB_AES
- help
- Length-preserving ciphers: AES cipher algorithms (FIPS-197)
- with block cipher modes:
- - ECB (Electronic Codebook) mode (NIST SP800-38A)
- - CBC (Cipher Block Chaining) mode (NIST SP800-38A)
- - CTR (Counter) mode (NIST SP800-38A)
- - XTS (XOR Encrypt XOR with ciphertext stealing) mode (NIST SP800-38E
- and IEEE 1619)
- Architecture: arm64 using:
- - NEON (Advanced SIMD) extensions
- config CRYPTO_CHACHA20_NEON
- tristate "Ciphers: ChaCha (NEON)"
- depends on KERNEL_MODE_NEON
- select CRYPTO_SKCIPHER
- select CRYPTO_LIB_CHACHA_GENERIC
- select CRYPTO_ARCH_HAVE_LIB_CHACHA
- help
- Length-preserving ciphers: ChaCha20, XChaCha20, and XChaCha12
- stream cipher algorithms
- Architecture: arm64 using:
- - NEON (Advanced SIMD) extensions
- config CRYPTO_AES_ARM64_BS
- tristate "Ciphers: AES, modes: ECB/CBC/CTR/XCTR/XTS modes (bit-sliced NEON)"
- depends on KERNEL_MODE_NEON
- select CRYPTO_SKCIPHER
- select CRYPTO_AES_ARM64_NEON_BLK
- select CRYPTO_LIB_AES
- help
- Length-preserving ciphers: AES cipher algorithms (FIPS-197)
- with block cipher modes:
- - ECB (Electronic Codebook) mode (NIST SP800-38A)
- - CBC (Cipher Block Chaining) mode (NIST SP800-38A)
- - CTR (Counter) mode (NIST SP800-38A)
- - XCTR mode for HCTR2
- - XTS (XOR Encrypt XOR with ciphertext stealing) mode (NIST SP800-38E
- and IEEE 1619)
- Architecture: arm64 using:
- - bit-sliced algorithm
- - NEON (Advanced SIMD) extensions
- config CRYPTO_SM4_ARM64_CE
- tristate "Ciphers: SM4 (ARMv8.2 Crypto Extensions)"
- depends on KERNEL_MODE_NEON
- select CRYPTO_ALGAPI
- select CRYPTO_SM4
- help
- Block ciphers: SM4 cipher algorithms (OSCCA GB/T 32907-2016)
- Architecture: arm64 using:
- - ARMv8.2 Crypto Extensions
- - NEON (Advanced SIMD) extensions
- config CRYPTO_SM4_ARM64_CE_BLK
- tristate "Ciphers: SM4, modes: ECB/CBC/CFB/CTR (ARMv8 Crypto Extensions)"
- depends on KERNEL_MODE_NEON
- select CRYPTO_SKCIPHER
- select CRYPTO_SM4
- help
- Length-preserving ciphers: SM4 cipher algorithms (OSCCA GB/T 32907-2016)
- with block cipher modes:
- - ECB (Electronic Codebook) mode (NIST SP800-38A)
- - CBC (Cipher Block Chaining) mode (NIST SP800-38A)
- - CFB (Cipher Feedback) mode (NIST SP800-38A)
- - CTR (Counter) mode (NIST SP800-38A)
- Architecture: arm64 using:
- - ARMv8 Crypto Extensions
- - NEON (Advanced SIMD) extensions
- config CRYPTO_SM4_ARM64_NEON_BLK
- tristate "Ciphers: SM4, modes: ECB/CBC/CFB/CTR (NEON)"
- depends on KERNEL_MODE_NEON
- select CRYPTO_SKCIPHER
- select CRYPTO_SM4
- help
- Length-preserving ciphers: SM4 cipher algorithms (OSCCA GB/T 32907-2016)
- with block cipher modes:
- - ECB (Electronic Codebook) mode (NIST SP800-38A)
- - CBC (Cipher Block Chaining) mode (NIST SP800-38A)
- - CFB (Cipher Feedback) mode (NIST SP800-38A)
- - CTR (Counter) mode (NIST SP800-38A)
- Architecture: arm64 using:
- - NEON (Advanced SIMD) extensions
- config CRYPTO_AES_ARM64_CE_CCM
- tristate "AEAD cipher: AES in CCM mode (ARMv8 Crypto Extensions)"
- depends on ARM64 && KERNEL_MODE_NEON
- select CRYPTO_ALGAPI
- select CRYPTO_AES_ARM64_CE
- select CRYPTO_AEAD
- select CRYPTO_LIB_AES
- help
- AEAD cipher: AES cipher algorithms (FIPS-197) with
- CCM (Counter with Cipher Block Chaining-Message Authentication Code)
- authenticated encryption mode (NIST SP800-38C)
- Architecture: arm64 using:
- - ARMv8 Crypto Extensions
- - NEON (Advanced SIMD) extensions
- config CRYPTO_CRCT10DIF_ARM64_CE
- tristate "CRCT10DIF (PMULL)"
- depends on KERNEL_MODE_NEON && CRC_T10DIF
- select CRYPTO_HASH
- help
- CRC16 CRC algorithm used for the T10 (SCSI) Data Integrity Field (DIF)
- Architecture: arm64 using
- - PMULL (Polynomial Multiply Long) instructions
- endmenu
|