Kconfig 12.3 KB
Newer Older
Linus Torvalds's avatar
Linus Torvalds committed
1 2 3 4
#
# Library configuration
#

5 6 7
config BINARY_PRINTF
	def_bool n

Linus Torvalds's avatar
Linus Torvalds committed
8 9
menu "Library routines"

10 11 12
config RAID6_PQ
	tristate

13 14 15
config BITREVERSE
	tristate

16
config HAVE_ARCH_BITREVERSE
17
	bool
18 19 20
	default n
	depends on BITREVERSE
	help
21 22
	  This option enables the use of hardware bit-reversal instructions on
	  architectures which support such operations.
23

24
config RATIONAL
25
	bool
26

27 28 29
config GENERIC_STRNCPY_FROM_USER
	bool

30 31 32
config GENERIC_STRNLEN_USER
	bool

33 34 35
config GENERIC_NET_UTILS
	bool

36
config GENERIC_FIND_FIRST_BIT
37
	bool
38

39 40 41
config NO_GENERIC_PCI_IOPORT_MAP
	bool

42 43 44
config GENERIC_PCI_IOMAP
	bool

45 46
config GENERIC_IOMAP
	bool
47
	select GENERIC_PCI_IOMAP
48

49
config GENERIC_IO
50
	bool
51 52
	default n

53 54
config STMP_DEVICE
	bool
55

56 57 58
config ARCH_USE_CMPXCHG_LOCKREF
	bool

59 60 61
config ARCH_HAS_FAST_MULTIPLIER
	bool

Linus Torvalds's avatar
Linus Torvalds committed
62 63 64 65 66 67 68 69
config CRC_CCITT
	tristate "CRC-CCITT functions"
	help
	  This option is provided for the case where no in-kernel-tree
	  modules require CRC-CCITT functions, but a module built outside
	  the kernel tree does. Such modules that use library CRC-CCITT
	  functions require M here.

70 71 72 73 74 75 76 77
config CRC16
	tristate "CRC16 functions"
	help
	  This option is provided for the case where no in-kernel-tree
	  modules require CRC16 functions, but a module built outside
	  the kernel tree does. Such modules that use library CRC16
	  functions require M here.

78 79
config CRC_T10DIF
	tristate "CRC calculation for the T10 Data Integrity Field"
80 81
	select CRYPTO
	select CRYPTO_CRCT10DIF
82 83 84 85 86
	help
	  This option is only needed if a module that's not in the
	  kernel tree needs to calculate CRC checks for use with the
	  SCSI data integrity subsystem.

Ivo van Doorn's avatar
Ivo van Doorn committed
87 88 89 90 91 92 93 94
config CRC_ITU_T
	tristate "CRC ITU-T V.41 functions"
	help
	  This option is provided for the case where no in-kernel-tree
	  modules require CRC ITU-T V.41 functions, but a module built outside
	  the kernel tree does. Such modules that use library CRC ITU-T V.41
	  functions require M here.

Linus Torvalds's avatar
Linus Torvalds committed
95
config CRC32
Darrick J. Wong's avatar
Darrick J. Wong committed
96
	tristate "CRC32/CRC32c functions"
Linus Torvalds's avatar
Linus Torvalds committed
97
	default y
98
	select BITREVERSE
Linus Torvalds's avatar
Linus Torvalds committed
99 100
	help
	  This option is provided for the case where no in-kernel-tree
Darrick J. Wong's avatar
Darrick J. Wong committed
101 102 103
	  modules require CRC32/CRC32c functions, but a module built outside
	  the kernel tree does. Such modules that use library CRC32/CRC32c
	  functions require M here.
Linus Torvalds's avatar
Linus Torvalds committed
104

105
config CRC32_SELFTEST
106
	tristate "CRC32 perform self test on init"
107 108 109 110 111 112 113
	depends on CRC32
	help
	  This option enables the CRC32 library functions to perform a
	  self test on initialization. The self test computes crc32_le
	  and crc32_be over byte strings with random alignment and length
	  and computes the total elapsed time and number of bytes processed.

114 115 116 117
choice
	prompt "CRC32 implementation"
	depends on CRC32
	default CRC32_SLICEBY8
118 119 120 121
	help
	  This option allows a kernel builder to override the default choice
	  of CRC32 algorithm.  Choose the default ("slice by 8") unless you
	  know that you need one of the others.
122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160

