Kconfig 25.3 KB
Newer Older
1
# SPDX-License-Identifier: GPL-2.0
Linus Torvalds's avatar
Linus Torvalds committed
2
config MMU
3
	def_bool y
Linus Torvalds's avatar
Linus Torvalds committed
4

5 6 7
config CPU_BIG_ENDIAN
	def_bool y

Ingo Molnar's avatar
Ingo Molnar committed
8
config LOCKDEP_SUPPORT
9
	def_bool y
Ingo Molnar's avatar
Ingo Molnar committed
10

11
config STACKTRACE_SUPPORT
12
	def_bool y
13

14
config ARCH_HAS_ILOG2_U32
15
	def_bool n
16 17

config ARCH_HAS_ILOG2_U64
18
	def_bool n
19

20
config GENERIC_HWEIGHT
21
	def_bool y
22

Heiko Carstens's avatar
Heiko Carstens committed
23
config GENERIC_BUG
24
	def_bool y if BUG
Heiko Carstens's avatar
Heiko Carstens committed
25

26 27 28
config GENERIC_BUG_RELATIVE_POINTERS
	def_bool y

29 30 31 32
config GENERIC_CSUM
	bool
	default y if KASAN

33
config GENERIC_LOCKBREAK
34
	def_bool y if PREEMPTION
35

36
config PGSTE
37
	def_bool y if KVM
38

39 40 41
config AUDIT_ARCH
	def_bool y

42
config NO_IOPORT_MAP
43 44 45 46 47
	def_bool y

config PCI_QUIRKS
	def_bool n

48
config ARCH_SUPPORTS_UPROBES
Heiko Carstens's avatar
Heiko Carstens committed
49
	def_bool y
50

51 52 53
config KASAN_SHADOW_OFFSET
	hex
	depends on KASAN
54
	default 0x1C000000000000
55

56
config S390
57
	def_bool y
58 59 60 61
	#
	# Note: keep this list sorted alphabetically
	#
	imply IMA_SECURE_AND_OR_TRUSTED_BOOT
62
	select ALTERNATE_USER_ADDRESS_SPACE
63
	select ARCH_32BIT_USTAT_F_TINODE
64
	select ARCH_BINFMT_ELF_STATE
65
	select ARCH_CORRECT_STACKTRACE_ON_KRETPROBE
66 67
	select ARCH_ENABLE_MEMORY_HOTPLUG if SPARSEMEM
	select ARCH_ENABLE_MEMORY_HOTREMOVE
68
	select ARCH_ENABLE_SPLIT_PMD_PTLOCK if PGTABLE_LEVELS > 2
69
	select ARCH_HAS_CURRENT_STACK_POINTER
70
	select ARCH_HAS_DEBUG_VM_PGTABLE
71
	select ARCH_HAS_DEBUG_WX
72
	select ARCH_HAS_DEVMEM_IS_ALLOWED
73
	select ARCH_HAS_ELF_RANDOMIZE
74
	select ARCH_HAS_FORCE_DMA_UNENCRYPTED
75
	select ARCH_HAS_FORTIFY_SOURCE
76
	select ARCH_HAS_GCOV_PROFILE_ALL
77
	select ARCH_HAS_GIGANTIC_PAGE
Heiko Carstens's avatar
Heiko Carstens committed
78
	select ARCH_HAS_KCOV
79
	select ARCH_HAS_MEMBARRIER_SYNC_CORE
80
	select ARCH_HAS_MEM_ENCRYPT
81
	select ARCH_HAS_NMI_SAFE_THIS_CPU_OPS
82
	select ARCH_HAS_PTE_SPECIAL
83
	select ARCH_HAS_SCALED_CPUTIME
84
	select ARCH_HAS_SET_MEMORY
85 86
	select ARCH_HAS_STRICT_KERNEL_RWX
	select ARCH_HAS_STRICT_MODULE_RWX
87
	select ARCH_HAS_SYSCALL_WRAPPER
Christian Borntraeger's avatar
Christian Borntraeger committed
88
	select ARCH_HAS_UBSAN_SANITIZE_ALL
Sven Schnelle's avatar
Sven Schnelle committed
89
	select ARCH_HAS_VDSO_DATA
90
	select ARCH_HAVE_NMI_SAFE_CMPXCHG
91 92 93 94
	select ARCH_INLINE_READ_LOCK
	select ARCH_INLINE_READ_LOCK_BH
	select ARCH_INLINE_READ_LOCK_IRQ
	select ARCH_INLINE_READ_LOCK_IRQSAVE
95
	select ARCH_INLINE_READ_TRYLOCK
96 97 98 99
	select ARCH_INLINE_READ_UNLOCK
	select ARCH_INLINE_READ_UNLOCK_BH
	select ARCH_INLINE_READ_UNLOCK_IRQ
	select ARCH_INLINE_READ_UNLOCK_IRQRESTORE
