blob: 9c86f704515761c47bbafc579827651b2810cf9b [file] [log] [blame]
Greg Kroah-Hartmanb2441312017-11-01 15:07:57 +01001# SPDX-License-Identifier: GPL-2.0
Linus Torvalds1da177e2005-04-16 15:20:36 -07002#
Dan Williams685784a2007-07-09 11:56:42 -07003# Generic algorithms support
4#
5config XOR_BLOCKS
6 tristate
7
8#
Dan Williams9bc89cd2007-01-02 11:10:44 -07009# async_tx api: hardware offloaded memory transfer/transform support
10#
11source "crypto/async_tx/Kconfig"
12
13#
Linus Torvalds1da177e2005-04-16 15:20:36 -070014# Cryptographic API Configuration
15#
Jan Engelhardt2e290f42007-05-18 15:11:01 +100016menuconfig CRYPTO
Sebastian Siewiorc3715cb92008-03-30 16:36:09 +080017 tristate "Cryptographic API"
Eric Biggers7033b932022-07-25 11:36:34 -070018 select CRYPTO_LIB_UTILS
Linus Torvalds1da177e2005-04-16 15:20:36 -070019 help
20 This option provides the core Cryptographic API.
21
Herbert Xucce9e062006-08-21 21:08:13 +100022if CRYPTO
23
Robert Elliottf1f142a2022-08-20 13:41:44 -050024menu "Crypto core or helper"
Sebastian Siewior584fffc2008-04-05 21:04:48 +080025
Neil Hormanccb778e2008-08-05 14:13:08 +080026config CRYPTO_FIPS
27 bool "FIPS 200 compliance"
Herbert Xuf2c89a12014-07-04 22:15:08 +080028 depends on (CRYPTO_ANSI_CPRNG || CRYPTO_DRBG) && !CRYPTO_MANAGER_DISABLE_TESTS
Alec Ari1f696092016-10-04 19:34:30 -030029 depends on (MODULE_SIG || !MODULES)
Neil Hormanccb778e2008-08-05 14:13:08 +080030 help
Geert Uytterhoevend99324c2019-03-20 11:41:03 +010031 This option enables the fips boot option which is
32 required if you want the system to operate in a FIPS 200
Neil Hormanccb778e2008-08-05 14:13:08 +080033 certification. You should say no unless you know what
Chuck Ebberte84c5482010-09-03 19:17:49 +080034 this is.
Neil Hormanccb778e2008-08-05 14:13:08 +080035
Vladis Dronov5a447492022-07-08 14:33:13 +020036config CRYPTO_FIPS_NAME
37 string "FIPS Module Name"
38 default "Linux Kernel Cryptographic API"
39 depends on CRYPTO_FIPS
40 help
41 This option sets the FIPS Module name reported by the Crypto API via
42 the /proc/sys/crypto/fips_name file.
43
44config CRYPTO_FIPS_CUSTOM_VERSION
45 bool "Use Custom FIPS Module Version"
46 depends on CRYPTO_FIPS
47 default n
48
49config CRYPTO_FIPS_VERSION
50 string "FIPS Module Version"
51 default "(none)"
52 depends on CRYPTO_FIPS_CUSTOM_VERSION
53 help
54 This option provides the ability to override the FIPS Module Version.
55 By default the KERNELRELEASE value is used.
56
Herbert Xucce9e062006-08-21 21:08:13 +100057config CRYPTO_ALGAPI
58 tristate
Herbert Xu6a0fcbb2008-12-10 23:29:44 +110059 select CRYPTO_ALGAPI2
Herbert Xucce9e062006-08-21 21:08:13 +100060 help
61 This option provides the API for cryptographic algorithms.
62
Herbert Xu6a0fcbb2008-12-10 23:29:44 +110063config CRYPTO_ALGAPI2
64 tristate
65
Herbert Xu1ae97822007-08-30 15:36:14 +080066config CRYPTO_AEAD
67 tristate
Herbert Xu6a0fcbb2008-12-10 23:29:44 +110068 select CRYPTO_AEAD2
Herbert Xu1ae97822007-08-30 15:36:14 +080069 select CRYPTO_ALGAPI
70
Herbert Xu6a0fcbb2008-12-10 23:29:44 +110071config CRYPTO_AEAD2
72 tristate
73 select CRYPTO_ALGAPI2
Herbert Xu149a3972015-08-13 17:28:58 +080074 select CRYPTO_NULL2
75 select CRYPTO_RNG2
Herbert Xu6a0fcbb2008-12-10 23:29:44 +110076
Eric Biggersb95bba52019-10-25 12:41:13 -070077config CRYPTO_SKCIPHER
Herbert Xu5cde0af2006-08-22 00:07:53 +100078 tristate
Eric Biggersb95bba52019-10-25 12:41:13 -070079 select CRYPTO_SKCIPHER2
Herbert Xu5cde0af2006-08-22 00:07:53 +100080 select CRYPTO_ALGAPI
Herbert Xu6a0fcbb2008-12-10 23:29:44 +110081
Eric Biggersb95bba52019-10-25 12:41:13 -070082config CRYPTO_SKCIPHER2
Herbert Xu6a0fcbb2008-12-10 23:29:44 +110083 tristate
84 select CRYPTO_ALGAPI2
85 select CRYPTO_RNG2
Herbert Xu5cde0af2006-08-22 00:07:53 +100086
Herbert Xu055bcee2006-08-19 22:24:23 +100087config CRYPTO_HASH
88 tristate
Herbert Xu6a0fcbb2008-12-10 23:29:44 +110089 select CRYPTO_HASH2
Herbert Xu055bcee2006-08-19 22:24:23 +100090 select CRYPTO_ALGAPI
91
Herbert Xu6a0fcbb2008-12-10 23:29:44 +110092config CRYPTO_HASH2
93 tristate
94 select CRYPTO_ALGAPI2
95
Neil Horman17f0f4a2008-08-14 22:15:52 +100096config CRYPTO_RNG
97 tristate
Herbert Xu6a0fcbb2008-12-10 23:29:44 +110098 select CRYPTO_RNG2
Neil Horman17f0f4a2008-08-14 22:15:52 +100099 select CRYPTO_ALGAPI
100
Herbert Xu6a0fcbb2008-12-10 23:29:44 +1100101config CRYPTO_RNG2
102 tristate
103 select CRYPTO_ALGAPI2
104
Herbert Xu401e4232015-06-03 14:49:31 +0800105config CRYPTO_RNG_DEFAULT
106 tristate
107 select CRYPTO_DRBG_MENU
108
Tadeusz Struk3c339ab2015-06-16 10:30:55 -0700109config CRYPTO_AKCIPHER2
110 tristate
111 select CRYPTO_ALGAPI2
112
113config CRYPTO_AKCIPHER
114 tristate
115 select CRYPTO_AKCIPHER2
116 select CRYPTO_ALGAPI
117
Salvatore Benedetto4e5f2c42016-06-22 17:49:13 +0100118config CRYPTO_KPP2
119 tristate
120 select CRYPTO_ALGAPI2
121
122config CRYPTO_KPP
123 tristate
124 select CRYPTO_ALGAPI
125 select CRYPTO_KPP2
126
Giovanni Cabiddu2ebda742016-10-21 13:19:47 +0100127config CRYPTO_ACOMP2
128 tristate
129 select CRYPTO_ALGAPI2
Bart Van Assche8cd579d2018-01-05 08:26:47 -0800130 select SGL_ALLOC
Giovanni Cabiddu2ebda742016-10-21 13:19:47 +0100131
132config CRYPTO_ACOMP
133 tristate
134 select CRYPTO_ALGAPI
135 select CRYPTO_ACOMP2
136
Herbert Xu2b8c19d2006-09-21 11:31:44 +1000137config CRYPTO_MANAGER
138 tristate "Cryptographic algorithm manager"
Herbert Xu6a0fcbb2008-12-10 23:29:44 +1100139 select CRYPTO_MANAGER2
Herbert Xu2b8c19d2006-09-21 11:31:44 +1000140 help
141 Create default cryptographic template instantiations such as
142 cbc(aes).
143
Herbert Xu6a0fcbb2008-12-10 23:29:44 +1100144config CRYPTO_MANAGER2
145 def_tristate CRYPTO_MANAGER || (CRYPTO_MANAGER!=n && CRYPTO_ALGAPI=y)
146 select CRYPTO_AEAD2
147 select CRYPTO_HASH2
Eric Biggersb95bba52019-10-25 12:41:13 -0700148 select CRYPTO_SKCIPHER2
Tadeusz Struk946cc462015-06-16 10:31:06 -0700149 select CRYPTO_AKCIPHER2
Salvatore Benedetto4e5f2c42016-06-22 17:49:13 +0100150 select CRYPTO_KPP2
Giovanni Cabiddu2ebda742016-10-21 13:19:47 +0100151 select CRYPTO_ACOMP2
Herbert Xu6a0fcbb2008-12-10 23:29:44 +1100152
Steffen Klasserta38f7902011-09-27 07:23:50 +0200153config CRYPTO_USER
154 tristate "Userspace cryptographic algorithm configuration"
Herbert Xu5db017a2011-11-01 12:12:43 +1100155 depends on NET
Steffen Klasserta38f7902011-09-27 07:23:50 +0200156 select CRYPTO_MANAGER
157 help
Valdis.Kletnieks@vt.edud19978f2011-11-09 01:29:20 -0500158 Userspace configuration for cryptographic instantiations such as
Steffen Klasserta38f7902011-09-27 07:23:50 +0200159 cbc(aes).
160
Herbert Xu326a6342010-08-06 09:40:28 +0800161config CRYPTO_MANAGER_DISABLE_TESTS
162 bool "Disable run-time self tests"
Herbert Xu00ca28a2010-08-06 10:34:00 +0800163 default y
Alexander Shishkin0b767f92010-06-03 20:53:43 +1000164 help
Herbert Xu326a6342010-08-06 09:40:28 +0800165 Disable run-time self tests that normally take place at
166 algorithm registration.
Alexander Shishkin0b767f92010-06-03 20:53:43 +1000167
Eric Biggers5b2706a2019-01-31 23:51:44 -0800168config CRYPTO_MANAGER_EXTRA_TESTS
169 bool "Enable extra run-time crypto self tests"
Jason A. Donenfeld6569e302020-11-02 14:48:15 +0100170 depends on DEBUG_KERNEL && !CRYPTO_MANAGER_DISABLE_TESTS && CRYPTO_MANAGER
Eric Biggers5b2706a2019-01-31 23:51:44 -0800171 help
172 Enable extra run-time self tests of registered crypto algorithms,
173 including randomized fuzz tests.
174
175 This is intended for developer use only, as these tests take much
176 longer to run than the normal self tests.
177
Sebastian Siewior584fffc2008-04-05 21:04:48 +0800178config CRYPTO_NULL
179 tristate "Null algorithms"
Herbert Xu149a3972015-08-13 17:28:58 +0800180 select CRYPTO_NULL2
Sebastian Siewior584fffc2008-04-05 21:04:48 +0800181 help
182 These are 'Null' algorithms, used by IPsec, which do nothing.
183
Herbert Xu149a3972015-08-13 17:28:58 +0800184config CRYPTO_NULL2
Herbert Xudd43c4e2015-08-17 20:39:40 +0800185 tristate
Herbert Xu149a3972015-08-13 17:28:58 +0800186 select CRYPTO_ALGAPI2
Eric Biggersb95bba52019-10-25 12:41:13 -0700187 select CRYPTO_SKCIPHER2
Herbert Xu149a3972015-08-13 17:28:58 +0800188 select CRYPTO_HASH2
189
Steffen Klassert5068c7a2010-01-07 15:57:19 +1100190config CRYPTO_PCRYPT
Kees Cook3b4afaf2012-10-02 11:16:49 -0700191 tristate "Parallel crypto engine"
192 depends on SMP
Steffen Klassert5068c7a2010-01-07 15:57:19 +1100193 select PADATA
194 select CRYPTO_MANAGER
195 select CRYPTO_AEAD
196 help
197 This converts an arbitrary crypto algorithm into a parallel
198 algorithm that executes in kernel threads.
199
Sebastian Siewior584fffc2008-04-05 21:04:48 +0800200config CRYPTO_CRYPTD
201 tristate "Software async crypto daemon"
Eric Biggersb95bba52019-10-25 12:41:13 -0700202 select CRYPTO_SKCIPHER
Loc Hob8a28252008-05-14 21:23:00 +0800203 select CRYPTO_HASH
Herbert Xu43518402006-10-16 21:28:58 +1000204 select CRYPTO_MANAGER
Herbert Xudb131ef2006-09-21 11:44:08 +1000205 help
Sebastian Siewior584fffc2008-04-05 21:04:48 +0800206 This is a generic software asynchronous crypto daemon that
207 converts an arbitrary synchronous software crypto algorithm
208 into an asynchronous algorithm that executes in a kernel thread.
209
210config CRYPTO_AUTHENC
211 tristate "Authenc support"
212 select CRYPTO_AEAD
Eric Biggersb95bba52019-10-25 12:41:13 -0700213 select CRYPTO_SKCIPHER
Sebastian Siewior584fffc2008-04-05 21:04:48 +0800214 select CRYPTO_MANAGER
215 select CRYPTO_HASH
Herbert Xue94c6a72015-08-04 21:23:14 +0800216 select CRYPTO_NULL
Sebastian Siewior584fffc2008-04-05 21:04:48 +0800217 help
218 Authenc: Combined mode wrapper for IPsec.
Robert Elliottcf514b22022-08-20 13:41:50 -0500219
220 This is required for IPSec ESP (XFRM_ESP).
Sebastian Siewior584fffc2008-04-05 21:04:48 +0800221
222config CRYPTO_TEST
223 tristate "Testing module"
Ard Biesheuvel00ea27f2020-11-20 12:04:32 +0100224 depends on m || EXPERT
Herbert Xuda7f0332008-07-31 17:08:25 +0800225 select CRYPTO_MANAGER
Sebastian Siewior584fffc2008-04-05 21:04:48 +0800226 help
227 Quick & dirty crypto test module.
228
Herbert Xu266d0512016-11-22 20:08:25 +0800229config CRYPTO_SIMD
230 tristate
231 select CRYPTO_CRYPTD
232
Baolin Wang735d37b2016-01-26 20:25:39 +0800233config CRYPTO_ENGINE
234 tristate
235
Robert Elliottf1f142a2022-08-20 13:41:44 -0500236endmenu
237
238menu "Public-key cryptography"
Vitaly Chikunov3d6228a52019-04-11 18:51:18 +0300239
240config CRYPTO_RSA
Robert Elliott05b37462022-08-20 13:41:45 -0500241 tristate "RSA (Rivest-Shamir-Adleman)"
Vitaly Chikunov3d6228a52019-04-11 18:51:18 +0300242 select CRYPTO_AKCIPHER
243 select CRYPTO_MANAGER
244 select MPILIB
245 select ASN1
246 help
Robert Elliott05b37462022-08-20 13:41:45 -0500247 RSA (Rivest-Shamir-Adleman) public key algorithm (RFC8017)
Vitaly Chikunov3d6228a52019-04-11 18:51:18 +0300248
249config CRYPTO_DH
Robert Elliott05b37462022-08-20 13:41:45 -0500250 tristate "DH (Diffie-Hellman)"
Vitaly Chikunov3d6228a52019-04-11 18:51:18 +0300251 select CRYPTO_KPP
252 select MPILIB
253 help
Robert Elliott05b37462022-08-20 13:41:45 -0500254 DH (Diffie-Hellman) key exchange algorithm
Vitaly Chikunov3d6228a52019-04-11 18:51:18 +0300255
Nicolai Stange7dce5982022-02-21 13:10:53 +0100256config CRYPTO_DH_RFC7919_GROUPS
Robert Elliott05b37462022-08-20 13:41:45 -0500257 bool "RFC 7919 FFDHE groups"
Nicolai Stange7dce5982022-02-21 13:10:53 +0100258 depends on CRYPTO_DH
Nicolai Stange1e207962022-02-21 13:10:55 +0100259 select CRYPTO_RNG_DEFAULT
Nicolai Stange7dce5982022-02-21 13:10:53 +0100260 help
Robert Elliott05b37462022-08-20 13:41:45 -0500261 FFDHE (Finite-Field-based Diffie-Hellman Ephemeral) groups
262 defined in RFC7919.
263
264 Support these finite-field groups in DH key exchanges:
265 - ffdhe2048, ffdhe3072, ffdhe4096, ffdhe6144, ffdhe8192
266
267 If unsure, say N.
Nicolai Stange7dce5982022-02-21 13:10:53 +0100268
Vitaly Chikunov4a2289d2019-04-11 18:51:19 +0300269config CRYPTO_ECC
270 tristate
Arnd Bergmann38aa1922021-09-20 12:05:35 +0200271 select CRYPTO_RNG_DEFAULT
Vitaly Chikunov4a2289d2019-04-11 18:51:19 +0300272
Vitaly Chikunov3d6228a52019-04-11 18:51:18 +0300273config CRYPTO_ECDH
Robert Elliott05b37462022-08-20 13:41:45 -0500274 tristate "ECDH (Elliptic Curve Diffie-Hellman)"
Vitaly Chikunov4a2289d2019-04-11 18:51:19 +0300275 select CRYPTO_ECC
Vitaly Chikunov3d6228a52019-04-11 18:51:18 +0300276 select CRYPTO_KPP
Vitaly Chikunov3d6228a52019-04-11 18:51:18 +0300277 help
Robert Elliott05b37462022-08-20 13:41:45 -0500278 ECDH (Elliptic Curve Diffie-Hellman) key exchange algorithm
279 using curves P-192, P-256, and P-384 (FIPS 186)
Vitaly Chikunov3d6228a52019-04-11 18:51:18 +0300280
Stefan Berger4e660292021-03-16 17:07:32 -0400281config CRYPTO_ECDSA
Robert Elliott05b37462022-08-20 13:41:45 -0500282 tristate "ECDSA (Elliptic Curve Digital Signature Algorithm)"
Stefan Berger4e660292021-03-16 17:07:32 -0400283 select CRYPTO_ECC
284 select CRYPTO_AKCIPHER
285 select ASN1
286 help
Robert Elliott05b37462022-08-20 13:41:45 -0500287 ECDSA (Elliptic Curve Digital Signature Algorithm) (FIPS 186,
288 ISO/IEC 14888-3)
289 using curves P-192, P-256, and P-384
290
291 Only signature verification is implemented.
Stefan Berger4e660292021-03-16 17:07:32 -0400292
Vitaly Chikunov0d7a7862019-04-11 18:51:20 +0300293config CRYPTO_ECRDSA
Robert Elliott05b37462022-08-20 13:41:45 -0500294 tristate "EC-RDSA (Elliptic Curve Russian Digital Signature Algorithm)"
Vitaly Chikunov0d7a7862019-04-11 18:51:20 +0300295 select CRYPTO_ECC
296 select CRYPTO_AKCIPHER
297 select CRYPTO_STREEBOG
Vitaly Chikunov10366332019-04-24 04:32:40 +0300298 select OID_REGISTRY
299 select ASN1
Vitaly Chikunov0d7a7862019-04-11 18:51:20 +0300300 help
301 Elliptic Curve Russian Digital Signature Algorithm (GOST R 34.10-2012,
Robert Elliott05b37462022-08-20 13:41:45 -0500302 RFC 7091, ISO/IEC 14888-3)
303
304 One of the Russian cryptographic standard algorithms (called GOST
305 algorithms). Only signature verification is implemented.
Vitaly Chikunov0d7a7862019-04-11 18:51:20 +0300306
Tianjia Zhangea7ecb62020-09-21 00:20:57 +0800307config CRYPTO_SM2
Robert Elliott05b37462022-08-20 13:41:45 -0500308 tristate "SM2 (ShangMi 2)"
Jason A. Donenfeldd2825fa2022-03-13 21:11:01 -0600309 select CRYPTO_SM3
Tianjia Zhangea7ecb62020-09-21 00:20:57 +0800310 select CRYPTO_AKCIPHER
311 select CRYPTO_MANAGER
312 select MPILIB
313 select ASN1
314 help
Robert Elliott05b37462022-08-20 13:41:45 -0500315 SM2 (ShangMi 2) public key algorithm
316
317 Published by State Encryption Management Bureau, China,
Tianjia Zhangea7ecb62020-09-21 00:20:57 +0800318 as specified by OSCCA GM/T 0003.1-2012 -- 0003.5-2012.
319
320 References:
Robert Elliott05b37462022-08-20 13:41:45 -0500321 https://datatracker.ietf.org/doc/draft-shen-sm2-ecdsa/
Tianjia Zhangea7ecb62020-09-21 00:20:57 +0800322 http://www.oscca.gov.cn/sca/xxgk/2010-12/17/content_1002386.shtml
323 http://www.gmbz.org.cn/main/bzlb.html
324
Ard Biesheuvelee772cb2019-11-08 13:22:34 +0100325config CRYPTO_CURVE25519
Robert Elliott05b37462022-08-20 13:41:45 -0500326 tristate "Curve25519"
Ard Biesheuvelee772cb2019-11-08 13:22:34 +0100327 select CRYPTO_KPP
328 select CRYPTO_LIB_CURVE25519_GENERIC
Robert Elliott05b37462022-08-20 13:41:45 -0500329 help
330 Curve25519 elliptic curve (RFC7748)
Ard Biesheuvelee772cb2019-11-08 13:22:34 +0100331
Robert Elliottf1f142a2022-08-20 13:41:44 -0500332endmenu
Sebastian Siewior584fffc2008-04-05 21:04:48 +0800333
Robert Elliottf1f142a2022-08-20 13:41:44 -0500334menu "Block ciphers"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700335
336config CRYPTO_AES
Robert Elliottcf514b22022-08-20 13:41:50 -0500337 tristate "AES (Advanced Encryption Standard)"
Herbert Xucce9e062006-08-21 21:08:13 +1000338 select CRYPTO_ALGAPI
Ard Biesheuvel5bb12d72019-07-02 21:41:33 +0200339 select CRYPTO_LIB_AES
Linus Torvalds1da177e2005-04-16 15:20:36 -0700340 help
Robert Elliottcf514b22022-08-20 13:41:50 -0500341 AES cipher algorithms (Rijndael)(FIPS-197, ISO/IEC 18033-3)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700342
343 Rijndael appears to be consistently a very good performer in
Sebastian Siewior584fffc2008-04-05 21:04:48 +0800344 both hardware and software across a wide range of computing
345 environments regardless of its use in feedback or non-feedback
346 modes. Its key setup time is excellent, and its key agility is
347 good. Rijndael's very low memory requirements make it very well
348 suited for restricted-space environments, in which it also
349 demonstrates excellent performance. Rijndael's operations are
350 among the easiest to defend against power and timing attacks.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700351
Sebastian Siewior584fffc2008-04-05 21:04:48 +0800352 The AES specifies three key sizes: 128, 192 and 256 bits
Linus Torvalds1da177e2005-04-16 15:20:36 -0700353
Ard Biesheuvelb5e0b032017-02-02 16:37:40 +0000354config CRYPTO_AES_TI
Robert Elliottcf514b22022-08-20 13:41:50 -0500355 tristate "AES (Advanced Encryption Standard) (fixed time)"
Ard Biesheuvelb5e0b032017-02-02 16:37:40 +0000356 select CRYPTO_ALGAPI
Ard Biesheuvele59c1c92019-07-02 21:41:22 +0200357 select CRYPTO_LIB_AES
Ard Biesheuvelb5e0b032017-02-02 16:37:40 +0000358 help
Robert Elliottcf514b22022-08-20 13:41:50 -0500359 AES cipher algorithms (Rijndael)(FIPS-197, ISO/IEC 18033-3)
360
Ard Biesheuvelb5e0b032017-02-02 16:37:40 +0000361 This is a generic implementation of AES that attempts to eliminate
362 data dependent latencies as much as possible without affecting
363 performance too much. It is intended for use by the generic CCM
364 and GCM drivers, and other CTR or CMAC/XCBC based modes that rely
365 solely on encryption (although decryption is supported as well, but
366 with a more dramatic performance hit)
367
368 Instead of using 16 lookup tables of 1 KB each, (8 for encryption and
369 8 for decryption), this implementation only uses just two S-boxes of
370 256 bytes each, and attempts to eliminate data dependent latencies by
371 prefetching the entire table into the cache at the start of each
Eric Biggers0a6a40c2018-10-17 21:37:58 -0700372 block. Interrupts are also disabled to avoid races where cachelines
373 are evicted when the CPU is interrupted to do something else.
Ard Biesheuvelb5e0b032017-02-02 16:37:40 +0000374
Sebastian Siewior584fffc2008-04-05 21:04:48 +0800375config CRYPTO_ANUBIS
Robert Elliottcf514b22022-08-20 13:41:50 -0500376 tristate "Anubis"
Ard Biesheuvel1674aea2020-09-11 17:11:03 +0300377 depends on CRYPTO_USER_API_ENABLE_OBSOLETE
Sebastian Siewior584fffc2008-04-05 21:04:48 +0800378 select CRYPTO_ALGAPI
379 help
Robert Elliottcf514b22022-08-20 13:41:50 -0500380 Anubis cipher algorithm
Sebastian Siewior584fffc2008-04-05 21:04:48 +0800381
382 Anubis is a variable key length cipher which can use keys from
383 128 bits to 320 bits in length. It was evaluated as a entrant
384 in the NESSIE competition.
385
Robert Elliottcf514b22022-08-20 13:41:50 -0500386 See https://web.archive.org/web/20160606112246/http://www.larc.usp.br/~pbarreto/AnubisPage.html
387 for further information.
Sebastian Siewior584fffc2008-04-05 21:04:48 +0800388
Robert Elliottf1f142a2022-08-20 13:41:44 -0500389config CRYPTO_ARIA
Robert Elliottcf514b22022-08-20 13:41:50 -0500390 tristate "ARIA"
Robert Elliottf1f142a2022-08-20 13:41:44 -0500391 select CRYPTO_ALGAPI
Sebastian Siewior584fffc2008-04-05 21:04:48 +0800392 help
Robert Elliottcf514b22022-08-20 13:41:50 -0500393 ARIA cipher algorithm (RFC5794)
Sebastian Siewior584fffc2008-04-05 21:04:48 +0800394
Robert Elliottf1f142a2022-08-20 13:41:44 -0500395 ARIA is a standard encryption algorithm of the Republic of Korea.
396 The ARIA specifies three key sizes and rounds.
397 128-bit: 12 rounds.
398 192-bit: 14 rounds.
399 256-bit: 16 rounds.
400
Robert Elliottcf514b22022-08-20 13:41:50 -0500401 See:
402 https://seed.kisa.or.kr/kisa/algorithm/EgovAriaInfo.do
Sebastian Siewior584fffc2008-04-05 21:04:48 +0800403
404config CRYPTO_BLOWFISH
Robert Elliottcf514b22022-08-20 13:41:50 -0500405 tristate "Blowfish"
Sebastian Siewior584fffc2008-04-05 21:04:48 +0800406 select CRYPTO_ALGAPI
Jussi Kivilinna52ba8672011-09-02 01:45:07 +0300407 select CRYPTO_BLOWFISH_COMMON
Sebastian Siewior584fffc2008-04-05 21:04:48 +0800408 help
Robert Elliottcf514b22022-08-20 13:41:50 -0500409 Blowfish cipher algorithm, by Bruce Schneier
Sebastian Siewior584fffc2008-04-05 21:04:48 +0800410
411 This is a variable key length cipher which can use keys from 32
412 bits to 448 bits in length. It's fast, simple and specifically
413 designed for use on "large microprocessors".
414
Robert Elliottcf514b22022-08-20 13:41:50 -0500415 See https://www.schneier.com/blowfish.html for further information.
Sebastian Siewior584fffc2008-04-05 21:04:48 +0800416
Jussi Kivilinna52ba8672011-09-02 01:45:07 +0300417config CRYPTO_BLOWFISH_COMMON
418 tristate
419 help
420 Common parts of the Blowfish cipher algorithm shared by the
421 generic c and the assembler implementations.
422
Sebastian Siewior584fffc2008-04-05 21:04:48 +0800423config CRYPTO_CAMELLIA
Robert Elliottcf514b22022-08-20 13:41:50 -0500424 tristate "Camellia"
Sebastian Siewior584fffc2008-04-05 21:04:48 +0800425 select CRYPTO_ALGAPI
426 help
Robert Elliottcf514b22022-08-20 13:41:50 -0500427 Camellia cipher algorithms (ISO/IEC 18033-3)
Sebastian Siewior584fffc2008-04-05 21:04:48 +0800428
429 Camellia is a symmetric key block cipher developed jointly
430 at NTT and Mitsubishi Electric Corporation.
431
432 The Camellia specifies three key sizes: 128, 192 and 256 bits.
433
Robert Elliottcf514b22022-08-20 13:41:50 -0500434 See https://info.isl.ntt.co.jp/crypt/eng/camellia/ for further information.
Sebastian Siewior584fffc2008-04-05 21:04:48 +0800435
Jussi Kivilinna044ab522012-11-13 11:43:14 +0200436config CRYPTO_CAST_COMMON
437 tristate
438 help
439 Common parts of the CAST cipher algorithms shared by the
440 generic c and the assembler implementations.
441
Linus Torvalds1da177e2005-04-16 15:20:36 -0700442config CRYPTO_CAST5
Robert Elliottcf514b22022-08-20 13:41:50 -0500443 tristate "CAST5 (CAST-128)"
Herbert Xucce9e062006-08-21 21:08:13 +1000444 select CRYPTO_ALGAPI
Jussi Kivilinna044ab522012-11-13 11:43:14 +0200445 select CRYPTO_CAST_COMMON
Linus Torvalds1da177e2005-04-16 15:20:36 -0700446 help
Robert Elliottcf514b22022-08-20 13:41:50 -0500447 CAST5 (CAST-128) cipher algorithm (RFC2144, ISO/IEC 18033-3)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700448
449config CRYPTO_CAST6
Robert Elliottcf514b22022-08-20 13:41:50 -0500450 tristate "CAST6 (CAST-256)"
Herbert Xucce9e062006-08-21 21:08:13 +1000451 select CRYPTO_ALGAPI
Jussi Kivilinna044ab522012-11-13 11:43:14 +0200452 select CRYPTO_CAST_COMMON
Linus Torvalds1da177e2005-04-16 15:20:36 -0700453 help
Robert Elliottcf514b22022-08-20 13:41:50 -0500454 CAST6 (CAST-256) encryption algorithm (RFC2612)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700455
Sebastian Siewior584fffc2008-04-05 21:04:48 +0800456config CRYPTO_DES
Robert Elliottcf514b22022-08-20 13:41:50 -0500457 tristate "DES and Triple DES EDE"
Herbert Xucce9e062006-08-21 21:08:13 +1000458 select CRYPTO_ALGAPI
Ard Biesheuvel04007b02019-08-15 12:01:09 +0300459 select CRYPTO_LIB_DES
Linus Torvalds1da177e2005-04-16 15:20:36 -0700460 help
Robert Elliottcf514b22022-08-20 13:41:50 -0500461 DES (Data Encryption Standard)(FIPS 46-2, ISO/IEC 18033-3) and
462 Triple DES EDE (Encrypt/Decrypt/Encrypt) (FIPS 46-3, ISO/IEC 18033-3)
463 cipher algorithms
Linus Torvalds1da177e2005-04-16 15:20:36 -0700464
Sebastian Siewior584fffc2008-04-05 21:04:48 +0800465config CRYPTO_FCRYPT
Robert Elliottcf514b22022-08-20 13:41:50 -0500466 tristate "FCrypt"
Herbert Xucce9e062006-08-21 21:08:13 +1000467 select CRYPTO_ALGAPI
Eric Biggersb95bba52019-10-25 12:41:13 -0700468 select CRYPTO_SKCIPHER
Linus Torvalds1da177e2005-04-16 15:20:36 -0700469 help
Robert Elliottcf514b22022-08-20 13:41:50 -0500470 FCrypt algorithm used by RxRPC
471
472 See https://ota.polyonymo.us/fcrypt-paper.txt
Linus Torvalds1da177e2005-04-16 15:20:36 -0700473
474config CRYPTO_KHAZAD
Robert Elliottcf514b22022-08-20 13:41:50 -0500475 tristate "Khazad"
Ard Biesheuvel1674aea2020-09-11 17:11:03 +0300476 depends on CRYPTO_USER_API_ENABLE_OBSOLETE
Herbert Xucce9e062006-08-21 21:08:13 +1000477 select CRYPTO_ALGAPI
Linus Torvalds1da177e2005-04-16 15:20:36 -0700478 help
Robert Elliottcf514b22022-08-20 13:41:50 -0500479 Khazad cipher algorithm
Linus Torvalds1da177e2005-04-16 15:20:36 -0700480
481 Khazad was a finalist in the initial NESSIE competition. It is
482 an algorithm optimized for 64-bit processors with good performance
483 on 32-bit processors. Khazad uses an 128 bit key size.
484
Robert Elliottcf514b22022-08-20 13:41:50 -0500485 See https://web.archive.org/web/20171011071731/http://www.larc.usp.br/~pbarreto/KhazadPage.html
486 for further information.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700487
Sebastian Siewior584fffc2008-04-05 21:04:48 +0800488config CRYPTO_SEED
Robert Elliottcf514b22022-08-20 13:41:50 -0500489 tristate "SEED"
Ard Biesheuvel1674aea2020-09-11 17:11:03 +0300490 depends on CRYPTO_USER_API_ENABLE_OBSOLETE
Sebastian Siewior584fffc2008-04-05 21:04:48 +0800491 select CRYPTO_ALGAPI
492 help
Robert Elliottcf514b22022-08-20 13:41:50 -0500493 SEED cipher algorithm (RFC4269, ISO/IEC 18033-3)
Sebastian Siewior584fffc2008-04-05 21:04:48 +0800494
495 SEED is a 128-bit symmetric key block cipher that has been
496 developed by KISA (Korea Information Security Agency) as a
497 national standard encryption algorithm of the Republic of Korea.
498 It is a 16 round block cipher with the key size of 128 bit.
499
Robert Elliottcf514b22022-08-20 13:41:50 -0500500 See https://seed.kisa.or.kr/kisa/algorithm/EgovSeedInfo.do
501 for further information.
Sebastian Siewior584fffc2008-04-05 21:04:48 +0800502
503config CRYPTO_SERPENT
Robert Elliottcf514b22022-08-20 13:41:50 -0500504 tristate "Serpent"
Sebastian Siewior584fffc2008-04-05 21:04:48 +0800505 select CRYPTO_ALGAPI
506 help
Robert Elliottcf514b22022-08-20 13:41:50 -0500507 Serpent cipher algorithm, by Anderson, Biham & Knudsen
Sebastian Siewior584fffc2008-04-05 21:04:48 +0800508
509 Keys are allowed to be from 0 to 256 bits in length, in steps
Ard Biesheuvel784506a2021-02-01 19:02:30 +0100510 of 8 bits.
Sebastian Siewior584fffc2008-04-05 21:04:48 +0800511
Robert Elliottcf514b22022-08-20 13:41:50 -0500512 See https://www.cl.cam.ac.uk/~rja14/serpent.html for further information.
Sebastian Siewior584fffc2008-04-05 21:04:48 +0800513
Gilad Ben-Yossef747c8ce2018-03-06 09:44:42 +0000514config CRYPTO_SM4
Jason A. Donenfeldd2825fa2022-03-13 21:11:01 -0600515 tristate
516
517config CRYPTO_SM4_GENERIC
Robert Elliottcf514b22022-08-20 13:41:50 -0500518 tristate "SM4 (ShangMi 4)"
Gilad Ben-Yossef747c8ce2018-03-06 09:44:42 +0000519 select CRYPTO_ALGAPI
Jason A. Donenfeldd2825fa2022-03-13 21:11:01 -0600520 select CRYPTO_SM4
Gilad Ben-Yossef747c8ce2018-03-06 09:44:42 +0000521 help
Robert Elliottcf514b22022-08-20 13:41:50 -0500522 SM4 cipher algorithms (OSCCA GB/T 32907-2016,
523 ISO/IEC 18033-3:2010/Amd 1:2021)
Gilad Ben-Yossef747c8ce2018-03-06 09:44:42 +0000524
525 SM4 (GBT.32907-2016) is a cryptographic standard issued by the
526 Organization of State Commercial Administration of China (OSCCA)
527 as an authorized cryptographic algorithms for the use within China.
528
529 SMS4 was originally created for use in protecting wireless
530 networks, and is mandated in the Chinese National Standard for
531 Wireless LAN WAPI (Wired Authentication and Privacy Infrastructure)
532 (GB.15629.11-2003).
533
534 The latest SM4 standard (GBT.32907-2016) was proposed by OSCCA and
535 standardized through TC 260 of the Standardization Administration
536 of the People's Republic of China (SAC).
537
538 The input, output, and key of SMS4 are each 128 bits.
539
Robert Elliottcf514b22022-08-20 13:41:50 -0500540 See https://eprint.iacr.org/2008/329.pdf for further information.
Gilad Ben-Yossef747c8ce2018-03-06 09:44:42 +0000541
542 If unsure, say N.
543
Sebastian Siewior584fffc2008-04-05 21:04:48 +0800544config CRYPTO_TEA
Robert Elliottcf514b22022-08-20 13:41:50 -0500545 tristate "TEA, XTEA and XETA"
Ard Biesheuvel1674aea2020-09-11 17:11:03 +0300546 depends on CRYPTO_USER_API_ENABLE_OBSOLETE
Sebastian Siewior584fffc2008-04-05 21:04:48 +0800547 select CRYPTO_ALGAPI
548 help
Robert Elliottcf514b22022-08-20 13:41:50 -0500549 TEA (Tiny Encryption Algorithm) cipher algorithms
Sebastian Siewior584fffc2008-04-05 21:04:48 +0800550
551 Tiny Encryption Algorithm is a simple cipher that uses
552 many rounds for security. It is very fast and uses
553 little memory.
554
555 Xtendend Tiny Encryption Algorithm is a modification to
556 the TEA algorithm to address a potential key weakness
557 in the TEA algorithm.
558
559 Xtendend Encryption Tiny Algorithm is a mis-implementation
560 of the XTEA algorithm for compatibility purposes.
561
562config CRYPTO_TWOFISH
Robert Elliottcf514b22022-08-20 13:41:50 -0500563 tristate "Twofish"
Sebastian Siewior584fffc2008-04-05 21:04:48 +0800564 select CRYPTO_ALGAPI
565 select CRYPTO_TWOFISH_COMMON
566 help
Robert Elliottcf514b22022-08-20 13:41:50 -0500567 Twofish cipher algorithm
Sebastian Siewior584fffc2008-04-05 21:04:48 +0800568
569 Twofish was submitted as an AES (Advanced Encryption Standard)
570 candidate cipher by researchers at CounterPane Systems. It is a
571 16 round block cipher supporting key sizes of 128, 192, and 256
572 bits.
573
Robert Elliottcf514b22022-08-20 13:41:50 -0500574 See https://www.schneier.com/twofish.html for further information.
Sebastian Siewior584fffc2008-04-05 21:04:48 +0800575
576config CRYPTO_TWOFISH_COMMON
577 tristate
578 help
579 Common parts of the Twofish cipher algorithm shared by the
580 generic c and the assembler implementations.
581
Robert Elliottf1f142a2022-08-20 13:41:44 -0500582endmenu
583
584menu "Length-preserving ciphers and modes"
585
586config CRYPTO_ADIANTUM
Robert Elliottcf514b22022-08-20 13:41:50 -0500587 tristate "Adiantum"
Robert Elliottf1f142a2022-08-20 13:41:44 -0500588 select CRYPTO_CHACHA20
589 select CRYPTO_LIB_POLY1305_GENERIC
590 select CRYPTO_NHPOLY1305
591 select CRYPTO_MANAGER
592 help
Robert Elliottcf514b22022-08-20 13:41:50 -0500593 Adiantum tweakable, length-preserving encryption mode
594
595 Designed for fast and secure disk encryption, especially on
Robert Elliottf1f142a2022-08-20 13:41:44 -0500596 CPUs without dedicated crypto instructions. It encrypts
597 each sector using the XChaCha12 stream cipher, two passes of
598 an ε-almost-∆-universal hash function, and an invocation of
599 the AES-256 block cipher on a single 16-byte block. On CPUs
600 without AES instructions, Adiantum is much faster than
601 AES-XTS.
602
603 Adiantum's security is provably reducible to that of its
604 underlying stream and block ciphers, subject to a security
605 bound. Unlike XTS, Adiantum is a true wide-block encryption
606 mode, so it actually provides an even stronger notion of
607 security than XTS, subject to the security bound.
608
609 If unsure, say N.
610
611config CRYPTO_ARC4
Robert Elliottcf514b22022-08-20 13:41:50 -0500612 tristate "ARC4 (Alleged Rivest Cipher 4)"
Robert Elliottf1f142a2022-08-20 13:41:44 -0500613 depends on CRYPTO_USER_API_ENABLE_OBSOLETE
614 select CRYPTO_SKCIPHER
615 select CRYPTO_LIB_ARC4
616 help
Robert Elliottcf514b22022-08-20 13:41:50 -0500617 ARC4 cipher algorithm
Robert Elliottf1f142a2022-08-20 13:41:44 -0500618
619 ARC4 is a stream cipher using keys ranging from 8 bits to 2048
620 bits in length. This algorithm is required for driver-based
621 WEP, but it should not be for other purposes because of the
622 weakness of the algorithm.
623
624config CRYPTO_CHACHA20
Robert Elliottcf514b22022-08-20 13:41:50 -0500625 tristate "ChaCha"
Robert Elliottf1f142a2022-08-20 13:41:44 -0500626 select CRYPTO_LIB_CHACHA_GENERIC
627 select CRYPTO_SKCIPHER
628 help
Robert Elliottcf514b22022-08-20 13:41:50 -0500629 The ChaCha20, XChaCha20, and XChaCha12 stream cipher algorithms
Robert Elliottf1f142a2022-08-20 13:41:44 -0500630
631 ChaCha20 is a 256-bit high-speed stream cipher designed by Daniel J.
632 Bernstein and further specified in RFC7539 for use in IETF protocols.
Robert Elliottcf514b22022-08-20 13:41:50 -0500633 This is the portable C implementation of ChaCha20. See
634 https://cr.yp.to/chacha/chacha-20080128.pdf for further information.
Robert Elliottf1f142a2022-08-20 13:41:44 -0500635
636 XChaCha20 is the application of the XSalsa20 construction to ChaCha20
637 rather than to Salsa20. XChaCha20 extends ChaCha20's nonce length
638 from 64 bits (or 96 bits using the RFC7539 convention) to 192 bits,
Robert Elliottcf514b22022-08-20 13:41:50 -0500639 while provably retaining ChaCha20's security. See
640 https://cr.yp.to/snuffle/xsalsa-20081128.pdf for further information.
Robert Elliottf1f142a2022-08-20 13:41:44 -0500641
642 XChaCha12 is XChaCha20 reduced to 12 rounds, with correspondingly
643 reduced security margin but increased performance. It can be needed
644 in some performance-sensitive scenarios.
645
646config CRYPTO_CBC
Robert Elliottcf514b22022-08-20 13:41:50 -0500647 tristate "CBC (Cipher Block Chaining)"
Robert Elliottf1f142a2022-08-20 13:41:44 -0500648 select CRYPTO_SKCIPHER
649 select CRYPTO_MANAGER
650 help
Robert Elliottcf514b22022-08-20 13:41:50 -0500651 CBC (Cipher Block Chaining) mode (NIST SP800-38A)
652
653 This block cipher mode is required for IPSec ESP (XFRM_ESP).
Robert Elliottf1f142a2022-08-20 13:41:44 -0500654
655config CRYPTO_CFB
Robert Elliottcf514b22022-08-20 13:41:50 -0500656 tristate "CFB (Cipher Feedback)"
Robert Elliottf1f142a2022-08-20 13:41:44 -0500657 select CRYPTO_SKCIPHER
658 select CRYPTO_MANAGER
659 help
Robert Elliottcf514b22022-08-20 13:41:50 -0500660 CFB (Cipher Feedback) mode (NIST SP800-38A)
661
662 This block cipher mode is required for TPM2 Cryptography.
Robert Elliottf1f142a2022-08-20 13:41:44 -0500663
664config CRYPTO_CTR
Robert Elliottcf514b22022-08-20 13:41:50 -0500665 tristate "CTR (Counter)"
Robert Elliottf1f142a2022-08-20 13:41:44 -0500666 select CRYPTO_SKCIPHER
667 select CRYPTO_MANAGER
668 help
Robert Elliottcf514b22022-08-20 13:41:50 -0500669 CTR (Counter) mode (NIST SP800-38A)
Robert Elliottf1f142a2022-08-20 13:41:44 -0500670
671config CRYPTO_CTS
Robert Elliottcf514b22022-08-20 13:41:50 -0500672 tristate "CTS (Cipher Text Stealing)"
Robert Elliottf1f142a2022-08-20 13:41:44 -0500673 select CRYPTO_SKCIPHER
674 select CRYPTO_MANAGER
675 help
Robert Elliottcf514b22022-08-20 13:41:50 -0500676 CBC-CS3 variant of CTS (Cipher Text Stealing) (NIST
677 Addendum to SP800-38A (October 2010))
678
Robert Elliottf1f142a2022-08-20 13:41:44 -0500679 This mode is required for Kerberos gss mechanism support
680 for AES encryption.
681
Robert Elliottf1f142a2022-08-20 13:41:44 -0500682config CRYPTO_ECB
Robert Elliottcf514b22022-08-20 13:41:50 -0500683 tristate "ECB (Electronic Codebook)"
Robert Elliottf1f142a2022-08-20 13:41:44 -0500684 select CRYPTO_SKCIPHER
685 select CRYPTO_MANAGER
686 help
Robert Elliottcf514b22022-08-20 13:41:50 -0500687 ECB (Electronic Codebook) mode (NIST SP800-38A)
Robert Elliottf1f142a2022-08-20 13:41:44 -0500688
689config CRYPTO_HCTR2
Robert Elliottcf514b22022-08-20 13:41:50 -0500690 tristate "HCTR2"
Robert Elliottf1f142a2022-08-20 13:41:44 -0500691 select CRYPTO_XCTR
692 select CRYPTO_POLYVAL
693 select CRYPTO_MANAGER
694 help
Robert Elliottcf514b22022-08-20 13:41:50 -0500695 HCTR2 length-preserving encryption mode
696
697 A mode for storage encryption that is efficient on processors with
698 instructions to accelerate AES and carryless multiplication, e.g.
699 x86 processors with AES-NI and CLMUL, and ARM processors with the
700 ARMv8 crypto extensions.
701
702 See https://eprint.iacr.org/2021/1441
Robert Elliottf1f142a2022-08-20 13:41:44 -0500703
704config CRYPTO_KEYWRAP
Robert Elliottcf514b22022-08-20 13:41:50 -0500705 tristate "KW (AES Key Wrap)"
Robert Elliottf1f142a2022-08-20 13:41:44 -0500706 select CRYPTO_SKCIPHER
707 select CRYPTO_MANAGER
708 help
Robert Elliottcf514b22022-08-20 13:41:50 -0500709 KW (AES Key Wrap) authenticated encryption mode (NIST SP800-38F
710 and RFC3394) without padding.
Robert Elliottf1f142a2022-08-20 13:41:44 -0500711
712config CRYPTO_LRW
Robert Elliottcf514b22022-08-20 13:41:50 -0500713 tristate "LRW (Liskov Rivest Wagner)"
Ard Biesheuvel61c581a2022-11-03 20:22:57 +0100714 select CRYPTO_LIB_GF128MUL
Robert Elliottf1f142a2022-08-20 13:41:44 -0500715 select CRYPTO_SKCIPHER
716 select CRYPTO_MANAGER
Robert Elliottf1f142a2022-08-20 13:41:44 -0500717 select CRYPTO_ECB
718 help
Robert Elliottcf514b22022-08-20 13:41:50 -0500719 LRW (Liskov Rivest Wagner) mode
720
721 A tweakable, non malleable, non movable
Robert Elliottf1f142a2022-08-20 13:41:44 -0500722 narrow block cipher mode for dm-crypt. Use it with cipher
723 specification string aes-lrw-benbi, the key must be 256, 320 or 384.
724 The first 128, 192 or 256 bits in the key are used for AES and the
725 rest is used to tie each cipher block to its logical position.
726
Robert Elliottcf514b22022-08-20 13:41:50 -0500727 See https://people.csail.mit.edu/rivest/pubs/LRW02.pdf
728
Robert Elliottf1f142a2022-08-20 13:41:44 -0500729config CRYPTO_OFB
Robert Elliottcf514b22022-08-20 13:41:50 -0500730 tristate "OFB (Output Feedback)"
Robert Elliottf1f142a2022-08-20 13:41:44 -0500731 select CRYPTO_SKCIPHER
732 select CRYPTO_MANAGER
733 help
Robert Elliottcf514b22022-08-20 13:41:50 -0500734 OFB (Output Feedback) mode (NIST SP800-38A)
735
736 This mode makes a block cipher into a synchronous
Robert Elliottf1f142a2022-08-20 13:41:44 -0500737 stream cipher. It generates keystream blocks, which are then XORed
738 with the plaintext blocks to get the ciphertext. Flipping a bit in the
739 ciphertext produces a flipped bit in the plaintext at the same
740 location. This property allows many error correcting codes to function
741 normally even when applied before encryption.
742
743config CRYPTO_PCBC
Robert Elliottcf514b22022-08-20 13:41:50 -0500744 tristate "PCBC (Propagating Cipher Block Chaining)"
Robert Elliottf1f142a2022-08-20 13:41:44 -0500745 select CRYPTO_SKCIPHER
746 select CRYPTO_MANAGER
747 help
Robert Elliottcf514b22022-08-20 13:41:50 -0500748 PCBC (Propagating Cipher Block Chaining) mode
749
750 This block cipher mode is required for RxRPC.
Robert Elliottf1f142a2022-08-20 13:41:44 -0500751
752config CRYPTO_XCTR
753 tristate
754 select CRYPTO_SKCIPHER
755 select CRYPTO_MANAGER
756 help
Robert Elliottcf514b22022-08-20 13:41:50 -0500757 XCTR (XOR Counter) mode for HCTR2
758
759 This blockcipher mode is a variant of CTR mode using XORs and little-endian
760 addition rather than big-endian arithmetic.
761
Robert Elliottf1f142a2022-08-20 13:41:44 -0500762 XCTR mode is used to implement HCTR2.
763
764config CRYPTO_XTS
Robert Elliottcf514b22022-08-20 13:41:50 -0500765 tristate "XTS (XOR Encrypt XOR with ciphertext stealing)"
Robert Elliottf1f142a2022-08-20 13:41:44 -0500766 select CRYPTO_SKCIPHER
767 select CRYPTO_MANAGER
768 select CRYPTO_ECB
769 help
Robert Elliottcf514b22022-08-20 13:41:50 -0500770 XTS (XOR Encrypt XOR with ciphertext stealing) mode (NIST SP800-38E
771 and IEEE 1619)
772
773 Use with aes-xts-plain, key size 256, 384 or 512 bits. This
774 implementation currently can't handle a sectorsize which is not a
775 multiple of 16 bytes.
Robert Elliottf1f142a2022-08-20 13:41:44 -0500776
777config CRYPTO_NHPOLY1305
778 tristate
779 select CRYPTO_HASH
780 select CRYPTO_LIB_POLY1305_GENERIC
781
782endmenu
783
784menu "AEAD (authenticated encryption with associated data) ciphers"
785
786config CRYPTO_AEGIS128
Robert Elliotte3d2ead2022-08-20 13:41:47 -0500787 tristate "AEGIS-128"
Robert Elliottf1f142a2022-08-20 13:41:44 -0500788 select CRYPTO_AEAD
789 select CRYPTO_AES # for AES S-box tables
790 help
Robert Elliotte3d2ead2022-08-20 13:41:47 -0500791 AEGIS-128 AEAD algorithm
Robert Elliottf1f142a2022-08-20 13:41:44 -0500792
793config CRYPTO_AEGIS128_SIMD
Robert Elliotte3d2ead2022-08-20 13:41:47 -0500794 bool "AEGIS-128 (arm NEON, arm64 NEON)"
Robert Elliottf1f142a2022-08-20 13:41:44 -0500795 depends on CRYPTO_AEGIS128 && ((ARM || ARM64) && KERNEL_MODE_NEON)
796 default y
Robert Elliotte3d2ead2022-08-20 13:41:47 -0500797 help
798 AEGIS-128 AEAD algorithm
799
800 Architecture: arm or arm64 using:
801 - NEON (Advanced SIMD) extension
Robert Elliottf1f142a2022-08-20 13:41:44 -0500802
803config CRYPTO_CHACHA20POLY1305
Robert Elliotte3d2ead2022-08-20 13:41:47 -0500804 tristate "ChaCha20-Poly1305"
Robert Elliottf1f142a2022-08-20 13:41:44 -0500805 select CRYPTO_CHACHA20
806 select CRYPTO_POLY1305
807 select CRYPTO_AEAD
808 select CRYPTO_MANAGER
809 help
Robert Elliotte3d2ead2022-08-20 13:41:47 -0500810 ChaCha20 stream cipher and Poly1305 authenticator combined
811 mode (RFC8439)
Robert Elliottf1f142a2022-08-20 13:41:44 -0500812
813config CRYPTO_CCM
Robert Elliottcf514b22022-08-20 13:41:50 -0500814 tristate "CCM (Counter with Cipher Block Chaining-MAC)"
Robert Elliottf1f142a2022-08-20 13:41:44 -0500815 select CRYPTO_CTR
816 select CRYPTO_HASH
817 select CRYPTO_AEAD
818 select CRYPTO_MANAGER
819 help
Robert Elliotte3d2ead2022-08-20 13:41:47 -0500820 CCM (Counter with Cipher Block Chaining-Message Authentication Code)
821 authenticated encryption mode (NIST SP800-38C)
Robert Elliottf1f142a2022-08-20 13:41:44 -0500822
823config CRYPTO_GCM
Robert Elliottcf514b22022-08-20 13:41:50 -0500824 tristate "GCM (Galois/Counter Mode) and GMAC (GCM MAC)"
Robert Elliottf1f142a2022-08-20 13:41:44 -0500825 select CRYPTO_CTR
826 select CRYPTO_AEAD
827 select CRYPTO_GHASH
828 select CRYPTO_NULL
829 select CRYPTO_MANAGER
830 help
Robert Elliotte3d2ead2022-08-20 13:41:47 -0500831 GCM (Galois/Counter Mode) authenticated encryption mode and GMAC
832 (GCM Message Authentication Code) (NIST SP800-38D)
833
834 This is required for IPSec ESP (XFRM_ESP).
Robert Elliottf1f142a2022-08-20 13:41:44 -0500835
836config CRYPTO_SEQIV
837 tristate "Sequence Number IV Generator"
838 select CRYPTO_AEAD
839 select CRYPTO_SKCIPHER
840 select CRYPTO_NULL
841 select CRYPTO_RNG_DEFAULT
842 select CRYPTO_MANAGER
843 help
Robert Elliotte3d2ead2022-08-20 13:41:47 -0500844 Sequence Number IV generator
845
Robert Elliottf1f142a2022-08-20 13:41:44 -0500846 This IV generator generates an IV based on a sequence number by
Robert Elliotte3d2ead2022-08-20 13:41:47 -0500847 xoring it with a salt. This algorithm is mainly useful for CTR.
848
849 This is required for IPsec ESP (XFRM_ESP).
Robert Elliottf1f142a2022-08-20 13:41:44 -0500850
851config CRYPTO_ECHAINIV
852 tristate "Encrypted Chain IV Generator"
853 select CRYPTO_AEAD
854 select CRYPTO_NULL
855 select CRYPTO_RNG_DEFAULT
856 select CRYPTO_MANAGER
857 help
Robert Elliotte3d2ead2022-08-20 13:41:47 -0500858 Encrypted Chain IV generator
859
Robert Elliottf1f142a2022-08-20 13:41:44 -0500860 This IV generator generates an IV based on the encryption of
861 a sequence number xored with a salt. This is the default
862 algorithm for CBC.
863
864config CRYPTO_ESSIV
Robert Elliotte3d2ead2022-08-20 13:41:47 -0500865 tristate "Encrypted Salt-Sector IV Generator"
Robert Elliottf1f142a2022-08-20 13:41:44 -0500866 select CRYPTO_AUTHENC
867 help
Robert Elliotte3d2ead2022-08-20 13:41:47 -0500868 Encrypted Salt-Sector IV generator
869
870 This IV generator is used in some cases by fscrypt and/or
Robert Elliottf1f142a2022-08-20 13:41:44 -0500871 dm-crypt. It uses the hash of the block encryption key as the
872 symmetric key for a block encryption pass applied to the input
873 IV, making low entropy IV sources more suitable for block
874 encryption.
875
876 This driver implements a crypto API template that can be
877 instantiated either as an skcipher or as an AEAD (depending on the
878 type of the first template argument), and which defers encryption
879 and decryption requests to the encapsulated cipher after applying
880 ESSIV to the input IV. Note that in the AEAD case, it is assumed
881 that the keys are presented in the same format used by the authenc
882 template, and that the IV appears at the end of the authenticated
883 associated data (AAD) region (which is how dm-crypt uses it.)
884
885 Note that the use of ESSIV is not recommended for new deployments,
886 and so this only needs to be enabled when interoperability with
887 existing encrypted volumes of filesystems is required, or when
888 building for a particular system that requires it (e.g., when
889 the SoC in question has accelerated CBC but not XTS, making CBC
890 combined with ESSIV the only feasible mode for h/w accelerated
891 block encryption)
892
893endmenu
894
895menu "Hashes, digests, and MACs"
896
897config CRYPTO_BLAKE2B
Robert Elliott3f342a22022-08-20 13:41:48 -0500898 tristate "BLAKE2b"
Robert Elliottf1f142a2022-08-20 13:41:44 -0500899 select CRYPTO_HASH
900 help
Robert Elliott3f342a22022-08-20 13:41:48 -0500901 BLAKE2b cryptographic hash function (RFC 7693)
902
903 BLAKE2b is optimized for 64-bit platforms and can produce digests
904 of any size between 1 and 64 bytes. The keyed hash is also implemented.
Robert Elliottf1f142a2022-08-20 13:41:44 -0500905
906 This module provides the following algorithms:
Robert Elliottf1f142a2022-08-20 13:41:44 -0500907 - blake2b-160
908 - blake2b-256
909 - blake2b-384
910 - blake2b-512
911
Robert Elliott3f342a22022-08-20 13:41:48 -0500912 Used by the btrfs filesystem.
913
Robert Elliottf1f142a2022-08-20 13:41:44 -0500914 See https://blake2.net for further information.
915
916config CRYPTO_CMAC
Robert Elliott3f342a22022-08-20 13:41:48 -0500917 tristate "CMAC (Cipher-based MAC)"
Robert Elliottf1f142a2022-08-20 13:41:44 -0500918 select CRYPTO_HASH
919 select CRYPTO_MANAGER
920 help
Robert Elliott3f342a22022-08-20 13:41:48 -0500921 CMAC (Cipher-based Message Authentication Code) authentication
922 mode (NIST SP800-38B and IETF RFC4493)
Robert Elliottf1f142a2022-08-20 13:41:44 -0500923
924config CRYPTO_GHASH
Robert Elliott3f342a22022-08-20 13:41:48 -0500925 tristate "GHASH"
Robert Elliottf1f142a2022-08-20 13:41:44 -0500926 select CRYPTO_HASH
Ard Biesheuvel61c581a2022-11-03 20:22:57 +0100927 select CRYPTO_LIB_GF128MUL
Robert Elliottf1f142a2022-08-20 13:41:44 -0500928 help
Robert Elliott3f342a22022-08-20 13:41:48 -0500929 GCM GHASH function (NIST SP800-38D)
Robert Elliottf1f142a2022-08-20 13:41:44 -0500930
931config CRYPTO_HMAC
Robert Elliott3f342a22022-08-20 13:41:48 -0500932 tristate "HMAC (Keyed-Hash MAC)"
Robert Elliottf1f142a2022-08-20 13:41:44 -0500933 select CRYPTO_HASH
934 select CRYPTO_MANAGER
935 help
Robert Elliott3f342a22022-08-20 13:41:48 -0500936 HMAC (Keyed-Hash Message Authentication Code) (FIPS 198 and
937 RFC2104)
938
939 This is required for IPsec AH (XFRM_AH) and IPsec ESP (XFRM_ESP).
Robert Elliottf1f142a2022-08-20 13:41:44 -0500940
941config CRYPTO_MD4
Robert Elliott3f342a22022-08-20 13:41:48 -0500942 tristate "MD4"
Robert Elliottf1f142a2022-08-20 13:41:44 -0500943 select CRYPTO_HASH
944 help
Robert Elliott3f342a22022-08-20 13:41:48 -0500945 MD4 message digest algorithm (RFC1320)
Robert Elliottf1f142a2022-08-20 13:41:44 -0500946
947config CRYPTO_MD5
Robert Elliott3f342a22022-08-20 13:41:48 -0500948 tristate "MD5"
Robert Elliottf1f142a2022-08-20 13:41:44 -0500949 select CRYPTO_HASH
950 help
Robert Elliott3f342a22022-08-20 13:41:48 -0500951 MD5 message digest algorithm (RFC1321)
Robert Elliottf1f142a2022-08-20 13:41:44 -0500952
953config CRYPTO_MICHAEL_MIC
Robert Elliott3f342a22022-08-20 13:41:48 -0500954 tristate "Michael MIC"
Robert Elliottf1f142a2022-08-20 13:41:44 -0500955 select CRYPTO_HASH
956 help
Robert Elliott3f342a22022-08-20 13:41:48 -0500957 Michael MIC (Message Integrity Code) (IEEE 802.11i)
958
959 Defined by the IEEE 802.11i TKIP (Temporal Key Integrity Protocol),
960 known as WPA (Wif-Fi Protected Access).
961
962 This algorithm is required for TKIP, but it should not be used for
963 other purposes because of the weakness of the algorithm.
Robert Elliottf1f142a2022-08-20 13:41:44 -0500964
965config CRYPTO_POLYVAL
966 tristate
Robert Elliottf1f142a2022-08-20 13:41:44 -0500967 select CRYPTO_HASH
Ard Biesheuvel61c581a2022-11-03 20:22:57 +0100968 select CRYPTO_LIB_GF128MUL
Robert Elliottf1f142a2022-08-20 13:41:44 -0500969 help
Robert Elliott3f342a22022-08-20 13:41:48 -0500970 POLYVAL hash function for HCTR2
971
972 This is used in HCTR2. It is not a general-purpose
Robert Elliottf1f142a2022-08-20 13:41:44 -0500973 cryptographic hash function.
974
975config CRYPTO_POLY1305
Robert Elliott3f342a22022-08-20 13:41:48 -0500976 tristate "Poly1305"
Robert Elliottf1f142a2022-08-20 13:41:44 -0500977 select CRYPTO_HASH
978 select CRYPTO_LIB_POLY1305_GENERIC
979 help
Robert Elliott3f342a22022-08-20 13:41:48 -0500980 Poly1305 authenticator algorithm (RFC7539)
Robert Elliottf1f142a2022-08-20 13:41:44 -0500981
982 Poly1305 is an authenticator algorithm designed by Daniel J. Bernstein.
983 It is used for the ChaCha20-Poly1305 AEAD, specified in RFC7539 for use
984 in IETF protocols. This is the portable C implementation of Poly1305.
985
986config CRYPTO_RMD160
Robert Elliott3f342a22022-08-20 13:41:48 -0500987 tristate "RIPEMD-160"
Robert Elliottf1f142a2022-08-20 13:41:44 -0500988 select CRYPTO_HASH
989 help
Robert Elliott3f342a22022-08-20 13:41:48 -0500990 RIPEMD-160 hash function (ISO/IEC 10118-3)
Robert Elliottf1f142a2022-08-20 13:41:44 -0500991
992 RIPEMD-160 is a 160-bit cryptographic hash function. It is intended
993 to be used as a secure replacement for the 128-bit hash functions
994 MD4, MD5 and its predecessor RIPEMD
995 (not to be confused with RIPEMD-128).
996
Robert Elliott3f342a22022-08-20 13:41:48 -0500997 Its speed is comparable to SHA-1 and there are no known attacks
Robert Elliottf1f142a2022-08-20 13:41:44 -0500998 against RIPEMD-160.
999
1000 Developed by Hans Dobbertin, Antoon Bosselaers and Bart Preneel.
Robert Elliott3f342a22022-08-20 13:41:48 -05001001 See https://homes.esat.kuleuven.be/~bosselae/ripemd160.html
1002 for further information.
Robert Elliottf1f142a2022-08-20 13:41:44 -05001003
1004config CRYPTO_SHA1
Robert Elliott3f342a22022-08-20 13:41:48 -05001005 tristate "SHA-1"
Robert Elliottf1f142a2022-08-20 13:41:44 -05001006 select CRYPTO_HASH
1007 select CRYPTO_LIB_SHA1
1008 help
Robert Elliott3f342a22022-08-20 13:41:48 -05001009 SHA-1 secure hash algorithm (FIPS 180, ISO/IEC 10118-3)
Robert Elliottf1f142a2022-08-20 13:41:44 -05001010
1011config CRYPTO_SHA256
Robert Elliott3f342a22022-08-20 13:41:48 -05001012 tristate "SHA-224 and SHA-256"
Robert Elliottf1f142a2022-08-20 13:41:44 -05001013 select CRYPTO_HASH
1014 select CRYPTO_LIB_SHA256
1015 help
Robert Elliott3f342a22022-08-20 13:41:48 -05001016 SHA-224 and SHA-256 secure hash algorithms (FIPS 180, ISO/IEC 10118-3)
Robert Elliottf1f142a2022-08-20 13:41:44 -05001017
Robert Elliott3f342a22022-08-20 13:41:48 -05001018 This is required for IPsec AH (XFRM_AH) and IPsec ESP (XFRM_ESP).
1019 Used by the btrfs filesystem, Ceph, NFS, and SMB.
Robert Elliottf1f142a2022-08-20 13:41:44 -05001020
1021config CRYPTO_SHA512
Robert Elliott3f342a22022-08-20 13:41:48 -05001022 tristate "SHA-384 and SHA-512"
Robert Elliottf1f142a2022-08-20 13:41:44 -05001023 select CRYPTO_HASH
1024 help
Robert Elliott3f342a22022-08-20 13:41:48 -05001025 SHA-384 and SHA-512 secure hash algorithms (FIPS 180, ISO/IEC 10118-3)
Robert Elliottf1f142a2022-08-20 13:41:44 -05001026
1027config CRYPTO_SHA3
Robert Elliott3f342a22022-08-20 13:41:48 -05001028 tristate "SHA-3"
Robert Elliottf1f142a2022-08-20 13:41:44 -05001029 select CRYPTO_HASH
1030 help
Robert Elliott3f342a22022-08-20 13:41:48 -05001031 SHA-3 secure hash algorithms (FIPS 202, ISO/IEC 10118-3)
Robert Elliottf1f142a2022-08-20 13:41:44 -05001032
1033config CRYPTO_SM3
1034 tristate
1035
1036config CRYPTO_SM3_GENERIC
Robert Elliott3f342a22022-08-20 13:41:48 -05001037 tristate "SM3 (ShangMi 3)"
Robert Elliottf1f142a2022-08-20 13:41:44 -05001038 select CRYPTO_HASH
1039 select CRYPTO_SM3
1040 help
Robert Elliott3f342a22022-08-20 13:41:48 -05001041 SM3 (ShangMi 3) secure hash function (OSCCA GM/T 0004-2012, ISO/IEC 10118-3)
1042
1043 This is part of the Chinese Commercial Cryptography suite.
Robert Elliottf1f142a2022-08-20 13:41:44 -05001044
1045 References:
1046 http://www.oscca.gov.cn/UpFile/20101222141857786.pdf
1047 https://datatracker.ietf.org/doc/html/draft-shen-sm3-hash
1048
1049config CRYPTO_STREEBOG
Robert Elliott3f342a22022-08-20 13:41:48 -05001050 tristate "Streebog"
Robert Elliottf1f142a2022-08-20 13:41:44 -05001051 select CRYPTO_HASH
1052 help
Robert Elliott3f342a22022-08-20 13:41:48 -05001053 Streebog Hash Function (GOST R 34.11-2012, RFC 6986, ISO/IEC 10118-3)
1054
1055 This is one of the Russian cryptographic standard algorithms (called
1056 GOST algorithms). This setting enables two hash algorithms with
1057 256 and 512 bits output.
Robert Elliottf1f142a2022-08-20 13:41:44 -05001058
1059 References:
1060 https://tc26.ru/upload/iblock/fed/feddbb4d26b685903faa2ba11aea43f6.pdf
1061 https://tools.ietf.org/html/rfc6986
1062
1063config CRYPTO_VMAC
Robert Elliott3f342a22022-08-20 13:41:48 -05001064 tristate "VMAC"
Robert Elliottf1f142a2022-08-20 13:41:44 -05001065 select CRYPTO_HASH
1066 select CRYPTO_MANAGER
1067 help
1068 VMAC is a message authentication algorithm designed for
1069 very high speed on 64-bit architectures.
1070
Robert Elliott3f342a22022-08-20 13:41:48 -05001071 See https://fastcrypto.org/vmac for further information.
Robert Elliottf1f142a2022-08-20 13:41:44 -05001072
1073config CRYPTO_WP512
Robert Elliott3f342a22022-08-20 13:41:48 -05001074 tristate "Whirlpool"
Robert Elliottf1f142a2022-08-20 13:41:44 -05001075 select CRYPTO_HASH
1076 help
Robert Elliott3f342a22022-08-20 13:41:48 -05001077 Whirlpool hash function (ISO/IEC 10118-3)
1078
1079 512, 384 and 256-bit hashes.
Robert Elliottf1f142a2022-08-20 13:41:44 -05001080
1081 Whirlpool-512 is part of the NESSIE cryptographic primitives.
Robert Elliottf1f142a2022-08-20 13:41:44 -05001082
Robert Elliott3f342a22022-08-20 13:41:48 -05001083 See https://web.archive.org/web/20171129084214/http://www.larc.usp.br/~pbarreto/WhirlpoolPage.html
1084 for further information.
Robert Elliottf1f142a2022-08-20 13:41:44 -05001085
1086config CRYPTO_XCBC
Robert Elliott3f342a22022-08-20 13:41:48 -05001087 tristate "XCBC-MAC (Extended Cipher Block Chaining MAC)"
Robert Elliottf1f142a2022-08-20 13:41:44 -05001088 select CRYPTO_HASH
1089 select CRYPTO_MANAGER
1090 help
Robert Elliott3f342a22022-08-20 13:41:48 -05001091 XCBC-MAC (Extended Cipher Block Chaining Message Authentication
1092 Code) (RFC3566)
Robert Elliottf1f142a2022-08-20 13:41:44 -05001093
1094config CRYPTO_XXHASH
Robert Elliott3f342a22022-08-20 13:41:48 -05001095 tristate "xxHash"
Robert Elliottf1f142a2022-08-20 13:41:44 -05001096 select CRYPTO_HASH
1097 select XXHASH
1098 help
Robert Elliott3f342a22022-08-20 13:41:48 -05001099 xxHash non-cryptographic hash algorithm
1100
1101 Extremely fast, working at speeds close to RAM limits.
1102
1103 Used by the btrfs filesystem.
Robert Elliottf1f142a2022-08-20 13:41:44 -05001104
1105endmenu
1106
1107menu "CRCs (cyclic redundancy checks)"
1108
1109config CRYPTO_CRC32C
Robert Elliottec843482022-08-20 13:41:46 -05001110 tristate "CRC32c"
Robert Elliottf1f142a2022-08-20 13:41:44 -05001111 select CRYPTO_HASH
1112 select CRC32
1113 help
Robert Elliottec843482022-08-20 13:41:46 -05001114 CRC32c CRC algorithm with the iSCSI polynomial (RFC 3385 and RFC 3720)
1115
1116 A 32-bit CRC (cyclic redundancy check) with a polynomial defined
1117 by G. Castagnoli, S. Braeuer and M. Herrman in "Optimization of Cyclic
1118 Redundancy-Check Codes with 24 and 32 Parity Bits", IEEE Transactions
1119 on Communications, Vol. 41, No. 6, June 1993, selected for use with
1120 iSCSI.
1121
1122 Used by btrfs, ext4, jbd2, NVMeoF/TCP, and iSCSI.
Robert Elliottf1f142a2022-08-20 13:41:44 -05001123
1124config CRYPTO_CRC32
Robert Elliottec843482022-08-20 13:41:46 -05001125 tristate "CRC32"
Robert Elliottf1f142a2022-08-20 13:41:44 -05001126 select CRYPTO_HASH
1127 select CRC32
1128 help
Robert Elliottec843482022-08-20 13:41:46 -05001129 CRC32 CRC algorithm (IEEE 802.3)
1130
1131 Used by RoCEv2 and f2fs.
Robert Elliottf1f142a2022-08-20 13:41:44 -05001132
1133config CRYPTO_CRCT10DIF
Robert Elliottec843482022-08-20 13:41:46 -05001134 tristate "CRCT10DIF"
Robert Elliottf1f142a2022-08-20 13:41:44 -05001135 select CRYPTO_HASH
1136 help
Robert Elliottec843482022-08-20 13:41:46 -05001137 CRC16 CRC algorithm used for the T10 (SCSI) Data Integrity Field (DIF)
1138
1139 CRC algorithm used by the SCSI Block Commands standard.
Robert Elliottf1f142a2022-08-20 13:41:44 -05001140
1141config CRYPTO_CRC64_ROCKSOFT
Robert Elliottec843482022-08-20 13:41:46 -05001142 tristate "CRC64 based on Rocksoft Model algorithm"
Robert Elliottf1f142a2022-08-20 13:41:44 -05001143 depends on CRC64
1144 select CRYPTO_HASH
Robert Elliottec843482022-08-20 13:41:46 -05001145 help
1146 CRC64 CRC algorithm based on the Rocksoft Model CRC Algorithm
1147
1148 Used by the NVMe implementation of T10 DIF (BLK_DEV_INTEGRITY)
1149
1150 See https://zlib.net/crc_v3.txt
Robert Elliottf1f142a2022-08-20 13:41:44 -05001151
1152endmenu
1153
1154menu "Compression"
Sebastian Siewior584fffc2008-04-05 21:04:48 +08001155
Linus Torvalds1da177e2005-04-16 15:20:36 -07001156config CRYPTO_DEFLATE
Robert Elliotta9a98d42022-08-20 13:41:51 -05001157 tristate "Deflate"
Herbert Xucce9e062006-08-21 21:08:13 +10001158 select CRYPTO_ALGAPI
Giovanni Cabidduf6ded092016-10-21 13:19:53 +01001159 select CRYPTO_ACOMP2
Linus Torvalds1da177e2005-04-16 15:20:36 -07001160 select ZLIB_INFLATE
1161 select ZLIB_DEFLATE
1162 help
Robert Elliotta9a98d42022-08-20 13:41:51 -05001163 Deflate compression algorithm (RFC1951)
Sebastian Siewior584fffc2008-04-05 21:04:48 +08001164
Robert Elliotta9a98d42022-08-20 13:41:51 -05001165 Used by IPSec with the IPCOMP protocol (RFC3173, RFC2394)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001166
Zoltan Sogor0b77abb2007-12-07 16:53:23 +08001167config CRYPTO_LZO
Robert Elliotta9a98d42022-08-20 13:41:51 -05001168 tristate "LZO"
Zoltan Sogor0b77abb2007-12-07 16:53:23 +08001169 select CRYPTO_ALGAPI
Giovanni Cabidduac9d2c42016-10-21 13:19:49 +01001170 select CRYPTO_ACOMP2
Zoltan Sogor0b77abb2007-12-07 16:53:23 +08001171 select LZO_COMPRESS
1172 select LZO_DECOMPRESS
1173 help
Robert Elliotta9a98d42022-08-20 13:41:51 -05001174 LZO compression algorithm
1175
1176 See https://www.oberhumer.com/opensource/lzo/ for further information.
Zoltan Sogor0b77abb2007-12-07 16:53:23 +08001177
Seth Jennings35a1fc12012-07-19 09:42:41 -05001178config CRYPTO_842
Robert Elliotta9a98d42022-08-20 13:41:51 -05001179 tristate "842"
Dan Streetman2062c5b2015-05-07 13:49:15 -04001180 select CRYPTO_ALGAPI
Giovanni Cabiddu6a8de3a2016-10-21 13:19:52 +01001181 select CRYPTO_ACOMP2
Dan Streetman2062c5b2015-05-07 13:49:15 -04001182 select 842_COMPRESS
1183 select 842_DECOMPRESS
Seth Jennings35a1fc12012-07-19 09:42:41 -05001184 help
Robert Elliotta9a98d42022-08-20 13:41:51 -05001185 842 compression algorithm by IBM
1186
1187 See https://github.com/plauth/lib842 for further information.
Seth Jennings35a1fc12012-07-19 09:42:41 -05001188
Chanho Min0ea85302013-07-08 16:01:51 -07001189config CRYPTO_LZ4
Robert Elliotta9a98d42022-08-20 13:41:51 -05001190 tristate "LZ4"
Chanho Min0ea85302013-07-08 16:01:51 -07001191 select CRYPTO_ALGAPI
Giovanni Cabiddu8cd93302016-10-21 13:19:50 +01001192 select CRYPTO_ACOMP2
Chanho Min0ea85302013-07-08 16:01:51 -07001193 select LZ4_COMPRESS
1194 select LZ4_DECOMPRESS
1195 help
Robert Elliotta9a98d42022-08-20 13:41:51 -05001196 LZ4 compression algorithm
1197
1198 See https://github.com/lz4/lz4 for further information.
Chanho Min0ea85302013-07-08 16:01:51 -07001199
1200config CRYPTO_LZ4HC
Robert Elliotta9a98d42022-08-20 13:41:51 -05001201 tristate "LZ4HC"
Chanho Min0ea85302013-07-08 16:01:51 -07001202 select CRYPTO_ALGAPI
Giovanni Cabiddu91d53d92016-10-21 13:19:51 +01001203 select CRYPTO_ACOMP2
Chanho Min0ea85302013-07-08 16:01:51 -07001204 select LZ4HC_COMPRESS
1205 select LZ4_DECOMPRESS
1206 help
Robert Elliotta9a98d42022-08-20 13:41:51 -05001207 LZ4 high compression mode algorithm
1208
1209 See https://github.com/lz4/lz4 for further information.
Chanho Min0ea85302013-07-08 16:01:51 -07001210
Nick Terrelld28fc3d2018-03-30 12:14:53 -07001211config CRYPTO_ZSTD
Robert Elliotta9a98d42022-08-20 13:41:51 -05001212 tristate "Zstd"
Nick Terrelld28fc3d2018-03-30 12:14:53 -07001213 select CRYPTO_ALGAPI
1214 select CRYPTO_ACOMP2
1215 select ZSTD_COMPRESS
1216 select ZSTD_DECOMPRESS
1217 help
Robert Elliotta9a98d42022-08-20 13:41:51 -05001218 zstd compression algorithm
1219
1220 See https://github.com/facebook/zstd for further information.
Nick Terrelld28fc3d2018-03-30 12:14:53 -07001221
Robert Elliottf1f142a2022-08-20 13:41:44 -05001222endmenu
1223
1224menu "Random number generation"
Neil Horman17f0f4a2008-08-14 22:15:52 +10001225
1226config CRYPTO_ANSI_CPRNG
Robert Elliotta9a98d42022-08-20 13:41:51 -05001227 tristate "ANSI PRNG (Pseudo Random Number Generator)"
Neil Horman17f0f4a2008-08-14 22:15:52 +10001228 select CRYPTO_AES
1229 select CRYPTO_RNG
Neil Horman17f0f4a2008-08-14 22:15:52 +10001230 help
Robert Elliotta9a98d42022-08-20 13:41:51 -05001231 Pseudo RNG (random number generator) (ANSI X9.31 Appendix A.2.4)
1232
1233 This uses the AES cipher algorithm.
1234
1235 Note that this option must be enabled if CRYPTO_FIPS is selected
Neil Horman17f0f4a2008-08-14 22:15:52 +10001236
Herbert Xuf2c89a12014-07-04 22:15:08 +08001237menuconfig CRYPTO_DRBG_MENU
Robert Elliotta9a98d42022-08-20 13:41:51 -05001238 tristate "NIST SP800-90A DRBG (Deterministic Random Bit Generator)"
Stephan Mueller419090c2014-05-31 17:22:31 +02001239 help
Robert Elliotta9a98d42022-08-20 13:41:51 -05001240 DRBG (Deterministic Random Bit Generator) (NIST SP800-90A)
1241
1242 In the following submenu, one or more of the DRBG types must be selected.
Stephan Mueller419090c2014-05-31 17:22:31 +02001243
Herbert Xuf2c89a12014-07-04 22:15:08 +08001244if CRYPTO_DRBG_MENU
Stephan Mueller419090c2014-05-31 17:22:31 +02001245
1246config CRYPTO_DRBG_HMAC
Herbert Xu401e4232015-06-03 14:49:31 +08001247 bool
Stephan Mueller419090c2014-05-31 17:22:31 +02001248 default y
Stephan Mueller419090c2014-05-31 17:22:31 +02001249 select CRYPTO_HMAC
Stephan Mueller5261cdf2021-06-30 12:32:52 +02001250 select CRYPTO_SHA512
Stephan Mueller419090c2014-05-31 17:22:31 +02001251
1252config CRYPTO_DRBG_HASH
Robert Elliotta9a98d42022-08-20 13:41:51 -05001253 bool "Hash_DRBG"
Herbert Xu826775b2015-06-11 08:55:10 +08001254 select CRYPTO_SHA256
Stephan Mueller419090c2014-05-31 17:22:31 +02001255 help
Robert Elliotta9a98d42022-08-20 13:41:51 -05001256 Hash_DRBG variant as defined in NIST SP800-90A.
1257
1258 This uses the SHA-1, SHA-256, SHA-384, or SHA-512 hash algorithms.
Stephan Mueller419090c2014-05-31 17:22:31 +02001259
1260config CRYPTO_DRBG_CTR
Robert Elliotta9a98d42022-08-20 13:41:51 -05001261 bool "CTR_DRBG"
Stephan Mueller419090c2014-05-31 17:22:31 +02001262 select CRYPTO_AES
Corentin Labbed6fc1a42020-04-24 13:40:47 +00001263 select CRYPTO_CTR
Stephan Mueller419090c2014-05-31 17:22:31 +02001264 help
Robert Elliotta9a98d42022-08-20 13:41:51 -05001265 CTR_DRBG variant as defined in NIST SP800-90A.
1266
1267 This uses the AES cipher algorithm with the counter block mode.
Stephan Mueller419090c2014-05-31 17:22:31 +02001268
Herbert Xuf2c89a12014-07-04 22:15:08 +08001269config CRYPTO_DRBG
1270 tristate
Herbert Xu401e4232015-06-03 14:49:31 +08001271 default CRYPTO_DRBG_MENU
Herbert Xuf2c89a12014-07-04 22:15:08 +08001272 select CRYPTO_RNG
Stephan Muellerbb5530e2015-05-25 15:10:20 +02001273 select CRYPTO_JITTERENTROPY
Herbert Xuf2c89a12014-07-04 22:15:08 +08001274
1275endif # if CRYPTO_DRBG_MENU
Stephan Mueller419090c2014-05-31 17:22:31 +02001276
Stephan Muellerbb5530e2015-05-25 15:10:20 +02001277config CRYPTO_JITTERENTROPY
Robert Elliotta9a98d42022-08-20 13:41:51 -05001278 tristate "CPU Jitter Non-Deterministic RNG (Random Number Generator)"
Arnd Bergmann2f313e02016-01-26 14:47:10 +01001279 select CRYPTO_RNG
Stephan Muellerbb5530e2015-05-25 15:10:20 +02001280 help
Robert Elliotta9a98d42022-08-20 13:41:51 -05001281 CPU Jitter RNG (Random Number Generator) from the Jitterentropy library
1282
1283 A non-physical non-deterministic ("true") RNG (e.g., an entropy source
1284 compliant with NIST SP800-90B) intended to provide a seed to a
1285 deterministic RNG (e.g. per NIST SP800-90C).
1286 This RNG does not perform any cryptographic whitening of the generated
1287
1288 See https://www.chronox.de/jent.html
Stephan Muellerbb5530e2015-05-25 15:10:20 +02001289
Stephan Müller026a7332021-11-19 07:55:58 +01001290config CRYPTO_KDF800108_CTR
1291 tristate
Herbert Xua88592c2022-01-18 16:31:29 +11001292 select CRYPTO_HMAC
Stephan Müller304b4ac2021-12-21 20:31:42 +01001293 select CRYPTO_SHA256
Stephan Müller026a7332021-11-19 07:55:58 +01001294
Robert Elliottf1f142a2022-08-20 13:41:44 -05001295endmenu
Robert Elliott9bc51712022-08-20 13:41:49 -05001296menu "Userspace interface"
Robert Elliottf1f142a2022-08-20 13:41:44 -05001297
Herbert Xu03c8efc2010-10-19 21:12:39 +08001298config CRYPTO_USER_API
1299 tristate
1300
Herbert Xufe869cd2010-10-19 21:23:00 +08001301config CRYPTO_USER_API_HASH
Robert Elliott9bc51712022-08-20 13:41:49 -05001302 tristate "Hash algorithms"
Herbert Xu74517082010-11-29 22:56:03 +08001303 depends on NET
Herbert Xufe869cd2010-10-19 21:23:00 +08001304 select CRYPTO_HASH
1305 select CRYPTO_USER_API
1306 help
Robert Elliott9bc51712022-08-20 13:41:49 -05001307 Enable the userspace interface for hash algorithms.
1308
1309 See Documentation/crypto/userspace-if.rst and
1310 https://www.chronox.de/libkcapi/html/index.html
Herbert Xufe869cd2010-10-19 21:23:00 +08001311
Herbert Xu8ff59092010-10-19 21:31:55 +08001312config CRYPTO_USER_API_SKCIPHER
Robert Elliott9bc51712022-08-20 13:41:49 -05001313 tristate "Symmetric key cipher algorithms"
Herbert Xu74517082010-11-29 22:56:03 +08001314 depends on NET
Eric Biggersb95bba52019-10-25 12:41:13 -07001315 select CRYPTO_SKCIPHER
Herbert Xu8ff59092010-10-19 21:31:55 +08001316 select CRYPTO_USER_API
1317 help
Robert Elliott9bc51712022-08-20 13:41:49 -05001318 Enable the userspace interface for symmetric key cipher algorithms.
1319
1320 See Documentation/crypto/userspace-if.rst and
1321 https://www.chronox.de/libkcapi/html/index.html
Herbert Xu8ff59092010-10-19 21:31:55 +08001322
Stephan Mueller2f3755382014-12-25 23:00:39 +01001323config CRYPTO_USER_API_RNG
Robert Elliott9bc51712022-08-20 13:41:49 -05001324 tristate "RNG (random number generator) algorithms"
Stephan Mueller2f3755382014-12-25 23:00:39 +01001325 depends on NET
1326 select CRYPTO_RNG
1327 select CRYPTO_USER_API
1328 help
Robert Elliott9bc51712022-08-20 13:41:49 -05001329 Enable the userspace interface for RNG (random number generator)
1330 algorithms.
1331
1332 See Documentation/crypto/userspace-if.rst and
1333 https://www.chronox.de/libkcapi/html/index.html
Stephan Mueller2f3755382014-12-25 23:00:39 +01001334
Elena Petrova77ebdab2020-09-18 16:42:16 +01001335config CRYPTO_USER_API_RNG_CAVP
1336 bool "Enable CAVP testing of DRBG"
1337 depends on CRYPTO_USER_API_RNG && CRYPTO_DRBG
1338 help
Robert Elliott9bc51712022-08-20 13:41:49 -05001339 Enable extra APIs in the userspace interface for NIST CAVP
1340 (Cryptographic Algorithm Validation Program) testing:
1341 - resetting DRBG entropy
1342 - providing Additional Data
1343
Elena Petrova77ebdab2020-09-18 16:42:16 +01001344 This should only be enabled for CAVP testing. You should say
1345 no unless you know what this is.
1346
Herbert Xub64a2d92015-05-28 11:30:35 +08001347config CRYPTO_USER_API_AEAD
Robert Elliott9bc51712022-08-20 13:41:49 -05001348 tristate "AEAD cipher algorithms"
Herbert Xub64a2d92015-05-28 11:30:35 +08001349 depends on NET
1350 select CRYPTO_AEAD
Eric Biggersb95bba52019-10-25 12:41:13 -07001351 select CRYPTO_SKCIPHER
Stephan Mueller72548b02017-07-30 14:32:58 +02001352 select CRYPTO_NULL
Herbert Xub64a2d92015-05-28 11:30:35 +08001353 select CRYPTO_USER_API
1354 help
Robert Elliott9bc51712022-08-20 13:41:49 -05001355 Enable the userspace interface for AEAD cipher algorithms.
1356
1357 See Documentation/crypto/userspace-if.rst and
1358 https://www.chronox.de/libkcapi/html/index.html
Herbert Xub64a2d92015-05-28 11:30:35 +08001359
Ard Biesheuvel9ace6772020-08-31 18:16:49 +03001360config CRYPTO_USER_API_ENABLE_OBSOLETE
Robert Elliott9bc51712022-08-20 13:41:49 -05001361 bool "Obsolete cryptographic algorithms"
Ard Biesheuvel9ace6772020-08-31 18:16:49 +03001362 depends on CRYPTO_USER_API
1363 default y
1364 help
1365 Allow obsolete cryptographic algorithms to be selected that have
1366 already been phased out from internal use by the kernel, and are
1367 only useful for userspace clients that still rely on them.
1368
Corentin Labbecac58182018-09-19 10:10:54 +00001369config CRYPTO_STATS
Robert Elliott9bc51712022-08-20 13:41:49 -05001370 bool "Crypto usage statistics"
Corentin Labbea6a31382018-11-29 14:42:17 +00001371 depends on CRYPTO_USER
Corentin Labbecac58182018-09-19 10:10:54 +00001372 help
Robert Elliott9bc51712022-08-20 13:41:49 -05001373 Enable the gathering of crypto stats.
1374
1375 This collects data sizes, numbers of requests, and numbers
1376 of errors processed by:
1377 - AEAD ciphers (encrypt, decrypt)
1378 - asymmetric key ciphers (encrypt, decrypt, verify, sign)
1379 - symmetric key ciphers (encrypt, decrypt)
1380 - compression algorithms (compress, decompress)
1381 - hash algorithms (hash)
1382 - key-agreement protocol primitives (setsecret, generate
1383 public key, compute shared secret)
1384 - RNG (generate, seed)
Corentin Labbecac58182018-09-19 10:10:54 +00001385
Robert Elliottf1f142a2022-08-20 13:41:44 -05001386endmenu
1387
Dmitry Kasatkinee089972013-05-06 15:40:01 +03001388config CRYPTO_HASH_INFO
1389 bool
1390
Linus Torvalds27bc50f2022-10-10 17:53:04 -07001391if !KMSAN # avoid false positives from assembly
Robert Elliott4a329fe2022-08-20 13:41:41 -05001392if ARM
1393source "arch/arm/crypto/Kconfig"
1394endif
1395if ARM64
1396source "arch/arm64/crypto/Kconfig"
1397endif
Robert Elliotte45f7102022-08-20 13:41:35 -05001398if MIPS
1399source "arch/mips/crypto/Kconfig"
1400endif
Robert Elliott6a490a42022-08-20 13:41:36 -05001401if PPC
1402source "arch/powerpc/crypto/Kconfig"
1403endif
Robert Elliottc9d24c92022-08-20 13:41:37 -05001404if S390
1405source "arch/s390/crypto/Kconfig"
1406endif
Robert Elliott0e9f9ea62022-08-20 13:41:38 -05001407if SPARC
1408source "arch/sparc/crypto/Kconfig"
1409endif
Robert Elliott28a936e2022-08-20 13:41:39 -05001410if X86
1411source "arch/x86/crypto/Kconfig"
1412endif
Linus Torvalds27bc50f2022-10-10 17:53:04 -07001413endif
Robert Elliotte45f7102022-08-20 13:41:35 -05001414
Linus Torvalds1da177e2005-04-16 15:20:36 -07001415source "drivers/crypto/Kconfig"
Masahiro Yamada8636a1f2018-12-11 20:01:04 +09001416source "crypto/asymmetric_keys/Kconfig"
1417source "certs/Kconfig"
Linus Torvalds1da177e2005-04-16 15:20:36 -07001418
Herbert Xucce9e062006-08-21 21:08:13 +10001419endif # if CRYPTO