Commit | Line | Data |
---|---|---|
b2441318 | 1 | # SPDX-License-Identifier: GPL-2.0 |
2c98833a AB |
2 | |
3 | menuconfig ARM64_CRYPTO | |
4 | bool "ARM64 Accelerated Cryptographic Algorithms" | |
5 | depends on ARM64 | |
6 | help | |
7 | Say Y here to choose from a selection of cryptographic algorithms | |
8 | implemented using ARM64 specific CPU features or instructions. | |
9 | ||
10 | if ARM64_CRYPTO | |
11 | ||
7918ecef AB |
12 | config CRYPTO_SHA256_ARM64 |
13 | tristate "SHA-224/SHA-256 digest algorithm for arm64" | |
14 | select CRYPTO_HASH | |
15 | ||
16 | config CRYPTO_SHA512_ARM64 | |
17 | tristate "SHA-384/SHA-512 digest algorithm for arm64" | |
18 | select CRYPTO_HASH | |
19 | ||
2c98833a AB |
20 | config CRYPTO_SHA1_ARM64_CE |
21 | tristate "SHA-1 digest algorithm (ARMv8 Crypto Extensions)" | |
0771f323 | 22 | depends on KERNEL_MODE_NEON |
2c98833a | 23 | select CRYPTO_HASH |
0771f323 | 24 | select CRYPTO_SHA1 |
2c98833a | 25 | |
6ba6c74d AB |
26 | config CRYPTO_SHA2_ARM64_CE |
27 | tristate "SHA-224/SHA-256 digest algorithm (ARMv8 Crypto Extensions)" | |
da179331 | 28 | depends on KERNEL_MODE_NEON |
6ba6c74d | 29 | select CRYPTO_HASH |
da179331 | 30 | select CRYPTO_SHA256_ARM64 |
6ba6c74d | 31 | |
bb6c8c46 AB |
32 | config CRYPTO_SHA512_ARM64_CE |
33 | tristate "SHA-384/SHA-512 digest algorithm (ARMv8 Crypto Extensions)" | |
34 | depends on KERNEL_MODE_NEON | |
35 | select CRYPTO_HASH | |
36 | select CRYPTO_SHA512_ARM64 | |
37 | ||
15d5910e AB |
38 | config CRYPTO_SHA3_ARM64 |
39 | tristate "SHA3 digest algorithm (ARMv8.2 Crypto Extensions)" | |
40 | depends on KERNEL_MODE_NEON | |
41 | select CRYPTO_HASH | |
42 | select CRYPTO_SHA3 | |
43 | ||
140aa50d AB |
44 | config CRYPTO_SM3_ARM64_CE |
45 | tristate "SM3 digest algorithm (ARMv8.2 Crypto Extensions)" | |
46 | depends on KERNEL_MODE_NEON | |
47 | select CRYPTO_HASH | |
48 | select CRYPTO_SM3 | |
49 | ||
e99ce921 AB |
50 | config CRYPTO_SM4_ARM64_CE |
51 | tristate "SM4 symmetric cipher (ARMv8.2 Crypto Extensions)" | |
52 | depends on KERNEL_MODE_NEON | |
53 | select CRYPTO_ALGAPI | |
54 | select CRYPTO_SM4 | |
55 | ||
fdd23894 | 56 | config CRYPTO_GHASH_ARM64_CE |
537c1445 | 57 | tristate "GHASH/AES-GCM using ARMv8 Crypto Extensions" |
6d6254d7 | 58 | depends on KERNEL_MODE_NEON |
fdd23894 | 59 | select CRYPTO_HASH |
6d6254d7 | 60 | select CRYPTO_GF128MUL |
fe3b99b6 | 61 | select CRYPTO_LIB_AES |
fdd23894 | 62 | |
6ef5737f AB |
63 | config CRYPTO_CRCT10DIF_ARM64_CE |
64 | tristate "CRCT10DIF digest algorithm using PMULL instructions" | |
65 | depends on KERNEL_MODE_NEON && CRC_T10DIF | |
66 | select CRYPTO_HASH | |
67 | ||
bed593c0 AB |
68 | config CRYPTO_AES_ARM64 |
69 | tristate "AES core cipher using scalar instructions" | |
70 | select CRYPTO_AES | |
71 | ||
317f2f75 AB |
72 | config CRYPTO_AES_ARM64_CE |
73 | tristate "AES core cipher using ARMv8 Crypto Extensions" | |
74 | depends on ARM64 && KERNEL_MODE_NEON | |
75 | select CRYPTO_ALGAPI | |
4d3f9d89 | 76 | select CRYPTO_LIB_AES |
317f2f75 | 77 | |
a3fd8210 AB |
78 | config CRYPTO_AES_ARM64_CE_CCM |
79 | tristate "AES in CCM mode using ARMv8 Crypto Extensions" | |
80 | depends on ARM64 && KERNEL_MODE_NEON | |
81 | select CRYPTO_ALGAPI | |
12ac3efe | 82 | select CRYPTO_AES_ARM64_CE |
a3fd8210 | 83 | select CRYPTO_AEAD |
c59a6dff | 84 | select CRYPTO_LIB_AES |
a3fd8210 | 85 | |
49788fe2 AB |
86 | config CRYPTO_AES_ARM64_CE_BLK |
87 | tristate "AES in ECB/CBC/CTR/XTS modes using ARMv8 Crypto Extensions" | |
e2115069 | 88 | depends on KERNEL_MODE_NEON |
b95bba5d | 89 | select CRYPTO_SKCIPHER |
12ac3efe | 90 | select CRYPTO_AES_ARM64_CE |
e2115069 | 91 | select CRYPTO_AES_ARM64 |
585b5fa6 | 92 | select CRYPTO_SIMD |
49788fe2 AB |
93 | |
94 | config CRYPTO_AES_ARM64_NEON_BLK | |
95 | tristate "AES in ECB/CBC/CTR/XTS modes using NEON instructions" | |
e2115069 | 96 | depends on KERNEL_MODE_NEON |
b95bba5d | 97 | select CRYPTO_SKCIPHER |
e2115069 | 98 | select CRYPTO_AES_ARM64 |
c1844729 | 99 | select CRYPTO_LIB_AES |
585b5fa6 | 100 | select CRYPTO_SIMD |
49788fe2 | 101 | |
b7171ce9 | 102 | config CRYPTO_CHACHA20_NEON |
19c11c97 | 103 | tristate "ChaCha20, XChaCha20, and XChaCha12 stream ciphers using NEON instructions" |
b7171ce9 | 104 | depends on KERNEL_MODE_NEON |
b95bba5d | 105 | select CRYPTO_SKCIPHER |
c77da486 | 106 | select CRYPTO_LIB_CHACHA_GENERIC |
b3aad5ba | 107 | select CRYPTO_ARCH_HAVE_LIB_CHACHA |
b7171ce9 | 108 | |
f569ca16 AB |
109 | config CRYPTO_POLY1305_NEON |
110 | tristate "Poly1305 hash function using scalar or NEON instructions" | |
111 | depends on KERNEL_MODE_NEON | |
112 | select CRYPTO_HASH | |
113 | select CRYPTO_ARCH_HAVE_LIB_POLY1305 | |
114 | ||
a00fa0c8 EB |
115 | config CRYPTO_NHPOLY1305_NEON |
116 | tristate "NHPoly1305 hash function using NEON instructions (for Adiantum)" | |
117 | depends on KERNEL_MODE_NEON | |
118 | select CRYPTO_NHPOLY1305 | |
119 | ||
1abee99e AB |
120 | config CRYPTO_AES_ARM64_BS |
121 | tristate "AES in ECB/CBC/CTR/XTS modes using bit-sliced NEON algorithm" | |
122 | depends on KERNEL_MODE_NEON | |
b95bba5d | 123 | select CRYPTO_SKCIPHER |
12fcd923 | 124 | select CRYPTO_AES_ARM64_NEON_BLK |
ec808bbe | 125 | select CRYPTO_AES_ARM64 |
f68df543 | 126 | select CRYPTO_LIB_AES |
1abee99e AB |
127 | select CRYPTO_SIMD |
128 | ||
2c98833a | 129 | endif |