100 101 102 103 104 105 106 107 108 109
	select ARCH_INLINE_SPIN_LOCK
	select ARCH_INLINE_SPIN_LOCK_BH
	select ARCH_INLINE_SPIN_LOCK_IRQ
	select ARCH_INLINE_SPIN_LOCK_IRQSAVE
	select ARCH_INLINE_SPIN_TRYLOCK
	select ARCH_INLINE_SPIN_TRYLOCK_BH
	select ARCH_INLINE_SPIN_UNLOCK
	select ARCH_INLINE_SPIN_UNLOCK_BH
	select ARCH_INLINE_SPIN_UNLOCK_IRQ
	select ARCH_INLINE_SPIN_UNLOCK_IRQRESTORE
110 111 112 113
	select ARCH_INLINE_WRITE_LOCK
	select ARCH_INLINE_WRITE_LOCK_BH
	select ARCH_INLINE_WRITE_LOCK_IRQ
	select ARCH_INLINE_WRITE_LOCK_IRQSAVE
114
	select ARCH_INLINE_WRITE_TRYLOCK
115 116 117 118
	select ARCH_INLINE_WRITE_UNLOCK
	select ARCH_INLINE_WRITE_UNLOCK_BH
	select ARCH_INLINE_WRITE_UNLOCK_IRQ
	select ARCH_INLINE_WRITE_UNLOCK_IRQRESTORE
119
	select ARCH_STACKWALK
120
	select ARCH_SUPPORTS_ATOMIC_RMW
121
	select ARCH_SUPPORTS_DEBUG_PAGEALLOC
122
	select ARCH_SUPPORTS_HUGETLBFS
123
	select ARCH_SUPPORTS_NUMA_BALANCING
124
	select ARCH_USE_BUILTIN_BSWAP
125
	select ARCH_USE_CMPXCHG_LOCKREF
126
	select ARCH_WANTS_DYNAMIC_TASK_STRUCT
127
	select ARCH_WANTS_NO_INSTR
128
	select ARCH_WANT_DEFAULT_BPF_JIT
129
	select ARCH_WANT_HUGETLB_PAGE_OPTIMIZE_VMEMMAP
130
	select ARCH_WANT_IPC_PARSE_VERSION
131
	select BUILDTIME_TABLE_SORT
132
	select CLONE_BACKWARDS2
133
	select DMA_OPS if PCI
134
	select DYNAMIC_FTRACE if FUNCTION_TRACER
135 136
	select FUNCTION_ALIGNMENT_8B if CC_IS_GCC
	select FUNCTION_ALIGNMENT_16B if !CC_IS_GCC
137
	select GCC12_NO_ARRAY_BOUNDS
138
	select GENERIC_ALLOCATOR
139
	select GENERIC_CPU_AUTOPROBE
140
	select GENERIC_CPU_VULNERABILITIES
141
	select GENERIC_ENTRY
Sven Schnelle's avatar
Sven Schnelle committed
142
	select GENERIC_GETTIMEOFDAY
143
	select GENERIC_PTDUMP
144
	select GENERIC_SMP_IDLE_THREAD
145
	select GENERIC_TIME_VSYSCALL
146
	select GENERIC_VDSO_TIME_NS
147
	select HAVE_ALIGNED_STRUCT_PAGE if SLUB
148
	select HAVE_ARCH_AUDITSYSCALL
Heiko Carstens's avatar
Heiko Carstens committed
149
	select HAVE_ARCH_JUMP_LABEL
150
	select HAVE_ARCH_JUMP_LABEL_RELATIVE
151
	select HAVE_ARCH_KASAN
152
	select HAVE_ARCH_KASAN_VMALLOC
Ilya Leoshkevich's avatar
Ilya Leoshkevich committed
153
	select HAVE_ARCH_KCSAN
Sven Schnelle's avatar
Sven Schnelle committed
154
	select HAVE_ARCH_KFENCE
155
	select HAVE_ARCH_RANDOMIZE_KSTACK_OFFSET
156
	select HAVE_ARCH_SECCOMP_FILTER
157
	select HAVE_ARCH_SOFT_DIRTY
158
	select HAVE_ARCH_TRACEHOOK
Heiko Carstens's avatar
Heiko Carstens committed
159
	select HAVE_ARCH_TRANSPARENT_HUGEPAGE
160
	select HAVE_ARCH_VMAP_STACK
161
	select HAVE_ASM_MODVERSIONS
162 163 164
	select HAVE_CMPXCHG_DOUBLE
	select HAVE_CMPXCHG_LOCAL
	select HAVE_DEBUG_KMEMLEAK
Heiko Carstens's avatar
Heiko Carstens committed
165
	select HAVE_DMA_CONTIGUOUS
Heiko Carstens's avatar
Heiko Carstens committed
166
	select HAVE_DYNAMIC_FTRACE
167
	select HAVE_DYNAMIC_FTRACE_WITH_ARGS
168
	select HAVE_DYNAMIC_FTRACE_WITH_DIRECT_CALLS
Heiko Carstens's avatar
Heiko Carstens committed
169
	select HAVE_DYNAMIC_FTRACE_WITH_REGS
170
	select HAVE_EBPF_JIT if HAVE_MARCH_Z196_FEATURES
171
	select HAVE_EFFICIENT_UNALIGNED_ACCESS
172
	select HAVE_FAST_GUP
173
	select HAVE_FENTRY
174
	select HAVE_FTRACE_MCOUNT_RECORD
175
	select HAVE_FUNCTION_ARG_ACCESS_API