config CRC32_SLICEBY8
	bool "Slice by 8 bytes"
	help
	  Calculate checksum 8 bytes at a time with a clever slicing algorithm.
	  This is the fastest algorithm, but comes with a 8KiB lookup table.
	  Most modern processors have enough cache to hold this table without
	  thrashing the cache.

	  This is the default implementation choice.  Choose this one unless
	  you have a good reason not to.

config CRC32_SLICEBY4
	bool "Slice by 4 bytes"
	help
	  Calculate checksum 4 bytes at a time with a clever slicing algorithm.
	  This is a bit slower than slice by 8, but has a smaller 4KiB lookup
	  table.

	  Only choose this option if you know what you are doing.

config CRC32_SARWATE
	bool "Sarwate's Algorithm (one byte at a time)"
	help
	  Calculate checksum a byte at a time using Sarwate's algorithm.  This
	  is not particularly fast, but has a small 256 byte lookup table.

	  Only choose this option if you know what you are doing.

config CRC32_BIT
	bool "Classic Algorithm (one bit at a time)"
	help
	  Calculate checksum one bit at a time.  This is VERY slow, but has
	  no lookup table.  This is provided as a debugging option.

	  Only choose this option if you are debugging crc32.

endchoice

Jan Nikitenko's avatar
Jan Nikitenko committed
161 162 163 164 165 166 167 168
config CRC7
	tristate "CRC7 functions"
	help
	  This option is provided for the case where no in-kernel-tree
	  modules require CRC7 functions, but a module built outside
	  the kernel tree does. Such modules that use library CRC7
	  functions require M here.

Linus Torvalds's avatar
Linus Torvalds committed
169 170
config LIBCRC32C
	tristate "CRC32c (Castagnoli, et al) Cyclic Redundancy-Check"
171
	select CRYPTO
172
	select CRYPTO_CRC32C
Linus Torvalds's avatar
Linus Torvalds committed
173 174 175 176 177 178 179
	help
	  This option is provided for the case where no in-kernel-tree
	  modules require CRC32c functions, but a module built outside the
	  kernel tree does. Such modules that use library CRC32c functions
	  require M here.  See Castagnoli93.
	  Module will be libcrc32c.

180 181 182 183 184 185 186
config CRC8
	tristate "CRC8 function"
	help
	  This option provides CRC8 function. Drivers may select this
	  when they need to do cyclic redundancy check according CRC8
	  algorithm. Module will be called crc8.

187 188 189 190 191
config AUDIT_GENERIC
	bool
	depends on AUDIT && !AUDIT_ARCH
	default y

192 193 194 195 196 197 198 199 200
config AUDIT_ARCH_COMPAT_GENERIC
	bool
	default n

config AUDIT_COMPAT_GENERIC
	bool
	depends on AUDIT_GENERIC && AUDIT_ARCH_COMPAT_GENERIC && COMPAT
	default y

201 202 203 204 205 206 207
config RANDOM32_SELFTEST
	bool "PRNG perform self test on init"
	default n
	help
	  This option enables the 32 bit PRNG library functions to perform a
	  self test on initialization.

Linus Torvalds's avatar
Linus Torvalds committed
208 209 210
#
# compression support is select'ed if needed
#
211
config 842_COMPRESS
Arnd Bergmann's avatar
Arnd Bergmann committed
212
	select CRC32
213 214 215
	tristate

config 842_DECOMPRESS
Arnd Bergmann's avatar
Arnd Bergmann committed
216
	select CRC32
217 218
	tristate

Linus Torvalds's avatar
Linus Torvalds committed
219 220 221 222 223
config ZLIB_INFLATE
	tristate

config ZLIB_DEFLATE
	tristate
224
	select BITREVERSE
Linus Torvalds's avatar
Linus Torvalds committed
225

226 227 228 229 230 231
config LZO_COMPRESS
	tristate

config LZO_DECOMPRESS
	tristate

232 233 234 235 236 237
config LZ4_COMPRESS
	tristate

config LZ4HC_COMPRESS
	tristate

238 239 240
config LZ4_DECOMPRESS
	tristate

241 242
source "lib/xz/Kconfig"

243 244 245 246 247
#
# These all provide a common interface (hence the apparent duplication with
# ZLIB_INFLATE; DECOMPRESS_GZIP is just a wrapper.)
#
config DECOMPRESS_GZIP
248
	select ZLIB_INFLATE
249 250 251 252 253 254 255 256
	tristate

config DECOMPRESS_BZIP2
	tristate

config DECOMPRESS_LZMA
	tristate

257 258 259 260
config DECOMPRESS_XZ
	select XZ_DEC
	tristate

261 262 263 264
config DECOMPRESS_LZO
	select LZO_DECOMPRESS
	tristate

