[PATCH] sysrq: irq change build fix.
[linux-block.git] / arch / s390 / Kconfig
CommitLineData
1da177e4
LT
1#
2# For a description of the syntax of this configuration file,
3# see Documentation/kbuild/kconfig-language.txt.
4#
5
6config MMU
7 bool
8 default y
9
2b105ff9
IM
10config LOCKDEP_SUPPORT
11 bool
12 default y
13
5bdc9b44
HC
14config STACKTRACE_SUPPORT
15 bool
16 default y
17
1da177e4
LT
18config RWSEM_GENERIC_SPINLOCK
19 bool
20
21config RWSEM_XCHGADD_ALGORITHM
22 bool
23 default y
24
7e33db4e
AM
25config GENERIC_HWEIGHT
26 bool
27 default y
28
1da177e4
LT
29config GENERIC_CALIBRATE_DELAY
30 bool
31 default y
32
33config GENERIC_BUST_SPINLOCK
34 bool
35
36mainmenu "Linux Kernel Configuration"
37
347a8dc3 38config S390
1da177e4
LT
39 bool
40 default y
41
1da177e4
LT
42source "init/Kconfig"
43
44menu "Base setup"
45
46comment "Processor type and features"
47
347a8dc3 48config 64BIT
1da177e4
LT
49 bool "64 bit kernel"
50 help
51 Select this option if you have a 64 bit IBM zSeries machine
52 and want to use the 64 bit addressing mode.
53
d9f7a745
MS
54config 32BIT
55 bool
56 default y if !64BIT
57
1da177e4
LT
58config SMP
59 bool "Symmetric multi-processing support"
60 ---help---
61 This enables support for systems with more than one CPU. If you have
62 a system with only one CPU, like most personal computers, say N. If
63 you have a system with more than one CPU, say Y.
64
65 If you say N here, the kernel will run on single and multiprocessor
66 machines, but will use only one CPU of a multiprocessor machine. If
67 you say Y here, the kernel will run on many, but not all,
68 singleprocessor machines. On a singleprocessor machine, the kernel
69 will run faster if you say N here.
70
71 See also the <file:Documentation/smp.txt> and the SMP-HOWTO
72 available at <http://www.tldp.org/docs.html#howto>.
73
74 Even if you don't know what to do here, say Y.
75
76config NR_CPUS
77 int "Maximum number of CPUs (2-64)"
78 range 2 64
79 depends on SMP
80 default "32"
81 help
82 This allows you to specify the maximum number of CPUs which this
83 kernel will support. The maximum supported value is 64 and the
84 minimum value which makes sense is 2.
85
86 This is purely to save memory - each supported CPU adds
87 approximately sixteen kilobytes to the kernel image.
88
89config HOTPLUG_CPU
90 bool "Support for hot-pluggable CPUs"
91 depends on SMP
92 select HOTPLUG
93 default n
94 help
95 Say Y here to be able to turn CPUs off and on. CPUs
96 can be controlled through /sys/devices/system/cpu/cpu#.
97 Say N if you want to disable CPU hotplug.
98
4bbf39c2
IM
99config DEFAULT_MIGRATION_COST
100 int
101 default "1000000"
102
1da177e4
LT
103config MATHEMU
104 bool "IEEE FPU emulation"
105 depends on MARCH_G5
106 help
107 This option is required for IEEE compliant floating point arithmetic
108 on older S/390 machines. Say Y unless you know your machine doesn't
109 need this.
110
347a8dc3 111config COMPAT
1da177e4 112 bool "Kernel support for 31 bit emulation"
347a8dc3 113 depends on 64BIT
1da177e4
LT
114 help
115 Select this option if you want to enable your system kernel to
116 handle system-calls from ELF binaries for 31 bit ESA. This option
117 (and some other stuff like libraries and such) is needed for
118 executing 31 bit applications. It is safe to say "Y".
119
1da177e4
LT
120config SYSVIPC_COMPAT
121 bool
122 depends on COMPAT && SYSVIPC
123 default y
124
e65e1fc2
AV
125config AUDIT_ARCH
126 bool
127 default y
128
1da177e4
LT
129comment "Code generation options"
130
131choice
132 prompt "Processor type"
133 default MARCH_G5
134
135config MARCH_G5
136 bool "S/390 model G5 and G6"
347a8dc3 137 depends on !64BIT
1da177e4
LT
138 help
139 Select this to build a 31 bit kernel that works
140 on all S/390 and zSeries machines.
141
142config MARCH_Z900
143 bool "IBM eServer zSeries model z800 and z900"
144 help
145 Select this to optimize for zSeries machines. This
146 will enable some optimizations that are not available
147 on older 31 bit only CPUs.
148
149config MARCH_Z990
150 bool "IBM eServer zSeries model z890 and z990"
151 help
152 Select this enable optimizations for model z890/z990.
153 This will be slightly faster but does not work on
154 older machines such as the z900.
155
0efa4703
CB
156config MARCH_Z9_109
157 bool "IBM System z9"
158 help
159 Select this to enable optimizations for IBM System z9-109, IBM
160 System z9 Enterprise Class (z9 EC), and IBM System z9 Business
161 Class (z9 BC). The kernel will be slightly faster but will not
162 work on older machines such as the z990, z890, z900, and z800.
163
1da177e4
LT
164endchoice
165
166config PACK_STACK
167 bool "Pack kernel stack"
168 help
169 This option enables the compiler option -mkernel-backchain if it
170 is available. If the option is available the compiler supports
171 the new stack layout which dramatically reduces the minimum stack
172 frame size. With an old compiler a non-leaf function needs a
173 minimum of 96 bytes on 31 bit and 160 bytes on 64 bit. With
174 -mkernel-backchain the minimum size drops to 16 byte on 31 bit
175 and 24 byte on 64 bit.
176
177 Say Y if you are unsure.
178
179config SMALL_STACK
180 bool "Use 4kb/8kb for kernel stack instead of 8kb/16kb"
181 depends on PACK_STACK
182 help
183 If you say Y here and the compiler supports the -mkernel-backchain
184 option the kernel will use a smaller kernel stack size. For 31 bit
185 the reduced size is 4kb instead of 8kb and for 64 bit it is 8kb
186 instead of 16kb. This allows to run more thread on a system and
187 reduces the pressure on the memory management for higher order
188 page allocations.
189
190 Say N if you are unsure.
191
192
193config CHECK_STACK
194 bool "Detect kernel stack overflow"
195 help
196 This option enables the compiler option -mstack-guard and
197 -mstack-size if they are available. If the compiler supports them
198 it will emit additional code to each function prolog to trigger
199 an illegal operation if the kernel stack is about to overflow.
200
201 Say N if you are unsure.
202
203config STACK_GUARD
204 int "Size of the guard area (128-1024)"
205 range 128 1024
206 depends on CHECK_STACK
207 default "256"
208 help
209 This allows you to specify the size of the guard area at the lower
210 end of the kernel stack. If the kernel stack points into the guard
211 area on function entry an illegal operation is triggered. The size
212 needs to be a power of 2. Please keep in mind that the size of an
213 interrupt frame is 184 bytes for 31 bit and 328 bytes on 64 bit.
214 The minimum size for the stack guard should be 256 for 31 bit and
215 512 for 64 bit.
216
217config WARN_STACK
218 bool "Emit compiler warnings for function with broken stack usage"
219 help
220 This option enables the compiler options -mwarn-framesize and
221 -mwarn-dynamicstack. If the compiler supports these options it
222 will generate warnings for function which either use alloca or
223 create a stack frame bigger then CONFIG_WARN_STACK_SIZE.
224
225 Say N if you are unsure.
226
227config WARN_STACK_SIZE
228 int "Maximum frame size considered safe (128-2048)"
229 range 128 2048
230 depends on WARN_STACK
231 default "256"
232 help
233 This allows you to specify the maximum frame size a function may
234 have without the compiler complaining about it.
235
7676bef9
HC
236config ARCH_POPULATES_NODE_MAP
237 def_bool y
238
3f22ab27
DH
239source "mm/Kconfig"
240
1da177e4
LT
241comment "I/O subsystem configuration"
242
243config MACHCHK_WARNING
244 bool "Process warning machine checks"
245 help
246 Select this option if you want the machine check handler on IBM S/390 or
247 zSeries to process warning machine checks (e.g. on power failures).
248 If unsure, say "Y".
249
250config QDIO
251 tristate "QDIO support"
252 ---help---
8129ee16
FP
253 This driver provides the Queued Direct I/O base support for
254 IBM mainframes.
1da177e4
LT
255
256 For details please refer to the documentation provided by IBM at
257 <http://www10.software.ibm.com/developerworks/opensource/linux390>
258
259 To compile this driver as a module, choose M here: the
260 module will be called qdio.
261
262 If unsure, say Y.
263
264config QDIO_PERF_STATS
265 bool "Performance statistics in /proc"
266 depends on QDIO
267 help
268 Say Y here to get performance statistics in /proc/qdio_perf
269
270 If unsure, say N.
271
272config QDIO_DEBUG
273 bool "Extended debugging information"
274 depends on QDIO
275 help
8129ee16
FP
276 Say Y here to get extended debugging output in
277 /sys/kernel/debug/s390dbf/qdio...
1da177e4
LT
278 Warning: this option reduces the performance of the QDIO module.
279
280 If unsure, say N.
281
282comment "Misc"
283
284config PREEMPT
285 bool "Preemptible Kernel"
286 help
287 This option reduces the latency of the kernel when reacting to
288 real-time or interactive events by allowing a low priority process to
289 be preempted even if it is in kernel mode executing a system call.
290 This allows applications to run more reliably even when the system is
291 under load.
292
293 Say N if you are unsure.
294
295config IPL
296 bool "Builtin IPL record support"
297 help
298 If you want to use the produced kernel to IPL directly from a
299 device, you have to merge a bootsector specific to the device
300 into the first bytes of the kernel. You will have to select the
301 IPL device.
302
303choice
304 prompt "IPL method generated into head.S"
305 depends on IPL
306 default IPL_TAPE
307 help
308 Select "tape" if you want to IPL the image from a Tape.
309
310 Select "vm_reader" if you are running under VM/ESA and want
311 to IPL the image from the emulated card reader.
312
313config IPL_TAPE
314 bool "tape"
315
316config IPL_VM
317 bool "vm_reader"
318
319endchoice
320
321source "fs/Kconfig.binfmt"
322
323config PROCESS_DEBUG
324 bool "Show crashed user process info"
325 help
326 Say Y to print all process fault locations to the console. This is
327 a debugging option; you probably do not want to set it unless you
328 are an S390 port maintainer.
329
330config PFAULT
331 bool "Pseudo page fault support"
332 help
333 Select this option, if you want to use PFAULT pseudo page fault
334 handling under VM. If running native or in LPAR, this option
335 has no effect. If your VM does not support PFAULT, PAGEEX
336 pseudo page fault handling will be used.
337 Note that VM 4.2 supports PFAULT but has a bug in its
338 implementation that causes some problems.
339 Everybody who wants to run Linux under VM != VM4.2 should select
340 this option.
341
342config SHARED_KERNEL
343 bool "VM shared kernel support"
344 help
345 Select this option, if you want to share the text segment of the
346 Linux kernel between different VM guests. This reduces memory
347 usage with lots of guests but greatly increases kernel size.
348 You should only select this option if you know what you are
349 doing and want to exploit this feature.
350
351config CMM
352 tristate "Cooperative memory management"
353 help
354 Select this option, if you want to enable the kernel interface
355 to reduce the memory size of the system. This is accomplished
356 by allocating pages of memory and put them "on hold". This only
357 makes sense for a system running under VM where the unused pages
358 will be reused by VM for other guest systems. The interface
359 allows an external monitor to balance memory of many systems.
360 Everybody who wants to run Linux under VM should select this
361 option.
362
363config CMM_PROC
364 bool "/proc interface to cooperative memory management"
365 depends on CMM
366 help
367 Select this option to enable the /proc interface to the
368 cooperative memory management.
369
370config CMM_IUCV
371 bool "IUCV special message interface to cooperative memory management"
372 depends on CMM && (SMSGIUCV=y || CMM=SMSGIUCV)
373 help
374 Select this option to enable the special message interface to
375 the cooperative memory management.
376
377config VIRT_TIMER
378 bool "Virtual CPU timer support"
379 help
380 This provides a kernel interface for virtual CPU timers.
381 Default is disabled.
382
383config VIRT_CPU_ACCOUNTING
384 bool "Base user process accounting on virtual cpu timer"
385 depends on VIRT_TIMER
386 help
387 Select this option to use CPU timer deltas to do user
388 process accounting.
389
390config APPLDATA_BASE
391 bool "Linux - VM Monitor Stream, base infrastructure"
392 depends on PROC_FS && VIRT_TIMER=y
393 help
394 This provides a kernel interface for creating and updating z/VM APPLDATA
395 monitor records. The monitor records are updated at certain time
396 intervals, once the timer is started.
397 Writing 1 or 0 to /proc/appldata/timer starts(1) or stops(0) the timer,
398 i.e. enables or disables monitoring on the Linux side.
399 A custom interval value (in seconds) can be written to
400 /proc/appldata/interval.
401
402 Defaults are 60 seconds interval and timer off.
403 The /proc entries can also be read from, showing the current settings.
404
405config APPLDATA_MEM
406 tristate "Monitor memory management statistics"
407 depends on APPLDATA_BASE
408 help
409 This provides memory management related data to the Linux - VM Monitor
410 Stream, like paging/swapping rate, memory utilisation, etc.
411 Writing 1 or 0 to /proc/appldata/memory creates(1) or removes(0) a z/VM
412 APPLDATA monitor record, i.e. enables or disables monitoring this record
413 on the z/VM side.
414
415 Default is disabled.
416 The /proc entry can also be read from, showing the current settings.
417
418 This can also be compiled as a module, which will be called
419 appldata_mem.o.
420
421config APPLDATA_OS
422 tristate "Monitor OS statistics"
423 depends on APPLDATA_BASE
424 help
425 This provides OS related data to the Linux - VM Monitor Stream, like
426 CPU utilisation, etc.
427 Writing 1 or 0 to /proc/appldata/os creates(1) or removes(0) a z/VM
428 APPLDATA monitor record, i.e. enables or disables monitoring this record
429 on the z/VM side.
430
431 Default is disabled.
432 This can also be compiled as a module, which will be called
433 appldata_os.o.
434
435config APPLDATA_NET_SUM
436 tristate "Monitor overall network statistics"
437 depends on APPLDATA_BASE
438 help
439 This provides network related data to the Linux - VM Monitor Stream,
440 currently there is only a total sum of network I/O statistics, no
441 per-interface data.
442 Writing 1 or 0 to /proc/appldata/net_sum creates(1) or removes(0) a z/VM
443 APPLDATA monitor record, i.e. enables or disables monitoring this record
444 on the z/VM side.
445
446 Default is disabled.
447 This can also be compiled as a module, which will be called
448 appldata_net_sum.o.
449
450config NO_IDLE_HZ
451 bool "No HZ timer ticks in idle"
452 help
453 Switches the regular HZ timer off when the system is going idle.
454 This helps z/VM to detect that the Linux system is idle. VM can
455 then "swap-out" this guest which reduces memory usage. It also
456 reduces the overhead of idle systems.
457
458 The HZ timer can be switched on/off via /proc/sys/kernel/hz_timer.
459 hz_timer=0 means HZ timer is disabled. hz_timer=1 means HZ
460 timer is active.
461
462config NO_IDLE_HZ_INIT
463 bool "HZ timer in idle off by default"
464 depends on NO_IDLE_HZ
465 help
466 The HZ timer is switched off in idle by default. That means the
467 HZ timer is already disabled at boot time.
468
24bbb1fa
MH
469config S390_HYPFS_FS
470 bool "s390 hypervisor file system support"
471 select SYS_HYPERVISOR
472 default y
473 help
474 This is a virtual file system intended to provide accounting
475 information in an s390 hypervisor environment.
476
cf13f0ea 477config KEXEC
07d43ce6 478 bool "kexec system call"
cf13f0ea
HC
479 help
480 kexec is a system call that implements the ability to shutdown your
481 current kernel, and to start another kernel. It is like a reboot
482 but is independent of hardware/microcode support.
483
1da177e4
LT
484endmenu
485
d5950b43
SR
486source "net/Kconfig"
487
1da177e4
LT
488config PCMCIA
489 bool
490 default n
491
492source "drivers/base/Kconfig"
493
61d3ad0e
MS
494source "drivers/connector/Kconfig"
495
1da177e4
LT
496source "drivers/scsi/Kconfig"
497
498source "drivers/s390/Kconfig"
499
d5950b43 500source "drivers/net/Kconfig"
1da177e4
LT
501
502source "fs/Kconfig"
503
4ba069b8
MG
504menu "Instrumentation Support"
505
1da177e4
LT
506source "arch/s390/oprofile/Kconfig"
507
4ba069b8
MG
508config KPROBES
509 bool "Kprobes (EXPERIMENTAL)"
510 depends on EXPERIMENTAL && MODULES
511 help
512 Kprobes allows you to trap at almost any kernel address and
513 execute a callback function. register_kprobe() establishes
514 a probepoint and specifies the callback. Kprobes is useful
515 for kernel debugging, non-intrusive instrumentation and testing.
516 If in doubt, say "N".
517
518endmenu
519
1da177e4
LT
520source "arch/s390/Kconfig.debug"
521
522source "security/Kconfig"
523
524source "crypto/Kconfig"
525
526source "lib/Kconfig"