176
	select HAVE_FUNCTION_ERROR_INJECTION
Heiko Carstens's avatar
Heiko Carstens committed
177 178
	select HAVE_FUNCTION_GRAPH_TRACER
	select HAVE_FUNCTION_TRACER
179
	select HAVE_GCC_PLUGINS
Sven Schnelle's avatar
Sven Schnelle committed
180
	select HAVE_GENERIC_VDSO
181
	select HAVE_IOREMAP_PROT if PCI
182 183
	select HAVE_KERNEL_BZIP2
	select HAVE_KERNEL_GZIP
184
	select HAVE_KERNEL_LZ4
185 186
	select HAVE_KERNEL_LZMA
	select HAVE_KERNEL_LZO
187
	select HAVE_KERNEL_UNCOMPRESSED
188
	select HAVE_KERNEL_XZ
189
	select HAVE_KERNEL_ZSTD
190
	select HAVE_KPROBES
191
	select HAVE_KPROBES_ON_FTRACE
192
	select HAVE_KRETPROBES
Heiko Carstens's avatar
Heiko Carstens committed
193
	select HAVE_KVM
Jiri Slaby's avatar
Jiri Slaby committed
194
	select HAVE_LIVEPATCH
195
	select HAVE_MEMBLOCK_PHYS_MAP
196
	select HAVE_MOD_ARCH_SPECIFIC
197
	select HAVE_NMI
198
	select HAVE_NOP_MCOUNT
199
	select HAVE_PCI
200
	select HAVE_PERF_EVENTS
201 202
	select HAVE_PERF_REGS
	select HAVE_PERF_USER_STACK_DUMP
203
	select HAVE_REGS_AND_STACK_ACCESS_API
204
	select HAVE_RELIABLE_STACKTRACE
205
	select HAVE_RETHOOK
206
	select HAVE_RSEQ
207
	select HAVE_SAMPLE_FTRACE_DIRECT
208
	select HAVE_SAMPLE_FTRACE_DIRECT_MULTI
209
	select HAVE_SETUP_PER_CPU_AREA
210
	select HAVE_SOFTIRQ_ON_OWN_STACK
211 212
	select HAVE_SYSCALL_TRACEPOINTS
	select HAVE_VIRT_CPU_ACCOUNTING
213
	select HAVE_VIRT_CPU_ACCOUNTING_IDLE
214 215
	select IOMMU_HELPER		if PCI
	select IOMMU_SUPPORT		if PCI
216
	select MMU_GATHER_MERGE_VMAS
217 218
	select MMU_GATHER_NO_GATHER
	select MMU_GATHER_RCU_TABLE_FREE
219
	select MODULES_USE_ELF_RELA
220
	select NEED_DMA_MAP_STATE	if PCI
221
	select NEED_PER_CPU_EMBED_FIRST_CHUNK
222
	select NEED_SG_DMA_LENGTH	if PCI
223
	select OLD_SIGACTION
Heiko Carstens's avatar
Heiko Carstens committed
224
	select OLD_SIGSUSPEND3
225
	select PCI_DOMAINS		if PCI
226
	select PCI_MSI			if PCI
227
	select PCI_MSI_ARCH_FALLBACKS	if PCI_MSI
Sebastian Ott's avatar
Sebastian Ott committed
228
	select SPARSE_IRQ
229
	select SWIOTLB
230
	select SYSCTL_EXCEPTION_TRACE
231
	select THREAD_INFO_IN_TASK
232
	select TRACE_IRQFLAGS_SUPPORT
233
	select TTY
234
	select VIRT_CPU_ACCOUNTING
Kefeng Wang's avatar
Kefeng Wang committed
235
	select ZONE_DMA
236
	# Note: keep the above list sorted alphabetically
Linus Torvalds's avatar
Linus Torvalds committed
237

238
config SCHED_OMIT_FRAME_POINTER
239
	def_bool y
240

241 242
config PGTABLE_LEVELS
	int
243
	default 5
244

Jiri Slaby's avatar
Jiri Slaby committed
245 246
source "kernel/livepatch/Kconfig"

247 248 249 250 251 252 253 254 255
menu "Processor type and features"

config HAVE_MARCH_Z10_FEATURES
	def_bool n

config HAVE_MARCH_Z196_FEATURES
	def_bool n
	select HAVE_MARCH_Z10_FEATURES

256 257 258 259
config HAVE_MARCH_ZEC12_FEATURES
	def_bool n
	select HAVE_MARCH_Z196_FEATURES

260 261 262 263
config HAVE_MARCH_Z13_FEATURES
	def_bool n
	select HAVE_MARCH_ZEC12_FEATURES

264 265 266 267
config HAVE_MARCH_Z14_FEATURES
	def_bool n
	select HAVE_MARCH_Z13_FEATURES

268 269 270 271
config HAVE_MARCH_Z15_FEATURES
	def_bool n
	select HAVE_MARCH_Z14_FEATURES

272 273 274 275
config HAVE_MARCH_Z16_FEATURES
	def_bool n
	select HAVE_MARCH_Z15_FEATURES

276 277
choice
	prompt "Processor type"
278
	default MARCH_Z196
Linus Torvalds's avatar
Linus Torvalds committed
279