265 266 267 268
config DECOMPRESS_LZ4
	select LZ4_DECOMPRESS
	tristate

269 270 271 272
#
# Generic allocator support is selected if needed
#
config GENERIC_ALLOCATOR
273
	bool
274

Linus Torvalds's avatar
Linus Torvalds committed
275 276 277 278 279 280 281
#
# reed solomon support is select'ed if needed
#
config REED_SOLOMON
	tristate
	
config REED_SOLOMON_ENC8
282
	bool
Linus Torvalds's avatar
Linus Torvalds committed
283 284

config REED_SOLOMON_DEC8
285
	bool
Linus Torvalds's avatar
Linus Torvalds committed
286 287

config REED_SOLOMON_ENC16
288
	bool
Linus Torvalds's avatar
Linus Torvalds committed
289 290

config REED_SOLOMON_DEC16
291
	bool
Linus Torvalds's avatar
Linus Torvalds committed
292

293 294 295 296 297 298 299
#
# BCH support is selected if needed
#
config BCH
	tristate

config BCH_CONST_PARAMS
300
	bool
301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331
	help
	  Drivers may select this option to force specific constant
	  values for parameters 'm' (Galois field order) and 't'
	  (error correction capability). Those specific values must
	  be set by declaring default values for symbols BCH_CONST_M
	  and BCH_CONST_T.
	  Doing so will enable extra compiler optimizations,
	  improving encoding and decoding performance up to 2x for
	  usual (m,t) values (typically such that m*t < 200).
	  When this option is selected, the BCH library supports
	  only a single (m,t) configuration. This is mainly useful
	  for NAND flash board drivers requiring known, fixed BCH
	  parameters.

config BCH_CONST_M
	int
	range 5 15
	help
	  Constant value for Galois field order 'm'. If 'k' is the
	  number of data bits to protect, 'm' should be chosen such
	  that (k + m*t) <= 2**m - 1.
	  Drivers should declare a default value for this symbol if
	  they select option BCH_CONST_PARAMS.

config BCH_CONST_T
	int
	help
	  Constant value for error correction capability in bits 't'.
	  Drivers should declare a default value for this symbol if
	  they select option BCH_CONST_PARAMS.

332 333 334
#
# Textsearch support is select'ed if needed
#
335
config TEXTSEARCH
336
	bool
Linus Torvalds's avatar
Linus Torvalds committed
337

338
config TEXTSEARCH_KMP
339
	tristate
340

341
config TEXTSEARCH_BM
342
	tristate
343

344
config TEXTSEARCH_FSM
345
	tristate
346

347
config BTREE
348
	bool
349

Chris Wilson's avatar
Chris Wilson committed
350
config INTERVAL_TREE
351
	bool
Chris Wilson's avatar
Chris Wilson committed
352 353 354 355 356 357 358 359 360 361 362 363
	help
	  Simple, embeddable, interval-tree. Can find the start of an
	  overlapping range in log(n) time and then iterate over all
	  overlapping nodes. The algorithm is implemented as an
	  augmented rbtree.

	  See:

		Documentation/rbtree.txt

	  for more information.

364 365 366
config RADIX_TREE_MULTIORDER
	bool

367 368 369 370 371 372 373 374 375 376 377 378 379 380
config ASSOCIATIVE_ARRAY
	bool
	help
	  Generic associative array.  Can be searched and iterated over whilst
	  it is being modified.  It is also reasonably quick to search and
	  modify.  The algorithms are non-recursive, and the trees are highly
	  capacious.

	  See:

		Documentation/assoc_array.txt

	  for more information.

381
config HAS_IOMEM
382
	bool
383
	depends on !NO_IOMEM
384
	select GENERIC_IO
385 386
	default y

387
config HAS_IOPORT_MAP
388
	bool
389
	depends on HAS_IOMEM && !NO_IOPORT_MAP
390 391
	default y

392
config HAS_DMA
393
	bool
394 395 396
	depends on !NO_DMA
	default y

397 398 399 400 401
config DMA_NOOP_OPS
	bool
	depends on HAS_DMA && (!64BIT || ARCH_DMA_ADDR_T_64BIT)
	default n

402 403 404 405 406
config DMA_VIRT_OPS
	bool
	depends on HAS_DMA && (!64BIT || ARCH_DMA_ADDR_T_64BIT)
	default n

407 408 409
config CHECK_SIGNATURE
	bool

410 411 412 413 414 415 416
config CPUMASK_OFFSTACK
	bool "Force CPU masks off stack" if DEBUG_PER_CPU_MAPS
	help
	  Use dynamic allocation for cpumask_var_t, instead of putting
	  them on the stack.  This is a bit more expensive, but avoids
	  stack overflow.

