blob: a9e56539bd11687881ec3e43c1e11cd85d8a4157 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001#
2# Library configuration
3#
4
Lai Jiangshan4370aa42009-03-06 17:21:46 +01005config BINARY_PRINTF
6 def_bool n
7
Linus Torvalds1da177e2005-04-16 15:20:36 -07008menu "Library routines"
9
David Woodhousef5e70d02009-07-13 11:35:12 +010010config RAID6_PQ
11 tristate
12
Daniel Verkampbe85f932018-11-12 15:26:52 -080013config RAID6_PQ_BENCHMARK
14 bool "Automatically choose fastest RAID6 PQ functions"
15 depends on RAID6_PQ
16 default y
17 help
18 Benchmark all available RAID6 PQ functions on init and choose the
19 fastest one.
20
Akinobu Mitaa5cfc1ec582006-12-08 02:36:25 -080021config BITREVERSE
22 tristate
23
Yalin Wang556d2f02014-11-03 03:01:03 +010024config HAVE_ARCH_BITREVERSE
Christoph Jaeger841c0092015-02-16 16:00:20 -080025 bool
Yalin Wang556d2f02014-11-03 03:01:03 +010026 default n
27 depends on BITREVERSE
28 help
Andrew Morton9e522c02015-04-16 12:49:07 -070029 This option enables the use of hardware bit-reversal instructions on
30 architectures which support such operations.
Yalin Wang556d2f02014-11-03 03:01:03 +010031
Oskar Schirmer8759ef32009-06-11 14:51:15 +010032config RATIONAL
Christoph Jaeger6341e622014-12-20 15:41:11 -050033 bool
Oskar Schirmer8759ef32009-06-11 14:51:15 +010034
David S. Miller29225852012-05-24 13:12:28 -070035config GENERIC_STRNCPY_FROM_USER
36 bool
37
Linus Torvaldsa08c5352012-05-26 11:06:38 -070038config GENERIC_STRNLEN_USER
39 bool
40
Andy Shevchenko4cd57732013-06-04 19:46:26 +030041config GENERIC_NET_UTILS
42 bool
43
Alexander van Heukelum19870de2008-04-25 13:12:53 +020044config GENERIC_FIND_FIRST_BIT
Jan Beulich9ba16082008-10-15 22:01:38 -070045 bool
Alexander van Heukelum19870de2008-04-25 13:12:53 +020046
Michael S. Tsirkinb9236502012-01-30 00:20:48 +020047config NO_GENERIC_PCI_IOPORT_MAP
48 bool
49
Michael S. Tsirkin66eab4d2011-11-24 20:45:20 +020050config GENERIC_PCI_IOMAP
51 bool
52
Michael S. Tsirkin4673ca82011-11-24 14:54:28 +020053config GENERIC_IOMAP
54 bool
Michael S. Tsirkin66eab4d2011-11-24 20:45:20 +020055 select GENERIC_PCI_IOMAP
Michael S. Tsirkin4673ca82011-11-24 14:54:28 +020056
Wolfram Sang4ccf4be2011-08-31 20:35:40 +020057config STMP_DEVICE
58 bool
59
Linus Torvaldsbc08b442013-09-02 12:12:15 -070060config ARCH_USE_CMPXCHG_LOCKREF
61 bool
62
Linus Torvalds72d93102014-09-13 11:14:53 -070063config ARCH_HAS_FAST_MULTIPLIER
64 bool
65
Zhichang Yuan031e3602018-03-15 02:15:50 +080066config INDIRECT_PIO
67 bool "Access I/O in non-MMIO mode"
68 depends on ARM64
69 help
70 On some platforms where no separate I/O space exists, there are I/O
71 hosts which can not be accessed in MMIO mode. Using the logical PIO
72 mechanism, the host-local I/O resource can be mapped into system
73 logic PIO space shared with MMIO hosts, such as PCI/PCIe, then the
74 system can access the I/O devices with the mapped-logic PIO through
75 I/O accessors.
76
77 This way has relatively little I/O performance cost. Please make
78 sure your devices really need this configure item enabled.
79
80 When in doubt, say N.
81
Linus Torvalds1da177e2005-04-16 15:20:36 -070082config CRC_CCITT
83 tristate "CRC-CCITT functions"
84 help
85 This option is provided for the case where no in-kernel-tree
86 modules require CRC-CCITT functions, but a module built outside
87 the kernel tree does. Such modules that use library CRC-CCITT
88 functions require M here.
89
Evgeniy Polyakov7657ec12005-08-17 15:17:26 +040090config CRC16
91 tristate "CRC16 functions"
92 help
93 This option is provided for the case where no in-kernel-tree
94 modules require CRC16 functions, but a module built outside
95 the kernel tree does. Such modules that use library CRC16
96 functions require M here.
97
Martin K. Petersenf11f5942008-06-25 11:22:42 -040098config CRC_T10DIF
99 tristate "CRC calculation for the T10 Data Integrity Field"
Herbert Xu684115212013-09-07 12:56:26 +1000100 select CRYPTO
101 select CRYPTO_CRCT10DIF
Martin K. Petersenf11f5942008-06-25 11:22:42 -0400102 help
103 This option is only needed if a module that's not in the
104 kernel tree needs to calculate CRC checks for use with the
105 SCSI data integrity subsystem.
106
Ivo van Doorn3e7cbae2006-06-12 16:17:04 +0200107config CRC_ITU_T
108 tristate "CRC ITU-T V.41 functions"
109 help
110 This option is provided for the case where no in-kernel-tree
111 modules require CRC ITU-T V.41 functions, but a module built outside
112 the kernel tree does. Such modules that use library CRC ITU-T V.41
113 functions require M here.
114
Linus Torvalds1da177e2005-04-16 15:20:36 -0700115config CRC32
Darrick J. Wong46c58012012-03-23 15:02:25 -0700116 tristate "CRC32/CRC32c functions"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700117 default y
Akinobu Mita906d66d2006-12-08 02:36:25 -0800118 select BITREVERSE
Linus Torvalds1da177e2005-04-16 15:20:36 -0700119 help
120 This option is provided for the case where no in-kernel-tree
Darrick J. Wong46c58012012-03-23 15:02:25 -0700121 modules require CRC32/CRC32c functions, but a module built outside
122 the kernel tree does. Such modules that use library CRC32/CRC32c
123 functions require M here.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700124
Bob Pearson3863ef32012-03-23 15:02:22 -0700125config CRC32_SELFTEST
Geert Uytterhoeven5fb7f872017-02-24 15:00:49 -0800126 tristate "CRC32 perform self test on init"
Bob Pearson3863ef32012-03-23 15:02:22 -0700127 depends on CRC32
128 help
129 This option enables the CRC32 library functions to perform a
130 self test on initialization. The self test computes crc32_le
131 and crc32_be over byte strings with random alignment and length
132 and computes the total elapsed time and number of bytes processed.
133
Darrick J. Wong5cde7652012-03-23 15:02:26 -0700134choice
135 prompt "CRC32 implementation"
136 depends on CRC32
137 default CRC32_SLICEBY8
Darrick J. Wong82edb4b2012-03-28 14:42:56 -0700138 help
139 This option allows a kernel builder to override the default choice
140 of CRC32 algorithm. Choose the default ("slice by 8") unless you
141 know that you need one of the others.
Darrick J. Wong5cde7652012-03-23 15:02:26 -0700142
143config CRC32_SLICEBY8
144 bool "Slice by 8 bytes"
145 help
146 Calculate checksum 8 bytes at a time with a clever slicing algorithm.
147 This is the fastest algorithm, but comes with a 8KiB lookup table.
148 Most modern processors have enough cache to hold this table without
149 thrashing the cache.
150
151 This is the default implementation choice. Choose this one unless
152 you have a good reason not to.
153
154config CRC32_SLICEBY4
155 bool "Slice by 4 bytes"
156 help
157 Calculate checksum 4 bytes at a time with a clever slicing algorithm.
158 This is a bit slower than slice by 8, but has a smaller 4KiB lookup
159 table.
160
161 Only choose this option if you know what you are doing.
162
163config CRC32_SARWATE
164 bool "Sarwate's Algorithm (one byte at a time)"
165 help
166 Calculate checksum a byte at a time using Sarwate's algorithm. This
167 is not particularly fast, but has a small 256 byte lookup table.
168
169 Only choose this option if you know what you are doing.
170
171config CRC32_BIT
172 bool "Classic Algorithm (one bit at a time)"
173 help
174 Calculate checksum one bit at a time. This is VERY slow, but has
175 no lookup table. This is provided as a debugging option.
176
177 Only choose this option if you are debugging crc32.
178
179endchoice
180
Coly Lifeba04f2018-08-21 21:57:11 -0700181config CRC64
182 tristate "CRC64 functions"
183 help
184 This option is provided for the case where no in-kernel-tree
185 modules require CRC64 functions, but a module built outside
186 the kernel tree does. Such modules that use library CRC64
187 functions require M here.
188
Jeremy Kerr0cbaa442017-06-06 16:08:39 -0500189config CRC4
190 tristate "CRC4 functions"
191 help
192 This option is provided for the case where no in-kernel-tree
193 modules require CRC4 functions, but a module built outside
194 the kernel tree does. Such modules that use library CRC4
195 functions require M here.
196
Jan Nikitenkoad241522007-07-17 04:04:03 -0700197config CRC7
198 tristate "CRC7 functions"
199 help
200 This option is provided for the case where no in-kernel-tree
201 modules require CRC7 functions, but a module built outside
202 the kernel tree does. Such modules that use library CRC7
203 functions require M here.
204
Linus Torvalds1da177e2005-04-16 15:20:36 -0700205config LIBCRC32C
206 tristate "CRC32c (Castagnoli, et al) Cyclic Redundancy-Check"
Herbert Xu93027352008-11-13 22:05:13 +0800207 select CRYPTO
Herbert Xu69c35ef2008-11-07 15:11:47 +0800208 select CRYPTO_CRC32C
Linus Torvalds1da177e2005-04-16 15:20:36 -0700209 help
210 This option is provided for the case where no in-kernel-tree
211 modules require CRC32c functions, but a module built outside the
212 kernel tree does. Such modules that use library CRC32c functions
213 require M here. See Castagnoli93.
214 Module will be libcrc32c.
215
Arend van Spriel71509622011-05-31 11:22:15 +0200216config CRC8
217 tristate "CRC8 function"
218 help
219 This option provides CRC8 function. Drivers may select this
220 when they need to do cyclic redundancy check according CRC8
221 algorithm. Module will be called crc8.
222
Nick Terrell5d240522017-08-04 13:19:17 -0700223config XXHASH
224 tristate
225
Al Viroe65e1fc2006-09-12 03:04:40 -0400226config AUDIT_GENERIC
227 bool
228 depends on AUDIT && !AUDIT_ARCH
229 default y
230
AKASHI Takahiro4b588412014-03-15 14:48:00 +0900231config AUDIT_ARCH_COMPAT_GENERIC
232 bool
233 default n
234
235config AUDIT_COMPAT_GENERIC
236 bool
237 depends on AUDIT_GENERIC && AUDIT_ARCH_COMPAT_GENERIC && COMPAT
238 default y
239
Daniel Borkmanna6a9c0f2013-11-11 12:20:37 +0100240config RANDOM32_SELFTEST
241 bool "PRNG perform self test on init"
Daniel Borkmanna6a9c0f2013-11-11 12:20:37 +0100242 help
243 This option enables the 32 bit PRNG library functions to perform a
244 self test on initialization.
245
Linus Torvalds1da177e2005-04-16 15:20:36 -0700246#
247# compression support is select'ed if needed
248#
Dan Streetman2da572c2015-05-07 13:49:14 -0400249config 842_COMPRESS
Arnd Bergmann5b571672016-01-13 23:24:02 +0100250 select CRC32
Dan Streetman2da572c2015-05-07 13:49:14 -0400251 tristate
252
253config 842_DECOMPRESS
Arnd Bergmann5b571672016-01-13 23:24:02 +0100254 select CRC32
Dan Streetman2da572c2015-05-07 13:49:14 -0400255 tristate
256
Linus Torvalds1da177e2005-04-16 15:20:36 -0700257config ZLIB_INFLATE
258 tristate
259
260config ZLIB_DEFLATE
261 tristate
Andrew Morton1fd4e5c2015-10-15 15:28:35 -0700262 select BITREVERSE
Linus Torvalds1da177e2005-04-16 15:20:36 -0700263
Richard Purdie64c70b12007-07-10 17:22:24 -0700264config LZO_COMPRESS
265 tristate
266
267config LZO_DECOMPRESS
268 tristate
269
Chanho Minc72ac7a2013-07-08 16:01:49 -0700270config LZ4_COMPRESS
271 tristate
272
273config LZ4HC_COMPRESS
274 tristate
275
Kyungsik Leee76e1fd2013-07-08 16:01:46 -0700276config LZ4_DECOMPRESS
277 tristate
278
Nick Terrell73f3d1b2017-08-09 19:35:53 -0700279config ZSTD_COMPRESS
280 select XXHASH
281 tristate
282
283config ZSTD_DECOMPRESS
284 select XXHASH
285 tristate
286
Lasse Collin24fa0402011-01-12 17:01:22 -0800287source "lib/xz/Kconfig"
288
Linus Torvalds1da177e2005-04-16 15:20:36 -0700289#
H. Peter Anvinc8531ab2009-01-05 13:48:31 -0800290# These all provide a common interface (hence the apparent duplication with
291# ZLIB_INFLATE; DECOMPRESS_GZIP is just a wrapper.)
292#
293config DECOMPRESS_GZIP
H. Peter Anvin7856a16e2009-01-07 00:01:43 -0800294 select ZLIB_INFLATE
H. Peter Anvinc8531ab2009-01-05 13:48:31 -0800295 tristate
296
297config DECOMPRESS_BZIP2
298 tristate
299
300config DECOMPRESS_LZMA
301 tristate
302
Lasse Collin3ebe1242011-01-12 17:01:23 -0800303config DECOMPRESS_XZ
304 select XZ_DEC
305 tristate
306
Albin Tonnerrecacb2462010-01-08 14:42:46 -0800307config DECOMPRESS_LZO
308 select LZO_DECOMPRESS
309 tristate
310
Kyungsik Leee76e1fd2013-07-08 16:01:46 -0700311config DECOMPRESS_LZ4
312 select LZ4_DECOMPRESS
313 tristate
314
H. Peter Anvinc8531ab2009-01-05 13:48:31 -0800315#
Jes Sorensenf14f75b2005-06-21 17:15:02 -0700316# Generic allocator support is selected if needed
317#
318config GENERIC_ALLOCATOR
Christoph Jaeger6341e622014-12-20 15:41:11 -0500319 bool
Jes Sorensenf14f75b2005-06-21 17:15:02 -0700320
321#
Linus Torvalds1da177e2005-04-16 15:20:36 -0700322# reed solomon support is select'ed if needed
323#
324config REED_SOLOMON
325 tristate
326
327config REED_SOLOMON_ENC8
Christoph Jaeger6341e622014-12-20 15:41:11 -0500328 bool
Linus Torvalds1da177e2005-04-16 15:20:36 -0700329
330config REED_SOLOMON_DEC8
Christoph Jaeger6341e622014-12-20 15:41:11 -0500331 bool
Linus Torvalds1da177e2005-04-16 15:20:36 -0700332
333config REED_SOLOMON_ENC16
Christoph Jaeger6341e622014-12-20 15:41:11 -0500334 bool
Linus Torvalds1da177e2005-04-16 15:20:36 -0700335
336config REED_SOLOMON_DEC16
Christoph Jaeger6341e622014-12-20 15:41:11 -0500337 bool
Linus Torvalds1da177e2005-04-16 15:20:36 -0700338
David S. Millerf7704342005-06-24 17:39:03 -0700339#
Ivan Djelic437aa562011-03-11 11:05:32 +0100340# BCH support is selected if needed
341#
342config BCH
343 tristate
344
345config BCH_CONST_PARAMS
Christoph Jaeger6341e622014-12-20 15:41:11 -0500346 bool
Ivan Djelic437aa562011-03-11 11:05:32 +0100347 help
348 Drivers may select this option to force specific constant
349 values for parameters 'm' (Galois field order) and 't'
350 (error correction capability). Those specific values must
351 be set by declaring default values for symbols BCH_CONST_M
352 and BCH_CONST_T.
353 Doing so will enable extra compiler optimizations,
354 improving encoding and decoding performance up to 2x for
355 usual (m,t) values (typically such that m*t < 200).
356 When this option is selected, the BCH library supports
357 only a single (m,t) configuration. This is mainly useful
358 for NAND flash board drivers requiring known, fixed BCH
359 parameters.
360
361config BCH_CONST_M
362 int
363 range 5 15
364 help
365 Constant value for Galois field order 'm'. If 'k' is the
366 number of data bits to protect, 'm' should be chosen such
367 that (k + m*t) <= 2**m - 1.
368 Drivers should declare a default value for this symbol if
369 they select option BCH_CONST_PARAMS.
370
371config BCH_CONST_T
372 int
373 help
374 Constant value for error correction capability in bits 't'.
375 Drivers should declare a default value for this symbol if
376 they select option BCH_CONST_PARAMS.
377
378#
David S. Millerf7704342005-06-24 17:39:03 -0700379# Textsearch support is select'ed if needed
380#
Thomas Graf2de4ff72005-06-23 20:49:30 -0700381config TEXTSEARCH
Christoph Jaeger6341e622014-12-20 15:41:11 -0500382 bool
Linus Torvalds1da177e2005-04-16 15:20:36 -0700383
Thomas Grafdf3fb932005-06-23 20:58:37 -0700384config TEXTSEARCH_KMP
David S. Millerf7704342005-06-24 17:39:03 -0700385 tristate
Thomas Grafdf3fb932005-06-23 20:58:37 -0700386
Pablo Neira Ayuso8082e4e2005-08-25 16:12:22 -0700387config TEXTSEARCH_BM
David S. Miller29cb9f92005-08-25 16:23:11 -0700388 tristate
Pablo Neira Ayuso8082e4e2005-08-25 16:12:22 -0700389
Thomas Graf6408f792005-06-23 20:59:16 -0700390config TEXTSEARCH_FSM
David S. Millerf7704342005-06-24 17:39:03 -0700391 tristate
Thomas Graf6408f792005-06-23 20:59:16 -0700392
Joern Engel5db53f32009-11-20 20:13:39 +0100393config BTREE
Christoph Jaeger6341e622014-12-20 15:41:11 -0500394 bool
Joern Engel5db53f32009-11-20 20:13:39 +0100395
Chris Wilsona88cc102014-03-17 12:21:54 +0000396config INTERVAL_TREE
Christoph Jaeger6341e622014-12-20 15:41:11 -0500397 bool
Chris Wilsona88cc102014-03-17 12:21:54 +0000398 help
399 Simple, embeddable, interval-tree. Can find the start of an
400 overlapping range in log(n) time and then iterate over all
401 overlapping nodes. The algorithm is implemented as an
402 augmented rbtree.
403
404 See:
405
406 Documentation/rbtree.txt
407
408 for more information.
409
Matthew Wilcox02c02bf2017-11-03 23:09:45 -0400410config XARRAY_MULTI
Matthew Wilcox57578c22016-05-20 17:01:54 -0700411 bool
Matthew Wilcox02c02bf2017-11-03 23:09:45 -0400412 help
413 Support entries which occupy multiple consecutive indices in the
414 XArray.
Matthew Wilcox57578c22016-05-20 17:01:54 -0700415
David Howells3cb98952013-09-24 10:35:17 +0100416config ASSOCIATIVE_ARRAY
417 bool
418 help
419 Generic associative array. Can be searched and iterated over whilst
420 it is being modified. It is also reasonably quick to search and
421 modify. The algorithms are non-recursive, and the trees are highly
422 capacious.
423
424 See:
425
Mauro Carvalho Chehab5fb94e92018-05-08 15:14:57 -0300426 Documentation/core-api/assoc_array.rst
David Howells3cb98952013-09-24 10:35:17 +0100427
428 for more information.
429
Al Viro5ea81762007-02-11 15:41:31 +0000430config HAS_IOMEM
Christoph Jaeger6341e622014-12-20 15:41:11 -0500431 bool
Al Viro5ea81762007-02-11 15:41:31 +0000432 depends on !NO_IOMEM
Richard Weinberger087fafd2012-02-07 01:22:46 +0100433 select GENERIC_IO
Al Viro5ea81762007-02-11 15:41:31 +0000434 default y
435
Uwe Kleine-Königce816fa2014-04-07 15:39:19 -0700436config HAS_IOPORT_MAP
Christoph Jaeger6341e622014-12-20 15:41:11 -0500437 bool
Uwe Kleine-Königce816fa2014-04-07 15:39:19 -0700438 depends on HAS_IOMEM && !NO_IOPORT_MAP
Al Viroee36c2b2006-12-13 00:35:00 -0800439 default y
440
Christoph Hellwigcf65a0f2018-06-12 19:01:45 +0200441source "kernel/dma/Kconfig"
Heiko Carstens411f0f32007-05-06 14:49:09 -0700442
Bart Van Asschee80a0af2018-01-05 08:26:46 -0800443config SGL_ALLOC
444 bool
445 default n
446
Christoph Hellwiga4ce5a42018-04-03 15:47:59 +0200447config IOMMU_HELPER
448 bool
449
Geert Uytterhoeven928923c2007-08-22 14:01:36 -0700450config CHECK_SIGNATURE
451 bool
452
Rusty Russellaab46da2008-12-13 21:20:27 +1030453config CPUMASK_OFFSTACK
454 bool "Force CPU masks off stack" if DEBUG_PER_CPU_MAPS
455 help
456 Use dynamic allocation for cpumask_var_t, instead of putting
457 them on the stack. This is a bit more expensive, but avoids
458 stack overflow.
459
Ben Hutchingsc39649c2011-01-19 11:03:25 +0000460config CPU_RMAP
461 bool
462 depends on SMP
463
Tom Herbert75957ba2011-11-28 16:32:35 +0000464config DQL
465 bool
466
George Spelvinb0125082014-08-06 16:09:23 -0700467config GLOB
468 bool
469# This actually supports modular compilation, but the module overhead
470# is ridiculous for the amount of code involved. Until an out-of-tree
471# driver asks for it, we'll just link it directly it into the kernel
472# when required. Since we're ignoring out-of-tree users, there's also
473# no need bother prompting for a manual decision:
474# prompt "glob_match() function"
475 help
476 This option provides a glob_match function for performing
477 simple text pattern matching. It originated in the ATA code
478 to blacklist particular drive models, but other device drivers
479 may need similar functionality.
480
481 All drivers in the Linux kernel tree that require this function
482 should automatically select this option. Say N unless you
483 are compiling an out-of tree driver which tells you that it
484 depends on this.
485
George Spelvin5f9be822014-08-06 16:09:25 -0700486config GLOB_SELFTEST
Geert Uytterhoevenba95b042017-02-24 15:00:52 -0800487 tristate "glob self-test on init"
George Spelvin5f9be822014-08-06 16:09:25 -0700488 depends on GLOB
489 help
490 This option enables a simple self-test of the glob_match
491 function on startup. It is primarily useful for people
492 working on the code to ensure they haven't introduced any
493 regressions.
494
495 It only adds a little bit of code and slows kernel boot (or
496 module load) by a small amount, so you're welcome to play with
497 it, but you probably don't need it.
498
Geert Uytterhoevene9cc8bd2009-03-04 14:53:30 +0800499#
500# Netlink attribute parsing support is select'ed if needed
501#
502config NLATTR
503 bool
504
Paul Mackerras09d4e0e2009-06-12 21:10:05 +0000505#
506# Generic 64-bit atomic support is selected if needed
507#
508config GENERIC_ATOMIC64
509 bool
510
Philipp Reisnerb411b362009-09-25 16:07:19 -0700511config LRU_CACHE
512 tristate
513
David Millerc6df4b12012-02-02 00:17:54 +0200514config CLZ_TAB
515 bool
516
Arend van Spriel10f81132011-05-31 11:22:16 +0200517config CORDIC
Michael Wittend89ce932011-07-29 12:59:51 +0000518 tristate "CORDIC algorithm"
Arend van Spriel10f81132011-05-31 11:22:16 +0200519 help
Michael Witten435a95c2011-07-29 13:36:04 +0000520 This option provides an implementation of the CORDIC algorithm;
521 calculations are in fixed point. Module will be called cordic.
Arend van Spriel10f81132011-05-31 11:22:16 +0200522
Aneesh V9c1c21a2012-04-27 17:54:03 +0530523config DDR
524 bool "JEDEC DDR data"
525 help
526 Data from JEDEC specs for DDR SDRAM memories,
527 particularly the AC timing parameters and addressing
528 information. This data is useful for drivers handling
529 DDR SDRAM controllers.
530
Christoph Hellwig511cbce2015-11-10 14:56:14 +0100531config IRQ_POLL
532 bool "IRQ polling library"
533 help
534 Helper library to poll interrupt mitigation using polling.
535
Dmitry Kasatkind9c46b12011-08-31 14:05:16 +0300536config MPILIB
Dmitry Kasatkin2e5f0942012-01-17 17:12:06 +0200537 tristate
David Millerc6df4b12012-02-02 00:17:54 +0200538 select CLZ_TAB
Dmitry Kasatkind9c46b12011-08-31 14:05:16 +0300539 help
540 Multiprecision maths library from GnuPG.
541 It is used to implement RSA digital signature verification,
542 which is used by IMA/EVM digital signature extension.
543
Dmitry Kasatkin5e8898e2012-01-17 17:12:03 +0200544config SIGNATURE
Dmitry Kasatkin2e5f0942012-01-17 17:12:06 +0200545 tristate
Dmitry Kasatkin0d1f64f2014-07-11 18:59:45 +0300546 depends on KEYS
547 select CRYPTO
Dmitry Kasatkinbe440ec2012-01-17 17:12:04 +0200548 select CRYPTO_SHA1
Dmitry Kasatkin051dbb92011-10-14 15:25:16 +0300549 select MPILIB
550 help
551 Digital signature verification. Currently only RSA is supported.
552 Implementation is done using GnuPG MPI library
553
David Daneyab253832012-07-05 18:12:38 +0200554#
555# libfdt files, only selected if needed.
556#
557config LIBFDT
558 bool
559
David Howellsa77ad6e2012-09-21 23:30:46 +0100560config OID_REGISTRY
561 tristate
562 help
563 Enable fast lookup object identifier registry.
564
Matthew Garrett0635eb82013-04-15 13:09:45 -0700565config UCS2_STRING
566 tristate
567
Geert Uytterhoevenee89bd62013-06-09 11:46:43 +0200568source "lib/fonts/Kconfig"
569
Robert Jarzmikf8bcbe62015-08-08 10:44:10 +0200570config SG_SPLIT
571 def_bool n
572 help
Geert Uytterhoeven7f7e92f2015-09-04 12:45:05 +0200573 Provides a helper to split scatterlists into chunks, each chunk being
574 a scatterlist. This should be selected by a driver or an API which
575 whishes to split a scatterlist amongst multiple DMA channels.
Robert Jarzmikf8bcbe62015-08-08 10:44:10 +0200576
Ming Lin9b1d6c82016-04-04 14:48:11 -0700577config SG_POOL
578 def_bool n
579 help
580 Provides a helper to allocate chained scatterlists. This should be
581 selected by a driver or an API which whishes to allocate chained
582 scatterlist.
583
Laura Abbott308c09f2014-08-08 14:23:25 -0700584#
585# sg chaining option
586#
587
Christoph Hellwig7c703e52018-11-09 09:51:00 +0100588config ARCH_NO_SG_CHAIN
Laura Abbott308c09f2014-08-08 14:23:25 -0700589 def_bool n
590
Ross Zwisler61031952015-06-25 03:08:39 -0400591config ARCH_HAS_PMEM_API
592 bool
593
Dan Williams0aed55a2017-05-29 12:22:50 -0700594config ARCH_HAS_UACCESS_FLUSHCACHE
595 bool
596
Dan Williams522239b2018-05-22 23:17:03 -0700597config ARCH_HAS_UACCESS_MCSAFE
598 bool
599
Alexander Potapenkocd110162016-03-25 14:22:08 -0700600config STACKDEPOT
601 bool
602 select STACKTRACE
603
Omar Sandoval88459642016-09-17 08:38:44 -0600604config SBITMAP
605 bool
606
Jiri Pirko44091d22017-02-03 10:29:06 +0100607config PARMAN
Geert Uytterhoeven9d25af62017-02-24 11:25:55 +0100608 tristate "parman" if COMPILE_TEST
Jiri Pirko44091d22017-02-03 10:29:06 +0100609
Chris Wilsoncf4a7202016-12-22 14:45:14 +0000610config PRIME_NUMBERS
Dave Airlie64a57712017-02-24 12:11:21 +1000611 tristate
Chris Wilsoncf4a7202016-12-22 14:45:14 +0000612
Matthew Wilcox03270c12017-09-08 16:13:52 -0700613config STRING_SELFTEST
Geert Uytterhoevend6b28e02017-11-17 15:27:56 -0800614 tristate "Test string functions"
Matthew Wilcox03270c12017-09-08 16:13:52 -0700615
Thomas Graf2de4ff72005-06-23 20:49:30 -0700616endmenu
Palmer Dabbeltb35cd982017-05-23 10:28:26 -0700617
Matt Redfearne3d59802018-04-11 08:50:17 +0100618config GENERIC_LIB_ASHLDI3
Palmer Dabbeltb35cd982017-05-23 10:28:26 -0700619 bool
620
Matt Redfearne3d59802018-04-11 08:50:17 +0100621config GENERIC_LIB_ASHRDI3
Palmer Dabbeltb35cd982017-05-23 10:28:26 -0700622 bool
623
Matt Redfearne3d59802018-04-11 08:50:17 +0100624config GENERIC_LIB_LSHRDI3
Palmer Dabbeltb35cd982017-05-23 10:28:26 -0700625 bool
626
Matt Redfearne3d59802018-04-11 08:50:17 +0100627config GENERIC_LIB_MULDI3
Palmer Dabbeltb35cd982017-05-23 10:28:26 -0700628 bool
629
Matt Redfearne3d59802018-04-11 08:50:17 +0100630config GENERIC_LIB_CMPDI2
Palmer Dabbeltb35cd982017-05-23 10:28:26 -0700631 bool
632
Matt Redfearne3d59802018-04-11 08:50:17 +0100633config GENERIC_LIB_UCMPDI2
Palmer Dabbeltb35cd982017-05-23 10:28:26 -0700634 bool
Jiri Pirko0a020d42018-11-14 08:22:28 +0000635
636config OBJAGG
637 tristate "objagg" if COMPILE_TEST