280 281
config MARCH_Z10
	bool "IBM System z10"
Heiko Carstens's avatar
Heiko Carstens committed
282
	select HAVE_MARCH_Z10_FEATURES
283
	depends on $(cc-option,-march=z10)
284
	help
285 286
	  Select this to enable optimizations for IBM System z10 (2097 and 2098
	  series). This is the oldest machine generation currently supported.
287 288 289

config MARCH_Z196
	bool "IBM zEnterprise 114 and 196"
Heiko Carstens's avatar
Heiko Carstens committed
290
	select HAVE_MARCH_Z196_FEATURES
291
	depends on $(cc-option,-march=z196)
292 293 294 295
	help
	  Select this to enable optimizations for IBM zEnterprise 114 and 196
	  (2818 and 2817 series). The kernel will be slightly faster but will
	  not work on older machines.
Linus Torvalds's avatar
Linus Torvalds committed
296

297
config MARCH_ZEC12
298
	bool "IBM zBC12 and zEC12"
Heiko Carstens's avatar
Heiko Carstens committed
299
	select HAVE_MARCH_ZEC12_FEATURES
300
	depends on $(cc-option,-march=zEC12)
301
	help
302 303 304
	  Select this to enable optimizations for IBM zBC12 and zEC12 (2828 and
	  2827 series). The kernel will be slightly faster but will not work on
	  older machines.
305

306
config MARCH_Z13
307
	bool "IBM z13s and z13"
Heiko Carstens's avatar
Heiko Carstens committed
308
	select HAVE_MARCH_Z13_FEATURES
309
	depends on $(cc-option,-march=z13)
310
	help
311 312 313
	  Select this to enable optimizations for IBM z13s and z13 (2965 and
	  2964 series). The kernel will be slightly faster but will not work on
	  older machines.
314

315
config MARCH_Z14
316
	bool "IBM z14 ZR1 and z14"
317
	select HAVE_MARCH_Z14_FEATURES
318
	depends on $(cc-option,-march=z14)
319
	help
320 321 322
	  Select this to enable optimizations for IBM z14 ZR1 and z14 (3907
	  and 3906 series). The kernel will be slightly faster but will not
	  work on older machines.
323

324 325 326
config MARCH_Z15
	bool "IBM z15"
	select HAVE_MARCH_Z15_FEATURES
327
	depends on $(cc-option,-march=z15)
328 329 330 331 332
	help
	  Select this to enable optimizations for IBM z15 (8562
	  and 8561 series). The kernel will be slightly faster but will not
	  work on older machines.

333 334 335 336 337 338 339 340
config MARCH_Z16
	bool "IBM z16"
	select HAVE_MARCH_Z16_FEATURES
	depends on $(cc-option,-march=z16)
	help
	  Select this to enable optimizations for IBM z16 (3931 and
	  3932 series).

341
endchoice
Linus Torvalds's avatar
Linus Torvalds committed
342

343 344 345 346 347 348 349 350 351
config MARCH_Z10_TUNE
	def_bool TUNE_Z10 || MARCH_Z10 && TUNE_DEFAULT

config MARCH_Z196_TUNE
	def_bool TUNE_Z196 || MARCH_Z196 && TUNE_DEFAULT

config MARCH_ZEC12_TUNE
	def_bool TUNE_ZEC12 || MARCH_ZEC12 && TUNE_DEFAULT

352 353 354
config MARCH_Z13_TUNE
	def_bool TUNE_Z13 || MARCH_Z13 && TUNE_DEFAULT

355 356 357
config MARCH_Z14_TUNE
	def_bool TUNE_Z14 || MARCH_Z14 && TUNE_DEFAULT

358 359 360
config MARCH_Z15_TUNE
	def_bool TUNE_Z15 || MARCH_Z15 && TUNE_DEFAULT

361 362 363
config MARCH_Z16_TUNE
	def_bool TUNE_Z16 || MARCH_Z16 && TUNE_DEFAULT

364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385
choice
	prompt "Tune code generation"
	default TUNE_DEFAULT
	help
	  Cause the compiler to tune (-mtune) the generated code for a machine.
	  This will make the code run faster on the selected machine but
	  somewhat slower on other machines.
	  This option only changes how the compiler emits instructions, not the
	  selection of instructions itself, so the resulting kernel will run on
	  all other machines.

config TUNE_DEFAULT
	bool "Default"
	help
	  Tune the generated code for the target processor for which the kernel
	  will be compiled.

config TUNE_Z10
	bool "IBM System z10"

config TUNE_Z196
	bool "IBM zEnterprise 114 and 196"
386
	depends on $(cc-option,-mtune=z196)
387 388 389

config TUNE_ZEC12
	bool "IBM zBC12 and zEC12"
390
	depends on $(cc-option,-mtune=zEC12)
391

392
config TUNE_Z13
393
	bool "IBM z13s and z13"
394
	depends on $(cc-option,-mtune=z13)
395

396
config TUNE_Z14
397
	bool "IBM z14 ZR1 and z14"
398
	depends on $(cc-option,-mtune=z14)
399

400 401
config TUNE_Z15
	bool "IBM z15"
402
	depends on $(cc-option,-mtune=z15)
403

