Merge branch 'regulator-4.18' into regulator-linus
[sfrench/cifs-2.6.git] / arch / arm64 / crypto / Kconfig
1 # SPDX-License-Identifier: GPL-2.0
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
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
20 config CRYPTO_SHA1_ARM64_CE
21         tristate "SHA-1 digest algorithm (ARMv8 Crypto Extensions)"
22         depends on KERNEL_MODE_NEON
23         select CRYPTO_HASH
24         select CRYPTO_SHA1
25
26 config CRYPTO_SHA2_ARM64_CE
27         tristate "SHA-224/SHA-256 digest algorithm (ARMv8 Crypto Extensions)"
28         depends on KERNEL_MODE_NEON
29         select CRYPTO_HASH
30         select CRYPTO_SHA256_ARM64
31
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
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
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
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
56 config CRYPTO_GHASH_ARM64_CE
57         tristate "GHASH/AES-GCM using ARMv8 Crypto Extensions"
58         depends on KERNEL_MODE_NEON
59         select CRYPTO_HASH
60         select CRYPTO_GF128MUL
61         select CRYPTO_AES
62         select CRYPTO_AES_ARM64
63
64 config CRYPTO_CRCT10DIF_ARM64_CE
65         tristate "CRCT10DIF digest algorithm using PMULL instructions"
66         depends on KERNEL_MODE_NEON && CRC_T10DIF
67         select CRYPTO_HASH
68
69 config CRYPTO_CRC32_ARM64_CE
70         tristate "CRC32 and CRC32C digest algorithms using ARMv8 extensions"
71         depends on CRC32
72         select CRYPTO_HASH
73
74 config CRYPTO_AES_ARM64
75         tristate "AES core cipher using scalar instructions"
76         select CRYPTO_AES
77
78 config CRYPTO_AES_ARM64_CE
79         tristate "AES core cipher using ARMv8 Crypto Extensions"
80         depends on ARM64 && KERNEL_MODE_NEON
81         select CRYPTO_ALGAPI
82         select CRYPTO_AES_ARM64
83
84 config CRYPTO_AES_ARM64_CE_CCM
85         tristate "AES in CCM mode using ARMv8 Crypto Extensions"
86         depends on ARM64 && KERNEL_MODE_NEON
87         select CRYPTO_ALGAPI
88         select CRYPTO_AES_ARM64_CE
89         select CRYPTO_AES_ARM64
90         select CRYPTO_AEAD
91
92 config CRYPTO_AES_ARM64_CE_BLK
93         tristate "AES in ECB/CBC/CTR/XTS modes using ARMv8 Crypto Extensions"
94         depends on KERNEL_MODE_NEON
95         select CRYPTO_BLKCIPHER
96         select CRYPTO_AES_ARM64_CE
97         select CRYPTO_AES_ARM64
98         select CRYPTO_SIMD
99
100 config CRYPTO_AES_ARM64_NEON_BLK
101         tristate "AES in ECB/CBC/CTR/XTS modes using NEON instructions"
102         depends on KERNEL_MODE_NEON
103         select CRYPTO_BLKCIPHER
104         select CRYPTO_AES_ARM64
105         select CRYPTO_AES
106         select CRYPTO_SIMD
107
108 config CRYPTO_CHACHA20_NEON
109         tristate "NEON accelerated ChaCha20 symmetric cipher"
110         depends on KERNEL_MODE_NEON
111         select CRYPTO_BLKCIPHER
112         select CRYPTO_CHACHA20
113
114 config CRYPTO_AES_ARM64_BS
115         tristate "AES in ECB/CBC/CTR/XTS modes using bit-sliced NEON algorithm"
116         depends on KERNEL_MODE_NEON
117         select CRYPTO_BLKCIPHER
118         select CRYPTO_AES_ARM64_NEON_BLK
119         select CRYPTO_AES_ARM64
120         select CRYPTO_SIMD
121
122 config CRYPTO_SPECK_NEON
123         tristate "NEON accelerated Speck cipher algorithms"
124         depends on KERNEL_MODE_NEON
125         select CRYPTO_BLKCIPHER
126         select CRYPTO_SPECK
127
128 endif