Avoid reading past buffer when calling GETACL
[zen-stable.git] / drivers / crypto / Kconfig
blob7e3002b6d010ce4110538d21811f4aee7fcb7313
2 menuconfig CRYPTO_HW
3         bool "Hardware crypto devices"
4         default y
5         ---help---
6           Say Y here to get to see options for hardware crypto devices and
7           processors. This option alone does not add any kernel code.
9           If you say N, all options in this submenu will be skipped and disabled.
11 if CRYPTO_HW
13 config CRYPTO_DEV_PADLOCK
14         tristate "Support for VIA PadLock ACE"
15         depends on X86 && !UML
16         help
17           Some VIA processors come with an integrated crypto engine
18           (so called VIA PadLock ACE, Advanced Cryptography Engine)
19           that provides instructions for very fast cryptographic
20           operations with supported algorithms.
21           
22           The instructions are used only when the CPU supports them.
23           Otherwise software encryption is used.
25 config CRYPTO_DEV_PADLOCK_AES
26         tristate "PadLock driver for AES algorithm"
27         depends on CRYPTO_DEV_PADLOCK
28         select CRYPTO_BLKCIPHER
29         select CRYPTO_AES
30         help
31           Use VIA PadLock for AES algorithm.
33           Available in VIA C3 and newer CPUs.
35           If unsure say M. The compiled module will be
36           called padlock-aes.
38 config CRYPTO_DEV_PADLOCK_SHA
39         tristate "PadLock driver for SHA1 and SHA256 algorithms"
40         depends on CRYPTO_DEV_PADLOCK
41         select CRYPTO_HASH
42         select CRYPTO_SHA1
43         select CRYPTO_SHA256
44         help
45           Use VIA PadLock for SHA1/SHA256 algorithms.
47           Available in VIA C7 and newer processors.
49           If unsure say M. The compiled module will be
50           called padlock-sha.
52 config CRYPTO_DEV_GEODE
53         tristate "Support for the Geode LX AES engine"
54         depends on X86_32 && PCI
55         select CRYPTO_ALGAPI
56         select CRYPTO_BLKCIPHER
57         help
58           Say 'Y' here to use the AMD Geode LX processor on-board AES
59           engine for the CryptoAPI AES algorithm.
61           To compile this driver as a module, choose M here: the module
62           will be called geode-aes.
64 config ZCRYPT
65         tristate "Support for PCI-attached cryptographic adapters"
66         depends on S390
67         select ZCRYPT_MONOLITHIC if ZCRYPT="y"
68         select HW_RANDOM
69         help
70           Select this option if you want to use a PCI-attached cryptographic
71           adapter like:
72           + PCI Cryptographic Accelerator (PCICA)
73           + PCI Cryptographic Coprocessor (PCICC)
74           + PCI-X Cryptographic Coprocessor (PCIXCC)
75           + Crypto Express2 Coprocessor (CEX2C)
76           + Crypto Express2 Accelerator (CEX2A)
77           + Crypto Express3 Coprocessor (CEX3C)
78           + Crypto Express3 Accelerator (CEX3A)
80 config ZCRYPT_MONOLITHIC
81         bool "Monolithic zcrypt module"
82         depends on ZCRYPT
83         help
84           Select this option if you want to have a single module z90crypt,
85           that contains all parts of the crypto device driver (ap bus,
86           request router and all the card drivers).
88 config CRYPTO_SHA1_S390
89         tristate "SHA1 digest algorithm"
90         depends on S390
91         select CRYPTO_HASH
92         help
93           This is the s390 hardware accelerated implementation of the
94           SHA-1 secure hash standard (FIPS 180-1/DFIPS 180-2).
96           It is available as of z990.
98 config CRYPTO_SHA256_S390
99         tristate "SHA256 digest algorithm"
100         depends on S390
101         select CRYPTO_HASH
102         help
103           This is the s390 hardware accelerated implementation of the
104           SHA256 secure hash standard (DFIPS 180-2).
106           It is available as of z9.
108 config CRYPTO_SHA512_S390
109         tristate "SHA384 and SHA512 digest algorithm"
110         depends on S390
111         select CRYPTO_HASH
112         help
113           This is the s390 hardware accelerated implementation of the
114           SHA512 secure hash standard.
116           It is available as of z10.
118 config CRYPTO_DES_S390
119         tristate "DES and Triple DES cipher algorithms"
120         depends on S390
121         select CRYPTO_ALGAPI
122         select CRYPTO_BLKCIPHER
123         help
124           This is the s390 hardware accelerated implementation of the
125           DES cipher algorithm (FIPS 46-2), and Triple DES EDE (FIPS 46-3).
127           As of z990 the ECB and CBC mode are hardware accelerated.
128           As of z196 the CTR mode is hardware accelerated.
130 config CRYPTO_AES_S390
131         tristate "AES cipher algorithms"
132         depends on S390
133         select CRYPTO_ALGAPI
134         select CRYPTO_BLKCIPHER
135         help
136           This is the s390 hardware accelerated implementation of the
137           AES cipher algorithms (FIPS-197).
139           As of z9 the ECB and CBC modes are hardware accelerated
140           for 128 bit keys.
141           As of z10 the ECB and CBC modes are hardware accelerated
142           for all AES key sizes.
143           As of z196 the CTR mode is hardware accelerated for all AES
144           key sizes and XTS mode is hardware accelerated for 256 and
145           512 bit keys.
147 config S390_PRNG
148         tristate "Pseudo random number generator device driver"
149         depends on S390
150         default "m"
151         help
152           Select this option if you want to use the s390 pseudo random number
153           generator. The PRNG is part of the cryptographic processor functions
154           and uses triple-DES to generate secure random numbers like the
155           ANSI X9.17 standard. User-space programs access the
156           pseudo-random-number device through the char device /dev/prandom.
158           It is available as of z9.
160 config CRYPTO_GHASH_S390
161         tristate "GHASH digest algorithm"
162         depends on S390
163         select CRYPTO_HASH
164         help
165           This is the s390 hardware accelerated implementation of the
166           GHASH message digest algorithm for GCM (Galois/Counter Mode).
168           It is available as of z196.
170 config CRYPTO_DEV_MV_CESA
171         tristate "Marvell's Cryptographic Engine"
172         depends on PLAT_ORION
173         select CRYPTO_ALGAPI
174         select CRYPTO_AES
175         select CRYPTO_BLKCIPHER2
176         select CRYPTO_HASH
177         help
178           This driver allows you to utilize the Cryptographic Engines and
179           Security Accelerator (CESA) which can be found on the Marvell Orion
180           and Kirkwood SoCs, such as QNAP's TS-209.
182           Currently the driver supports AES in ECB and CBC mode without DMA.
184 config CRYPTO_DEV_NIAGARA2
185        tristate "Niagara2 Stream Processing Unit driver"
186        select CRYPTO_DES
187        select CRYPTO_ALGAPI
188        depends on SPARC64
189        help
190           Each core of a Niagara2 processor contains a Stream
191           Processing Unit, which itself contains several cryptographic
192           sub-units.  One set provides the Modular Arithmetic Unit,
193           used for SSL offload.  The other set provides the Cipher
194           Group, which can perform encryption, decryption, hashing,
195           checksumming, and raw copies.
197 config CRYPTO_DEV_HIFN_795X
198         tristate "Driver HIFN 795x crypto accelerator chips"
199         select CRYPTO_DES
200         select CRYPTO_ALGAPI
201         select CRYPTO_BLKCIPHER
202         select HW_RANDOM if CRYPTO_DEV_HIFN_795X_RNG
203         depends on PCI
204         depends on !ARCH_DMA_ADDR_T_64BIT
205         help
206           This option allows you to have support for HIFN 795x crypto adapters.
208 config CRYPTO_DEV_HIFN_795X_RNG
209         bool "HIFN 795x random number generator"
210         depends on CRYPTO_DEV_HIFN_795X
211         help
212           Select this option if you want to enable the random number generator
213           on the HIFN 795x crypto adapters.
215 source drivers/crypto/caam/Kconfig
217 config CRYPTO_DEV_TALITOS
218         tristate "Talitos Freescale Security Engine (SEC)"
219         select CRYPTO_ALGAPI
220         select CRYPTO_AUTHENC
221         select HW_RANDOM
222         depends on FSL_SOC
223         help
224           Say 'Y' here to use the Freescale Security Engine (SEC)
225           to offload cryptographic algorithm computation.
227           The Freescale SEC is present on PowerQUICC 'E' processors, such
228           as the MPC8349E and MPC8548E.
230           To compile this driver as a module, choose M here: the module
231           will be called talitos.
233 config CRYPTO_DEV_IXP4XX
234         tristate "Driver for IXP4xx crypto hardware acceleration"
235         depends on ARCH_IXP4XX
236         select CRYPTO_DES
237         select CRYPTO_ALGAPI
238         select CRYPTO_AUTHENC
239         select CRYPTO_BLKCIPHER
240         help
241           Driver for the IXP4xx NPE crypto engine.
243 config CRYPTO_DEV_PPC4XX
244         tristate "Driver AMCC PPC4xx crypto accelerator"
245         depends on PPC && 4xx
246         select CRYPTO_HASH
247         select CRYPTO_ALGAPI
248         select CRYPTO_BLKCIPHER
249         help
250           This option allows you to have support for AMCC crypto acceleration.
252 config CRYPTO_DEV_OMAP_SHAM
253         tristate "Support for OMAP SHA1/MD5 hw accelerator"
254         depends on ARCH_OMAP2 || ARCH_OMAP3
255         select CRYPTO_SHA1
256         select CRYPTO_MD5
257         help
258           OMAP processors have SHA1/MD5 hw accelerator. Select this if you
259           want to use the OMAP module for SHA1/MD5 algorithms.
261 config CRYPTO_DEV_OMAP_AES
262         tristate "Support for OMAP AES hw engine"
263         depends on ARCH_OMAP2 || ARCH_OMAP3
264         select CRYPTO_AES
265         help
266           OMAP processors have AES module accelerator. Select this if you
267           want to use the OMAP module for AES algorithms.
269 config CRYPTO_DEV_PICOXCELL
270         tristate "Support for picoXcell IPSEC and Layer2 crypto engines"
271         depends on ARCH_PICOXCELL && HAVE_CLK
272         select CRYPTO_AES
273         select CRYPTO_AUTHENC
274         select CRYPTO_ALGAPI
275         select CRYPTO_DES
276         select CRYPTO_CBC
277         select CRYPTO_ECB
278         select CRYPTO_SEQIV
279         help
280           This option enables support for the hardware offload engines in the
281           Picochip picoXcell SoC devices. Select this for IPSEC ESP offload
282           and for 3gpp Layer 2 ciphering support.
284           Saying m here will build a module named pipcoxcell_crypto.
286 config CRYPTO_DEV_S5P
287         tristate "Support for Samsung S5PV210 crypto accelerator"
288         depends on ARCH_S5PV210
289         select CRYPTO_AES
290         select CRYPTO_ALGAPI
291         select CRYPTO_BLKCIPHER
292         help
293           This option allows you to have support for S5P crypto acceleration.
294           Select this to offload Samsung S5PV210 or S5PC110 from AES
295           algorithms execution.
297 endif # CRYPTO_HW