404 405 406 407
config TUNE_Z16
	bool "IBM z16"
	depends on $(cc-option,-mtune=z16)

408 409
endchoice

410
config 64BIT
411
	def_bool y
412

413 414 415 416 417 418 419 420
config COMMAND_LINE_SIZE
	int "Maximum size of kernel command line"
	default 4096
	range 896 1048576
	help
	  This allows you to specify the maximum length of the kernel command
	  line.

421 422 423 424
config COMPAT
	def_bool y
	prompt "Kernel support for 31 bit emulation"
	select ARCH_WANT_OLD_COMPAT_IPC
425
	select COMPAT_OLD_SIGACTION
426
	select HAVE_UID16
427
	depends on MULTIUSER
428
	depends on !CC_IS_CLANG
429 430 431 432 433 434
	help
	  Select this option if you want to enable your system kernel to
	  handle system-calls from ELF binaries for 31 bit ESA.  This option
	  (and some other stuff like libraries and such) is needed for
	  executing 31 bit applications.  It is safe to say "Y".

Linus Torvalds's avatar
Linus Torvalds committed
435
config SMP
436
	def_bool y
Linus Torvalds's avatar
Linus Torvalds committed
437 438

config NR_CPUS
439 440
	int "Maximum number of CPUs (2-512)"
	range 2 512
Heiko Carstens's avatar
Heiko Carstens committed
441
	default "64"
Linus Torvalds's avatar
Linus Torvalds committed
442 443
	help
	  This allows you to specify the maximum number of CPUs which this
444
	  kernel will support. The maximum supported value is 512 and the
Linus Torvalds's avatar
Linus Torvalds committed
445 446 447 448 449 450
	  minimum value which makes sense is 2.

	  This is purely to save memory - each supported CPU adds
	  approximately sixteen kilobytes to the kernel image.

config HOTPLUG_CPU
451
	def_bool y
Linus Torvalds's avatar
Linus Torvalds committed
452

453 454
config NUMA
	bool "NUMA support"
Heiko Carstens's avatar
Heiko Carstens committed
455
	depends on SCHED_TOPOLOGY
456 457 458 459 460 461 462
	default n
	help
	  Enable NUMA support

	  This option adds NUMA support to the kernel.

config NODES_SHIFT
463
	int
464
	depends on NUMA
465
	default "1"
466 467 468

config SCHED_SMT
	def_bool n
469

470
config SCHED_MC
471
	def_bool n
472

473
config SCHED_BOOK
Martin Schwidefsky's avatar
Martin Schwidefsky committed
474 475
	def_bool n

476 477 478
config SCHED_DRAWER
	def_bool n

Martin Schwidefsky's avatar
Martin Schwidefsky committed
479
config SCHED_TOPOLOGY
480
	def_bool y
Martin Schwidefsky's avatar
Martin Schwidefsky committed
481 482
	prompt "Topology scheduler support"
	select SCHED_SMT
483
	select SCHED_MC
Martin Schwidefsky's avatar
Martin Schwidefsky committed
484
	select SCHED_BOOK
485
	select SCHED_DRAWER
486
	help
Martin Schwidefsky's avatar
Martin Schwidefsky committed
487 488 489
	  Topology scheduler support improves the CPU scheduler's decision
	  making when dealing with machines that have multi-threading,
	  multiple cores or multiple books.
490

491
source "kernel/Kconfig.hz"
Linus Torvalds's avatar
Linus Torvalds committed
492

493 494 495 496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511
config KEXEC
	def_bool y
	select KEXEC_CORE

config KEXEC_FILE
	bool "kexec file based system call"
	select KEXEC_CORE
	depends on CRYPTO
	depends on CRYPTO_SHA256
	depends on CRYPTO_SHA256_S390
	help
	  Enable the kexec file based system call. In contrast to the normal
	  kexec system call this system call takes file descriptors for the
	  kernel and initramfs as arguments.

config ARCH_HAS_KEXEC_PURGATORY
	def_bool y
	depends on KEXEC_FILE

512
config KEXEC_SIG
513
	bool "Verify kernel signature during kexec_file_load() syscall"
514
	depends on KEXEC_FILE && MODULE_SIG_FORMAT
515 516 517 518 519 520 521 522
	help
	  This option makes kernel signature verification mandatory for
	  the kexec_file_load() syscall.

	  In addition to that option, you need to enable signature
	  verification for the corresponding kernel image type being
	  loaded in order for this to work.

523 524 525 526 527 528 529 530 531 532 533 534 535 536 537 538 539
config KERNEL_NOBP
	def_bool n
	prompt "Enable modified branch prediction for the kernel by default"
	help
	  If this option is selected the kernel will switch to a modified
	  branch prediction mode if the firmware interface is available.
	  The modified branch prediction mode improves the behaviour in
	  regard to speculative execution.

	  With the option enabled the kernel parameter "nobp=0" or "nospec"
	  can be used to run the kernel in the normal branch prediction mode.

	  With the option disabled the modified branch prediction mode is
	  enabled with the "nobp=1" kernel parameter.

	  If unsure, say N.

540 541
config EXPOLINE
	def_bool n
542
	depends on $(cc-option,-mindirect-branch=thunk)
