Merge branch 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs
[linux/fpc-iii.git] / lib / Kconfig
blob991c98bc4a3f51e9e7f377274084bec909483ea9
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 CRC_CCITT
55         tristate "CRC-CCITT functions"
56         help
57           This option is provided for the case where no in-kernel-tree
58           modules require CRC-CCITT functions, but a module built outside
59           the kernel tree does. Such modules that use library CRC-CCITT
60           functions require M here.
62 config CRC16
63         tristate "CRC16 functions"
64         help
65           This option is provided for the case where no in-kernel-tree
66           modules require CRC16 functions, but a module built outside
67           the kernel tree does. Such modules that use library CRC16
68           functions require M here.
70 config CRC_T10DIF
71         tristate "CRC calculation for the T10 Data Integrity Field"
72         select CRYPTO
73         select CRYPTO_CRCT10DIF
74         help
75           This option is only needed if a module that's not in the
76           kernel tree needs to calculate CRC checks for use with the
77           SCSI data integrity subsystem.
79 config CRC_ITU_T
80         tristate "CRC ITU-T V.41 functions"
81         help
82           This option is provided for the case where no in-kernel-tree
83           modules require CRC ITU-T V.41 functions, but a module built outside
84           the kernel tree does. Such modules that use library CRC ITU-T V.41
85           functions require M here.
87 config CRC32
88         tristate "CRC32/CRC32c functions"
89         default y
90         select BITREVERSE
91         help
92           This option is provided for the case where no in-kernel-tree
93           modules require CRC32/CRC32c functions, but a module built outside
94           the kernel tree does. Such modules that use library CRC32/CRC32c
95           functions require M here.
97 config CRC32_SELFTEST
98         bool "CRC32 perform self test on init"
99         default n
100         depends on CRC32
101         help
102           This option enables the CRC32 library functions to perform a
103           self test on initialization. The self test computes crc32_le
104           and crc32_be over byte strings with random alignment and length
105           and computes the total elapsed time and number of bytes processed.
107 choice
108         prompt "CRC32 implementation"
109         depends on CRC32
110         default CRC32_SLICEBY8
111         help
112           This option allows a kernel builder to override the default choice
113           of CRC32 algorithm.  Choose the default ("slice by 8") unless you
114           know that you need one of the others.
116 config CRC32_SLICEBY8
117         bool "Slice by 8 bytes"
118         help
119           Calculate checksum 8 bytes at a time with a clever slicing algorithm.
120           This is the fastest algorithm, but comes with a 8KiB lookup table.
121           Most modern processors have enough cache to hold this table without
122           thrashing the cache.
124           This is the default implementation choice.  Choose this one unless
125           you have a good reason not to.
127 config CRC32_SLICEBY4
128         bool "Slice by 4 bytes"
129         help
130           Calculate checksum 4 bytes at a time with a clever slicing algorithm.
131           This is a bit slower than slice by 8, but has a smaller 4KiB lookup
132           table.
134           Only choose this option if you know what you are doing.
136 config CRC32_SARWATE
137         bool "Sarwate's Algorithm (one byte at a time)"
138         help
139           Calculate checksum a byte at a time using Sarwate's algorithm.  This
140           is not particularly fast, but has a small 256 byte lookup table.
142           Only choose this option if you know what you are doing.
144 config CRC32_BIT
145         bool "Classic Algorithm (one bit at a time)"
146         help
147           Calculate checksum one bit at a time.  This is VERY slow, but has
148           no lookup table.  This is provided as a debugging option.
150           Only choose this option if you are debugging crc32.
152 endchoice
154 config CRC7
155         tristate "CRC7 functions"
156         help
157           This option is provided for the case where no in-kernel-tree
158           modules require CRC7 functions, but a module built outside
159           the kernel tree does. Such modules that use library CRC7
160           functions require M here.
162 config LIBCRC32C
163         tristate "CRC32c (Castagnoli, et al) Cyclic Redundancy-Check"
164         select CRYPTO
165         select CRYPTO_CRC32C
166         help
167           This option is provided for the case where no in-kernel-tree
168           modules require CRC32c functions, but a module built outside the
169           kernel tree does. Such modules that use library CRC32c functions
170           require M here.  See Castagnoli93.
171           Module will be libcrc32c.
173 config CRC8
174         tristate "CRC8 function"
175         help
176           This option provides CRC8 function. Drivers may select this
177           when they need to do cyclic redundancy check according CRC8
178           algorithm. Module will be called crc8.
180 config AUDIT_GENERIC
181         bool
182         depends on AUDIT && !AUDIT_ARCH
183         default y
185 config RANDOM32_SELFTEST
186         bool "PRNG perform self test on init"
187         default n
188         help
189           This option enables the 32 bit PRNG library functions to perform a
190           self test on initialization.
193 # compression support is select'ed if needed
195 config ZLIB_INFLATE
196         tristate
198 config ZLIB_DEFLATE
199         tristate
201 config LZO_COMPRESS
202         tristate
204 config LZO_DECOMPRESS
205         tristate
207 config LZ4_COMPRESS
208         tristate
210 config LZ4HC_COMPRESS
211         tristate
213 config LZ4_DECOMPRESS
214         tristate
216 source "lib/xz/Kconfig"
219 # These all provide a common interface (hence the apparent duplication with
220 # ZLIB_INFLATE; DECOMPRESS_GZIP is just a wrapper.)
222 config DECOMPRESS_GZIP
223         select ZLIB_INFLATE
224         tristate
226 config DECOMPRESS_BZIP2
227         tristate
229 config DECOMPRESS_LZMA
230         tristate
232 config DECOMPRESS_XZ
233         select XZ_DEC
234         tristate
236 config DECOMPRESS_LZO
237         select LZO_DECOMPRESS
238         tristate
240 config DECOMPRESS_LZ4
241         select LZ4_DECOMPRESS
242         tristate
245 # Generic allocator support is selected if needed
247 config GENERIC_ALLOCATOR
248         boolean
251 # reed solomon support is select'ed if needed
253 config REED_SOLOMON
254         tristate
255         
256 config REED_SOLOMON_ENC8
257         boolean
259 config REED_SOLOMON_DEC8
260         boolean
262 config REED_SOLOMON_ENC16
263         boolean
265 config REED_SOLOMON_DEC16
266         boolean
269 # BCH support is selected if needed
271 config BCH
272         tristate
274 config BCH_CONST_PARAMS
275         boolean
276         help
277           Drivers may select this option to force specific constant
278           values for parameters 'm' (Galois field order) and 't'
279           (error correction capability). Those specific values must
280           be set by declaring default values for symbols BCH_CONST_M
281           and BCH_CONST_T.
282           Doing so will enable extra compiler optimizations,
283           improving encoding and decoding performance up to 2x for
284           usual (m,t) values (typically such that m*t < 200).
285           When this option is selected, the BCH library supports
286           only a single (m,t) configuration. This is mainly useful
287           for NAND flash board drivers requiring known, fixed BCH
288           parameters.
290 config BCH_CONST_M
291         int
292         range 5 15
293         help
294           Constant value for Galois field order 'm'. If 'k' is the
295           number of data bits to protect, 'm' should be chosen such
296           that (k + m*t) <= 2**m - 1.
297           Drivers should declare a default value for this symbol if
298           they select option BCH_CONST_PARAMS.
300 config BCH_CONST_T
301         int
302         help
303           Constant value for error correction capability in bits 't'.
304           Drivers should declare a default value for this symbol if
305           they select option BCH_CONST_PARAMS.
308 # Textsearch support is select'ed if needed
310 config TEXTSEARCH
311         boolean
313 config TEXTSEARCH_KMP
314         tristate
316 config TEXTSEARCH_BM
317         tristate
319 config TEXTSEARCH_FSM
320         tristate
322 config BTREE
323         boolean
325 config ASSOCIATIVE_ARRAY
326         bool
327         help
328           Generic associative array.  Can be searched and iterated over whilst
329           it is being modified.  It is also reasonably quick to search and
330           modify.  The algorithms are non-recursive, and the trees are highly
331           capacious.
333           See:
335                 Documentation/assoc_array.txt
337           for more information.
339 config HAS_IOMEM
340         boolean
341         depends on !NO_IOMEM
342         select GENERIC_IO
343         default y
345 config HAS_IOPORT
346         boolean
347         depends on HAS_IOMEM && !NO_IOPORT
348         default y
350 config HAS_DMA
351         boolean
352         depends on !NO_DMA
353         default y
355 config CHECK_SIGNATURE
356         bool
358 config CPUMASK_OFFSTACK
359         bool "Force CPU masks off stack" if DEBUG_PER_CPU_MAPS
360         help
361           Use dynamic allocation for cpumask_var_t, instead of putting
362           them on the stack.  This is a bit more expensive, but avoids
363           stack overflow.
365 config DISABLE_OBSOLETE_CPUMASK_FUNCTIONS
366        bool "Disable obsolete cpumask functions" if DEBUG_PER_CPU_MAPS
367        depends on BROKEN
369 config CPU_RMAP
370         bool
371         depends on SMP
373 config DQL
374         bool
377 # Netlink attribute parsing support is select'ed if needed
379 config NLATTR
380         bool
383 # Generic 64-bit atomic support is selected if needed
385 config GENERIC_ATOMIC64
386        bool
388 config ARCH_HAS_ATOMIC64_DEC_IF_POSITIVE
389         def_bool y if GENERIC_ATOMIC64
391 config LRU_CACHE
392         tristate
394 config AVERAGE
395         bool "Averaging functions"
396         help
397           This option is provided for the case where no in-kernel-tree
398           modules require averaging functions, but a module built outside
399           the kernel tree does. Such modules that use library averaging
400           functions require Y here.
402           If unsure, say N.
404 config CLZ_TAB
405         bool
407 config CORDIC
408         tristate "CORDIC algorithm"
409         help
410           This option provides an implementation of the CORDIC algorithm;
411           calculations are in fixed point. Module will be called cordic.
413 config DDR
414         bool "JEDEC DDR data"
415         help
416           Data from JEDEC specs for DDR SDRAM memories,
417           particularly the AC timing parameters and addressing
418           information. This data is useful for drivers handling
419           DDR SDRAM controllers.
421 config MPILIB
422         tristate
423         select CLZ_TAB
424         help
425           Multiprecision maths library from GnuPG.
426           It is used to implement RSA digital signature verification,
427           which is used by IMA/EVM digital signature extension.
429 config SIGNATURE
430         tristate
431         depends on KEYS && CRYPTO
432         select CRYPTO_SHA1
433         select MPILIB
434         help
435           Digital signature verification. Currently only RSA is supported.
436           Implementation is done using GnuPG MPI library
439 # libfdt files, only selected if needed.
441 config LIBFDT
442         bool
444 config OID_REGISTRY
445         tristate
446         help
447           Enable fast lookup object identifier registry.
449 config UCS2_STRING
450         tristate
452 source "lib/fonts/Kconfig"
454 endmenu