xref: /linux/drivers/crypto/Kconfig (revision 60675d4ca1ef0857e44eba5849b74a3a998d0c0f)
1ec8f24b7SThomas Gleixner# SPDX-License-Identifier: GPL-2.0-only
2b511431dSJan Engelhardt
3b511431dSJan Engelhardtmenuconfig CRYPTO_HW
4b511431dSJan Engelhardt	bool "Hardware crypto devices"
5b511431dSJan Engelhardt	default y
6a7f7f624SMasahiro Yamada	help
706bfb7ebSJan Engelhardt	  Say Y here to get to see options for hardware crypto devices and
806bfb7ebSJan Engelhardt	  processors. This option alone does not add any kernel code.
906bfb7ebSJan Engelhardt
1006bfb7ebSJan Engelhardt	  If you say N, all options in this submenu will be skipped and disabled.
11b511431dSJan Engelhardt
12b511431dSJan Engelhardtif CRYPTO_HW
131da177e4SLinus Torvalds
143914b931SCorentin Labbesource "drivers/crypto/allwinner/Kconfig"
153914b931SCorentin Labbe
161da177e4SLinus Torvaldsconfig CRYPTO_DEV_PADLOCK
17d158325eSHerbert Xu	tristate "Support for VIA PadLock ACE"
182f817418SHerbert Xu	depends on X86 && !UML
191da177e4SLinus Torvalds	help
201da177e4SLinus Torvalds	  Some VIA processors come with an integrated crypto engine
211da177e4SLinus Torvalds	  (so called VIA PadLock ACE, Advanced Cryptography Engine)
221191f0a4SMichal Ludvig	  that provides instructions for very fast cryptographic
231191f0a4SMichal Ludvig	  operations with supported algorithms.
241da177e4SLinus Torvalds
251da177e4SLinus Torvalds	  The instructions are used only when the CPU supports them.
265644bda5SMichal Ludvig	  Otherwise software encryption is used.
275644bda5SMichal Ludvig
281da177e4SLinus Torvaldsconfig CRYPTO_DEV_PADLOCK_AES
291191f0a4SMichal Ludvig	tristate "PadLock driver for AES algorithm"
301da177e4SLinus Torvalds	depends on CRYPTO_DEV_PADLOCK
31b95bba5dSEric Biggers	select CRYPTO_SKCIPHER
328131878dSArd Biesheuvel	select CRYPTO_LIB_AES
331da177e4SLinus Torvalds	help
341da177e4SLinus Torvalds	  Use VIA PadLock for AES algorithm.
351da177e4SLinus Torvalds
361191f0a4SMichal Ludvig	  Available in VIA C3 and newer CPUs.
371191f0a4SMichal Ludvig
381191f0a4SMichal Ludvig	  If unsure say M. The compiled module will be
394737f097SPavel Machek	  called padlock-aes.
401191f0a4SMichal Ludvig
416c833275SMichal Ludvigconfig CRYPTO_DEV_PADLOCK_SHA
426c833275SMichal Ludvig	tristate "PadLock driver for SHA1 and SHA256 algorithms"
436c833275SMichal Ludvig	depends on CRYPTO_DEV_PADLOCK
44bbbee467SHerbert Xu	select CRYPTO_HASH
456c833275SMichal Ludvig	select CRYPTO_SHA1
466c833275SMichal Ludvig	select CRYPTO_SHA256
476c833275SMichal Ludvig	help
486c833275SMichal Ludvig	  Use VIA PadLock for SHA1/SHA256 algorithms.
496c833275SMichal Ludvig
506c833275SMichal Ludvig	  Available in VIA C7 and newer processors.
516c833275SMichal Ludvig
526c833275SMichal Ludvig	  If unsure say M. The compiled module will be
534737f097SPavel Machek	  called padlock-sha.
546c833275SMichal Ludvig
559fe757b0SJordan Crouseconfig CRYPTO_DEV_GEODE
569fe757b0SJordan Crouse	tristate "Support for the Geode LX AES engine"
57f6259deaSSimon Arlott	depends on X86_32 && PCI
589fe757b0SJordan Crouse	select CRYPTO_ALGAPI
59b95bba5dSEric Biggers	select CRYPTO_SKCIPHER
609fe757b0SJordan Crouse	help
619fe757b0SJordan Crouse	  Say 'Y' here to use the AMD Geode LX processor on-board AES
623dde6ad8SDavid Sterba	  engine for the CryptoAPI AES algorithm.
639fe757b0SJordan Crouse
649fe757b0SJordan Crouse	  To compile this driver as a module, choose M here: the module
659fe757b0SJordan Crouse	  will be called geode-aes.
669fe757b0SJordan Crouse
6761d48c2cSMartin Schwidefskyconfig ZCRYPT
68a3358e3dSHarald Freudenberger	tristate "Support for s390 cryptographic adapters"
6961d48c2cSMartin Schwidefsky	depends on S390
7012376084SHolger Dengler	depends on AP
712f7c8bd6SRalph Wuerthner	select HW_RANDOM
7261d48c2cSMartin Schwidefsky	help
73a3358e3dSHarald Freudenberger	  Select this option if you want to enable support for
745ac8c724SHarald Freudenberger	  s390 cryptographic adapters like Crypto Express 4 up
755ac8c724SHarald Freudenberger	  to 8 in Coprocessor (CEXxC), EP11 Coprocessor (CEXxP)
765ac8c724SHarald Freudenberger	  or Accelerator (CEXxA) mode.
770ae88ccfSHarald Freudenberger
78e80d4af0SHarald Freudenbergerconfig PKEY
79e80d4af0SHarald Freudenberger	tristate "Kernel API for protected key handling"
80e80d4af0SHarald Freudenberger	depends on S390
81e80d4af0SHarald Freudenberger	help
828fcc231cSHarald Freudenberger	  With this option enabled the pkey kernel modules provide an API
83e80d4af0SHarald Freudenberger	  for creation and handling of protected keys. Other parts of the
84e80d4af0SHarald Freudenberger	  kernel or userspace applications may use these functions.
85e80d4af0SHarald Freudenberger
868fcc231cSHarald Freudenberger	  The protected key support is distributed into:
878fcc231cSHarald Freudenberger	  - A pkey base and API kernel module (pkey.ko) which offers the
888fcc231cSHarald Freudenberger	    infrastructure for the pkey handler kernel modules, the ioctl
898fcc231cSHarald Freudenberger	    and the sysfs API and the in-kernel API to the crypto cipher
908fcc231cSHarald Freudenberger	    implementations using protected key.
918fcc231cSHarald Freudenberger	  - A pkey pckmo kernel module (pkey-pckmo.ko) which is automatically
928fcc231cSHarald Freudenberger	    loaded when pckmo support (that is generation of protected keys
938fcc231cSHarald Freudenberger	    from clear key values) is available.
948fcc231cSHarald Freudenberger	  - A pkey CCA kernel module (pkey-cca.ko) which is automatically
958fcc231cSHarald Freudenberger	    loaded when a CEX crypto card is available.
968fcc231cSHarald Freudenberger	  - A pkey EP11 kernel module (pkey-ep11.ko) which is automatically
978fcc231cSHarald Freudenberger	    loaded when a CEX crypto card is available.
98*73dfc79cSHarald Freudenberger	  - A pkey UV kernel module (pkey-uv.ko) which is automatically
99*73dfc79cSHarald Freudenberger	    loaded when the Ultravisor feature is available within a
100*73dfc79cSHarald Freudenberger	    protected execution environment.
101e80d4af0SHarald Freudenberger
1028fcc231cSHarald Freudenberger	  Select this option if you want to enable the kernel and userspace
1038fcc231cSHarald Freudenberger	  API for protected key handling.
1048fcc231cSHarald Freudenberger
1058fcc231cSHarald Freudenbergerconfig PKEY_CCA
1068fcc231cSHarald Freudenberger	tristate "PKEY CCA support handler"
1078fcc231cSHarald Freudenberger	depends on PKEY
1088fcc231cSHarald Freudenberger	depends on ZCRYPT
1098fcc231cSHarald Freudenberger	help
1108fcc231cSHarald Freudenberger	  This is the CCA support handler for deriving protected keys
1118fcc231cSHarald Freudenberger	  from CCA (secure) keys. Also this handler provides an alternate
1128fcc231cSHarald Freudenberger	  way to make protected keys from clear key values.
1138fcc231cSHarald Freudenberger
1148fcc231cSHarald Freudenberger	  The PKEY CCA support handler needs a Crypto Express card (CEX)
1158fcc231cSHarald Freudenberger	  in CCA mode.
1168fcc231cSHarald Freudenberger
1178fcc231cSHarald Freudenberger	  If you have selected the PKEY option then you should also enable
1188fcc231cSHarald Freudenberger	  this option unless you are sure you never need to derive protected
1198fcc231cSHarald Freudenberger	  keys from CCA key material.
1208fcc231cSHarald Freudenberger
1218fcc231cSHarald Freudenbergerconfig PKEY_EP11
1228fcc231cSHarald Freudenberger	tristate "PKEY EP11 support handler"
1238fcc231cSHarald Freudenberger	depends on PKEY
1248fcc231cSHarald Freudenberger	depends on ZCRYPT
1258fcc231cSHarald Freudenberger	help
1268fcc231cSHarald Freudenberger	  This is the EP11 support handler for deriving protected keys
1278fcc231cSHarald Freudenberger	  from EP11 (secure) keys. Also this handler provides an alternate
1288fcc231cSHarald Freudenberger	  way to make protected keys from clear key values.
1298fcc231cSHarald Freudenberger
1308fcc231cSHarald Freudenberger	  The PKEY EP11 support handler needs a Crypto Express card (CEX)
1318fcc231cSHarald Freudenberger	  in EP11 mode.
1328fcc231cSHarald Freudenberger
1338fcc231cSHarald Freudenberger	  If you have selected the PKEY option then you should also enable
1348fcc231cSHarald Freudenberger	  this option unless you are sure you never need to derive protected
1358fcc231cSHarald Freudenberger	  keys from EP11 key material.
1368fcc231cSHarald Freudenberger
1378fcc231cSHarald Freudenbergerconfig PKEY_PCKMO
1388fcc231cSHarald Freudenberger	tristate "PKEY PCKMO support handler"
1398fcc231cSHarald Freudenberger	depends on PKEY
1408fcc231cSHarald Freudenberger	help
1418fcc231cSHarald Freudenberger	  This is the PCKMO support handler for deriving protected keys
1428fcc231cSHarald Freudenberger	  from clear key values via invoking the PCKMO instruction.
1438fcc231cSHarald Freudenberger
1448fcc231cSHarald Freudenberger	  The PCKMO instruction can be enabled and disabled in the crypto
1458fcc231cSHarald Freudenberger	  settings at the LPAR profile. This handler checks for availability
1468fcc231cSHarald Freudenberger	  during initialization and if build as a kernel module unloads
1478fcc231cSHarald Freudenberger	  itself if PCKMO is disabled.
1488fcc231cSHarald Freudenberger
1498fcc231cSHarald Freudenberger	  The PCKMO way of deriving protected keys from clear key material
1508fcc231cSHarald Freudenberger	  is especially used during self test of protected key ciphers like
1518fcc231cSHarald Freudenberger	  PAES but the CCA and EP11 handler provide alternate ways to
1528fcc231cSHarald Freudenberger	  generate protected keys from clear key values.
1538fcc231cSHarald Freudenberger
1548fcc231cSHarald Freudenberger	  If you have selected the PKEY option then you should also enable
1558fcc231cSHarald Freudenberger	  this option unless you are sure you never need to derive protected
1568fcc231cSHarald Freudenberger	  keys from clear key values directly via PCKMO.
15761d48c2cSMartin Schwidefsky
158*73dfc79cSHarald Freudenbergerconfig PKEY_UV
159*73dfc79cSHarald Freudenberger	tristate "PKEY UV support handler"
160*73dfc79cSHarald Freudenberger	depends on PKEY
161*73dfc79cSHarald Freudenberger	depends on S390_UV_UAPI
162*73dfc79cSHarald Freudenberger	help
163*73dfc79cSHarald Freudenberger	  This is the PKEY Ultravisor support handler for deriving protected
164*73dfc79cSHarald Freudenberger	  keys from secrets stored within the Ultravisor (UV).
165*73dfc79cSHarald Freudenberger
166*73dfc79cSHarald Freudenberger	  This module works together with the UV device and supports the
167*73dfc79cSHarald Freudenberger	  retrieval of protected keys from secrets stored within the
168*73dfc79cSHarald Freudenberger	  UV firmware layer. This service is only available within
169*73dfc79cSHarald Freudenberger	  a protected execution guest and thus this module will fail upon
170*73dfc79cSHarald Freudenberger	  modprobe if no protected execution environment is detected.
171*73dfc79cSHarald Freudenberger
172*73dfc79cSHarald Freudenberger	  Enable this option if you intend to run this kernel with an KVM
173*73dfc79cSHarald Freudenberger	  guest with protected execution and you want to use UV retrievable
174*73dfc79cSHarald Freudenberger	  secrets via PKEY API.
175*73dfc79cSHarald Freudenberger
176c4684f98SHarald Freudenbergerconfig CRYPTO_PAES_S390
177c4684f98SHarald Freudenberger	tristate "PAES cipher algorithms"
178c4684f98SHarald Freudenberger	depends on S390
179c4684f98SHarald Freudenberger	depends on ZCRYPT
180c4684f98SHarald Freudenberger	depends on PKEY
181c4684f98SHarald Freudenberger	select CRYPTO_ALGAPI
182b95bba5dSEric Biggers	select CRYPTO_SKCIPHER
183c4684f98SHarald Freudenberger	help
184c4684f98SHarald Freudenberger	  This is the s390 hardware accelerated implementation of the
185c4684f98SHarald Freudenberger	  AES cipher algorithms for use with protected key.
186c4684f98SHarald Freudenberger
187c4684f98SHarald Freudenberger	  Select this option if you want to use the paes cipher
188c4684f98SHarald Freudenberger	  for example to use protected key encrypted devices.
189c4684f98SHarald Freudenberger
1903f5615e0SJan Glauberconfig S390_PRNG
1913f5615e0SJan Glauber	tristate "Pseudo random number generator device driver"
1923f5615e0SJan Glauber	depends on S390
1933f5615e0SJan Glauber	default "m"
1943f5615e0SJan Glauber	help
1953f5615e0SJan Glauber	  Select this option if you want to use the s390 pseudo random number
1963f5615e0SJan Glauber	  generator. The PRNG is part of the cryptographic processor functions
1973f5615e0SJan Glauber	  and uses triple-DES to generate secure random numbers like the
198d393d9b8SJan Glauber	  ANSI X9.17 standard. User-space programs access the
199d393d9b8SJan Glauber	  pseudo-random-number device through the char device /dev/prandom.
200d393d9b8SJan Glauber
201d393d9b8SJan Glauber	  It is available as of z9.
2023f5615e0SJan Glauber
2030a625fd2SDavid S. Millerconfig CRYPTO_DEV_NIAGARA2
2040a625fd2SDavid S. Miller	tristate "Niagara2 Stream Processing Unit driver"
20504007b0eSArd Biesheuvel	select CRYPTO_LIB_DES
206b95bba5dSEric Biggers	select CRYPTO_SKCIPHER
207596103cfSHerbert Xu	select CRYPTO_HASH
2088054b800SLABBE Corentin	select CRYPTO_MD5
2098054b800SLABBE Corentin	select CRYPTO_SHA1
2108054b800SLABBE Corentin	select CRYPTO_SHA256
2110a625fd2SDavid S. Miller	depends on SPARC64
2120a625fd2SDavid S. Miller	help
2130a625fd2SDavid S. Miller	  Each core of a Niagara2 processor contains a Stream
2140a625fd2SDavid S. Miller	  Processing Unit, which itself contains several cryptographic
2150a625fd2SDavid S. Miller	  sub-units.  One set provides the Modular Arithmetic Unit,
2160a625fd2SDavid S. Miller	  used for SSL offload.  The other set provides the Cipher
2170a625fd2SDavid S. Miller	  Group, which can perform encryption, decryption, hashing,
2180a625fd2SDavid S. Miller	  checksumming, and raw copies.
2190a625fd2SDavid S. Miller
22046c5338dSCorentin Labbeconfig CRYPTO_DEV_SL3516
221df941fddSGeert Uytterhoeven	tristate "Storlink SL3516 crypto offloader"
222e29dd5c8SGeert Uytterhoeven	depends on ARCH_GEMINI || COMPILE_TEST
223e29dd5c8SGeert Uytterhoeven	depends on HAS_IOMEM && PM
22446c5338dSCorentin Labbe	select CRYPTO_SKCIPHER
22546c5338dSCorentin Labbe	select CRYPTO_ENGINE
22646c5338dSCorentin Labbe	select CRYPTO_ECB
22746c5338dSCorentin Labbe	select CRYPTO_AES
22846c5338dSCorentin Labbe	select HW_RANDOM
22946c5338dSCorentin Labbe	help
23046c5338dSCorentin Labbe	  This option allows you to have support for SL3516 crypto offloader.
23146c5338dSCorentin Labbe
23246c5338dSCorentin Labbeconfig CRYPTO_DEV_SL3516_DEBUG
23346c5338dSCorentin Labbe	bool "Enable SL3516 stats"
23446c5338dSCorentin Labbe	depends on CRYPTO_DEV_SL3516
23546c5338dSCorentin Labbe	depends on DEBUG_FS
23646c5338dSCorentin Labbe	help
23746c5338dSCorentin Labbe	  Say y to enable SL3516 debug stats.
23846c5338dSCorentin Labbe	  This will create /sys/kernel/debug/sl3516/stats for displaying
23946c5338dSCorentin Labbe	  the number of requests per algorithm and other internal stats.
24046c5338dSCorentin Labbe
241f7d0561eSEvgeniy Polyakovconfig CRYPTO_DEV_HIFN_795X
242f7d0561eSEvgeniy Polyakov	tristate "Driver HIFN 795x crypto accelerator chips"
24304007b0eSArd Biesheuvel	select CRYPTO_LIB_DES
244b95bba5dSEric Biggers	select CRYPTO_SKCIPHER
245946fef4eSHerbert Xu	select HW_RANDOM if CRYPTO_DEV_HIFN_795X_RNG
2462707b937SJan Glauber	depends on PCI
24775b76625SRichard Weinberger	depends on !ARCH_DMA_ADDR_T_64BIT
248f7d0561eSEvgeniy Polyakov	help
249f7d0561eSEvgeniy Polyakov	  This option allows you to have support for HIFN 795x crypto adapters.
250f7d0561eSEvgeniy Polyakov
251946fef4eSHerbert Xuconfig CRYPTO_DEV_HIFN_795X_RNG
252946fef4eSHerbert Xu	bool "HIFN 795x random number generator"
253946fef4eSHerbert Xu	depends on CRYPTO_DEV_HIFN_795X
254946fef4eSHerbert Xu	help
255946fef4eSHerbert Xu	  Select this option if you want to enable the random number generator
256946fef4eSHerbert Xu	  on the HIFN 795x crypto adapters.
257f7d0561eSEvgeniy Polyakov
2588636a1f9SMasahiro Yamadasource "drivers/crypto/caam/Kconfig"
2598e8ec596SKim Phillips
2609c4a7965SKim Phillipsconfig CRYPTO_DEV_TALITOS
2619c4a7965SKim Phillips	tristate "Talitos Freescale Security Engine (SEC)"
262596103cfSHerbert Xu	select CRYPTO_AEAD
2639c4a7965SKim Phillips	select CRYPTO_AUTHENC
264b95bba5dSEric Biggers	select CRYPTO_SKCIPHER
265596103cfSHerbert Xu	select CRYPTO_HASH
266dbc2e87bSHerbert Xu	select CRYPTO_LIB_DES
2679c4a7965SKim Phillips	select HW_RANDOM
2689c4a7965SKim Phillips	depends on FSL_SOC
2699c4a7965SKim Phillips	help
2709c4a7965SKim Phillips	  Say 'Y' here to use the Freescale Security Engine (SEC)
2719c4a7965SKim Phillips	  to offload cryptographic algorithm computation.
2729c4a7965SKim Phillips
2739c4a7965SKim Phillips	  The Freescale SEC is present on PowerQUICC 'E' processors, such
2749c4a7965SKim Phillips	  as the MPC8349E and MPC8548E.
2759c4a7965SKim Phillips
2769c4a7965SKim Phillips	  To compile this driver as a module, choose M here: the module
2779c4a7965SKim Phillips	  will be called talitos.
2789c4a7965SKim Phillips
2795b841a65SLEROY Christopheconfig CRYPTO_DEV_TALITOS1
2805b841a65SLEROY Christophe	bool "SEC1 (SEC 1.0 and SEC Lite 1.2)"
2815b841a65SLEROY Christophe	depends on CRYPTO_DEV_TALITOS
2825b841a65SLEROY Christophe	depends on PPC_8xx || PPC_82xx
2835b841a65SLEROY Christophe	default y
2845b841a65SLEROY Christophe	help
2855b841a65SLEROY Christophe	  Say 'Y' here to use the Freescale Security Engine (SEC) version 1.0
2865b841a65SLEROY Christophe	  found on MPC82xx or the Freescale Security Engine (SEC Lite)
2875b841a65SLEROY Christophe	  version 1.2 found on MPC8xx
2885b841a65SLEROY Christophe
2895b841a65SLEROY Christopheconfig CRYPTO_DEV_TALITOS2
2905b841a65SLEROY Christophe	bool "SEC2+ (SEC version 2.0 or upper)"
2915b841a65SLEROY Christophe	depends on CRYPTO_DEV_TALITOS
2925b841a65SLEROY Christophe	default y if !PPC_8xx
2935b841a65SLEROY Christophe	help
2945b841a65SLEROY Christophe	  Say 'Y' here to use the Freescale Security Engine (SEC)
2955b841a65SLEROY Christophe	  version 2 and following as found on MPC83xx, MPC85xx, etc ...
2965b841a65SLEROY Christophe
297049359d6SJames Hsiaoconfig CRYPTO_DEV_PPC4XX
298049359d6SJames Hsiao	tristate "Driver AMCC PPC4xx crypto accelerator"
299049359d6SJames Hsiao	depends on PPC && 4xx
300049359d6SJames Hsiao	select CRYPTO_HASH
301a0aae821SChristian Lamparter	select CRYPTO_AEAD
302298b4c60SChristian Lamparter	select CRYPTO_AES
303da3e7a97SArd Biesheuvel	select CRYPTO_LIB_AES
304a0aae821SChristian Lamparter	select CRYPTO_CCM
30598e87e3dSChristian Lamparter	select CRYPTO_CTR
306a0aae821SChristian Lamparter	select CRYPTO_GCM
307b95bba5dSEric Biggers	select CRYPTO_SKCIPHER
308049359d6SJames Hsiao	help
309049359d6SJames Hsiao	  This option allows you to have support for AMCC crypto acceleration.
310049359d6SJames Hsiao
3115343e674SChristian Lamparterconfig HW_RANDOM_PPC4XX
3125343e674SChristian Lamparter	bool "PowerPC 4xx generic true random number generator support"
31363b8ee4fSFlorian Fainelli	depends on CRYPTO_DEV_PPC4XX && HW_RANDOM=y
3145343e674SChristian Lamparter	default y
315a7f7f624SMasahiro Yamada	help
3165343e674SChristian Lamparter	 This option provides the kernel-side support for the TRNG hardware
3175343e674SChristian Lamparter	 found in the security function of some PowerPC 4xx SoCs.
3185343e674SChristian Lamparter
31974ed87e7STero Kristoconfig CRYPTO_DEV_OMAP
32074ed87e7STero Kristo	tristate "Support for OMAP crypto HW accelerators"
32174ed87e7STero Kristo	depends on ARCH_OMAP2PLUS
32274ed87e7STero Kristo	help
32374ed87e7STero Kristo	  OMAP processors have various crypto HW accelerators. Select this if
32474ed87e7STero Kristo	  you want to use the OMAP modules for any of the crypto algorithms.
32574ed87e7STero Kristo
32674ed87e7STero Kristoif CRYPTO_DEV_OMAP
32774ed87e7STero Kristo
3288628e7c8SDmitry Kasatkinconfig CRYPTO_DEV_OMAP_SHAM
329eaef7e3fSLokesh Vutla	tristate "Support for OMAP MD5/SHA1/SHA2 hw accelerator"
330eaef7e3fSLokesh Vutla	depends on ARCH_OMAP2PLUS
33138281194SArnd Bergmann	select CRYPTO_ENGINE
3328628e7c8SDmitry Kasatkin	select CRYPTO_SHA1
3338628e7c8SDmitry Kasatkin	select CRYPTO_MD5
334eaef7e3fSLokesh Vutla	select CRYPTO_SHA256
335eaef7e3fSLokesh Vutla	select CRYPTO_SHA512
336eaef7e3fSLokesh Vutla	select CRYPTO_HMAC
3378628e7c8SDmitry Kasatkin	help
338eaef7e3fSLokesh Vutla	  OMAP processors have MD5/SHA1/SHA2 hw accelerator. Select this if you
339eaef7e3fSLokesh Vutla	  want to use the OMAP module for MD5/SHA1/SHA2 algorithms.
3408628e7c8SDmitry Kasatkin
341537559a5SDmitry Kasatkinconfig CRYPTO_DEV_OMAP_AES
342537559a5SDmitry Kasatkin	tristate "Support for OMAP AES hw engine"
3431bbf6437SJoel Fernandes	depends on ARCH_OMAP2 || ARCH_OMAP3 || ARCH_OMAP2PLUS
344537559a5SDmitry Kasatkin	select CRYPTO_AES
345b95bba5dSEric Biggers	select CRYPTO_SKCIPHER
3460529900aSBaolin Wang	select CRYPTO_ENGINE
3479fcb191aSLokesh Vutla	select CRYPTO_CBC
3489fcb191aSLokesh Vutla	select CRYPTO_ECB
3499fcb191aSLokesh Vutla	select CRYPTO_CTR
350ad18cc9dSTero Kristo	select CRYPTO_AEAD
351537559a5SDmitry Kasatkin	help
352537559a5SDmitry Kasatkin	  OMAP processors have AES module accelerator. Select this if you
353537559a5SDmitry Kasatkin	  want to use the OMAP module for AES algorithms.
354537559a5SDmitry Kasatkin
355701d0f19SJoel Fernandesconfig CRYPTO_DEV_OMAP_DES
35697ee7ed3SPeter Meerwald	tristate "Support for OMAP DES/3DES hw engine"
357701d0f19SJoel Fernandes	depends on ARCH_OMAP2PLUS
35804007b0eSArd Biesheuvel	select CRYPTO_LIB_DES
359b95bba5dSEric Biggers	select CRYPTO_SKCIPHER
360f1b77aacSBaolin Wang	select CRYPTO_ENGINE
361701d0f19SJoel Fernandes	help
362701d0f19SJoel Fernandes	  OMAP processors have DES/3DES module accelerator. Select this if you
363701d0f19SJoel Fernandes	  want to use the OMAP module for DES and 3DES algorithms. Currently
36497ee7ed3SPeter Meerwald	  the ECB and CBC modes of operation are supported by the driver. Also
36597ee7ed3SPeter Meerwald	  accesses made on unaligned boundaries are supported.
366701d0f19SJoel Fernandes
36774ed87e7STero Kristoendif # CRYPTO_DEV_OMAP
36874ed87e7STero Kristo
3695de88752SJavier Martinconfig CRYPTO_DEV_SAHARA
3705de88752SJavier Martin	tristate "Support for SAHARA crypto accelerator"
37174d24d83SPaul Bolle	depends on ARCH_MXC && OF
372b95bba5dSEric Biggers	select CRYPTO_SKCIPHER
3735de88752SJavier Martin	select CRYPTO_AES
3745de88752SJavier Martin	select CRYPTO_ECB
37544ff4ea1SOvidiu Panait	select CRYPTO_ENGINE
3765de88752SJavier Martin	help
3775de88752SJavier Martin	  This option enables support for the SAHARA HW crypto accelerator
3785de88752SJavier Martin	  found in some Freescale i.MX chips.
3795de88752SJavier Martin
380c46ea13fSKrzysztof Kozlowskiconfig CRYPTO_DEV_EXYNOS_RNG
381b279997fSKrzysztof Kozlowski	tristate "Exynos HW pseudo random number generator support"
382c46ea13fSKrzysztof Kozlowski	depends on ARCH_EXYNOS || COMPILE_TEST
383c46ea13fSKrzysztof Kozlowski	depends on HAS_IOMEM
384c46ea13fSKrzysztof Kozlowski	select CRYPTO_RNG
385a7f7f624SMasahiro Yamada	help
386c46ea13fSKrzysztof Kozlowski	  This driver provides kernel-side support through the
387c46ea13fSKrzysztof Kozlowski	  cryptographic API for the pseudo random number generator hardware
388c46ea13fSKrzysztof Kozlowski	  found on Exynos SoCs.
389c46ea13fSKrzysztof Kozlowski
390c46ea13fSKrzysztof Kozlowski	  To compile this driver as a module, choose M here: the
391c46ea13fSKrzysztof Kozlowski	  module will be called exynos-rng.
392c46ea13fSKrzysztof Kozlowski
393c46ea13fSKrzysztof Kozlowski	  If unsure, say Y.
394c46ea13fSKrzysztof Kozlowski
395a49e490cSVladimir Zapolskiyconfig CRYPTO_DEV_S5P
396e922e96fSNaveen Krishna Chatradhi	tristate "Support for Samsung S5PV210/Exynos crypto accelerator"
397dc1d9deeSKrzysztof Kozlowski	depends on ARCH_S5PV210 || ARCH_EXYNOS || COMPILE_TEST
398ee1b23d1SGeert Uytterhoeven	depends on HAS_IOMEM
399a49e490cSVladimir Zapolskiy	select CRYPTO_AES
400b95bba5dSEric Biggers	select CRYPTO_SKCIPHER
401a49e490cSVladimir Zapolskiy	help
402a49e490cSVladimir Zapolskiy	  This option allows you to have support for S5P crypto acceleration.
403e922e96fSNaveen Krishna Chatradhi	  Select this to offload Samsung S5PV210 or S5PC110, Exynos from AES
404a49e490cSVladimir Zapolskiy	  algorithms execution.
405a49e490cSVladimir Zapolskiy
406c2afad6cSKamil Koniecznyconfig CRYPTO_DEV_EXYNOS_HASH
407c2afad6cSKamil Konieczny	bool "Support for Samsung Exynos HASH accelerator"
408c2afad6cSKamil Konieczny	depends on CRYPTO_DEV_S5P
409c2afad6cSKamil Konieczny	depends on !CRYPTO_DEV_EXYNOS_RNG && CRYPTO_DEV_EXYNOS_RNG!=m
410c2afad6cSKamil Konieczny	select CRYPTO_SHA1
411c2afad6cSKamil Konieczny	select CRYPTO_MD5
412c2afad6cSKamil Konieczny	select CRYPTO_SHA256
413c2afad6cSKamil Konieczny	help
414c2afad6cSKamil Konieczny	  Select this to offload Exynos from HASH MD5/SHA1/SHA256.
415c2afad6cSKamil Konieczny	  This will select software SHA1, MD5 and SHA256 as they are
416c2afad6cSKamil Konieczny	  needed for small and zero-size messages.
417c2afad6cSKamil Konieczny	  HASH algorithms will be disabled if EXYNOS_RNG
418c2afad6cSKamil Konieczny	  is enabled due to hw conflict.
419c2afad6cSKamil Konieczny
420aef7b31cSKent Yoderconfig CRYPTO_DEV_NX
4217011a122SDan Streetman	bool "Support for IBM PowerPC Nest (NX) cryptographic acceleration"
4227011a122SDan Streetman	depends on PPC64
423aef7b31cSKent Yoder	help
4247011a122SDan Streetman	  This enables support for the NX hardware cryptographic accelerator
4257011a122SDan Streetman	  coprocessor that is in IBM PowerPC P7+ or later processors.  This
4267011a122SDan Streetman	  does not actually enable any drivers, it only allows you to select
4277011a122SDan Streetman	  which acceleration type (encryption and/or compression) to enable.
428322cacceSSeth Jennings
429322cacceSSeth Jenningsif CRYPTO_DEV_NX
430322cacceSSeth Jennings	source "drivers/crypto/nx/Kconfig"
431322cacceSSeth Jenningsendif
432aef7b31cSKent Yoder
43389a82ef8SCyrille Pitchenconfig CRYPTO_DEV_ATMEL_AUTHENC
434aee1f9f3SYueHaibing	bool "Support for Atmel IPSEC/SSL hw accelerator"
435ceb4afb3SArnd Bergmann	depends on ARCH_AT91 || COMPILE_TEST
436aee1f9f3SYueHaibing	depends on CRYPTO_DEV_ATMEL_AES
43789a82ef8SCyrille Pitchen	help
43889a82ef8SCyrille Pitchen	  Some Atmel processors can combine the AES and SHA hw accelerators
43989a82ef8SCyrille Pitchen	  to enhance support of IPSEC/SSL.
44089a82ef8SCyrille Pitchen	  Select this if you want to use the Atmel modules for
44189a82ef8SCyrille Pitchen	  authenc(hmac(shaX),Y(cbc)) algorithms.
44289a82ef8SCyrille Pitchen
443bd3c7b5cSNicolas Royerconfig CRYPTO_DEV_ATMEL_AES
444bd3c7b5cSNicolas Royer	tristate "Support for Atmel AES hw accelerator"
445ceb4afb3SArnd Bergmann	depends on ARCH_AT91 || COMPILE_TEST
446bd3c7b5cSNicolas Royer	select CRYPTO_AES
447d4419548SCyrille Pitchen	select CRYPTO_AEAD
448b95bba5dSEric Biggers	select CRYPTO_SKCIPHER
449aee1f9f3SYueHaibing	select CRYPTO_AUTHENC if CRYPTO_DEV_ATMEL_AUTHENC
450aee1f9f3SYueHaibing	select CRYPTO_DEV_ATMEL_SHA if CRYPTO_DEV_ATMEL_AUTHENC
451bd3c7b5cSNicolas Royer	help
452bd3c7b5cSNicolas Royer	  Some Atmel processors have AES hw accelerator.
453bd3c7b5cSNicolas Royer	  Select this if you want to use the Atmel module for
454bd3c7b5cSNicolas Royer	  AES algorithms.
455bd3c7b5cSNicolas Royer
456bd3c7b5cSNicolas Royer	  To compile this driver as a module, choose M here: the module
457bd3c7b5cSNicolas Royer	  will be called atmel-aes.
458bd3c7b5cSNicolas Royer
45913802005SNicolas Royerconfig CRYPTO_DEV_ATMEL_TDES
46013802005SNicolas Royer	tristate "Support for Atmel DES/TDES hw accelerator"
461ceb4afb3SArnd Bergmann	depends on ARCH_AT91 || COMPILE_TEST
46204007b0eSArd Biesheuvel	select CRYPTO_LIB_DES
463b95bba5dSEric Biggers	select CRYPTO_SKCIPHER
46413802005SNicolas Royer	help
46513802005SNicolas Royer	  Some Atmel processors have DES/TDES hw accelerator.
46613802005SNicolas Royer	  Select this if you want to use the Atmel module for
46713802005SNicolas Royer	  DES/TDES algorithms.
46813802005SNicolas Royer
46913802005SNicolas Royer	  To compile this driver as a module, choose M here: the module
47013802005SNicolas Royer	  will be called atmel-tdes.
47113802005SNicolas Royer
472ebc82efaSNicolas Royerconfig CRYPTO_DEV_ATMEL_SHA
473d4905b38SNicolas Royer	tristate "Support for Atmel SHA hw accelerator"
474ceb4afb3SArnd Bergmann	depends on ARCH_AT91 || COMPILE_TEST
475596103cfSHerbert Xu	select CRYPTO_HASH
476ebc82efaSNicolas Royer	help
477d4905b38SNicolas Royer	  Some Atmel processors have SHA1/SHA224/SHA256/SHA384/SHA512
478d4905b38SNicolas Royer	  hw accelerator.
479ebc82efaSNicolas Royer	  Select this if you want to use the Atmel module for
480d4905b38SNicolas Royer	  SHA1/SHA224/SHA256/SHA384/SHA512 algorithms.
481ebc82efaSNicolas Royer
482ebc82efaSNicolas Royer	  To compile this driver as a module, choose M here: the module
483ebc82efaSNicolas Royer	  will be called atmel-sha.
484ebc82efaSNicolas Royer
485c34a3201SArd Biesheuvelconfig CRYPTO_DEV_ATMEL_I2C
486c34a3201SArd Biesheuvel	tristate
487d33a23b0SArnd Bergmann	select BITREVERSE
488c34a3201SArd Biesheuvel
48911105693STudor-Dan Ambarusconfig CRYPTO_DEV_ATMEL_ECC
49011105693STudor-Dan Ambarus	tristate "Support for Microchip / Atmel ECC hw accelerator"
49111105693STudor-Dan Ambarus	depends on I2C
492c34a3201SArd Biesheuvel	select CRYPTO_DEV_ATMEL_I2C
49311105693STudor-Dan Ambarus	select CRYPTO_ECDH
49411105693STudor-Dan Ambarus	select CRC16
49511105693STudor-Dan Ambarus	help
49611105693STudor-Dan Ambarus	  Microhip / Atmel ECC hw accelerator.
49711105693STudor-Dan Ambarus	  Select this if you want to use the Microchip / Atmel module for
49811105693STudor-Dan Ambarus	  ECDH algorithm.
49911105693STudor-Dan Ambarus
50011105693STudor-Dan Ambarus	  To compile this driver as a module, choose M here: the module
50111105693STudor-Dan Ambarus	  will be called atmel-ecc.
50211105693STudor-Dan Ambarus
503da001fb6SArd Biesheuvelconfig CRYPTO_DEV_ATMEL_SHA204A
504da001fb6SArd Biesheuvel	tristate "Support for Microchip / Atmel SHA accelerator and RNG"
505da001fb6SArd Biesheuvel	depends on I2C
506da001fb6SArd Biesheuvel	select CRYPTO_DEV_ATMEL_I2C
507da001fb6SArd Biesheuvel	select HW_RANDOM
5084bb02dbdSYueHaibing	select CRC16
509da001fb6SArd Biesheuvel	help
510da001fb6SArd Biesheuvel	  Microhip / Atmel SHA accelerator and RNG.
511da001fb6SArd Biesheuvel	  Select this if you want to use the Microchip / Atmel SHA204A
512da001fb6SArd Biesheuvel	  module as a random number generator. (Other functions of the
513da001fb6SArd Biesheuvel	  chip are currently not exposed by this driver)
514da001fb6SArd Biesheuvel
515da001fb6SArd Biesheuvel	  To compile this driver as a module, choose M here: the module
516da001fb6SArd Biesheuvel	  will be called atmel-sha204a.
517da001fb6SArd Biesheuvel
518f1147660STom Lendackyconfig CRYPTO_DEV_CCP
519720419f0SBrijesh Singh	bool "Support for AMD Secure Processor"
5206c506343STom Lendacky	depends on ((X86 && PCI) || (ARM64 && (OF_ADDRESS || ACPI))) && HAS_IOMEM
521f1147660STom Lendacky	help
522720419f0SBrijesh Singh	  The AMD Secure Processor provides support for the Cryptographic Coprocessor
523720419f0SBrijesh Singh	  (CCP) and the Platform Security Processor (PSP) devices.
524f1147660STom Lendacky
525f1147660STom Lendackyif CRYPTO_DEV_CCP
526f1147660STom Lendacky	source "drivers/crypto/ccp/Kconfig"
527f1147660STom Lendackyendif
528f1147660STom Lendacky
52915b59e7cSMarek Vasutconfig CRYPTO_DEV_MXS_DCP
53015b59e7cSMarek Vasut	tristate "Support for Freescale MXS DCP"
531a2712e6cSFabio Estevam	depends on (ARCH_MXS || ARCH_MXC)
532dc97fa02SArnd Bergmann	select STMP_DEVICE
53315b59e7cSMarek Vasut	select CRYPTO_CBC
53415b59e7cSMarek Vasut	select CRYPTO_ECB
53515b59e7cSMarek Vasut	select CRYPTO_AES
536b95bba5dSEric Biggers	select CRYPTO_SKCIPHER
537596103cfSHerbert Xu	select CRYPTO_HASH
53815b59e7cSMarek Vasut	help
53915b59e7cSMarek Vasut	  The Freescale i.MX23/i.MX28 has SHA1/SHA256 and AES128 CBC/ECB
54015b59e7cSMarek Vasut	  co-processor on the die.
54115b59e7cSMarek Vasut
54215b59e7cSMarek Vasut	  To compile this driver as a module, choose M here: the module
54315b59e7cSMarek Vasut	  will be called mxs-dcp.
54415b59e7cSMarek Vasut
54562ad8b5cSGeorge Cheriansource "drivers/crypto/cavium/cpt/Kconfig"
54614fa93cdSSrikanth Jampalasource "drivers/crypto/cavium/nitrox/Kconfig"
547655ff1a1SSrujanaChallasource "drivers/crypto/marvell/Kconfig"
548fbf31dd5STom Zanussisource "drivers/crypto/intel/Kconfig"
549c672752dSStanimir Varbanov
550640035a2SMahipal Challaconfig CRYPTO_DEV_CAVIUM_ZIP
551640035a2SMahipal Challa	tristate "Cavium ZIP driver"
552640035a2SMahipal Challa	depends on PCI && 64BIT && (ARM64 || COMPILE_TEST)
553a7f7f624SMasahiro Yamada	help
554640035a2SMahipal Challa	  Select this option if you want to enable compression/decompression
555640035a2SMahipal Challa	  acceleration on Cavium's ARM based SoCs
556640035a2SMahipal Challa
557c672752dSStanimir Varbanovconfig CRYPTO_DEV_QCE
558c672752dSStanimir Varbanov	tristate "Qualcomm crypto engine accelerator"
559ee1b23d1SGeert Uytterhoeven	depends on ARCH_QCOM || COMPILE_TEST
560ee1b23d1SGeert Uytterhoeven	depends on HAS_IOMEM
56159e056cdSEneas U de Queiroz	help
56259e056cdSEneas U de Queiroz	  This driver supports Qualcomm crypto engine accelerator
56359e056cdSEneas U de Queiroz	  hardware. To compile this driver as a module, choose M here. The
56459e056cdSEneas U de Queiroz	  module will be called qcrypto.
56559e056cdSEneas U de Queiroz
56659e056cdSEneas U de Queirozconfig CRYPTO_DEV_QCE_SKCIPHER
56759e056cdSEneas U de Queiroz	bool
56859e056cdSEneas U de Queiroz	depends on CRYPTO_DEV_QCE
569c672752dSStanimir Varbanov	select CRYPTO_AES
57004007b0eSArd Biesheuvel	select CRYPTO_LIB_DES
571c672752dSStanimir Varbanov	select CRYPTO_ECB
572c672752dSStanimir Varbanov	select CRYPTO_CBC
573c672752dSStanimir Varbanov	select CRYPTO_XTS
574c672752dSStanimir Varbanov	select CRYPTO_CTR
575b95bba5dSEric Biggers	select CRYPTO_SKCIPHER
57659e056cdSEneas U de Queiroz
57759e056cdSEneas U de Queirozconfig CRYPTO_DEV_QCE_SHA
57859e056cdSEneas U de Queiroz	bool
57959e056cdSEneas U de Queiroz	depends on CRYPTO_DEV_QCE
5808ac1b9ccSSivaprakash Murugesan	select CRYPTO_SHA1
5818ac1b9ccSSivaprakash Murugesan	select CRYPTO_SHA256
58259e056cdSEneas U de Queiroz
5839363efb4SThara Gopinathconfig CRYPTO_DEV_QCE_AEAD
5849363efb4SThara Gopinath	bool
5859363efb4SThara Gopinath	depends on CRYPTO_DEV_QCE
5869363efb4SThara Gopinath	select CRYPTO_AUTHENC
5879363efb4SThara Gopinath	select CRYPTO_LIB_DES
5889363efb4SThara Gopinath
58959e056cdSEneas U de Queirozchoice
59059e056cdSEneas U de Queiroz	prompt "Algorithms enabled for QCE acceleration"
59159e056cdSEneas U de Queiroz	default CRYPTO_DEV_QCE_ENABLE_ALL
59259e056cdSEneas U de Queiroz	depends on CRYPTO_DEV_QCE
593c672752dSStanimir Varbanov	help
5942e0e386aSColin Ian King	  This option allows to choose whether to build support for all algorithms
59559e056cdSEneas U de Queiroz	  (default), hashes-only, or skciphers-only.
59659e056cdSEneas U de Queiroz
59759e056cdSEneas U de Queiroz	  The QCE engine does not appear to scale as well as the CPU to handle
59859e056cdSEneas U de Queiroz	  multiple crypto requests.  While the ipq40xx chips have 4-core CPUs, the
59959e056cdSEneas U de Queiroz	  QCE handles only 2 requests in parallel.
60059e056cdSEneas U de Queiroz
60159e056cdSEneas U de Queiroz	  Ipsec throughput seems to improve when disabling either family of
60259e056cdSEneas U de Queiroz	  algorithms, sharing the load with the CPU.  Enabling skciphers-only
60359e056cdSEneas U de Queiroz	  appears to work best.
60459e056cdSEneas U de Queiroz
60559e056cdSEneas U de Queiroz	config CRYPTO_DEV_QCE_ENABLE_ALL
60659e056cdSEneas U de Queiroz		bool "All supported algorithms"
60759e056cdSEneas U de Queiroz		select CRYPTO_DEV_QCE_SKCIPHER
60859e056cdSEneas U de Queiroz		select CRYPTO_DEV_QCE_SHA
6099363efb4SThara Gopinath		select CRYPTO_DEV_QCE_AEAD
61059e056cdSEneas U de Queiroz		help
61159e056cdSEneas U de Queiroz		  Enable all supported algorithms:
61259e056cdSEneas U de Queiroz			- AES (CBC, CTR, ECB, XTS)
61359e056cdSEneas U de Queiroz			- 3DES (CBC, ECB)
61459e056cdSEneas U de Queiroz			- DES (CBC, ECB)
61559e056cdSEneas U de Queiroz			- SHA1, HMAC-SHA1
61659e056cdSEneas U de Queiroz			- SHA256, HMAC-SHA256
61759e056cdSEneas U de Queiroz
61859e056cdSEneas U de Queiroz	config CRYPTO_DEV_QCE_ENABLE_SKCIPHER
61959e056cdSEneas U de Queiroz		bool "Symmetric-key ciphers only"
62059e056cdSEneas U de Queiroz		select CRYPTO_DEV_QCE_SKCIPHER
62159e056cdSEneas U de Queiroz		help
62259e056cdSEneas U de Queiroz		  Enable symmetric-key ciphers only:
62359e056cdSEneas U de Queiroz			- AES (CBC, CTR, ECB, XTS)
62459e056cdSEneas U de Queiroz			- 3DES (ECB, CBC)
62559e056cdSEneas U de Queiroz			- DES (ECB, CBC)
62659e056cdSEneas U de Queiroz
62759e056cdSEneas U de Queiroz	config CRYPTO_DEV_QCE_ENABLE_SHA
62859e056cdSEneas U de Queiroz		bool "Hash/HMAC only"
62959e056cdSEneas U de Queiroz		select CRYPTO_DEV_QCE_SHA
63059e056cdSEneas U de Queiroz		help
63159e056cdSEneas U de Queiroz		  Enable hashes/HMAC algorithms only:
63259e056cdSEneas U de Queiroz			- SHA1, HMAC-SHA1
63359e056cdSEneas U de Queiroz			- SHA256, HMAC-SHA256
63459e056cdSEneas U de Queiroz
6359363efb4SThara Gopinath	config CRYPTO_DEV_QCE_ENABLE_AEAD
6369363efb4SThara Gopinath		bool "AEAD algorithms only"
6379363efb4SThara Gopinath		select CRYPTO_DEV_QCE_AEAD
6389363efb4SThara Gopinath		help
6399363efb4SThara Gopinath		  Enable AEAD algorithms only:
6409363efb4SThara Gopinath			- authenc()
6419363efb4SThara Gopinath			- ccm(aes)
6429363efb4SThara Gopinath			- rfc4309(ccm(aes))
64359e056cdSEneas U de Queirozendchoice
644c672752dSStanimir Varbanov
645ce163ba0SEneas U de Queirozconfig CRYPTO_DEV_QCE_SW_MAX_LEN
646ce163ba0SEneas U de Queiroz	int "Default maximum request size to use software for AES"
647ce163ba0SEneas U de Queiroz	depends on CRYPTO_DEV_QCE && CRYPTO_DEV_QCE_SKCIPHER
648ce163ba0SEneas U de Queiroz	default 512
649ce163ba0SEneas U de Queiroz	help
650ce163ba0SEneas U de Queiroz	  This sets the default maximum request size to perform AES requests
651ce163ba0SEneas U de Queiroz	  using software instead of the crypto engine.  It can be changed by
652ce163ba0SEneas U de Queiroz	  setting the aes_sw_max_len parameter.
653ce163ba0SEneas U de Queiroz
654ce163ba0SEneas U de Queiroz	  Small blocks are processed faster in software than hardware.
655ce163ba0SEneas U de Queiroz	  Considering the 256-bit ciphers, software is 2-3 times faster than
656ce163ba0SEneas U de Queiroz	  qce at 256-bytes, 30% faster at 512, and about even at 768-bytes.
657ce163ba0SEneas U de Queiroz	  With 128-bit keys, the break-even point would be around 1024-bytes.
658ce163ba0SEneas U de Queiroz
659ce163ba0SEneas U de Queiroz	  The default is set a little lower, to 512 bytes, to balance the
660ce163ba0SEneas U de Queiroz	  cost in CPU usage.  The minimum recommended setting is 16-bytes
661ce163ba0SEneas U de Queiroz	  (1 AES block), since AES-GCM will fail if you set it lower.
662ce163ba0SEneas U de Queiroz	  Setting this to zero will send all requests to the hardware.
663ce163ba0SEneas U de Queiroz
664ce163ba0SEneas U de Queiroz	  Note that 192-bit keys are not supported by the hardware and are
665ce163ba0SEneas U de Queiroz	  always processed by the software fallback, and all DES requests
666ce163ba0SEneas U de Queiroz	  are done by the hardware.
667ce163ba0SEneas U de Queiroz
668ceec5f5bSVinod Koulconfig CRYPTO_DEV_QCOM_RNG
669ceec5f5bSVinod Koul	tristate "Qualcomm Random Number Generator Driver"
670ceec5f5bSVinod Koul	depends on ARCH_QCOM || COMPILE_TEST
671a2786e8bSAndré Apitzsch	depends on HW_RANDOM
672ceec5f5bSVinod Koul	select CRYPTO_RNG
673ceec5f5bSVinod Koul	help
674ceec5f5bSVinod Koul	  This driver provides support for the Random Number
675ceec5f5bSVinod Koul	  Generator hardware found on Qualcomm SoCs.
676ceec5f5bSVinod Koul
677ceec5f5bSVinod Koul	  To compile this driver as a module, choose M here. The
678ceec5f5bSVinod Koul	  module will be called qcom-rng. If unsure, say N.
679ceec5f5bSVinod Koul
68010930333SDanny Tsen#config CRYPTO_DEV_VMX
68110930333SDanny Tsen#	bool "Support for VMX cryptographic acceleration instructions"
68210930333SDanny Tsen#	depends on PPC64 && VSX
68310930333SDanny Tsen#	help
68410930333SDanny Tsen#	  Support for VMX cryptographic acceleration instructions.
68510930333SDanny Tsen#
68610930333SDanny Tsen#source "drivers/crypto/vmx/Kconfig"
687d2e3ae6fSLeonidas S. Barbosa
688d358f1abSJames Hartleyconfig CRYPTO_DEV_IMGTEC_HASH
689d358f1abSJames Hartley	tristate "Imagination Technologies hardware hash accelerator"
6908c98ebd7SGeert Uytterhoeven	depends on MIPS || COMPILE_TEST
691d358f1abSJames Hartley	select CRYPTO_MD5
692d358f1abSJames Hartley	select CRYPTO_SHA1
693d358f1abSJames Hartley	select CRYPTO_SHA256
694d358f1abSJames Hartley	select CRYPTO_HASH
695d358f1abSJames Hartley	help
696d358f1abSJames Hartley	  This driver interfaces with the Imagination Technologies
697d358f1abSJames Hartley	  hardware hash accelerator. Supporting MD5/SHA1/SHA224/SHA256
698d358f1abSJames Hartley	  hashing algorithms.
699d358f1abSJames Hartley
700433cd2c6SZain Wangconfig CRYPTO_DEV_ROCKCHIP
701433cd2c6SZain Wang	tristate "Rockchip's Cryptographic Engine driver"
702433cd2c6SZain Wang	depends on OF && ARCH_ROCKCHIP
70368ef8af0SCorentin Labbe	depends on PM
70468ef8af0SCorentin Labbe	select CRYPTO_ECB
70568ef8af0SCorentin Labbe	select CRYPTO_CBC
70668ef8af0SCorentin Labbe	select CRYPTO_DES
707433cd2c6SZain Wang	select CRYPTO_AES
70857d67c6eSCorentin Labbe	select CRYPTO_ENGINE
70904007b0eSArd Biesheuvel	select CRYPTO_LIB_DES
710bfd927ffSZain Wang	select CRYPTO_MD5
711bfd927ffSZain Wang	select CRYPTO_SHA1
712bfd927ffSZain Wang	select CRYPTO_SHA256
713bfd927ffSZain Wang	select CRYPTO_HASH
714b95bba5dSEric Biggers	select CRYPTO_SKCIPHER
715433cd2c6SZain Wang
716433cd2c6SZain Wang	help
717433cd2c6SZain Wang	  This driver interfaces with the hardware crypto accelerator.
718433cd2c6SZain Wang	  Supporting cbc/ecb chainmode, and aes/des/des3_ede cipher mode.
719433cd2c6SZain Wang
72048d904d4SCorentin Labbeconfig CRYPTO_DEV_ROCKCHIP_DEBUG
72148d904d4SCorentin Labbe	bool "Enable Rockchip crypto stats"
72248d904d4SCorentin Labbe	depends on CRYPTO_DEV_ROCKCHIP
72348d904d4SCorentin Labbe	depends on DEBUG_FS
72448d904d4SCorentin Labbe	help
72548d904d4SCorentin Labbe	  Say y to enable Rockchip crypto debug stats.
72648d904d4SCorentin Labbe	  This will create /sys/kernel/debug/rk3288_crypto/stats for displaying
72748d904d4SCorentin Labbe	  the number of requests per algorithm and other internal stats.
72848d904d4SCorentin Labbe
7290880bb3bSAkhil Rconfig CRYPTO_DEV_TEGRA
7300880bb3bSAkhil R	tristate "Enable Tegra Security Engine"
7310880bb3bSAkhil R	depends on TEGRA_HOST1X
7320880bb3bSAkhil R	select CRYPTO_ENGINE
7330880bb3bSAkhil R
7340880bb3bSAkhil R	help
7350880bb3bSAkhil R	  Select this to enable Tegra Security Engine which accelerates various
7360880bb3bSAkhil R	  AES encryption/decryption and HASH algorithms.
73748d904d4SCorentin Labbe
7384d96f7d4SKalyani Akulaconfig CRYPTO_DEV_ZYNQMP_AES
7394d96f7d4SKalyani Akula	tristate "Support for Xilinx ZynqMP AES hw accelerator"
7404d96f7d4SKalyani Akula	depends on ZYNQMP_FIRMWARE || COMPILE_TEST
7414d96f7d4SKalyani Akula	select CRYPTO_AES
7424d96f7d4SKalyani Akula	select CRYPTO_ENGINE
7434d96f7d4SKalyani Akula	select CRYPTO_AEAD
7444d96f7d4SKalyani Akula	help
7454d96f7d4SKalyani Akula	  Xilinx ZynqMP has AES-GCM engine used for symmetric key
7464d96f7d4SKalyani Akula	  encryption and decryption. This driver interfaces with AES hw
7474d96f7d4SKalyani Akula	  accelerator. Select this if you want to use the ZynqMP module
7484d96f7d4SKalyani Akula	  for AES algorithms.
7494d96f7d4SKalyani Akula
7507ecc3e34SHarshaconfig CRYPTO_DEV_ZYNQMP_SHA3
7510e03b8fdSHerbert Xu	tristate "Support for Xilinx ZynqMP SHA3 hardware accelerator"
7520e03b8fdSHerbert Xu	depends on ZYNQMP_FIRMWARE || COMPILE_TEST
7537ecc3e34SHarsha	select CRYPTO_SHA3
7547ecc3e34SHarsha	help
7557ecc3e34SHarsha	  Xilinx ZynqMP has SHA3 engine used for secure hash calculation.
7567ecc3e34SHarsha	  This driver interfaces with SHA3 hardware engine.
7577ecc3e34SHarsha	  Select this if you want to use the ZynqMP module
7587ecc3e34SHarsha	  for SHA3 hash computation.
7597ecc3e34SHarsha
76002038fd6SHariprasad Shenaisource "drivers/crypto/chelsio/Kconfig"
76102038fd6SHariprasad Shenai
762dbaf0624SGongleisource "drivers/crypto/virtio/Kconfig"
763dbaf0624SGonglei
7649d12ba86SRob Riceconfig CRYPTO_DEV_BCM_SPU
7659d12ba86SRob Rice	tristate "Broadcom symmetric crypto/hash acceleration support"
7669d12ba86SRob Rice	depends on ARCH_BCM_IPROC
767efc856edSraveendra padasalagi	depends on MAILBOX
7689d12ba86SRob Rice	default m
769ab57b335SEric Biggers	select CRYPTO_AUTHENC
77004007b0eSArd Biesheuvel	select CRYPTO_LIB_DES
7719d12ba86SRob Rice	select CRYPTO_MD5
7729d12ba86SRob Rice	select CRYPTO_SHA1
7739d12ba86SRob Rice	select CRYPTO_SHA256
7749d12ba86SRob Rice	select CRYPTO_SHA512
7759d12ba86SRob Rice	help
7769d12ba86SRob Rice	  This driver provides support for Broadcom crypto acceleration using the
777a9c01cd6SArd Biesheuvel	  Secure Processing Unit (SPU). The SPU driver registers skcipher,
7789d12ba86SRob Rice	  ahash, and aead algorithms with the kernel cryptographic API.
7799d12ba86SRob Rice
780b51dbe90SFabien DESSENNEsource "drivers/crypto/stm32/Kconfig"
781b51dbe90SFabien DESSENNE
7821b44c5a6SAntoine Ténartconfig CRYPTO_DEV_SAFEXCEL
7831b44c5a6SAntoine Ténart	tristate "Inside Secure's SafeXcel cryptographic engine driver"
7846dc0e310SBrendan Higgins	depends on (OF || PCI || COMPILE_TEST) && HAS_IOMEM
785363a90c2SArd Biesheuvel	select CRYPTO_LIB_AES
786f6beaea3SAntoine Tenart	select CRYPTO_AUTHENC
787b95bba5dSEric Biggers	select CRYPTO_SKCIPHER
78804007b0eSArd Biesheuvel	select CRYPTO_LIB_DES
7891b44c5a6SAntoine Ténart	select CRYPTO_HASH
7901b44c5a6SAntoine Ténart	select CRYPTO_HMAC
791293f89cfSOfer Heifetz	select CRYPTO_MD5
7921b44c5a6SAntoine Ténart	select CRYPTO_SHA1
7931b44c5a6SAntoine Ténart	select CRYPTO_SHA256
7941b44c5a6SAntoine Ténart	select CRYPTO_SHA512
795fc0f82b1SPascal van Leeuwen	select CRYPTO_CHACHA20POLY1305
7961d448f27SPascal van Leeuwen	select CRYPTO_SHA3
7971b44c5a6SAntoine Ténart	help
7980f6e5c82SPascal van Leeuwen	  This driver interfaces with the SafeXcel EIP-97 and EIP-197 cryptographic
7990f6e5c82SPascal van Leeuwen	  engines designed by Inside Secure. It currently accelerates DES, 3DES and
8000f6e5c82SPascal van Leeuwen	  AES block ciphers in ECB and CBC mode, as well as SHA1, SHA224, SHA256,
8010f6e5c82SPascal van Leeuwen	  SHA384 and SHA512 hash algorithms for both basic hash and HMAC.
8020f6e5c82SPascal van Leeuwen	  Additionally, it accelerates combined AES-CBC/HMAC-SHA AEAD operations.
8031b44c5a6SAntoine Ténart
804a21eb94fSLars Perssonconfig CRYPTO_DEV_ARTPEC6
805a21eb94fSLars Persson	tristate "Support for Axis ARTPEC-6/7 hardware crypto acceleration."
806a21eb94fSLars Persson	depends on ARM && (ARCH_ARTPEC || COMPILE_TEST)
807a21eb94fSLars Persson	depends on OF
808a21eb94fSLars Persson	select CRYPTO_AEAD
809a21eb94fSLars Persson	select CRYPTO_AES
810a21eb94fSLars Persson	select CRYPTO_ALGAPI
811b95bba5dSEric Biggers	select CRYPTO_SKCIPHER
812a21eb94fSLars Persson	select CRYPTO_CTR
813a21eb94fSLars Persson	select CRYPTO_HASH
814a21eb94fSLars Persson	select CRYPTO_SHA1
815a21eb94fSLars Persson	select CRYPTO_SHA256
816a21eb94fSLars Persson	select CRYPTO_SHA512
817a21eb94fSLars Persson	help
818a21eb94fSLars Persson	  Enables the driver for the on-chip crypto accelerator
819a21eb94fSLars Persson	  of Axis ARTPEC SoCs.
820a21eb94fSLars Persson
821a21eb94fSLars Persson	  To compile this driver as a module, choose M here.
822a21eb94fSLars Persson
8234c3f9727SGilad Ben-Yossefconfig CRYPTO_DEV_CCREE
8244c3f9727SGilad Ben-Yossef	tristate "Support for ARM TrustZone CryptoCell family of security processors"
8254c3f9727SGilad Ben-Yossef	depends on CRYPTO && CRYPTO_HW && OF && HAS_DMA
826ed490503SHerbert Xu	depends on HAS_IOMEM
8274c3f9727SGilad Ben-Yossef	select CRYPTO_HASH
828b95bba5dSEric Biggers	select CRYPTO_SKCIPHER
82904007b0eSArd Biesheuvel	select CRYPTO_LIB_DES
8304c3f9727SGilad Ben-Yossef	select CRYPTO_AEAD
8314c3f9727SGilad Ben-Yossef	select CRYPTO_AUTHENC
8324c3f9727SGilad Ben-Yossef	select CRYPTO_SHA1
8334c3f9727SGilad Ben-Yossef	select CRYPTO_MD5
8344c3f9727SGilad Ben-Yossef	select CRYPTO_SHA256
8354c3f9727SGilad Ben-Yossef	select CRYPTO_SHA512
8364c3f9727SGilad Ben-Yossef	select CRYPTO_HMAC
8374c3f9727SGilad Ben-Yossef	select CRYPTO_AES
8384c3f9727SGilad Ben-Yossef	select CRYPTO_CBC
8394c3f9727SGilad Ben-Yossef	select CRYPTO_ECB
8404c3f9727SGilad Ben-Yossef	select CRYPTO_CTR
8414c3f9727SGilad Ben-Yossef	select CRYPTO_XTS
8422ae6feb1STianjia Zhang	select CRYPTO_SM4_GENERIC
8432ae6feb1STianjia Zhang	select CRYPTO_SM3_GENERIC
8444c3f9727SGilad Ben-Yossef	help
84527b3b22dSGilad Ben-Yossef	  Say 'Y' to enable a driver for the REE interface of the Arm
84627b3b22dSGilad Ben-Yossef	  TrustZone CryptoCell family of processors. Currently the
8471c876a90SGilad Ben-Yossef	  CryptoCell 713, 703, 712, 710 and 630 are supported.
8484c3f9727SGilad Ben-Yossef	  Choose this if you wish to use hardware acceleration of
8494c3f9727SGilad Ben-Yossef	  cryptographic operations on the system REE.
8504c3f9727SGilad Ben-Yossef	  If unsure say Y.
8514c3f9727SGilad Ben-Yossef
852915e4e84SJonathan Cameronsource "drivers/crypto/hisilicon/Kconfig"
853915e4e84SJonathan Cameron
85448fe583fSCorentin Labbesource "drivers/crypto/amlogic/Kconfig"
85548fe583fSCorentin Labbe
8567694b6caSKeerthyconfig CRYPTO_DEV_SA2UL
8577694b6caSKeerthy	tristate "Support for TI security accelerator"
8587694b6caSKeerthy	depends on ARCH_K3 || COMPILE_TEST
8597694b6caSKeerthy	select CRYPTO_AES
8607694b6caSKeerthy	select CRYPTO_ALGAPI
86161f033baSHerbert Xu	select CRYPTO_AUTHENC
8628832023eSSuman Anna	select CRYPTO_DES
863bfe8fe93SRandy Dunlap	select CRYPTO_SHA1
864bfe8fe93SRandy Dunlap	select CRYPTO_SHA256
865bfe8fe93SRandy Dunlap	select CRYPTO_SHA512
8667694b6caSKeerthy	select HW_RANDOM
8677694b6caSKeerthy	select SG_SPLIT
8687694b6caSKeerthy	help
8697694b6caSKeerthy	  K3 devices include a security accelerator engine that may be
8707694b6caSKeerthy	  used for crypto offload.  Select this if you want to use hardware
8717694b6caSKeerthy	  acceleration for cryptographic algorithms on these devices.
8727694b6caSKeerthy
873108713a7SNeal Liusource "drivers/crypto/aspeed/Kconfig"
87442ef0e94SJia Jie Hosource "drivers/crypto/starfive/Kconfig"
87588574332SMike Healy
876b511431dSJan Engelhardtendif # CRYPTO_HW
877