xref: /openbmc/linux/arch/s390/Kconfig (revision f79e4d5f92a129a1159c973735007d4ddc8541f3)
1# SPDX-License-Identifier: GPL-2.0
2config MMU
3	def_bool y
4
5config ZONE_DMA
6	def_bool y
7
8config CPU_BIG_ENDIAN
9	def_bool y
10
11config LOCKDEP_SUPPORT
12	def_bool y
13
14config STACKTRACE_SUPPORT
15	def_bool y
16
17config RWSEM_GENERIC_SPINLOCK
18	bool
19
20config RWSEM_XCHGADD_ALGORITHM
21	def_bool y
22
23config ARCH_HAS_ILOG2_U32
24	def_bool n
25
26config ARCH_HAS_ILOG2_U64
27	def_bool n
28
29config GENERIC_HWEIGHT
30	def_bool y
31
32config GENERIC_BUG
33	def_bool y if BUG
34
35config GENERIC_BUG_RELATIVE_POINTERS
36	def_bool y
37
38config GENERIC_LOCKBREAK
39	def_bool y if SMP && PREEMPT
40
41config PGSTE
42	def_bool y if KVM
43
44config ARCH_SUPPORTS_DEBUG_PAGEALLOC
45	def_bool y
46
47config AUDIT_ARCH
48	def_bool y
49
50config NO_IOPORT_MAP
51	def_bool y
52
53config PCI_QUIRKS
54	def_bool n
55
56config ARCH_SUPPORTS_UPROBES
57	def_bool y
58
59config S390
60	def_bool y
61	select ARCH_BINFMT_ELF_STATE
62	select ARCH_HAS_DEVMEM_IS_ALLOWED
63	select ARCH_HAS_ELF_RANDOMIZE
64	select ARCH_HAS_FORTIFY_SOURCE
65	select ARCH_HAS_GCOV_PROFILE_ALL
66	select ARCH_HAS_GIGANTIC_PAGE if (MEMORY_ISOLATION && COMPACTION) || CMA
67	select ARCH_HAS_KCOV
68	select ARCH_HAS_PTE_SPECIAL
69	select ARCH_HAS_SET_MEMORY
70	select ARCH_HAS_SG_CHAIN
71	select ARCH_HAS_STRICT_KERNEL_RWX
72	select ARCH_HAS_STRICT_MODULE_RWX
73	select ARCH_HAS_UBSAN_SANITIZE_ALL
74	select ARCH_HAVE_NMI_SAFE_CMPXCHG
75	select ARCH_INLINE_READ_LOCK
76	select ARCH_INLINE_READ_LOCK_BH
77	select ARCH_INLINE_READ_LOCK_IRQ
78	select ARCH_INLINE_READ_LOCK_IRQSAVE
79	select ARCH_INLINE_READ_TRYLOCK
80	select ARCH_INLINE_READ_UNLOCK
81	select ARCH_INLINE_READ_UNLOCK_BH
82	select ARCH_INLINE_READ_UNLOCK_IRQ
83	select ARCH_INLINE_READ_UNLOCK_IRQRESTORE
84	select ARCH_INLINE_SPIN_LOCK
85	select ARCH_INLINE_SPIN_LOCK_BH
86	select ARCH_INLINE_SPIN_LOCK_IRQ
87	select ARCH_INLINE_SPIN_LOCK_IRQSAVE
88	select ARCH_INLINE_SPIN_TRYLOCK
89	select ARCH_INLINE_SPIN_TRYLOCK_BH
90	select ARCH_INLINE_SPIN_UNLOCK
91	select ARCH_INLINE_SPIN_UNLOCK_BH
92	select ARCH_INLINE_SPIN_UNLOCK_IRQ
93	select ARCH_INLINE_SPIN_UNLOCK_IRQRESTORE
94	select ARCH_INLINE_WRITE_LOCK
95	select ARCH_INLINE_WRITE_LOCK_BH
96	select ARCH_INLINE_WRITE_LOCK_IRQ
97	select ARCH_INLINE_WRITE_LOCK_IRQSAVE
98	select ARCH_INLINE_WRITE_TRYLOCK
99	select ARCH_INLINE_WRITE_UNLOCK
100	select ARCH_INLINE_WRITE_UNLOCK_BH
101	select ARCH_INLINE_WRITE_UNLOCK_IRQ
102	select ARCH_INLINE_WRITE_UNLOCK_IRQRESTORE
103	select ARCH_SAVE_PAGE_KEYS if HIBERNATION
104	select ARCH_SUPPORTS_ATOMIC_RMW
105	select ARCH_SUPPORTS_NUMA_BALANCING
106	select ARCH_USE_BUILTIN_BSWAP
107	select ARCH_USE_CMPXCHG_LOCKREF
108	select ARCH_WANTS_DYNAMIC_TASK_STRUCT
109	select ARCH_WANTS_UBSAN_NO_NULL
110	select ARCH_WANT_IPC_PARSE_VERSION
111	select BUILDTIME_EXTABLE_SORT
112	select CLONE_BACKWARDS2
113	select DYNAMIC_FTRACE if FUNCTION_TRACER
114	select GENERIC_CLOCKEVENTS
115	select GENERIC_CPU_AUTOPROBE
116	select GENERIC_CPU_DEVICES if !SMP
117	select GENERIC_CPU_VULNERABILITIES
118	select GENERIC_FIND_FIRST_BIT
119	select GENERIC_SMP_IDLE_THREAD
120	select GENERIC_TIME_VSYSCALL
121	select HAVE_ALIGNED_STRUCT_PAGE if SLUB
122	select HAVE_ARCH_AUDITSYSCALL
123	select HAVE_ARCH_JUMP_LABEL
124	select CPU_NO_EFFICIENT_FFS if !HAVE_MARCH_Z9_109_FEATURES
125	select HAVE_ARCH_SECCOMP_FILTER
126	select HAVE_ARCH_SOFT_DIRTY
127	select HAVE_ARCH_TRACEHOOK
128	select HAVE_ARCH_TRANSPARENT_HUGEPAGE
129	select HAVE_EBPF_JIT if PACK_STACK && HAVE_MARCH_Z196_FEATURES
130	select HAVE_CMPXCHG_DOUBLE
131	select HAVE_CMPXCHG_LOCAL
132	select HAVE_COPY_THREAD_TLS
133	select HAVE_DEBUG_KMEMLEAK
134	select HAVE_DMA_CONTIGUOUS
135	select DMA_DIRECT_OPS
136	select HAVE_DYNAMIC_FTRACE
137	select HAVE_DYNAMIC_FTRACE_WITH_REGS
138	select HAVE_EFFICIENT_UNALIGNED_ACCESS
139	select HAVE_FTRACE_MCOUNT_RECORD
140	select HAVE_FUNCTION_GRAPH_TRACER
141	select HAVE_FUNCTION_TRACER
142	select HAVE_FUTEX_CMPXCHG if FUTEX
143	select HAVE_GCC_PLUGINS if BROKEN
144	select HAVE_KERNEL_BZIP2
145	select HAVE_KERNEL_GZIP
146	select HAVE_KERNEL_LZ4
147	select HAVE_KERNEL_LZMA
148	select HAVE_KERNEL_LZO
149	select HAVE_KERNEL_XZ
150	select HAVE_KPROBES
151	select HAVE_KRETPROBES
152	select HAVE_KVM
153	select HAVE_LIVEPATCH
154	select HAVE_PERF_REGS
155	select HAVE_PERF_USER_STACK_DUMP
156	select HAVE_MEMBLOCK
157	select HAVE_MEMBLOCK_NODE_MAP
158	select HAVE_MEMBLOCK_PHYS_MAP
159	select HAVE_MOD_ARCH_SPECIFIC
160	select HAVE_OPROFILE
161	select HAVE_PERF_EVENTS
162	select HAVE_REGS_AND_STACK_ACCESS_API
163	select HAVE_RSEQ
164	select HAVE_SYSCALL_TRACEPOINTS
165	select HAVE_VIRT_CPU_ACCOUNTING
166	select MODULES_USE_ELF_RELA
167	select NO_BOOTMEM
168	select OLD_SIGACTION
169	select OLD_SIGSUSPEND3
170	select SPARSE_IRQ
171	select SYSCTL_EXCEPTION_TRACE
172	select THREAD_INFO_IN_TASK
173	select TTY
174	select VIRT_CPU_ACCOUNTING
175	select ARCH_HAS_SCALED_CPUTIME
176	select VIRT_TO_BUS
177	select HAVE_NMI
178
179
180config SCHED_OMIT_FRAME_POINTER
181	def_bool y
182
183config PGTABLE_LEVELS
184	int
185	default 5
186
187source "init/Kconfig"
188
189source "kernel/Kconfig.freezer"
190
191source "kernel/livepatch/Kconfig"
192
193menu "Processor type and features"
194
195config HAVE_MARCH_Z900_FEATURES
196	def_bool n
197
198config HAVE_MARCH_Z990_FEATURES
199	def_bool n
200	select HAVE_MARCH_Z900_FEATURES
201
202config HAVE_MARCH_Z9_109_FEATURES
203	def_bool n
204	select HAVE_MARCH_Z990_FEATURES
205
206config HAVE_MARCH_Z10_FEATURES
207	def_bool n
208	select HAVE_MARCH_Z9_109_FEATURES
209
210config HAVE_MARCH_Z196_FEATURES
211	def_bool n
212	select HAVE_MARCH_Z10_FEATURES
213
214config HAVE_MARCH_ZEC12_FEATURES
215	def_bool n
216	select HAVE_MARCH_Z196_FEATURES
217
218config HAVE_MARCH_Z13_FEATURES
219	def_bool n
220	select HAVE_MARCH_ZEC12_FEATURES
221
222config HAVE_MARCH_Z14_FEATURES
223	def_bool n
224	select HAVE_MARCH_Z13_FEATURES
225
226choice
227	prompt "Processor type"
228	default MARCH_Z196
229
230config MARCH_Z900
231	bool "IBM zSeries model z800 and z900"
232	select HAVE_MARCH_Z900_FEATURES
233	help
234	  Select this to enable optimizations for model z800/z900 (2064 and
235	  2066 series). This will enable some optimizations that are not
236	  available on older ESA/390 (31 Bit) only CPUs.
237
238config MARCH_Z990
239	bool "IBM zSeries model z890 and z990"
240	select HAVE_MARCH_Z990_FEATURES
241	help
242	  Select this to enable optimizations for model z890/z990 (2084 and
243	  2086 series). The kernel will be slightly faster but will not work
244	  on older machines.
245
246config MARCH_Z9_109
247	bool "IBM System z9"
248	select HAVE_MARCH_Z9_109_FEATURES
249	help
250	  Select this to enable optimizations for IBM System z9 (2094 and
251	  2096 series). The kernel will be slightly faster but will not work
252	  on older machines.
253
254config MARCH_Z10
255	bool "IBM System z10"
256	select HAVE_MARCH_Z10_FEATURES
257	help
258	  Select this to enable optimizations for IBM System z10 (2097 and
259	  2098 series). The kernel will be slightly faster but will not work
260	  on older machines.
261
262config MARCH_Z196
263	bool "IBM zEnterprise 114 and 196"
264	select HAVE_MARCH_Z196_FEATURES
265	help
266	  Select this to enable optimizations for IBM zEnterprise 114 and 196
267	  (2818 and 2817 series). The kernel will be slightly faster but will
268	  not work on older machines.
269
270config MARCH_ZEC12
271	bool "IBM zBC12 and zEC12"
272	select HAVE_MARCH_ZEC12_FEATURES
273	help
274	  Select this to enable optimizations for IBM zBC12 and zEC12 (2828 and
275	  2827 series). The kernel will be slightly faster but will not work on
276	  older machines.
277
278config MARCH_Z13
279	bool "IBM z13s and z13"
280	select HAVE_MARCH_Z13_FEATURES
281	help
282	  Select this to enable optimizations for IBM z13s and z13 (2965 and
283	  2964 series). The kernel will be slightly faster but will not work on
284	  older machines.
285
286config MARCH_Z14
287	bool "IBM z14 ZR1 and z14"
288	select HAVE_MARCH_Z14_FEATURES
289	help
290	  Select this to enable optimizations for IBM z14 ZR1 and z14 (3907
291	  and 3906 series). The kernel will be slightly faster but will not
292	  work on older machines.
293
294endchoice
295
296config MARCH_Z900_TUNE
297	def_bool TUNE_Z900 || MARCH_Z900 && TUNE_DEFAULT
298
299config MARCH_Z990_TUNE
300	def_bool TUNE_Z990 || MARCH_Z990 && TUNE_DEFAULT
301
302config MARCH_Z9_109_TUNE
303	def_bool TUNE_Z9_109 || MARCH_Z9_109 && TUNE_DEFAULT
304
305config MARCH_Z10_TUNE
306	def_bool TUNE_Z10 || MARCH_Z10 && TUNE_DEFAULT
307
308config MARCH_Z196_TUNE
309	def_bool TUNE_Z196 || MARCH_Z196 && TUNE_DEFAULT
310
311config MARCH_ZEC12_TUNE
312	def_bool TUNE_ZEC12 || MARCH_ZEC12 && TUNE_DEFAULT
313
314config MARCH_Z13_TUNE
315	def_bool TUNE_Z13 || MARCH_Z13 && TUNE_DEFAULT
316
317config MARCH_Z14_TUNE
318	def_bool TUNE_Z14 || MARCH_Z14 && TUNE_DEFAULT
319
320choice
321	prompt "Tune code generation"
322	default TUNE_DEFAULT
323	help
324	  Cause the compiler to tune (-mtune) the generated code for a machine.
325	  This will make the code run faster on the selected machine but
326	  somewhat slower on other machines.
327	  This option only changes how the compiler emits instructions, not the
328	  selection of instructions itself, so the resulting kernel will run on
329	  all other machines.
330
331config TUNE_DEFAULT
332	bool "Default"
333	help
334	  Tune the generated code for the target processor for which the kernel
335	  will be compiled.
336
337config TUNE_Z900
338	bool "IBM zSeries model z800 and z900"
339
340config TUNE_Z990
341	bool "IBM zSeries model z890 and z990"
342
343config TUNE_Z9_109
344	bool "IBM System z9"
345
346config TUNE_Z10
347	bool "IBM System z10"
348
349config TUNE_Z196
350	bool "IBM zEnterprise 114 and 196"
351
352config TUNE_ZEC12
353	bool "IBM zBC12 and zEC12"
354
355config TUNE_Z13
356	bool "IBM z13"
357
358config TUNE_Z14
359	bool "IBM z14"
360
361endchoice
362
363config 64BIT
364	def_bool y
365
366config COMPAT
367	def_bool y
368	prompt "Kernel support for 31 bit emulation"
369	select COMPAT_BINFMT_ELF if BINFMT_ELF
370	select ARCH_WANT_OLD_COMPAT_IPC
371	select COMPAT_OLD_SIGACTION
372	depends on MULTIUSER
373	help
374	  Select this option if you want to enable your system kernel to
375	  handle system-calls from ELF binaries for 31 bit ESA.  This option
376	  (and some other stuff like libraries and such) is needed for
377	  executing 31 bit applications.  It is safe to say "Y".
378
379config SYSVIPC_COMPAT
380	def_bool y if COMPAT && SYSVIPC
381
382config SMP
383	def_bool y
384	prompt "Symmetric multi-processing support"
385	---help---
386	  This enables support for systems with more than one CPU. If you have
387	  a system with only one CPU, like most personal computers, say N. If
388	  you have a system with more than one CPU, say Y.
389
390	  If you say N here, the kernel will run on uni- and multiprocessor
391	  machines, but will use only one CPU of a multiprocessor machine. If
392	  you say Y here, the kernel will run on many, but not all,
393	  uniprocessor machines. On a uniprocessor machine, the kernel
394	  will run faster if you say N here.
395
396	  See also the SMP-HOWTO available at
397	  <http://www.tldp.org/docs.html#howto>.
398
399	  Even if you don't know what to do here, say Y.
400
401config NR_CPUS
402	int "Maximum number of CPUs (2-512)"
403	range 2 512
404	depends on SMP
405	default "64"
406	help
407	  This allows you to specify the maximum number of CPUs which this
408	  kernel will support. The maximum supported value is 512 and the
409	  minimum value which makes sense is 2.
410
411	  This is purely to save memory - each supported CPU adds
412	  approximately sixteen kilobytes to the kernel image.
413
414config HOTPLUG_CPU
415	def_bool y
416	prompt "Support for hot-pluggable CPUs"
417	depends on SMP
418	help
419	  Say Y here to be able to turn CPUs off and on. CPUs
420	  can be controlled through /sys/devices/system/cpu/cpu#.
421	  Say N if you want to disable CPU hotplug.
422
423# Some NUMA nodes have memory ranges that span
424# other nodes.	Even though a pfn is valid and
425# between a node's start and end pfns, it may not
426# reside on that node.	See memmap_init_zone()
427# for details. <- They meant memory holes!
428config NODES_SPAN_OTHER_NODES
429	def_bool NUMA
430
431config NUMA
432	bool "NUMA support"
433	depends on SMP && SCHED_TOPOLOGY
434	default n
435	help
436	  Enable NUMA support
437
438	  This option adds NUMA support to the kernel.
439
440	  An operation mode can be selected by appending
441	  numa=<method> to the kernel command line.
442
443	  The default behaviour is identical to appending numa=plain to
444	  the command line. This will create just one node with all
445	  available memory and all CPUs in it.
446
447config NODES_SHIFT
448	int "Maximum NUMA nodes (as a power of 2)"
449	range 1 10
450	depends on NUMA
451	default "4"
452	help
453	  Specify the maximum number of NUMA nodes available on the target
454	  system. Increases memory reserved to accommodate various tables.
455
456menu "Select NUMA modes"
457	depends on NUMA
458
459config NUMA_EMU
460	bool "NUMA emulation"
461	default y
462	help
463	  Numa emulation mode will split the available system memory into
464	  equal chunks which then are distributed over the configured number
465	  of nodes in a round-robin manner.
466
467	  The number of fake nodes is limited by the number of available memory
468	  chunks (i.e. memory size / fake size) and the number of supported
469	  nodes in the kernel.
470
471	  The CPUs are assigned to the nodes in a way that partially respects
472	  the original machine topology (if supported by the machine).
473	  Fair distribution of the CPUs is not guaranteed.
474
475config EMU_SIZE
476	hex "NUMA emulation memory chunk size"
477	default 0x10000000
478	range 0x400000 0x100000000
479	depends on NUMA_EMU
480	help
481	  Select the default size by which the memory is chopped and then
482	  assigned to emulated NUMA nodes.
483
484	  This can be overridden by specifying
485
486	  emu_size=<n>
487
488	  on the kernel command line where also suffixes K, M, G, and T are
489	  supported.
490
491endmenu
492
493config SCHED_SMT
494	def_bool n
495
496config SCHED_MC
497	def_bool n
498
499config SCHED_BOOK
500	def_bool n
501
502config SCHED_DRAWER
503	def_bool n
504
505config SCHED_TOPOLOGY
506	def_bool y
507	prompt "Topology scheduler support"
508	depends on SMP
509	select SCHED_SMT
510	select SCHED_MC
511	select SCHED_BOOK
512	select SCHED_DRAWER
513	help
514	  Topology scheduler support improves the CPU scheduler's decision
515	  making when dealing with machines that have multi-threading,
516	  multiple cores or multiple books.
517
518source kernel/Kconfig.preempt
519
520source kernel/Kconfig.hz
521
522config KEXEC
523	def_bool y
524	select KEXEC_CORE
525
526config KEXEC_FILE
527	bool "kexec file based system call"
528	select KEXEC_CORE
529	select BUILD_BIN2C
530	depends on CRYPTO
531	depends on CRYPTO_SHA256
532	depends on CRYPTO_SHA256_S390
533	help
534	  Enable the kexec file based system call. In contrast to the normal
535	  kexec system call this system call takes file descriptors for the
536	  kernel and initramfs as arguments.
537
538config ARCH_HAS_KEXEC_PURGATORY
539	def_bool y
540	depends on KEXEC_FILE
541
542config ARCH_RANDOM
543	def_bool y
544	prompt "s390 architectural random number generation API"
545	help
546	  Enable the s390 architectural random number generation API
547	  to provide random data for all consumers within the Linux
548	  kernel.
549
550	  When enabled the arch_random_* functions declared in linux/random.h
551	  are implemented. The implementation is based on the s390 CPACF
552	  instruction subfunction TRNG which provides a real true random
553	  number generator.
554
555	  If unsure, say Y.
556
557config KERNEL_NOBP
558	def_bool n
559	prompt "Enable modified branch prediction for the kernel by default"
560	help
561	  If this option is selected the kernel will switch to a modified
562	  branch prediction mode if the firmware interface is available.
563	  The modified branch prediction mode improves the behaviour in
564	  regard to speculative execution.
565
566	  With the option enabled the kernel parameter "nobp=0" or "nospec"
567	  can be used to run the kernel in the normal branch prediction mode.
568
569	  With the option disabled the modified branch prediction mode is
570	  enabled with the "nobp=1" kernel parameter.
571
572	  If unsure, say N.
573
574config EXPOLINE
575	def_bool n
576	prompt "Avoid speculative indirect branches in the kernel"
577	help
578	  Compile the kernel with the expoline compiler options to guard
579	  against kernel-to-user data leaks by avoiding speculative indirect
580	  branches.
581	  Requires a compiler with -mindirect-branch=thunk support for full
582	  protection. The kernel may run slower.
583
584	  If unsure, say N.
585
586choice
587	prompt "Expoline default"
588	depends on EXPOLINE
589	default EXPOLINE_FULL
590
591config EXPOLINE_OFF
592	bool "spectre_v2=off"
593
594config EXPOLINE_AUTO
595	bool "spectre_v2=auto"
596
597config EXPOLINE_FULL
598	bool "spectre_v2=on"
599
600endchoice
601
602endmenu
603
604menu "Memory setup"
605
606config ARCH_SPARSEMEM_ENABLE
607	def_bool y
608	select SPARSEMEM_VMEMMAP_ENABLE
609	select SPARSEMEM_VMEMMAP
610
611config ARCH_SPARSEMEM_DEFAULT
612	def_bool y
613
614config ARCH_SELECT_MEMORY_MODEL
615	def_bool y
616
617config ARCH_ENABLE_MEMORY_HOTPLUG
618	def_bool y if SPARSEMEM
619
620config ARCH_ENABLE_MEMORY_HOTREMOVE
621	def_bool y
622
623config ARCH_ENABLE_SPLIT_PMD_PTLOCK
624	def_bool y
625
626config FORCE_MAX_ZONEORDER
627	int
628	default "9"
629
630source "mm/Kconfig"
631
632config MAX_PHYSMEM_BITS
633	int "Maximum size of supported physical memory in bits (42-53)"
634	range 42 53
635	default "46"
636	help
637	  This option specifies the maximum supported size of physical memory
638	  in bits. Supported is any size between 2^42 (4TB) and 2^53 (8PB).
639	  Increasing the number of bits also increases the kernel image size.
640	  By default 46 bits (64TB) are supported.
641
642config PACK_STACK
643	def_bool y
644	prompt "Pack kernel stack"
645	help
646	  This option enables the compiler option -mkernel-backchain if it
647	  is available. If the option is available the compiler supports
648	  the new stack layout which dramatically reduces the minimum stack
649	  frame size. With an old compiler a non-leaf function needs a
650	  minimum of 96 bytes on 31 bit and 160 bytes on 64 bit. With
651	  -mkernel-backchain the minimum size drops to 16 byte on 31 bit
652	  and 24 byte on 64 bit.
653
654	  Say Y if you are unsure.
655
656config CHECK_STACK
657	def_bool y
658	prompt "Detect kernel stack overflow"
659	help
660	  This option enables the compiler option -mstack-guard and
661	  -mstack-size if they are available. If the compiler supports them
662	  it will emit additional code to each function prolog to trigger
663	  an illegal operation if the kernel stack is about to overflow.
664
665	  Say N if you are unsure.
666
667config STACK_GUARD
668	int "Size of the guard area (128-1024)"
669	range 128 1024
670	depends on CHECK_STACK
671	default "256"
672	help
673	  This allows you to specify the size of the guard area at the lower
674	  end of the kernel stack. If the kernel stack points into the guard
675	  area on function entry an illegal operation is triggered. The size
676	  needs to be a power of 2. Please keep in mind that the size of an
677	  interrupt frame is 184 bytes for 31 bit and 328 bytes on 64 bit.
678	  The minimum size for the stack guard should be 256 for 31 bit and
679	  512 for 64 bit.
680
681config WARN_DYNAMIC_STACK
682	def_bool n
683	prompt "Emit compiler warnings for function with dynamic stack usage"
684	help
685	  This option enables the compiler option -mwarn-dynamicstack. If the
686	  compiler supports this options generates warnings for functions
687	  that dynamically allocate stack space using alloca.
688
689	  Say N if you are unsure.
690
691endmenu
692
693menu "I/O subsystem"
694
695config QDIO
696	def_tristate y
697	prompt "QDIO support"
698	---help---
699	  This driver provides the Queued Direct I/O base support for
700	  IBM System z.
701
702	  To compile this driver as a module, choose M here: the
703	  module will be called qdio.
704
705	  If unsure, say Y.
706
707menuconfig PCI
708	bool "PCI support"
709	select PCI_MSI
710	select IOMMU_HELPER
711	select IOMMU_SUPPORT
712	select NEED_DMA_MAP_STATE
713	select NEED_SG_DMA_LENGTH
714
715	help
716	  Enable PCI support.
717
718if PCI
719
720config PCI_NR_FUNCTIONS
721	int "Maximum number of PCI functions (1-4096)"
722	range 1 4096
723	default "128"
724	help
725	  This allows you to specify the maximum number of PCI functions which
726	  this kernel will support.
727
728source "drivers/pci/Kconfig"
729
730endif	# PCI
731
732config PCI_DOMAINS
733	def_bool PCI
734
735config HAS_IOMEM
736	def_bool PCI
737
738config CHSC_SCH
739	def_tristate m
740	prompt "Support for CHSC subchannels"
741	help
742	  This driver allows usage of CHSC subchannels. A CHSC subchannel
743	  is usually present on LPAR only.
744	  The driver creates a device /dev/chsc, which may be used to
745	  obtain I/O configuration information about the machine and
746	  to issue asynchronous chsc commands (DANGEROUS).
747	  You will usually only want to use this interface on a special
748	  LPAR designated for system management.
749
750	  To compile this driver as a module, choose M here: the
751	  module will be called chsc_sch.
752
753	  If unsure, say N.
754
755config SCM_BUS
756	def_bool y
757	prompt "SCM bus driver"
758	help
759	  Bus driver for Storage Class Memory.
760
761config EADM_SCH
762	def_tristate m
763	prompt "Support for EADM subchannels"
764	depends on SCM_BUS
765	help
766	  This driver allows usage of EADM subchannels. EADM subchannels act
767	  as a communication vehicle for SCM increments.
768
769	  To compile this driver as a module, choose M here: the
770	  module will be called eadm_sch.
771
772config VFIO_CCW
773	def_tristate n
774	prompt "Support for VFIO-CCW subchannels"
775	depends on S390_CCW_IOMMU && VFIO_MDEV
776	help
777	  This driver allows usage of I/O subchannels via VFIO-CCW.
778
779	  To compile this driver as a module, choose M here: the
780	  module will be called vfio_ccw.
781
782endmenu
783
784menu "Dump support"
785
786config CRASH_DUMP
787	bool "kernel crash dumps"
788	depends on SMP
789	select KEXEC
790	help
791	  Generate crash dump after being started by kexec.
792	  Crash dump kernels are loaded in the main kernel with kexec-tools
793	  into a specially reserved region and then later executed after
794	  a crash by kdump/kexec.
795	  Refer to <file:Documentation/s390/zfcpdump.txt> for more details on this.
796	  This option also enables s390 zfcpdump.
797	  See also <file:Documentation/s390/zfcpdump.txt>
798
799endmenu
800
801menu "Executable file formats / Emulations"
802
803source "fs/Kconfig.binfmt"
804
805config SECCOMP
806	def_bool y
807	prompt "Enable seccomp to safely compute untrusted bytecode"
808	depends on PROC_FS
809	help
810	  This kernel feature is useful for number crunching applications
811	  that may need to compute untrusted bytecode during their
812	  execution. By using pipes or other transports made available to
813	  the process as file descriptors supporting the read/write
814	  syscalls, it's possible to isolate those applications in
815	  their own address space using seccomp. Once seccomp is
816	  enabled via /proc/<pid>/seccomp, it cannot be disabled
817	  and the task is only allowed to execute a few safe syscalls
818	  defined by each seccomp mode.
819
820	  If unsure, say Y.
821
822endmenu
823
824menu "Power Management"
825
826config ARCH_HIBERNATION_POSSIBLE
827	def_bool y
828
829source "kernel/power/Kconfig"
830
831endmenu
832
833source "net/Kconfig"
834
835config PCMCIA
836	def_bool n
837
838config CCW
839	def_bool y
840
841source "drivers/Kconfig"
842
843config HAVE_PNETID
844	tristate
845	default (SMC || CCWGROUP)
846
847source "fs/Kconfig"
848
849source "arch/s390/Kconfig.debug"
850
851source "security/Kconfig"
852
853source "crypto/Kconfig"
854
855source "lib/Kconfig"
856
857menu "Virtualization"
858
859config PFAULT
860	def_bool y
861	prompt "Pseudo page fault support"
862	help
863	  Select this option, if you want to use PFAULT pseudo page fault
864	  handling under VM. If running native or in LPAR, this option
865	  has no effect. If your VM does not support PFAULT, PAGEEX
866	  pseudo page fault handling will be used.
867	  Note that VM 4.2 supports PFAULT but has a bug in its
868	  implementation that causes some problems.
869	  Everybody who wants to run Linux under VM != VM4.2 should select
870	  this option.
871
872config CMM
873	def_tristate n
874	prompt "Cooperative memory management"
875	help
876	  Select this option, if you want to enable the kernel interface
877	  to reduce the memory size of the system. This is accomplished
878	  by allocating pages of memory and put them "on hold". This only
879	  makes sense for a system running under VM where the unused pages
880	  will be reused by VM for other guest systems. The interface
881	  allows an external monitor to balance memory of many systems.
882	  Everybody who wants to run Linux under VM should select this
883	  option.
884
885config CMM_IUCV
886	def_bool y
887	prompt "IUCV special message interface to cooperative memory management"
888	depends on CMM && (SMSGIUCV=y || CMM=SMSGIUCV)
889	help
890	  Select this option to enable the special message interface to
891	  the cooperative memory management.
892
893config APPLDATA_BASE
894	def_bool n
895	prompt "Linux - VM Monitor Stream, base infrastructure"
896	depends on PROC_FS
897	help
898	  This provides a kernel interface for creating and updating z/VM APPLDATA
899	  monitor records. The monitor records are updated at certain time
900	  intervals, once the timer is started.
901	  Writing 1 or 0 to /proc/appldata/timer starts(1) or stops(0) the timer,
902	  i.e. enables or disables monitoring on the Linux side.
903	  A custom interval value (in seconds) can be written to
904	  /proc/appldata/interval.
905
906	  Defaults are 60 seconds interval and timer off.
907	  The /proc entries can also be read from, showing the current settings.
908
909config APPLDATA_MEM
910	def_tristate m
911	prompt "Monitor memory management statistics"
912	depends on APPLDATA_BASE && VM_EVENT_COUNTERS
913	help
914	  This provides memory management related data to the Linux - VM Monitor
915	  Stream, like paging/swapping rate, memory utilisation, etc.
916	  Writing 1 or 0 to /proc/appldata/memory creates(1) or removes(0) a z/VM
917	  APPLDATA monitor record, i.e. enables or disables monitoring this record
918	  on the z/VM side.
919
920	  Default is disabled.
921	  The /proc entry can also be read from, showing the current settings.
922
923	  This can also be compiled as a module, which will be called
924	  appldata_mem.o.
925
926config APPLDATA_OS
927	def_tristate m
928	prompt "Monitor OS statistics"
929	depends on APPLDATA_BASE
930	help
931	  This provides OS related data to the Linux - VM Monitor Stream, like
932	  CPU utilisation, etc.
933	  Writing 1 or 0 to /proc/appldata/os creates(1) or removes(0) a z/VM
934	  APPLDATA monitor record, i.e. enables or disables monitoring this record
935	  on the z/VM side.
936
937	  Default is disabled.
938	  This can also be compiled as a module, which will be called
939	  appldata_os.o.
940
941config APPLDATA_NET_SUM
942	def_tristate m
943	prompt "Monitor overall network statistics"
944	depends on APPLDATA_BASE && NET
945	help
946	  This provides network related data to the Linux - VM Monitor Stream,
947	  currently there is only a total sum of network I/O statistics, no
948	  per-interface data.
949	  Writing 1 or 0 to /proc/appldata/net_sum creates(1) or removes(0) a z/VM
950	  APPLDATA monitor record, i.e. enables or disables monitoring this record
951	  on the z/VM side.
952
953	  Default is disabled.
954	  This can also be compiled as a module, which will be called
955	  appldata_net_sum.o.
956
957config S390_HYPFS_FS
958	def_bool y
959	prompt "s390 hypervisor file system support"
960	select SYS_HYPERVISOR
961	help
962	  This is a virtual file system intended to provide accounting
963	  information in an s390 hypervisor environment.
964
965source "arch/s390/kvm/Kconfig"
966
967config S390_GUEST
968	def_bool y
969	prompt "s390 support for virtio devices"
970	select TTY
971	select VIRTUALIZATION
972	select VIRTIO
973	select VIRTIO_CONSOLE
974	help
975	  Enabling this option adds support for virtio based paravirtual device
976	  drivers on s390.
977
978	  Select this option if you want to run the kernel as a guest under
979	  the KVM hypervisor.
980
981endmenu
982