]> Pileus Git - ~andy/linux/blob - arch/s390/Kconfig
s390/bpf,jit: BPF Just In Time compiler for s390
[~andy/linux] / arch / s390 / Kconfig
1 config MMU
2         def_bool y
3
4 config ZONE_DMA
5         def_bool y
6
7 config LOCKDEP_SUPPORT
8         def_bool y
9
10 config STACKTRACE_SUPPORT
11         def_bool y
12
13 config HAVE_LATENCYTOP_SUPPORT
14         def_bool y
15
16 config RWSEM_GENERIC_SPINLOCK
17         bool
18
19 config RWSEM_XCHGADD_ALGORITHM
20         def_bool y
21
22 config ARCH_HAS_ILOG2_U32
23         def_bool n
24
25 config ARCH_HAS_ILOG2_U64
26         def_bool n
27
28 config GENERIC_HWEIGHT
29         def_bool y
30
31 config GENERIC_BUG
32         def_bool y if BUG
33
34 config GENERIC_BUG_RELATIVE_POINTERS
35         def_bool y
36
37 config NO_IOMEM
38         def_bool y
39
40 config NO_DMA
41         def_bool y
42
43 config ARCH_DMA_ADDR_T_64BIT
44         def_bool 64BIT
45
46 config GENERIC_LOCKBREAK
47         def_bool y if SMP && PREEMPT
48
49 config PGSTE
50         def_bool y if KVM
51
52 config VIRT_CPU_ACCOUNTING
53         def_bool y
54
55 config ARCH_SUPPORTS_DEBUG_PAGEALLOC
56         def_bool y
57
58 config S390
59         def_bool y
60         select USE_GENERIC_SMP_HELPERS if SMP
61         select GENERIC_CPU_DEVICES if !SMP
62         select HAVE_SYSCALL_WRAPPERS
63         select HAVE_FUNCTION_TRACER
64         select HAVE_FUNCTION_TRACE_MCOUNT_TEST
65         select HAVE_FTRACE_MCOUNT_RECORD
66         select HAVE_C_RECORDMCOUNT
67         select HAVE_SYSCALL_TRACEPOINTS
68         select HAVE_DYNAMIC_FTRACE
69         select HAVE_FUNCTION_GRAPH_TRACER
70         select HAVE_REGS_AND_STACK_ACCESS_API
71         select HAVE_OPROFILE
72         select HAVE_KPROBES
73         select HAVE_KRETPROBES
74         select HAVE_KVM if 64BIT
75         select HAVE_ARCH_TRACEHOOK
76         select INIT_ALL_POSSIBLE
77         select HAVE_IRQ_WORK
78         select HAVE_PERF_EVENTS
79         select ARCH_HAVE_NMI_SAFE_CMPXCHG
80         select HAVE_KERNEL_GZIP
81         select HAVE_KERNEL_BZIP2
82         select HAVE_KERNEL_LZMA
83         select HAVE_KERNEL_LZO
84         select HAVE_KERNEL_XZ
85         select HAVE_ARCH_MUTEX_CPU_RELAX
86         select HAVE_ARCH_JUMP_LABEL if !MARCH_G5
87         select HAVE_BPF_JIT if 64BIT && PACK_STACK
88         select ARCH_SAVE_PAGE_KEYS if HIBERNATION
89         select ARCH_HAS_ATOMIC64_DEC_IF_POSITIVE
90         select HAVE_MEMBLOCK
91         select HAVE_MEMBLOCK_NODE_MAP
92         select HAVE_CMPXCHG_LOCAL
93         select ARCH_DISCARD_MEMBLOCK
94         select BUILDTIME_EXTABLE_SORT
95         select ARCH_INLINE_SPIN_TRYLOCK
96         select ARCH_INLINE_SPIN_TRYLOCK_BH
97         select ARCH_INLINE_SPIN_LOCK
98         select ARCH_INLINE_SPIN_LOCK_BH
99         select ARCH_INLINE_SPIN_LOCK_IRQ
100         select ARCH_INLINE_SPIN_LOCK_IRQSAVE
101         select ARCH_INLINE_SPIN_UNLOCK
102         select ARCH_INLINE_SPIN_UNLOCK_BH
103         select ARCH_INLINE_SPIN_UNLOCK_IRQ
104         select ARCH_INLINE_SPIN_UNLOCK_IRQRESTORE
105         select ARCH_INLINE_READ_TRYLOCK
106         select ARCH_INLINE_READ_LOCK
107         select ARCH_INLINE_READ_LOCK_BH
108         select ARCH_INLINE_READ_LOCK_IRQ
109         select ARCH_INLINE_READ_LOCK_IRQSAVE
110         select ARCH_INLINE_READ_UNLOCK
111         select ARCH_INLINE_READ_UNLOCK_BH
112         select ARCH_INLINE_READ_UNLOCK_IRQ
113         select ARCH_INLINE_READ_UNLOCK_IRQRESTORE
114         select ARCH_INLINE_WRITE_TRYLOCK
115         select ARCH_INLINE_WRITE_LOCK
116         select ARCH_INLINE_WRITE_LOCK_BH
117         select ARCH_INLINE_WRITE_LOCK_IRQ
118         select ARCH_INLINE_WRITE_LOCK_IRQSAVE
119         select ARCH_INLINE_WRITE_UNLOCK
120         select ARCH_INLINE_WRITE_UNLOCK_BH
121         select ARCH_INLINE_WRITE_UNLOCK_IRQ
122         select ARCH_INLINE_WRITE_UNLOCK_IRQRESTORE
123         select ARCH_WANT_IPC_PARSE_VERSION
124         select GENERIC_SMP_IDLE_THREAD
125         select GENERIC_TIME_VSYSCALL
126         select GENERIC_CLOCKEVENTS
127         select KTIME_SCALAR if 32BIT
128         select HAVE_ARCH_SECCOMP_FILTER
129
130 config SCHED_OMIT_FRAME_POINTER
131         def_bool y
132
133 source "init/Kconfig"
134
135 source "kernel/Kconfig.freezer"
136
137 menu "Base setup"
138
139 comment "Processor type and features"
140
141 config 64BIT
142         def_bool y
143         prompt "64 bit kernel"
144         help
145           Select this option if you have an IBM z/Architecture machine
146           and want to use the 64 bit addressing mode.
147
148 config 32BIT
149         def_bool y if !64BIT
150
151 config SMP
152         def_bool y
153         prompt "Symmetric multi-processing support"
154         ---help---
155           This enables support for systems with more than one CPU. If you have
156           a system with only one CPU, like most personal computers, say N. If
157           you have a system with more than one CPU, say Y.
158
159           If you say N here, the kernel will run on single and multiprocessor
160           machines, but will use only one CPU of a multiprocessor machine. If
161           you say Y here, the kernel will run on many, but not all,
162           singleprocessor machines. On a singleprocessor machine, the kernel
163           will run faster if you say N here.
164
165           See also the SMP-HOWTO available at
166           <http://www.tldp.org/docs.html#howto>.
167
168           Even if you don't know what to do here, say Y.
169
170 config NR_CPUS
171         int "Maximum number of CPUs (2-64)"
172         range 2 64
173         depends on SMP
174         default "32" if !64BIT
175         default "64" if 64BIT
176         help
177           This allows you to specify the maximum number of CPUs which this
178           kernel will support.  The maximum supported value is 64 and the
179           minimum value which makes sense is 2.
180
181           This is purely to save memory - each supported CPU adds
182           approximately sixteen kilobytes to the kernel image.
183
184 config HOTPLUG_CPU
185         def_bool y
186         prompt "Support for hot-pluggable CPUs"
187         depends on SMP
188         select HOTPLUG
189         help
190           Say Y here to be able to turn CPUs off and on. CPUs
191           can be controlled through /sys/devices/system/cpu/cpu#.
192           Say N if you want to disable CPU hotplug.
193
194 config SCHED_MC
195         def_bool n
196
197 config SCHED_BOOK
198         def_bool y
199         prompt "Book scheduler support"
200         depends on SMP
201         select SCHED_MC
202         help
203           Book scheduler support improves the CPU scheduler's decision making
204           when dealing with machines that have several books.
205
206 config MATHEMU
207         def_bool y
208         prompt "IEEE FPU emulation"
209         depends on MARCH_G5
210         help
211           This option is required for IEEE compliant floating point arithmetic
212           on older ESA/390 machines. Say Y unless you know your machine doesn't
213           need this.
214
215 config COMPAT
216         def_bool y
217         prompt "Kernel support for 31 bit emulation"
218         depends on 64BIT
219         select COMPAT_BINFMT_ELF if BINFMT_ELF
220         select ARCH_WANT_OLD_COMPAT_IPC
221         help
222           Select this option if you want to enable your system kernel to
223           handle system-calls from ELF binaries for 31 bit ESA.  This option
224           (and some other stuff like libraries and such) is needed for
225           executing 31 bit applications.  It is safe to say "Y".
226
227 config SYSVIPC_COMPAT
228         def_bool y if COMPAT && SYSVIPC
229
230 config KEYS_COMPAT
231         def_bool y if COMPAT && KEYS
232
233 config AUDIT_ARCH
234         def_bool y
235
236 config HAVE_MARCH_Z900_FEATURES
237         def_bool n
238
239 config HAVE_MARCH_Z990_FEATURES
240         def_bool n
241         select HAVE_MARCH_Z900_FEATURES
242
243 config HAVE_MARCH_Z9_109_FEATURES
244         def_bool n
245         select HAVE_MARCH_Z990_FEATURES
246
247 config HAVE_MARCH_Z10_FEATURES
248         def_bool n
249         select HAVE_MARCH_Z9_109_FEATURES
250
251 config HAVE_MARCH_Z196_FEATURES
252         def_bool n
253         select HAVE_MARCH_Z10_FEATURES
254
255 comment "Code generation options"
256
257 choice
258         prompt "Processor type"
259         default MARCH_G5
260
261 config MARCH_G5
262         bool "System/390 model G5 and G6"
263         depends on !64BIT
264         help
265           Select this to build a 31 bit kernel that works
266           on all ESA/390 and z/Architecture machines.
267
268 config MARCH_Z900
269         bool "IBM zSeries model z800 and z900"
270         select HAVE_MARCH_Z900_FEATURES if 64BIT
271         help
272           Select this to enable optimizations for model z800/z900 (2064 and
273           2066 series). This will enable some optimizations that are not
274           available on older ESA/390 (31 Bit) only CPUs.
275
276 config MARCH_Z990
277         bool "IBM zSeries model z890 and z990"
278         select HAVE_MARCH_Z990_FEATURES if 64BIT
279         help
280           Select this to enable optimizations for model z890/z990 (2084 and
281           2086 series). The kernel will be slightly faster but will not work
282           on older machines.
283
284 config MARCH_Z9_109
285         bool "IBM System z9"
286         select HAVE_MARCH_Z9_109_FEATURES if 64BIT
287         help
288           Select this to enable optimizations for IBM System z9 (2094 and
289           2096 series). The kernel will be slightly faster but will not work
290           on older machines.
291
292 config MARCH_Z10
293         bool "IBM System z10"
294         select HAVE_MARCH_Z10_FEATURES if 64BIT
295         help
296           Select this to enable optimizations for IBM System z10 (2097 and
297           2098 series). The kernel will be slightly faster but will not work
298           on older machines.
299
300 config MARCH_Z196
301         bool "IBM zEnterprise 114 and 196"
302         select HAVE_MARCH_Z196_FEATURES if 64BIT
303         help
304           Select this to enable optimizations for IBM zEnterprise 114 and 196
305           (2818 and 2817 series). The kernel will be slightly faster but will
306           not work on older machines.
307
308 endchoice
309
310 config PACK_STACK
311         def_bool y
312         prompt "Pack kernel stack"
313         help
314           This option enables the compiler option -mkernel-backchain if it
315           is available. If the option is available the compiler supports
316           the new stack layout which dramatically reduces the minimum stack
317           frame size. With an old compiler a non-leaf function needs a
318           minimum of 96 bytes on 31 bit and 160 bytes on 64 bit. With
319           -mkernel-backchain the minimum size drops to 16 byte on 31 bit
320           and 24 byte on 64 bit.
321
322           Say Y if you are unsure.
323
324 config SMALL_STACK
325         def_bool n
326         prompt "Use 8kb for kernel stack instead of 16kb"
327         depends on PACK_STACK && 64BIT && !LOCKDEP
328         help
329           If you say Y here and the compiler supports the -mkernel-backchain
330           option the kernel will use a smaller kernel stack size. The reduced
331           size is 8kb instead of 16kb. This allows to run more threads on a
332           system and reduces the pressure on the memory management for higher
333           order page allocations.
334
335           Say N if you are unsure.
336
337 config CHECK_STACK
338         def_bool y
339         prompt "Detect kernel stack overflow"
340         help
341           This option enables the compiler option -mstack-guard and
342           -mstack-size if they are available. If the compiler supports them
343           it will emit additional code to each function prolog to trigger
344           an illegal operation if the kernel stack is about to overflow.
345
346           Say N if you are unsure.
347
348 config STACK_GUARD
349         int "Size of the guard area (128-1024)"
350         range 128 1024
351         depends on CHECK_STACK
352         default "256"
353         help
354           This allows you to specify the size of the guard area at the lower
355           end of the kernel stack. If the kernel stack points into the guard
356           area on function entry an illegal operation is triggered. The size
357           needs to be a power of 2. Please keep in mind that the size of an
358           interrupt frame is 184 bytes for 31 bit and 328 bytes on 64 bit.
359           The minimum size for the stack guard should be 256 for 31 bit and
360           512 for 64 bit.
361
362 config WARN_DYNAMIC_STACK
363         def_bool n
364         prompt "Emit compiler warnings for function with dynamic stack usage"
365         help
366           This option enables the compiler option -mwarn-dynamicstack. If the
367           compiler supports this options generates warnings for functions
368           that dynamically allocate stack space using alloca.
369
370           Say N if you are unsure.
371
372 comment "Kernel preemption"
373
374 source "kernel/Kconfig.preempt"
375
376 config ARCH_SPARSEMEM_ENABLE
377         def_bool y
378         select SPARSEMEM_VMEMMAP_ENABLE
379         select SPARSEMEM_VMEMMAP
380         select SPARSEMEM_STATIC if !64BIT
381
382 config ARCH_SPARSEMEM_DEFAULT
383         def_bool y
384
385 config ARCH_SELECT_MEMORY_MODEL
386         def_bool y
387
388 config ARCH_ENABLE_MEMORY_HOTPLUG
389         def_bool y if SPARSEMEM
390
391 config ARCH_ENABLE_MEMORY_HOTREMOVE
392         def_bool y
393
394 config ARCH_HIBERNATION_POSSIBLE
395         def_bool y if 64BIT
396
397 source "mm/Kconfig"
398
399 comment "I/O subsystem configuration"
400
401 config QDIO
402         def_tristate y
403         prompt "QDIO support"
404         ---help---
405           This driver provides the Queued Direct I/O base support for
406           IBM System z.
407
408           To compile this driver as a module, choose M here: the
409           module will be called qdio.
410
411           If unsure, say Y.
412
413 config CHSC_SCH
414         def_tristate m
415         prompt "Support for CHSC subchannels"
416         help
417           This driver allows usage of CHSC subchannels. A CHSC subchannel
418           is usually present on LPAR only.
419           The driver creates a device /dev/chsc, which may be used to
420           obtain I/O configuration information about the machine and
421           to issue asynchronous chsc commands (DANGEROUS).
422           You will usually only want to use this interface on a special
423           LPAR designated for system management.
424
425           To compile this driver as a module, choose M here: the
426           module will be called chsc_sch.
427
428           If unsure, say N.
429
430 comment "Misc"
431
432 source "fs/Kconfig.binfmt"
433
434 config FORCE_MAX_ZONEORDER
435         int
436         default "9"
437
438 config PFAULT
439         def_bool y
440         prompt "Pseudo page fault support"
441         help
442           Select this option, if you want to use PFAULT pseudo page fault
443           handling under VM. If running native or in LPAR, this option
444           has no effect. If your VM does not support PFAULT, PAGEEX
445           pseudo page fault handling will be used.
446           Note that VM 4.2 supports PFAULT but has a bug in its
447           implementation that causes some problems.
448           Everybody who wants to run Linux under VM != VM4.2 should select
449           this option.
450
451 config SHARED_KERNEL
452         def_bool y
453         prompt "VM shared kernel support"
454         help
455           Select this option, if you want to share the text segment of the
456           Linux kernel between different VM guests. This reduces memory
457           usage with lots of guests but greatly increases kernel size.
458           Also if a kernel was IPL'ed from a shared segment the kexec system
459           call will not work.
460           You should only select this option if you know what you are
461           doing and want to exploit this feature.
462
463 config CMM
464         def_tristate n
465         prompt "Cooperative memory management"
466         help
467           Select this option, if you want to enable the kernel interface
468           to reduce the memory size of the system. This is accomplished
469           by allocating pages of memory and put them "on hold". This only
470           makes sense for a system running under VM where the unused pages
471           will be reused by VM for other guest systems. The interface
472           allows an external monitor to balance memory of many systems.
473           Everybody who wants to run Linux under VM should select this
474           option.
475
476 config CMM_IUCV
477         def_bool y
478         prompt "IUCV special message interface to cooperative memory management"
479         depends on CMM && (SMSGIUCV=y || CMM=SMSGIUCV)
480         help
481           Select this option to enable the special message interface to
482           the cooperative memory management.
483
484 config APPLDATA_BASE
485         def_bool n
486         prompt "Linux - VM Monitor Stream, base infrastructure"
487         depends on PROC_FS
488         help
489           This provides a kernel interface for creating and updating z/VM APPLDATA
490           monitor records. The monitor records are updated at certain time
491           intervals, once the timer is started.
492           Writing 1 or 0 to /proc/appldata/timer starts(1) or stops(0) the timer,
493           i.e. enables or disables monitoring on the Linux side.
494           A custom interval value (in seconds) can be written to
495           /proc/appldata/interval.
496
497           Defaults are 60 seconds interval and timer off.
498           The /proc entries can also be read from, showing the current settings.
499
500 config APPLDATA_MEM
501         def_tristate m
502         prompt "Monitor memory management statistics"
503         depends on APPLDATA_BASE && VM_EVENT_COUNTERS
504         help
505           This provides memory management related data to the Linux - VM Monitor
506           Stream, like paging/swapping rate, memory utilisation, etc.
507           Writing 1 or 0 to /proc/appldata/memory creates(1) or removes(0) a z/VM
508           APPLDATA monitor record, i.e. enables or disables monitoring this record
509           on the z/VM side.
510
511           Default is disabled.
512           The /proc entry can also be read from, showing the current settings.
513
514           This can also be compiled as a module, which will be called
515           appldata_mem.o.
516
517 config APPLDATA_OS
518         def_tristate m
519         prompt "Monitor OS statistics"
520         depends on APPLDATA_BASE
521         help
522           This provides OS related data to the Linux - VM Monitor Stream, like
523           CPU utilisation, etc.
524           Writing 1 or 0 to /proc/appldata/os creates(1) or removes(0) a z/VM
525           APPLDATA monitor record, i.e. enables or disables monitoring this record
526           on the z/VM side.
527
528           Default is disabled.
529           This can also be compiled as a module, which will be called
530           appldata_os.o.
531
532 config APPLDATA_NET_SUM
533         def_tristate m
534         prompt "Monitor overall network statistics"
535         depends on APPLDATA_BASE && NET
536         help
537           This provides network related data to the Linux - VM Monitor Stream,
538           currently there is only a total sum of network I/O statistics, no
539           per-interface data.
540           Writing 1 or 0 to /proc/appldata/net_sum creates(1) or removes(0) a z/VM
541           APPLDATA monitor record, i.e. enables or disables monitoring this record
542           on the z/VM side.
543
544           Default is disabled.
545           This can also be compiled as a module, which will be called
546           appldata_net_sum.o.
547
548 source kernel/Kconfig.hz
549
550 config S390_HYPFS_FS
551         def_bool y
552         prompt "s390 hypervisor file system support"
553         select SYS_HYPERVISOR
554         help
555           This is a virtual file system intended to provide accounting
556           information in an s390 hypervisor environment.
557
558 config KEXEC
559         def_bool n
560         prompt "kexec system call"
561         help
562           kexec is a system call that implements the ability to shutdown your
563           current kernel, and to start another kernel.  It is like a reboot
564           but is independent of hardware/microcode support.
565
566 config CRASH_DUMP
567         bool "kernel crash dumps"
568         depends on 64BIT && SMP
569         select KEXEC
570         help
571           Generate crash dump after being started by kexec.
572           Crash dump kernels are loaded in the main kernel with kexec-tools
573           into a specially reserved region and then later executed after
574           a crash by kdump/kexec.
575           For more details see Documentation/kdump/kdump.txt
576
577 config ZFCPDUMP
578         def_bool n
579         prompt "zfcpdump support"
580         select SMP
581         help
582           Select this option if you want to build an zfcpdump enabled kernel.
583           Refer to <file:Documentation/s390/zfcpdump.txt> for more details on this.
584
585 config S390_GUEST
586         def_bool y
587         prompt "s390 guest support for KVM (EXPERIMENTAL)"
588         depends on 64BIT && EXPERIMENTAL
589         select VIRTUALIZATION
590         select VIRTIO
591         select VIRTIO_RING
592         select VIRTIO_CONSOLE
593         help
594           Select this option if you want to run the kernel as a guest under
595           the KVM hypervisor. This will add detection for KVM as well  as a
596           virtio transport. If KVM is detected, the virtio console will be
597           the default console.
598
599 config SECCOMP
600         def_bool y
601         prompt "Enable seccomp to safely compute untrusted bytecode"
602         depends on PROC_FS
603         help
604           This kernel feature is useful for number crunching applications
605           that may need to compute untrusted bytecode during their
606           execution. By using pipes or other transports made available to
607           the process as file descriptors supporting the read/write
608           syscalls, it's possible to isolate those applications in
609           their own address space using seccomp. Once seccomp is
610           enabled via /proc/<pid>/seccomp, it cannot be disabled
611           and the task is only allowed to execute a few safe syscalls
612           defined by each seccomp mode.
613
614           If unsure, say Y.
615
616 endmenu
617
618 menu "Power Management"
619
620 source "kernel/power/Kconfig"
621
622 endmenu
623
624 source "net/Kconfig"
625
626 config PCMCIA
627         def_bool n
628
629 config CCW
630         def_bool y
631
632 source "drivers/Kconfig"
633
634 source "fs/Kconfig"
635
636 source "arch/s390/Kconfig.debug"
637
638 source "security/Kconfig"
639
640 source "crypto/Kconfig"
641
642 source "lib/Kconfig"
643
644 source "arch/s390/kvm/Kconfig"