crypto: caam - fix caam_jr_alloc() ret code
[linux/fpc-iii.git] / lib / Kconfig
blob54cf309a92a5ed7c8d4af783bd8811d0b706dfd6
2 # Library configuration
5 config BINARY_PRINTF
6         def_bool n
8 menu "Library routines"
10 config RAID6_PQ
11         tristate
13 config BITREVERSE
14         tristate
16 config RATIONAL
17         boolean
19 config GENERIC_STRNCPY_FROM_USER
20         bool
22 config GENERIC_STRNLEN_USER
23         bool
25 config GENERIC_NET_UTILS
26         bool
28 config GENERIC_FIND_FIRST_BIT
29         bool
31 config NO_GENERIC_PCI_IOPORT_MAP
32         bool
34 config GENERIC_PCI_IOMAP
35         bool
37 config GENERIC_IOMAP
38         bool
39         select GENERIC_PCI_IOMAP
41 config GENERIC_IO
42         boolean
43         default n
45 config STMP_DEVICE
46         bool
48 config PERCPU_RWSEM
49         boolean
51 config ARCH_USE_CMPXCHG_LOCKREF
52         bool
54 config ARCH_HAS_FAST_MULTIPLIER
55         bool
57 config CRC_CCITT
58         tristate "CRC-CCITT functions"
59         help
60           This option is provided for the case where no in-kernel-tree
61           modules require CRC-CCITT functions, but a module built outside
62           the kernel tree does. Such modules that use library CRC-CCITT
63           functions require M here.
65 config CRC16
66         tristate "CRC16 functions"
67         help
68           This option is provided for the case where no in-kernel-tree
69           modules require CRC16 functions, but a module built outside
70           the kernel tree does. Such modules that use library CRC16
71           functions require M here.
73 config CRC_T10DIF
74         tristate "CRC calculation for the T10 Data Integrity Field"
75         select CRYPTO
76         select CRYPTO_CRCT10DIF
77         help
78           This option is only needed if a module that's not in the
79           kernel tree needs to calculate CRC checks for use with the
80           SCSI data integrity subsystem.
82 config CRC_ITU_T
83         tristate "CRC ITU-T V.41 functions"
84         help
85           This option is provided for the case where no in-kernel-tree
86           modules require CRC ITU-T V.41 functions, but a module built outside
87           the kernel tree does. Such modules that use library CRC ITU-T V.41
88           functions require M here.
90 config CRC32
91         tristate "CRC32/CRC32c functions"
92         default y
93         select BITREVERSE
94         help
95           This option is provided for the case where no in-kernel-tree
96           modules require CRC32/CRC32c functions, but a module built outside
97           the kernel tree does. Such modules that use library CRC32/CRC32c
98           functions require M here.
100 config CRC32_SELFTEST
101         bool "CRC32 perform self test on init"
102         default n
103         depends on CRC32
104         help
105           This option enables the CRC32 library functions to perform a
106           self test on initialization. The self test computes crc32_le
107           and crc32_be over byte strings with random alignment and length
108           and computes the total elapsed time and number of bytes processed.
110 choice
111         prompt "CRC32 implementation"
112         depends on CRC32
113         default CRC32_SLICEBY8
114         help
115           This option allows a kernel builder to override the default choice
116           of CRC32 algorithm.  Choose the default ("slice by 8") unless you
117           know that you need one of the others.
119 config CRC32_SLICEBY8
120         bool "Slice by 8 bytes"
121         help
122           Calculate checksum 8 bytes at a time with a clever slicing algorithm.
123           This is the fastest algorithm, but comes with a 8KiB lookup table.
124           Most modern processors have enough cache to hold this table without
125           thrashing the cache.
127           This is the default implementation choice.  Choose this one unless
128           you have a good reason not to.
130 config CRC32_SLICEBY4
131         bool "Slice by 4 bytes"
132         help
133           Calculate checksum 4 bytes at a time with a clever slicing algorithm.
134           This is a bit slower than slice by 8, but has a smaller 4KiB lookup
135           table.
137           Only choose this option if you know what you are doing.
139 config CRC32_SARWATE
140         bool "Sarwate's Algorithm (one byte at a time)"
141         help
142           Calculate checksum a byte at a time using Sarwate's algorithm.  This
143           is not particularly fast, but has a small 256 byte lookup table.
145           Only choose this option if you know what you are doing.
147 config CRC32_BIT
148         bool "Classic Algorithm (one bit at a time)"
149         help
150           Calculate checksum one bit at a time.  This is VERY slow, but has
151           no lookup table.  This is provided as a debugging option.
153           Only choose this option if you are debugging crc32.
155 endchoice
157 config CRC7
158         tristate "CRC7 functions"
159         help
160           This option is provided for the case where no in-kernel-tree
161           modules require CRC7 functions, but a module built outside
162           the kernel tree does. Such modules that use library CRC7
163           functions require M here.
165 config LIBCRC32C
166         tristate "CRC32c (Castagnoli, et al) Cyclic Redundancy-Check"
167         select CRYPTO
168         select CRYPTO_CRC32C
169         help
170           This option is provided for the case where no in-kernel-tree
171           modules require CRC32c functions, but a module built outside the
172           kernel tree does. Such modules that use library CRC32c functions
173           require M here.  See Castagnoli93.
174           Module will be libcrc32c.
176 config CRC8
177         tristate "CRC8 function"
178         help
179           This option provides CRC8 function. Drivers may select this
180           when they need to do cyclic redundancy check according CRC8
181           algorithm. Module will be called crc8.
183 config AUDIT_GENERIC
184         bool
185         depends on AUDIT && !AUDIT_ARCH
186         default y
188 config AUDIT_ARCH_COMPAT_GENERIC
189         bool
190         default n
192 config AUDIT_COMPAT_GENERIC
193         bool
194         depends on AUDIT_GENERIC && AUDIT_ARCH_COMPAT_GENERIC && COMPAT
195         default y
197 config RANDOM32_SELFTEST
198         bool "PRNG perform self test on init"
199         default n
200         help
201           This option enables the 32 bit PRNG library functions to perform a
202           self test on initialization.
205 # compression support is select'ed if needed
207 config ZLIB_INFLATE
208         tristate
210 config ZLIB_DEFLATE
211         tristate
213 config LZO_COMPRESS
214         tristate
216 config LZO_DECOMPRESS
217         tristate
219 config LZ4_COMPRESS
220         tristate
222 config LZ4HC_COMPRESS
223         tristate
225 config LZ4_DECOMPRESS
226         tristate
228 source "lib/xz/Kconfig"
231 # These all provide a common interface (hence the apparent duplication with
232 # ZLIB_INFLATE; DECOMPRESS_GZIP is just a wrapper.)
234 config DECOMPRESS_GZIP
235         select ZLIB_INFLATE
236         tristate
238 config DECOMPRESS_BZIP2
239         tristate
241 config DECOMPRESS_LZMA
242         tristate
244 config DECOMPRESS_XZ
245         select XZ_DEC
246         tristate
248 config DECOMPRESS_LZO
249         select LZO_DECOMPRESS
250         tristate
252 config DECOMPRESS_LZ4
253         select LZ4_DECOMPRESS
254         tristate
257 # Generic allocator support is selected if needed
259 config GENERIC_ALLOCATOR
260         boolean
263 # reed solomon support is select'ed if needed
265 config REED_SOLOMON
266         tristate
267         
268 config REED_SOLOMON_ENC8
269         boolean
271 config REED_SOLOMON_DEC8
272         boolean
274 config REED_SOLOMON_ENC16
275         boolean
277 config REED_SOLOMON_DEC16
278         boolean
281 # BCH support is selected if needed
283 config BCH
284         tristate
286 config BCH_CONST_PARAMS
287         boolean
288         help
289           Drivers may select this option to force specific constant
290           values for parameters 'm' (Galois field order) and 't'
291           (error correction capability). Those specific values must
292           be set by declaring default values for symbols BCH_CONST_M
293           and BCH_CONST_T.
294           Doing so will enable extra compiler optimizations,
295           improving encoding and decoding performance up to 2x for
296           usual (m,t) values (typically such that m*t < 200).
297           When this option is selected, the BCH library supports
298           only a single (m,t) configuration. This is mainly useful
299           for NAND flash board drivers requiring known, fixed BCH
300           parameters.
302 config BCH_CONST_M
303         int
304         range 5 15
305         help
306           Constant value for Galois field order 'm'. If 'k' is the
307           number of data bits to protect, 'm' should be chosen such
308           that (k + m*t) <= 2**m - 1.
309           Drivers should declare a default value for this symbol if
310           they select option BCH_CONST_PARAMS.
312 config BCH_CONST_T
313         int
314         help
315           Constant value for error correction capability in bits 't'.
316           Drivers should declare a default value for this symbol if
317           they select option BCH_CONST_PARAMS.
320 # Textsearch support is select'ed if needed
322 config TEXTSEARCH
323         boolean
325 config TEXTSEARCH_KMP
326         tristate
328 config TEXTSEARCH_BM
329         tristate
331 config TEXTSEARCH_FSM
332         tristate
334 config BTREE
335         boolean
337 config INTERVAL_TREE
338         boolean
339         help
340           Simple, embeddable, interval-tree. Can find the start of an
341           overlapping range in log(n) time and then iterate over all
342           overlapping nodes. The algorithm is implemented as an
343           augmented rbtree.
345           See:
347                 Documentation/rbtree.txt
349           for more information.
351 config ASSOCIATIVE_ARRAY
352         bool
353         help
354           Generic associative array.  Can be searched and iterated over whilst
355           it is being modified.  It is also reasonably quick to search and
356           modify.  The algorithms are non-recursive, and the trees are highly
357           capacious.
359           See:
361                 Documentation/assoc_array.txt
363           for more information.
365 config HAS_IOMEM
366         boolean
367         depends on !NO_IOMEM
368         select GENERIC_IO
369         default y
371 config HAS_IOPORT_MAP
372         boolean
373         depends on HAS_IOMEM && !NO_IOPORT_MAP
374         default y
376 config HAS_DMA
377         boolean
378         depends on !NO_DMA
379         default y
381 config CHECK_SIGNATURE
382         bool
384 config CPUMASK_OFFSTACK
385         bool "Force CPU masks off stack" if DEBUG_PER_CPU_MAPS
386         help
387           Use dynamic allocation for cpumask_var_t, instead of putting
388           them on the stack.  This is a bit more expensive, but avoids
389           stack overflow.
391 config DISABLE_OBSOLETE_CPUMASK_FUNCTIONS
392        bool "Disable obsolete cpumask functions" if DEBUG_PER_CPU_MAPS
393        depends on BROKEN
395 config CPU_RMAP
396         bool
397         depends on SMP
399 config DQL
400         bool
402 config GLOB
403         bool
404 #       This actually supports modular compilation, but the module overhead
405 #       is ridiculous for the amount of code involved.  Until an out-of-tree
406 #       driver asks for it, we'll just link it directly it into the kernel
407 #       when required.  Since we're ignoring out-of-tree users, there's also
408 #       no need bother prompting for a manual decision:
409 #       prompt "glob_match() function"
410         help
411           This option provides a glob_match function for performing
412           simple text pattern matching.  It originated in the ATA code
413           to blacklist particular drive models, but other device drivers
414           may need similar functionality.
416           All drivers in the Linux kernel tree that require this function
417           should automatically select this option.  Say N unless you
418           are compiling an out-of tree driver which tells you that it
419           depends on this.
421 config GLOB_SELFTEST
422         bool "glob self-test on init"
423         default n
424         depends on GLOB
425         help
426           This option enables a simple self-test of the glob_match
427           function on startup.  It is primarily useful for people
428           working on the code to ensure they haven't introduced any
429           regressions.
431           It only adds a little bit of code and slows kernel boot (or
432           module load) by a small amount, so you're welcome to play with
433           it, but you probably don't need it.
436 # Netlink attribute parsing support is select'ed if needed
438 config NLATTR
439         bool
442 # Generic 64-bit atomic support is selected if needed
444 config GENERIC_ATOMIC64
445        bool
447 config ARCH_HAS_ATOMIC64_DEC_IF_POSITIVE
448         def_bool y if GENERIC_ATOMIC64
450 config LRU_CACHE
451         tristate
453 config AVERAGE
454         bool "Averaging functions"
455         help
456           This option is provided for the case where no in-kernel-tree
457           modules require averaging functions, but a module built outside
458           the kernel tree does. Such modules that use library averaging
459           functions require Y here.
461           If unsure, say N.
463 config CLZ_TAB
464         bool
466 config CORDIC
467         tristate "CORDIC algorithm"
468         help
469           This option provides an implementation of the CORDIC algorithm;
470           calculations are in fixed point. Module will be called cordic.
472 config DDR
473         bool "JEDEC DDR data"
474         help
475           Data from JEDEC specs for DDR SDRAM memories,
476           particularly the AC timing parameters and addressing
477           information. This data is useful for drivers handling
478           DDR SDRAM controllers.
480 config MPILIB
481         tristate
482         select CLZ_TAB
483         help
484           Multiprecision maths library from GnuPG.
485           It is used to implement RSA digital signature verification,
486           which is used by IMA/EVM digital signature extension.
488 config SIGNATURE
489         tristate
490         depends on KEYS
491         select CRYPTO
492         select CRYPTO_SHA1
493         select MPILIB
494         help
495           Digital signature verification. Currently only RSA is supported.
496           Implementation is done using GnuPG MPI library
499 # libfdt files, only selected if needed.
501 config LIBFDT
502         bool
504 config OID_REGISTRY
505         tristate
506         help
507           Enable fast lookup object identifier registry.
509 config UCS2_STRING
510         tristate
512 source "lib/fonts/Kconfig"
515 # sg chaining option
518 config ARCH_HAS_SG_CHAIN
519         def_bool n
521 endmenu