543 544 545 546 547 548 549 550 551 552
	prompt "Avoid speculative indirect branches in the kernel"
	help
	  Compile the kernel with the expoline compiler options to guard
	  against kernel-to-user data leaks by avoiding speculative indirect
	  branches.
	  Requires a compiler with -mindirect-branch=thunk support for full
	  protection. The kernel may run slower.

	  If unsure, say N.

553 554 555 556 557 558 559 560 561 562 563 564
config EXPOLINE_EXTERN
	def_bool n
	depends on EXPOLINE
	depends on CC_IS_GCC && GCC_VERSION >= 110200
	depends on $(success,$(srctree)/arch/s390/tools/gcc-thunk-extern.sh $(CC))
	prompt "Generate expolines as extern functions."
	help
	  This option is required for some tooling like kpatch. The kernel is
	  compiled with -mindirect-branch=thunk-extern and requires a newer
	  compiler.

	  If unsure, say N.
565 566 567 568 569 570 571 572 573

choice
	prompt "Expoline default"
	depends on EXPOLINE
	default EXPOLINE_FULL

config EXPOLINE_OFF
	bool "spectre_v2=off"

574
config EXPOLINE_AUTO
575 576 577 578 579 580 581
	bool "spectre_v2=auto"

config EXPOLINE_FULL
	bool "spectre_v2=on"

endchoice

582
config RELOCATABLE
583
	def_bool y
584 585 586 587 588 589 590 591
	help
	  This builds a kernel image that retains relocation information
	  so it can be loaded at an arbitrary address.
	  The kernel is linked as a position-independent executable (PIE)
	  and contains dynamic relocations which are processed early in the
	  bootup process.
	  The relocations make the kernel image about 15% larger (compressed
	  10%), but are discarded at runtime.
592 593
	  Note: this option exists only for documentation purposes, please do
	  not remove it.
594

595 596 597 598 599 600 601 602 603
config RANDOMIZE_BASE
	bool "Randomize the address of the kernel image (KASLR)"
	default y
	help
	  In support of Kernel Address Space Layout Randomization (KASLR),
	  this randomizes the address at which the kernel image is loaded,
	  as a security feature that deters exploit attempts relying on
	  knowledge of the location of kernel internals.

604
endmenu
Linus Torvalds's avatar
Linus Torvalds committed
605

606
menu "Memory setup"
607

608
config ARCH_SPARSEMEM_ENABLE
609
	def_bool y
610 611
	select SPARSEMEM_VMEMMAP_ENABLE
	select SPARSEMEM_VMEMMAP
612

613 614
config ARCH_SPARSEMEM_DEFAULT
	def_bool y
Linus Torvalds's avatar
Linus Torvalds committed
615

616 617 618 619 620 621 622 623 624 625
config MAX_PHYSMEM_BITS
	int "Maximum size of supported physical memory in bits (42-53)"
	range 42 53
	default "46"
	help
	  This option specifies the maximum supported size of physical memory
	  in bits. Supported is any size between 2^42 (4TB) and 2^53 (8PB).
	  Increasing the number of bits also increases the kernel image size.
	  By default 46 bits (64TB) are supported.

Linus Torvalds's avatar
Linus Torvalds committed
626
config CHECK_STACK
627
	def_bool y
628
	depends on !VMAP_STACK
629
	prompt "Detect kernel stack overflow"
Linus Torvalds's avatar
Linus Torvalds committed
630 631 632 633 634 635 636 637 638 639 640 641 642 643 644 645 646 647 648 649 650 651
	help
	  This option enables the compiler option -mstack-guard and
	  -mstack-size if they are available. If the compiler supports them
	  it will emit additional code to each function prolog to trigger
	  an illegal operation if the kernel stack is about to overflow.

	  Say N if you are unsure.

config STACK_GUARD
	int "Size of the guard area (128-1024)"
	range 128 1024
	depends on CHECK_STACK
	default "256"
	help
	  This allows you to specify the size of the guard area at the lower
	  end of the kernel stack. If the kernel stack points into the guard
	  area on function entry an illegal operation is triggered. The size
	  needs to be a power of 2. Please keep in mind that the size of an
	  interrupt frame is 184 bytes for 31 bit and 328 bytes on 64 bit.
	  The minimum size for the stack guard should be 256 for 31 bit and
	  512 for 64 bit.

652
endmenu
653

654
menu "I/O subsystem"
Linus Torvalds's avatar
Linus Torvalds committed
655 656

config QDIO
657 658
	def_tristate y
	prompt "QDIO support"
659
	help
660
	  This driver provides the Queued Direct I/O base support for
661
	  IBM System z.
Linus Torvalds's avatar
Linus Torvalds committed
662 663 664 665 666 667

	  To compile this driver as a module, choose M here: the
	  module will be called qdio.

	  If unsure, say Y.

668 669 670 671 672
if PCI

config PCI_NR_FUNCTIONS
	int "Maximum number of PCI functions (1-4096)"
	range 1 4096
673
	default "512"
674 675 676 677
	help
	  This allows you to specify the maximum number of PCI functions which
	  this kernel will support.

678
endif # PCI
679 680 681 682

config HAS_IOMEM
	def_bool PCI

683
config CHSC_SCH
684
	def_tristate m
685
	prompt "Support for CHSC subchannels"
