tracing: extend sched_pi_setprio
[deliverable/linux.git] / lib / Kconfig
CommitLineData
1da177e4
LT
1#
2# Library configuration
3#
4
4370aa4a
LJ
5config BINARY_PRINTF
6 def_bool n
7
1da177e4
LT
8menu "Library routines"
9
f5e70d0f
DW
10config RAID6_PQ
11 tristate
12
a5cfc1ec
AM
13config BITREVERSE
14 tristate
15
556d2f05 16config HAVE_ARCH_BITREVERSE
841c0090 17 bool
556d2f05
YW
18 default n
19 depends on BITREVERSE
20 help
9e522c0d
AM
21 This option enables the use of hardware bit-reversal instructions on
22 architectures which support such operations.
556d2f05 23
8759ef32 24config RATIONAL
6341e62b 25 bool
8759ef32 26
2922585b
DM
27config GENERIC_STRNCPY_FROM_USER
28 bool
29
a08c5356
LT
30config GENERIC_STRNLEN_USER
31 bool
32
4cd5773a
AS
33config GENERIC_NET_UTILS
34 bool
35
19870def 36config GENERIC_FIND_FIRST_BIT
9ba16087 37 bool
19870def 38
b923650b
MT
39config NO_GENERIC_PCI_IOPORT_MAP
40 bool
41
66eab4df
MT
42config GENERIC_PCI_IOMAP
43 bool
44
4673ca8e
MT
45config GENERIC_IOMAP
46 bool
66eab4df 47 select GENERIC_PCI_IOMAP
4673ca8e 48
087fafd1 49config GENERIC_IO
6341e62b 50 bool
087fafd1
RW
51 default n
52
4ccf4bea
WS
53config STMP_DEVICE
54 bool
22b361d1 55
bc08b449
LT
56config ARCH_USE_CMPXCHG_LOCKREF
57 bool
58
72d93104
LT
59config ARCH_HAS_FAST_MULTIPLIER
60 bool
61
1da177e4
LT
62config CRC_CCITT
63 tristate "CRC-CCITT functions"
64 help
65 This option is provided for the case where no in-kernel-tree
66 modules require CRC-CCITT functions, but a module built outside
67 the kernel tree does. Such modules that use library CRC-CCITT
68 functions require M here.
69
7657ec1f
EP
70config CRC16
71 tristate "CRC16 functions"
72 help
73 This option is provided for the case where no in-kernel-tree
74 modules require CRC16 functions, but a module built outside
75 the kernel tree does. Such modules that use library CRC16
76 functions require M here.
77
f11f594e
MP
78config CRC_T10DIF
79 tristate "CRC calculation for the T10 Data Integrity Field"
68411521
HX
80 select CRYPTO
81 select CRYPTO_CRCT10DIF
f11f594e
MP
82 help
83 This option is only needed if a module that's not in the
84 kernel tree needs to calculate CRC checks for use with the
85 SCSI data integrity subsystem.
86
3e7cbae7
ID
87config CRC_ITU_T
88 tristate "CRC ITU-T V.41 functions"
89 help
90 This option is provided for the case where no in-kernel-tree
91 modules require CRC ITU-T V.41 functions, but a module built outside
92 the kernel tree does. Such modules that use library CRC ITU-T V.41
93 functions require M here.
94
1da177e4 95config CRC32
46c5801e 96 tristate "CRC32/CRC32c functions"
1da177e4 97 default y
906d66df 98 select BITREVERSE
1da177e4
LT
99 help
100 This option is provided for the case where no in-kernel-tree
46c5801e
DW
101 modules require CRC32/CRC32c functions, but a module built outside
102 the kernel tree does. Such modules that use library CRC32/CRC32c
103 functions require M here.
1da177e4 104
3863ef31
BP
105config CRC32_SELFTEST
106 bool "CRC32 perform self test on init"
107 default n
108 depends on CRC32
109 help
110 This option enables the CRC32 library functions to perform a
111 self test on initialization. The self test computes crc32_le
112 and crc32_be over byte strings with random alignment and length
113 and computes the total elapsed time and number of bytes processed.
114
5cde7656
DW
115choice
116 prompt "CRC32 implementation"
117 depends on CRC32
118 default CRC32_SLICEBY8
82edb4ba
DW
119 help
120 This option allows a kernel builder to override the default choice
121 of CRC32 algorithm. Choose the default ("slice by 8") unless you
122 know that you need one of the others.
5cde7656
DW
123
124config CRC32_SLICEBY8
125 bool "Slice by 8 bytes"
126 help
127 Calculate checksum 8 bytes at a time with a clever slicing algorithm.
128 This is the fastest algorithm, but comes with a 8KiB lookup table.
129 Most modern processors have enough cache to hold this table without
130 thrashing the cache.
131
132 This is the default implementation choice. Choose this one unless
133 you have a good reason not to.
134
135config CRC32_SLICEBY4
136 bool "Slice by 4 bytes"
137 help
138 Calculate checksum 4 bytes at a time with a clever slicing algorithm.
139 This is a bit slower than slice by 8, but has a smaller 4KiB lookup
140 table.
141
142 Only choose this option if you know what you are doing.
143
144config CRC32_SARWATE
145 bool "Sarwate's Algorithm (one byte at a time)"
146 help
147 Calculate checksum a byte at a time using Sarwate's algorithm. This
148 is not particularly fast, but has a small 256 byte lookup table.
149
150 Only choose this option if you know what you are doing.
151
152config CRC32_BIT
153 bool "Classic Algorithm (one bit at a time)"
154 help
155 Calculate checksum one bit at a time. This is VERY slow, but has
156 no lookup table. This is provided as a debugging option.
157
158 Only choose this option if you are debugging crc32.
159
160endchoice
161
ad241528
JN
162config CRC7
163 tristate "CRC7 functions"
164 help
165 This option is provided for the case where no in-kernel-tree
166 modules require CRC7 functions, but a module built outside
167 the kernel tree does. Such modules that use library CRC7
168 functions require M here.
169
1da177e4
LT
170config LIBCRC32C
171 tristate "CRC32c (Castagnoli, et al) Cyclic Redundancy-Check"
93027354 172 select CRYPTO
69c35efc 173 select CRYPTO_CRC32C
1da177e4
LT
174 help
175 This option is provided for the case where no in-kernel-tree
176 modules require CRC32c functions, but a module built outside the
177 kernel tree does. Such modules that use library CRC32c functions
178 require M here. See Castagnoli93.
179 Module will be libcrc32c.
180
7150962d
AS
181config CRC8
182 tristate "CRC8 function"
183 help
184 This option provides CRC8 function. Drivers may select this
185 when they need to do cyclic redundancy check according CRC8
186 algorithm. Module will be called crc8.
187
274081c0
MC
188config CRC64_ECMA
189 tristate "CRC64 ECMA function"
190 help
191 This option provides CRC64 ECMA function. Drivers may select this
192 when they need to do cyclic redundancy check according to the CRC64
193 ECMA algorithm.
194
e65e1fc2
AV
195config AUDIT_GENERIC
196 bool
197 depends on AUDIT && !AUDIT_ARCH
198 default y
199
4b588411
AT
200config AUDIT_ARCH_COMPAT_GENERIC
201 bool
202 default n
203
204config AUDIT_COMPAT_GENERIC
205 bool
206 depends on AUDIT_GENERIC && AUDIT_ARCH_COMPAT_GENERIC && COMPAT
207 default y
208
a6a9c0f1
DB
209config RANDOM32_SELFTEST
210 bool "PRNG perform self test on init"
211 default n
212 help
213 This option enables the 32 bit PRNG library functions to perform a
214 self test on initialization.
215
1da177e4
LT
216#
217# compression support is select'ed if needed
218#
2da572c9 219config 842_COMPRESS
5b571677 220 select CRC32
2da572c9
DS
221 tristate
222
223config 842_DECOMPRESS
5b571677 224 select CRC32
2da572c9
DS
225 tristate
226
1da177e4
LT
227config ZLIB_INFLATE
228 tristate
229
230config ZLIB_DEFLATE
231 tristate
1fd4e5c3 232 select BITREVERSE
1da177e4 233
64c70b1c
RP
234config LZO_COMPRESS
235 tristate
236
237config LZO_DECOMPRESS
238 tristate
239
c72ac7a1
CM
240config LZ4_COMPRESS
241 tristate
242
243config LZ4HC_COMPRESS
244 tristate
245
e76e1fdf
KL
246config LZ4_DECOMPRESS
247 tristate
248
24fa0402
LC
249source "lib/xz/Kconfig"
250
c8531ab3
PA
251#
252# These all provide a common interface (hence the apparent duplication with
253# ZLIB_INFLATE; DECOMPRESS_GZIP is just a wrapper.)
254#
255config DECOMPRESS_GZIP
7856a16e 256 select ZLIB_INFLATE
c8531ab3
PA
257 tristate
258
259config DECOMPRESS_BZIP2
260 tristate
261
262config DECOMPRESS_LZMA
263 tristate
264
3ebe1243
LC
265config DECOMPRESS_XZ
266 select XZ_DEC
267 tristate
268
cacb246f
AT
269config DECOMPRESS_LZO
270 select LZO_DECOMPRESS
271 tristate
272
e76e1fdf
KL
273config DECOMPRESS_LZ4
274 select LZ4_DECOMPRESS
275 tristate
276
f14f75b8
JS
277#
278# Generic allocator support is selected if needed
279#
280config GENERIC_ALLOCATOR
6341e62b 281 bool
f14f75b8 282
1da177e4
LT
283#
284# reed solomon support is select'ed if needed
285#
286config REED_SOLOMON
287 tristate
288
289config REED_SOLOMON_ENC8
6341e62b 290 bool
1da177e4
LT
291
292config REED_SOLOMON_DEC8
6341e62b 293 bool
1da177e4
LT
294
295config REED_SOLOMON_ENC16
6341e62b 296 bool
1da177e4
LT
297
298config REED_SOLOMON_DEC16
6341e62b 299 bool
1da177e4 300
437aa565
ID
301#
302# BCH support is selected if needed
303#
304config BCH
305 tristate
306
307config BCH_CONST_PARAMS
6341e62b 308 bool
437aa565
ID
309 help
310 Drivers may select this option to force specific constant
311 values for parameters 'm' (Galois field order) and 't'
312 (error correction capability). Those specific values must
313 be set by declaring default values for symbols BCH_CONST_M
314 and BCH_CONST_T.
315 Doing so will enable extra compiler optimizations,
316 improving encoding and decoding performance up to 2x for
317 usual (m,t) values (typically such that m*t < 200).
318 When this option is selected, the BCH library supports
319 only a single (m,t) configuration. This is mainly useful
320 for NAND flash board drivers requiring known, fixed BCH
321 parameters.
322
323config BCH_CONST_M
324 int
325 range 5 15
326 help
327 Constant value for Galois field order 'm'. If 'k' is the
328 number of data bits to protect, 'm' should be chosen such
329 that (k + m*t) <= 2**m - 1.
330 Drivers should declare a default value for this symbol if
331 they select option BCH_CONST_PARAMS.
332
333config BCH_CONST_T
334 int
335 help
336 Constant value for error correction capability in bits 't'.
337 Drivers should declare a default value for this symbol if
338 they select option BCH_CONST_PARAMS.
339
f7704347
DM
340#
341# Textsearch support is select'ed if needed
342#
2de4ff7b 343config TEXTSEARCH
6341e62b 344 bool
1da177e4 345
df3fb93a 346config TEXTSEARCH_KMP
f7704347 347 tristate
df3fb93a 348
8082e4ed 349config TEXTSEARCH_BM
29cb9f9c 350 tristate
8082e4ed 351
6408f79c 352config TEXTSEARCH_FSM
f7704347 353 tristate
6408f79c 354
5db53f3e 355config BTREE
6341e62b 356 bool
5db53f3e 357
a88cc108 358config INTERVAL_TREE
6341e62b 359 bool
a88cc108
CW
360 help
361 Simple, embeddable, interval-tree. Can find the start of an
362 overlapping range in log(n) time and then iterate over all
363 overlapping nodes. The algorithm is implemented as an
364 augmented rbtree.
365
366 See:
367
368 Documentation/rbtree.txt
369
370 for more information.
371
57578c2e
MW
372config RADIX_TREE_MULTIORDER
373 bool
374
3cb98950
DH
375config ASSOCIATIVE_ARRAY
376 bool
377 help
378 Generic associative array. Can be searched and iterated over whilst
379 it is being modified. It is also reasonably quick to search and
380 modify. The algorithms are non-recursive, and the trees are highly
381 capacious.
382
383 See:
384
385 Documentation/assoc_array.txt
386
387 for more information.
388
5ea81769 389config HAS_IOMEM
6341e62b 390 bool
5ea81769 391 depends on !NO_IOMEM
087fafd1 392 select GENERIC_IO
5ea81769
AV
393 default y
394
ce816fa8 395config HAS_IOPORT_MAP
6341e62b 396 bool
ce816fa8 397 depends on HAS_IOMEM && !NO_IOPORT_MAP
ee36c2bf
AV
398 default y
399
411f0f3e 400config HAS_DMA
6341e62b 401 bool
411f0f3e
HC
402 depends on !NO_DMA
403 default y
404
928923c7
GU
405config CHECK_SIGNATURE
406 bool
407
aab46da0
RR
408config CPUMASK_OFFSTACK
409 bool "Force CPU masks off stack" if DEBUG_PER_CPU_MAPS
410 help
411 Use dynamic allocation for cpumask_var_t, instead of putting
412 them on the stack. This is a bit more expensive, but avoids
413 stack overflow.
414
c39649c3
BH
415config CPU_RMAP
416 bool
417 depends on SMP
418
75957ba3
TH
419config DQL
420 bool
421
b0125085
GS
422config GLOB
423 bool
424# This actually supports modular compilation, but the module overhead
425# is ridiculous for the amount of code involved. Until an out-of-tree
426# driver asks for it, we'll just link it directly it into the kernel
427# when required. Since we're ignoring out-of-tree users, there's also
428# no need bother prompting for a manual decision:
429# prompt "glob_match() function"
430 help
431 This option provides a glob_match function for performing
432 simple text pattern matching. It originated in the ATA code
433 to blacklist particular drive models, but other device drivers
434 may need similar functionality.
435
436 All drivers in the Linux kernel tree that require this function
437 should automatically select this option. Say N unless you
438 are compiling an out-of tree driver which tells you that it
439 depends on this.
440
5f9be824
GS
441config GLOB_SELFTEST
442 bool "glob self-test on init"
443 default n
444 depends on GLOB
445 help
446 This option enables a simple self-test of the glob_match
447 function on startup. It is primarily useful for people
448 working on the code to ensure they haven't introduced any
449 regressions.
450
451 It only adds a little bit of code and slows kernel boot (or
452 module load) by a small amount, so you're welcome to play with
453 it, but you probably don't need it.
454
e9cc8bdd
GU
455#
456# Netlink attribute parsing support is select'ed if needed
457#
458config NLATTR
459 bool
460
09d4e0ed
PM
461#
462# Generic 64-bit atomic support is selected if needed
463#
464config GENERIC_ATOMIC64
465 bool
466
7463449b
CM
467config ARCH_HAS_ATOMIC64_DEC_IF_POSITIVE
468 def_bool y if GENERIC_ATOMIC64
469
b411b363
PR
470config LRU_CACHE
471 tristate
472
c6df4b17
DM
473config CLZ_TAB
474 bool
475
10f8113e 476config CORDIC
d89ce936 477 tristate "CORDIC algorithm"
10f8113e 478 help
435a95c5
MW
479 This option provides an implementation of the CORDIC algorithm;
480 calculations are in fixed point. Module will be called cordic.
10f8113e 481
9c1c21a0
A
482config DDR
483 bool "JEDEC DDR data"
484 help
485 Data from JEDEC specs for DDR SDRAM memories,
486 particularly the AC timing parameters and addressing
487 information. This data is useful for drivers handling
488 DDR SDRAM controllers.
489
511cbce2
CH
490config IRQ_POLL
491 bool "IRQ polling library"
492 help
493 Helper library to poll interrupt mitigation using polling.
494
d9c46b18 495config MPILIB
2e5f094b 496 tristate
c6df4b17 497 select CLZ_TAB
d9c46b18
DK
498 help
499 Multiprecision maths library from GnuPG.
500 It is used to implement RSA digital signature verification,
501 which is used by IMA/EVM digital signature extension.
502
5e8898e9 503config SIGNATURE
2e5f094b 504 tristate
0d1f64f6
DK
505 depends on KEYS
506 select CRYPTO
be440ec7 507 select CRYPTO_SHA1
051dbb91
DK
508 select MPILIB
509 help
510 Digital signature verification. Currently only RSA is supported.
511 Implementation is done using GnuPG MPI library
512
ab253839
DD
513#
514# libfdt files, only selected if needed.
515#
516config LIBFDT
517 bool
518
a77ad6ea
DH
519config OID_REGISTRY
520 tristate
521 help
522 Enable fast lookup object identifier registry.
523
0635eb8a
MG
524config UCS2_STRING
525 tristate
526
ee89bd6b
GU
527source "lib/fonts/Kconfig"
528
f8bcbe62
RJ
529config SG_SPLIT
530 def_bool n
531 help
7f7e92f7
GU
532 Provides a helper to split scatterlists into chunks, each chunk being
533 a scatterlist. This should be selected by a driver or an API which
534 whishes to split a scatterlist amongst multiple DMA channels.
f8bcbe62 535
9b1d6c89
ML
536config SG_POOL
537 def_bool n
538 help
539 Provides a helper to allocate chained scatterlists. This should be
540 selected by a driver or an API which whishes to allocate chained
541 scatterlist.
542
308c09f1
LA
543#
544# sg chaining option
545#
546
547config ARCH_HAS_SG_CHAIN
548 def_bool n
549
61031952
RZ
550config ARCH_HAS_PMEM_API
551 bool
552
67a3e8fe
RZ
553config ARCH_HAS_MMIO_FLUSH
554 bool
555
cd11016e
AP
556config STACKDEPOT
557 bool
558 select STACKTRACE
559
2de4ff7b 560endmenu
This page took 0.844753 seconds and 5 git commands to generate.