417 418 419 420
config CPU_RMAP
	bool
	depends on SMP

Tom Herbert's avatar
Tom Herbert committed
421 422 423
config DQL
	bool

George Spelvin's avatar
George Spelvin committed
424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442
config GLOB
	bool
#	This actually supports modular compilation, but the module overhead
#	is ridiculous for the amount of code involved.	Until an out-of-tree
#	driver asks for it, we'll just link it directly it into the kernel
#	when required.  Since we're ignoring out-of-tree users,	there's also
#	no need bother prompting for a manual decision:
#	prompt "glob_match() function"
	help
	  This option provides a glob_match function for performing
	  simple text pattern matching.  It originated in the ATA code
	  to blacklist particular drive models, but other device drivers
	  may need similar functionality.

	  All drivers in the Linux kernel tree that require this function
	  should automatically select this option.  Say N unless you
	  are compiling an out-of tree driver which tells you that it
	  depends on this.

443
config GLOB_SELFTEST
444
	tristate "glob self-test on init"
445 446 447 448 449 450 451 452 453 454 455
	depends on GLOB
	help
	  This option enables a simple self-test of the glob_match
	  function on startup.	It is primarily useful for people
	  working on the code to ensure they haven't introduced any
	  regressions.

	  It only adds a little bit of code and slows kernel boot (or
	  module load) by a small amount, so you're welcome to play with
	  it, but you probably don't need it.

456 457 458 459 460 461
#
# Netlink attribute parsing support is select'ed if needed
#
config NLATTR
	bool

462 463 464 465 466 467
#
# Generic 64-bit atomic support is selected if needed
#
config GENERIC_ATOMIC64
       bool

Philipp Reisner's avatar
Philipp Reisner committed
468 469 470
config LRU_CACHE
	tristate

471 472 473
config CLZ_TAB
	bool

474
config CORDIC
475
	tristate "CORDIC algorithm"
476
	help
477 478
	  This option provides an implementation of the CORDIC algorithm;
	  calculations are in fixed point. Module will be called cordic.
479

480 481 482 483 484 485 486 487
config DDR
	bool "JEDEC DDR data"
	help
	  Data from JEDEC specs for DDR SDRAM memories,
	  particularly the AC timing parameters and addressing
	  information. This data is useful for drivers handling
	  DDR SDRAM controllers.

488 489 490 491 492
config IRQ_POLL
	bool "IRQ polling library"
	help
	  Helper library to poll interrupt mitigation using polling.

493
config MPILIB
494
	tristate
495
	select CLZ_TAB
496 497 498 499 500
	help
	  Multiprecision maths library from GnuPG.
	  It is used to implement RSA digital signature verification,
	  which is used by IMA/EVM digital signature extension.

501
config SIGNATURE
502
	tristate
503 504
	depends on KEYS
	select CRYPTO
505
	select CRYPTO_SHA1
506 507 508 509 510
	select MPILIB
	help
	  Digital signature verification. Currently only RSA is supported.
	  Implementation is done using GnuPG MPI library

511 512 513 514 515 516
#
# libfdt files, only selected if needed.
#
config LIBFDT
	bool

517 518 519 520 521
config OID_REGISTRY
	tristate
	help
	  Enable fast lookup object identifier registry.

522 523 524
config UCS2_STRING
        tristate

525 526
source "lib/fonts/Kconfig"

527 528 529
config SG_SPLIT
	def_bool n
	help
530 531 532
	 Provides a helper to split scatterlists into chunks, each chunk being
	 a scatterlist. This should be selected by a driver or an API which
	 whishes to split a scatterlist amongst multiple DMA channels.
533

534 535 536 537 538 539 540
config SG_POOL
	def_bool n
	help
	 Provides a helper to allocate chained scatterlists. This should be
	 selected by a driver or an API which whishes to allocate chained
	 scatterlist.

541 542 543 544 545 546 547
#
# sg chaining option
#

config ARCH_HAS_SG_CHAIN
	def_bool n

548 549 550
config ARCH_HAS_PMEM_API
	bool

551 552 553
config ARCH_HAS_MMIO_FLUSH
	bool

554 555 556 557
config STACKDEPOT
	bool
	select STACKTRACE

558 559 560
config SBITMAP
	bool

561
config PARMAN
562
	tristate "parman" if COMPILE_TEST
563

564
config PRIME_NUMBERS
565
	tristate
566

567
endmenu