686 687 688 689 690 691 692 693 694 695 696 697 698 699
	help
	  This driver allows usage of CHSC subchannels. A CHSC subchannel
	  is usually present on LPAR only.
	  The driver creates a device /dev/chsc, which may be used to
	  obtain I/O configuration information about the machine and
	  to issue asynchronous chsc commands (DANGEROUS).
	  You will usually only want to use this interface on a special
	  LPAR designated for system management.

	  To compile this driver as a module, choose M here: the
	  module will be called chsc_sch.

	  If unsure, say N.

Sebastian Ott's avatar
Sebastian Ott committed
700 701 702 703 704 705
config SCM_BUS
	def_bool y
	prompt "SCM bus driver"
	help
	  Bus driver for Storage Class Memory.

706 707 708 709 710 711 712 713 714 715 716
config EADM_SCH
	def_tristate m
	prompt "Support for EADM subchannels"
	depends on SCM_BUS
	help
	  This driver allows usage of EADM subchannels. EADM subchannels act
	  as a communication vehicle for SCM increments.

	  To compile this driver as a module, choose M here: the
	  module will be called eadm_sch.

717 718 719
config VFIO_CCW
	def_tristate n
	prompt "Support for VFIO-CCW subchannels"
720
	depends on S390_CCW_IOMMU
721
	depends on VFIO
722
	select VFIO_MDEV
723 724 725 726 727 728
	help
	  This driver allows usage of I/O subchannels via VFIO-CCW.

	  To compile this driver as a module, choose M here: the
	  module will be called vfio_ccw.

729 730 731
config VFIO_AP
	def_tristate n
	prompt "VFIO support for AP devices"
732
	depends on S390_AP_IOMMU && KVM
733
	depends on VFIO
734
	depends on ZCRYPT
735
	select VFIO_MDEV
736
	help
737 738
	  This driver grants access to Adjunct Processor (AP) devices
	  via the VFIO mediated device interface.
739

740 741
	  To compile this driver as a module, choose M here: the module
	  will be called vfio_ap.
742

743 744 745 746 747 748 749 750 751 752 753 754
endmenu

menu "Dump support"

config CRASH_DUMP
	bool "kernel crash dumps"
	select KEXEC
	help
	  Generate crash dump after being started by kexec.
	  Crash dump kernels are loaded in the main kernel with kexec-tools
	  into a specially reserved region and then later executed after
	  a crash by kdump/kexec.
755
	  Refer to <file:Documentation/s390/zfcpdump.rst> for more details on this.
756
	  This option also enables s390 zfcpdump.
757
	  See also <file:Documentation/s390/zfcpdump.rst>
758 759 760 761 762 763

endmenu

config CCW
	def_bool y

Ursula Braun's avatar
Ursula Braun committed
764 765 766 767
config HAVE_PNETID
	tristate
	default (SMC || CCWGROUP)

768
menu "Virtualization"
Heiko Carstens's avatar
Heiko Carstens committed
769

770 771 772 773 774 775 776 777 778 779 780
config PROTECTED_VIRTUALIZATION_GUEST
	def_bool n
	prompt "Protected virtualization guest support"
	help
	  Select this option, if you want to be able to run this
	  kernel as a protected virtualization KVM guest.
	  Protected virtualization capable machines have a mini hypervisor
	  located at machine level (an ultravisor). With help of the
	  Ultravisor, KVM will be able to run "protected" VMs, special
	  VMs whose memory and management data are unavailable to KVM.

Linus Torvalds's avatar
Linus Torvalds committed
781
config PFAULT
782 783
	def_bool y
	prompt "Pseudo page fault support"
Linus Torvalds's avatar
Linus Torvalds committed
784 785 786 787 788 789 790 791 792 793 794
	help
	  Select this option, if you want to use PFAULT pseudo page fault
	  handling under VM. If running native or in LPAR, this option
	  has no effect. If your VM does not support PFAULT, PAGEEX
	  pseudo page fault handling will be used.
	  Note that VM 4.2 supports PFAULT but has a bug in its
	  implementation that causes some problems.
	  Everybody who wants to run Linux under VM != VM4.2 should select
	  this option.

config CMM
795 796
	def_tristate n
	prompt "Cooperative memory management"
Linus Torvalds's avatar
Linus Torvalds committed
797 798 799 800 801 802 803 804 805 806 807
	help
	  Select this option, if you want to enable the kernel interface
	  to reduce the memory size of the system. This is accomplished
	  by allocating pages of memory and put them "on hold". This only
	  makes sense for a system running under VM where the unused pages
	  will be reused by VM for other guest systems. The interface
	  allows an external monitor to balance memory of many systems.
	  Everybody who wants to run Linux under VM should select this
	  option.

config CMM_IUCV
808 809
	def_bool y
	prompt "IUCV special message interface to cooperative memory management"
Linus Torvalds's avatar
Linus Torvalds committed
810 811 812 813 814 815
	depends on CMM && (SMSGIUCV=y || CMM=SMSGIUCV)
	help
	  Select this option to enable the special message interface to
	  the cooperative memory management.

config APPLDATA_BASE
816 817
	def_bool n
	prompt "Linux - VM Monitor Stream, base infrastructure"
