2 # Library configuration
8 menu "Library routines"
19 config GENERIC_STRNCPY_FROM_USER
22 config GENERIC_STRNLEN_USER
25 config GENERIC_NET_UTILS
28 config GENERIC_FIND_FIRST_BIT
31 config NO_GENERIC_PCI_IOPORT_MAP
34 config GENERIC_PCI_IOMAP
39 select GENERIC_PCI_IOMAP
51 config ARCH_USE_CMPXCHG_LOCKREF
55 tristate "CRC-CCITT functions"
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.
63 tristate "CRC16 functions"
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.
71 tristate "CRC calculation for the T10 Data Integrity Field"
73 select CRYPTO_CRCT10DIF
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.
80 tristate "CRC ITU-T V.41 functions"
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.
88 tristate "CRC32/CRC32c functions"
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.
98 bool "CRC32 perform self test on init"
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.
108 prompt "CRC32 implementation"
110 default CRC32_SLICEBY8
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"
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
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"
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
134 Only choose this option if you know what you are doing.
137 bool "Sarwate's Algorithm (one byte at a time)"
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.
145 bool "Classic Algorithm (one bit at a time)"
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.
155 tristate "CRC7 functions"
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.
163 tristate "CRC32c (Castagnoli, et al) Cyclic Redundancy-Check"
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.
174 tristate "CRC8 function"
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.
182 depends on AUDIT && !AUDIT_ARCH
185 config AUDIT_ARCH_COMPAT_GENERIC
189 config AUDIT_COMPAT_GENERIC
191 depends on AUDIT_GENERIC && AUDIT_ARCH_COMPAT_GENERIC && COMPAT
194 config RANDOM32_SELFTEST
195 bool "PRNG perform self test on init"
198 This option enables the 32 bit PRNG library functions to perform a
199 self test on initialization.
202 # compression support is select'ed if needed
213 config LZO_DECOMPRESS
219 config LZ4HC_COMPRESS
222 config LZ4_DECOMPRESS
225 source "lib/xz/Kconfig"
228 # These all provide a common interface (hence the apparent duplication with
229 # ZLIB_INFLATE; DECOMPRESS_GZIP is just a wrapper.)
231 config DECOMPRESS_GZIP
235 config DECOMPRESS_BZIP2
238 config DECOMPRESS_LZMA
245 config DECOMPRESS_LZO
246 select LZO_DECOMPRESS
249 config DECOMPRESS_LZ4
250 select LZ4_DECOMPRESS
254 # Generic allocator support is selected if needed
256 config GENERIC_ALLOCATOR
260 # reed solomon support is select'ed if needed
265 config REED_SOLOMON_ENC8
268 config REED_SOLOMON_DEC8
271 config REED_SOLOMON_ENC16
274 config REED_SOLOMON_DEC16
278 # BCH support is selected if needed
283 config BCH_CONST_PARAMS
286 Drivers may select this option to force specific constant
287 values for parameters 'm' (Galois field order) and 't'
288 (error correction capability). Those specific values must
289 be set by declaring default values for symbols BCH_CONST_M
291 Doing so will enable extra compiler optimizations,
292 improving encoding and decoding performance up to 2x for
293 usual (m,t) values (typically such that m*t < 200).
294 When this option is selected, the BCH library supports
295 only a single (m,t) configuration. This is mainly useful
296 for NAND flash board drivers requiring known, fixed BCH
303 Constant value for Galois field order 'm'. If 'k' is the
304 number of data bits to protect, 'm' should be chosen such
305 that (k + m*t) <= 2**m - 1.
306 Drivers should declare a default value for this symbol if
307 they select option BCH_CONST_PARAMS.
312 Constant value for error correction capability in bits 't'.
313 Drivers should declare a default value for this symbol if
314 they select option BCH_CONST_PARAMS.
317 # Textsearch support is select'ed if needed
322 config TEXTSEARCH_KMP
328 config TEXTSEARCH_FSM
337 Simple, embeddable, interval-tree. Can find the start of an
338 overlapping range in log(n) time and then iterate over all
339 overlapping nodes. The algorithm is implemented as an
344 Documentation/rbtree.txt
346 for more information.
348 config ASSOCIATIVE_ARRAY
351 Generic associative array. Can be searched and iterated over whilst
352 it is being modified. It is also reasonably quick to search and
353 modify. The algorithms are non-recursive, and the trees are highly
358 Documentation/assoc_array.txt
360 for more information.
368 config HAS_IOPORT_MAP
370 depends on HAS_IOMEM && !NO_IOPORT_MAP
378 config CHECK_SIGNATURE
381 config CPUMASK_OFFSTACK
382 bool "Force CPU masks off stack" if DEBUG_PER_CPU_MAPS
384 Use dynamic allocation for cpumask_var_t, instead of putting
385 them on the stack. This is a bit more expensive, but avoids
388 config DISABLE_OBSOLETE_CPUMASK_FUNCTIONS
389 bool "Disable obsolete cpumask functions" if DEBUG_PER_CPU_MAPS
400 # Netlink attribute parsing support is select'ed if needed
406 # Generic 64-bit atomic support is selected if needed
408 config GENERIC_ATOMIC64
411 config ARCH_HAS_ATOMIC64_DEC_IF_POSITIVE
412 def_bool y if GENERIC_ATOMIC64
418 bool "Averaging functions"
420 This option is provided for the case where no in-kernel-tree
421 modules require averaging functions, but a module built outside
422 the kernel tree does. Such modules that use library averaging
423 functions require Y here.
431 tristate "CORDIC algorithm"
433 This option provides an implementation of the CORDIC algorithm;
434 calculations are in fixed point. Module will be called cordic.
437 bool "JEDEC DDR data"
439 Data from JEDEC specs for DDR SDRAM memories,
440 particularly the AC timing parameters and addressing
441 information. This data is useful for drivers handling
442 DDR SDRAM controllers.
448 Multiprecision maths library from GnuPG.
449 It is used to implement RSA digital signature verification,
450 which is used by IMA/EVM digital signature extension.
454 depends on KEYS && CRYPTO
458 Digital signature verification. Currently only RSA is supported.
459 Implementation is done using GnuPG MPI library
462 # libfdt files, only selected if needed.
470 Enable fast lookup object identifier registry.
475 source "lib/fonts/Kconfig"