818
	depends on PROC_SYSCTL
Linus Torvalds's avatar
Linus Torvalds committed
819 820 821 822 823 824 825 826 827 828 829 830 831
	help
	  This provides a kernel interface for creating and updating z/VM APPLDATA
	  monitor records. The monitor records are updated at certain time
	  intervals, once the timer is started.
	  Writing 1 or 0 to /proc/appldata/timer starts(1) or stops(0) the timer,
	  i.e. enables or disables monitoring on the Linux side.
	  A custom interval value (in seconds) can be written to
	  /proc/appldata/interval.

	  Defaults are 60 seconds interval and timer off.
	  The /proc entries can also be read from, showing the current settings.

config APPLDATA_MEM
832 833
	def_tristate m
	prompt "Monitor memory management statistics"
834
	depends on APPLDATA_BASE && VM_EVENT_COUNTERS
Linus Torvalds's avatar
Linus Torvalds committed
835 836 837 838 839 840 841 842 843 844 845 846 847 848
	help
	  This provides memory management related data to the Linux - VM Monitor
	  Stream, like paging/swapping rate, memory utilisation, etc.
	  Writing 1 or 0 to /proc/appldata/memory creates(1) or removes(0) a z/VM
	  APPLDATA monitor record, i.e. enables or disables monitoring this record
	  on the z/VM side.

	  Default is disabled.
	  The /proc entry can also be read from, showing the current settings.

	  This can also be compiled as a module, which will be called
	  appldata_mem.o.

config APPLDATA_OS
849 850
	def_tristate m
	prompt "Monitor OS statistics"
Linus Torvalds's avatar
Linus Torvalds committed
851 852 853 854 855 856 857 858 859 860 861 862 863
	depends on APPLDATA_BASE
	help
	  This provides OS related data to the Linux - VM Monitor Stream, like
	  CPU utilisation, etc.
	  Writing 1 or 0 to /proc/appldata/os creates(1) or removes(0) a z/VM
	  APPLDATA monitor record, i.e. enables or disables monitoring this record
	  on the z/VM side.

	  Default is disabled.
	  This can also be compiled as a module, which will be called
	  appldata_os.o.

config APPLDATA_NET_SUM
864 865
	def_tristate m
	prompt "Monitor overall network statistics"
866
	depends on APPLDATA_BASE && NET
Linus Torvalds's avatar
Linus Torvalds committed
867 868 869 870 871 872 873 874 875 876 877 878
	help
	  This provides network related data to the Linux - VM Monitor Stream,
	  currently there is only a total sum of network I/O statistics, no
	  per-interface data.
	  Writing 1 or 0 to /proc/appldata/net_sum creates(1) or removes(0) a z/VM
	  APPLDATA monitor record, i.e. enables or disables monitoring this record
	  on the z/VM side.

	  Default is disabled.
	  This can also be compiled as a module, which will be called
	  appldata_net_sum.o.

879
config S390_HYPFS_FS
880 881
	def_bool y
	prompt "s390 hypervisor file system support"
882 883 884 885 886
	select SYS_HYPERVISOR
	help
	  This is a virtual file system intended to provide accounting
	  information in an s390 hypervisor environment.

887
source "arch/s390/kvm/Kconfig"
Michael Holzheu's avatar
Michael Holzheu committed
888

889
config S390_GUEST
890
	def_bool y
891
	prompt "s390 support for virtio devices"
892
	select TTY
893
	select VIRTUALIZATION
894 895
	select VIRTIO
	help
896 897
	  Enabling this option adds support for virtio based paravirtual device
	  drivers on s390.
Linus Torvalds's avatar
Linus Torvalds committed
898

899
	  Select this option if you want to run the kernel as a guest under
900
	  the KVM hypervisor.
901 902

endmenu
903

904 905 906
config S390_MODULES_SANITY_TEST_HELPERS
	def_bool n

907 908 909 910
menu "Selftests"

config S390_UNWIND_SELFTEST
	def_tristate n
911 912
	depends on KUNIT
	default KUNIT_ALL_TESTS
913 914 915 916 917 918 919 920
	prompt "Test unwind functions"
	help
	  This option enables s390 specific stack unwinder testing kernel
	  module. This option is not useful for distributions or general
	  kernels, but only for kernel developers working on architecture code.

	  Say N if you are unsure.

921 922 923 924 925 926 927 928 929 930 931 932
config S390_KPROBES_SANITY_TEST
	def_tristate n
	prompt "Enable s390 specific kprobes tests"
	depends on KPROBES
	depends on KUNIT
	help
	  This option enables an s390 specific kprobes test module. This option
	  is not useful for distributions or general kernels, but only for kernel
	  developers working on architecture code.

	  Say N if you are unsure.

933 934 935 936 937 938 939 940 941 942 943 944
config S390_MODULES_SANITY_TEST
	def_tristate n
	depends on KUNIT
	default KUNIT_ALL_TESTS
	prompt "Enable s390 specific modules tests"
	select S390_MODULES_SANITY_TEST_HELPERS
	help
	  This option enables an s390 specific modules test. This option is
	  not useful for distributions or general kernels, but only for
	  kernel developers working on architecture code.

	  Say N if you are unsure.
945
endmenu