blob: 4a7f14079e03b989bd4cd4b1a012b082e07447b3 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001config MMU
Martin Schwidefsky61d48c22007-05-10 15:46:00 +02002 def_bool y
Linus Torvalds1da177e2005-04-16 15:20:36 -07003
Christoph Lameter66701b12007-02-10 01:43:09 -08004config ZONE_DMA
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +01005 def_bool y if 64BIT
Christoph Lameter66701b12007-02-10 01:43:09 -08006
Ingo Molnar2b105ff2006-07-03 00:25:02 -07007config LOCKDEP_SUPPORT
Martin Schwidefsky61d48c22007-05-10 15:46:00 +02008 def_bool y
Ingo Molnar2b105ff2006-07-03 00:25:02 -07009
Heiko Carstens5bdc9b42006-07-03 00:24:41 -070010config STACKTRACE_SUPPORT
Martin Schwidefsky61d48c22007-05-10 15:46:00 +020011 def_bool y
Heiko Carstens5bdc9b42006-07-03 00:24:41 -070012
Heiko Carstensa3afe702008-02-05 16:50:45 +010013config HAVE_LATENCYTOP_SUPPORT
14 def_bool y
15
Linus Torvalds1da177e2005-04-16 15:20:36 -070016config RWSEM_GENERIC_SPINLOCK
17 bool
18
19config RWSEM_XCHGADD_ALGORITHM
Martin Schwidefsky61d48c22007-05-10 15:46:00 +020020 def_bool y
Linus Torvalds1da177e2005-04-16 15:20:36 -070021
David Howellsf0d1b0b2006-12-08 02:37:49 -080022config ARCH_HAS_ILOG2_U32
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +010023 def_bool n
David Howellsf0d1b0b2006-12-08 02:37:49 -080024
25config ARCH_HAS_ILOG2_U64
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +010026 def_bool n
David Howellsf0d1b0b2006-12-08 02:37:49 -080027
Akinobu Mita7e33db42006-03-26 01:39:34 -080028config GENERIC_HWEIGHT
Martin Schwidefsky61d48c22007-05-10 15:46:00 +020029 def_bool y
Akinobu Mita7e33db42006-03-26 01:39:34 -080030
Martin Schwidefskyb0206322008-12-25 13:38:36 +010031config GENERIC_TIME_VSYSCALL
32 def_bool y
33
Heiko Carstens5a62b192008-04-17 07:46:25 +020034config GENERIC_CLOCKEVENTS
35 def_bool y
36
Heiko Carstensc0007f12007-04-27 16:01:42 +020037config GENERIC_BUG
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +010038 def_bool y if BUG
Heiko Carstensc0007f12007-04-27 16:01:42 +020039
Heiko Carstens52499f42010-02-26 22:37:44 +010040config GENERIC_BUG_RELATIVE_POINTERS
41 def_bool y
42
Al Viro23db7642007-02-11 18:15:29 +000043config NO_IOMEM
Al Viro5ea81762007-02-11 15:41:31 +000044 def_bool y
45
Heiko Carstens411f0f32007-05-06 14:49:09 -070046config NO_DMA
47 def_bool y
48
FUJITA Tomonorieca577e2010-10-25 16:10:50 +020049config ARCH_DMA_ADDR_T_64BIT
50 def_bool 64BIT
51
Martin Schwidefskyb6b40c52008-02-05 16:50:42 +010052config GENERIC_LOCKBREAK
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +010053 def_bool y if SMP && PREEMPT
Martin Schwidefskyb6b40c52008-02-05 16:50:42 +010054
Carsten Otte402b0862008-03-25 18:47:10 +010055config PGSTE
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +010056 def_bool y if KVM
Carsten Otte402b0862008-03-25 18:47:10 +010057
Martin Schwidefskyc185b782008-12-25 13:39:25 +010058config VIRT_CPU_ACCOUNTING
59 def_bool y
60
Akinobu Mita6a11f752009-03-31 15:23:17 -070061config ARCH_SUPPORTS_DEBUG_PAGEALLOC
62 def_bool y
63
Martin Schwidefsky347a8dc2006-01-06 00:19:28 -080064config S390
Martin Schwidefsky61d48c22007-05-10 15:46:00 +020065 def_bool y
Heiko Carstensca9fc752008-12-25 13:38:39 +010066 select USE_GENERIC_SMP_HELPERS if SMP
Heiko Carstensed6bb612009-01-14 14:14:01 +010067 select HAVE_SYSCALL_WRAPPERS
Heiko Carstens5d360a72008-12-25 13:38:56 +010068 select HAVE_FUNCTION_TRACER
Heiko Carstens8b4488f2009-06-12 10:26:45 +020069 select HAVE_FUNCTION_TRACE_MCOUNT_TEST
Heiko Carstensdfd9f7a2009-06-12 10:26:44 +020070 select HAVE_FTRACE_MCOUNT_RECORD
Heiko Carstensb25c4772010-10-29 16:50:42 +020071 select HAVE_C_RECORDMCOUNT
Josh Stone66700002009-08-24 14:43:11 -070072 select HAVE_SYSCALL_TRACEPOINTS
Heiko Carstensdfd9f7a2009-06-12 10:26:44 +020073 select HAVE_DYNAMIC_FTRACE
Heiko Carstens88dbd202009-06-12 10:26:46 +020074 select HAVE_FUNCTION_GRAPH_TRACER
Heiko Carstens952974ac62010-02-12 13:38:40 +010075 select HAVE_REGS_AND_STACK_ACCESS_API
Mathieu Desnoyers42d4b832008-02-02 15:10:34 -050076 select HAVE_OPROFILE
Mathieu Desnoyers3f550092008-02-02 15:10:35 -050077 select HAVE_KPROBES
Ananth N Mavinakayanahalli9edddaa2008-03-04 14:28:37 -080078 select HAVE_KRETPROBES
Christian Borntraeger77b455f2008-03-25 18:47:36 +010079 select HAVE_KVM if 64BIT
Martin Schwidefsky753c4dd2008-10-10 21:33:20 +020080 select HAVE_ARCH_TRACEHOOK
Rusty Russell98a79d62008-12-13 21:19:41 +103081 select INIT_ALL_POSSIBLE
Peter Zijlstrae360adb2010-10-14 14:01:34 +080082 select HAVE_IRQ_WORK
Ingo Molnarcdd6c482009-09-21 12:02:48 +020083 select HAVE_PERF_EVENTS
Martin Schwidefsky1844c9b2010-02-26 22:37:53 +010084 select HAVE_KERNEL_GZIP
85 select HAVE_KERNEL_BZIP2
86 select HAVE_KERNEL_LZMA
Heiko Carstenscdf56642010-05-26 23:27:12 +020087 select HAVE_KERNEL_LZO
Heiko Carstensd7b081a2011-03-15 17:08:32 +010088 select HAVE_KERNEL_XZ
Martin Schwidefsky80217142010-10-25 16:10:11 +020089 select HAVE_GET_USER_PAGES_FAST
Gerald Schaefer34b133f2011-01-05 12:48:14 +010090 select HAVE_ARCH_MUTEX_CPU_RELAX
Jan Glauber5373db82011-03-16 15:58:30 -040091 select HAVE_ARCH_JUMP_LABEL if !MARCH_G5
Thomas Gleixner6beb0002009-11-09 15:21:34 +000092 select ARCH_INLINE_SPIN_TRYLOCK
93 select ARCH_INLINE_SPIN_TRYLOCK_BH
94 select ARCH_INLINE_SPIN_LOCK
95 select ARCH_INLINE_SPIN_LOCK_BH
96 select ARCH_INLINE_SPIN_LOCK_IRQ
97 select ARCH_INLINE_SPIN_LOCK_IRQSAVE
98 select ARCH_INLINE_SPIN_UNLOCK
99 select ARCH_INLINE_SPIN_UNLOCK_BH
100 select ARCH_INLINE_SPIN_UNLOCK_IRQ
101 select ARCH_INLINE_SPIN_UNLOCK_IRQRESTORE
102 select ARCH_INLINE_READ_TRYLOCK
103 select ARCH_INLINE_READ_LOCK
104 select ARCH_INLINE_READ_LOCK_BH
105 select ARCH_INLINE_READ_LOCK_IRQ
106 select ARCH_INLINE_READ_LOCK_IRQSAVE
107 select ARCH_INLINE_READ_UNLOCK
108 select ARCH_INLINE_READ_UNLOCK_BH
109 select ARCH_INLINE_READ_UNLOCK_IRQ
110 select ARCH_INLINE_READ_UNLOCK_IRQRESTORE
111 select ARCH_INLINE_WRITE_TRYLOCK
112 select ARCH_INLINE_WRITE_LOCK
113 select ARCH_INLINE_WRITE_LOCK_BH
114 select ARCH_INLINE_WRITE_LOCK_IRQ
115 select ARCH_INLINE_WRITE_LOCK_IRQSAVE
116 select ARCH_INLINE_WRITE_UNLOCK
117 select ARCH_INLINE_WRITE_UNLOCK_BH
118 select ARCH_INLINE_WRITE_UNLOCK_IRQ
119 select ARCH_INLINE_WRITE_UNLOCK_IRQRESTORE
Linus Torvalds1da177e2005-04-16 15:20:36 -0700120
Martin Schwidefskyfca3e352009-07-07 16:37:10 +0200121config SCHED_OMIT_FRAME_POINTER
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100122 def_bool y
Martin Schwidefskyfca3e352009-07-07 16:37:10 +0200123
Linus Torvalds1da177e2005-04-16 15:20:36 -0700124source "init/Kconfig"
125
Matt Helsleydc52ddc2008-10-18 20:27:21 -0700126source "kernel/Kconfig.freezer"
127
Linus Torvalds1da177e2005-04-16 15:20:36 -0700128menu "Base setup"
129
130comment "Processor type and features"
131
Heiko Carstens5a62b192008-04-17 07:46:25 +0200132source "kernel/time/Kconfig"
133
Martin Schwidefsky347a8dc2006-01-06 00:19:28 -0800134config 64BIT
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100135 def_bool y
136 prompt "64 bit kernel"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700137 help
Heiko Carstensdb81a232010-10-29 16:50:36 +0200138 Select this option if you have an IBM z/Architecture machine
Linus Torvalds1da177e2005-04-16 15:20:36 -0700139 and want to use the 64 bit addressing mode.
140
Martin Schwidefskyd9f7a742006-09-28 16:55:39 +0200141config 32BIT
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100142 def_bool y if !64BIT
Martin Schwidefskyd9f7a742006-09-28 16:55:39 +0200143
Martin Schwidefsky07606302009-07-07 16:37:13 +0200144config KTIME_SCALAR
145 def_bool 32BIT
146
Linus Torvalds1da177e2005-04-16 15:20:36 -0700147config SMP
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100148 def_bool y
149 prompt "Symmetric multi-processing support"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700150 ---help---
151 This enables support for systems with more than one CPU. If you have
152 a system with only one CPU, like most personal computers, say N. If
153 you have a system with more than one CPU, say Y.
154
155 If you say N here, the kernel will run on single and multiprocessor
156 machines, but will use only one CPU of a multiprocessor machine. If
157 you say Y here, the kernel will run on many, but not all,
158 singleprocessor machines. On a singleprocessor machine, the kernel
159 will run faster if you say N here.
160
Adrian Bunk03502fa2008-02-03 15:50:21 +0200161 See also the SMP-HOWTO available at
162 <http://www.tldp.org/docs.html#howto>.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700163
164 Even if you don't know what to do here, say Y.
165
166config NR_CPUS
167 int "Maximum number of CPUs (2-64)"
168 range 2 64
169 depends on SMP
Heiko Carstens057c5cb2008-02-19 15:29:25 +0100170 default "32" if !64BIT
171 default "64" if 64BIT
Linus Torvalds1da177e2005-04-16 15:20:36 -0700172 help
173 This allows you to specify the maximum number of CPUs which this
174 kernel will support. The maximum supported value is 64 and the
175 minimum value which makes sense is 2.
176
177 This is purely to save memory - each supported CPU adds
178 approximately sixteen kilobytes to the kernel image.
179
180config HOTPLUG_CPU
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100181 def_bool y
182 prompt "Support for hot-pluggable CPUs"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700183 depends on SMP
184 select HOTPLUG
Linus Torvalds1da177e2005-04-16 15:20:36 -0700185 help
186 Say Y here to be able to turn CPUs off and on. CPUs
187 can be controlled through /sys/devices/system/cpu/cpu#.
188 Say N if you want to disable CPU hotplug.
189
Heiko Carstens8d11e022010-10-29 16:50:37 +0200190config SCHED_MC
191 def_bool y
192 prompt "Multi-core scheduler support"
193 depends on SMP
194 help
195 Multi-core scheduler support improves the CPU scheduler's decision
196 making when dealing with multi-core CPU chips at a cost of slightly
197 increased overhead in some places.
198
Heiko Carstens4cb14bc2010-08-31 10:28:18 +0200199config SCHED_BOOK
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100200 def_bool y
201 prompt "Book scheduler support"
Heiko Carstens8d11e022010-10-29 16:50:37 +0200202 depends on SMP && SCHED_MC
Heiko Carstens4cb14bc2010-08-31 10:28:18 +0200203 help
204 Book scheduler support improves the CPU scheduler's decision making
205 when dealing with machines that have several books.
206
Linus Torvalds1da177e2005-04-16 15:20:36 -0700207config MATHEMU
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100208 def_bool y
209 prompt "IEEE FPU emulation"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700210 depends on MARCH_G5
211 help
212 This option is required for IEEE compliant floating point arithmetic
Heiko Carstensdb81a232010-10-29 16:50:36 +0200213 on older ESA/390 machines. Say Y unless you know your machine doesn't
Linus Torvalds1da177e2005-04-16 15:20:36 -0700214 need this.
215
Martin Schwidefsky347a8dc2006-01-06 00:19:28 -0800216config COMPAT
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100217 def_bool y
218 prompt "Kernel support for 31 bit emulation"
Martin Schwidefsky347a8dc2006-01-06 00:19:28 -0800219 depends on 64BIT
Martin Schwidefsky63506c42008-07-14 09:58:54 +0200220 select COMPAT_BINFMT_ELF
Linus Torvalds1da177e2005-04-16 15:20:36 -0700221 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
Linus Torvalds1da177e2005-04-16 15:20:36 -0700227config SYSVIPC_COMPAT
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100228 def_bool y if COMPAT && SYSVIPC
Linus Torvalds1da177e2005-04-16 15:20:36 -0700229
Al Viroe65e1fc2006-09-12 03:04:40 -0400230config AUDIT_ARCH
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100231 def_bool y
Al Viroe65e1fc2006-09-12 03:04:40 -0400232
Gerald Schaeferc1821c22007-02-05 21:18:17 +0100233config S390_EXEC_PROTECT
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100234 def_bool y
235 prompt "Data execute protection"
Gerald Schaeferc1821c22007-02-05 21:18:17 +0100236 help
237 This option allows to enable a buffer overflow protection for user
238 space programs and it also selects the addressing mode option above.
239 The kernel parameter noexec=on will enable this feature and also
240 switch the addressing modes, default is disabled. Enabling this (via
Heiko Carstensdb81a232010-10-29 16:50:36 +0200241 kernel parameter) on machines earlier than IBM System z9 this will
242 reduce system performance.
Gerald Schaeferc1821c22007-02-05 21:18:17 +0100243
Linus Torvalds1da177e2005-04-16 15:20:36 -0700244comment "Code generation options"
245
246choice
247 prompt "Processor type"
248 default MARCH_G5
249
250config MARCH_G5
Heiko Carstensdb81a232010-10-29 16:50:36 +0200251 bool "System/390 model G5 and G6"
Martin Schwidefsky347a8dc2006-01-06 00:19:28 -0800252 depends on !64BIT
Linus Torvalds1da177e2005-04-16 15:20:36 -0700253 help
254 Select this to build a 31 bit kernel that works
Heiko Carstensdb81a232010-10-29 16:50:36 +0200255 on all ESA/390 and z/Architecture machines.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700256
257config MARCH_Z900
Heiko Carstensdb81a232010-10-29 16:50:36 +0200258 bool "IBM zSeries model z800 and z900"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700259 help
Heiko Carstensdb81a232010-10-29 16:50:36 +0200260 Select this to enable optimizations for model z800/z900 (2064 and
261 2066 series). This will enable some optimizations that are not
262 available on older ESA/390 (31 Bit) only CPUs.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700263
264config MARCH_Z990
Heiko Carstensdb81a232010-10-29 16:50:36 +0200265 bool "IBM zSeries model z890 and z990"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700266 help
Heiko Carstensdb81a232010-10-29 16:50:36 +0200267 Select this to enable optimizations for model z890/z990 (2084 and
268 2086 series). The kernel will be slightly faster but will not work
269 on older machines.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700270
Christian Borntraeger0efa4702006-09-28 16:55:46 +0200271config MARCH_Z9_109
272 bool "IBM System z9"
273 help
Heiko Carstensdb81a232010-10-29 16:50:36 +0200274 Select this to enable optimizations for IBM System z9 (2094 and
275 2096 series). The kernel will be slightly faster but will not work
276 on older machines.
Christian Borntraeger0efa4702006-09-28 16:55:46 +0200277
Martin Schwidefskye37f50e2008-12-25 13:39:19 +0100278config MARCH_Z10
279 bool "IBM System z10"
280 help
Heiko Carstensdb81a232010-10-29 16:50:36 +0200281 Select this to enable optimizations for IBM System z10 (2097 and
282 2098 series). The kernel will be slightly faster but will not work
283 on older machines.
Martin Schwidefskye37f50e2008-12-25 13:39:19 +0100284
Heiko Carstensf861e402010-10-25 16:10:17 +0200285config MARCH_Z196
286 bool "IBM zEnterprise 196"
287 help
Heiko Carstensdb81a232010-10-29 16:50:36 +0200288 Select this to enable optimizations for IBM zEnterprise 196
289 (2817 series). The kernel will be slightly faster but will not work
290 on older machines.
Heiko Carstensf861e402010-10-25 16:10:17 +0200291
Linus Torvalds1da177e2005-04-16 15:20:36 -0700292endchoice
293
294config PACK_STACK
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100295 def_bool y
296 prompt "Pack kernel stack"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700297 help
298 This option enables the compiler option -mkernel-backchain if it
299 is available. If the option is available the compiler supports
300 the new stack layout which dramatically reduces the minimum stack
301 frame size. With an old compiler a non-leaf function needs a
302 minimum of 96 bytes on 31 bit and 160 bytes on 64 bit. With
303 -mkernel-backchain the minimum size drops to 16 byte on 31 bit
304 and 24 byte on 64 bit.
305
306 Say Y if you are unsure.
307
308config SMALL_STACK
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100309 def_bool n
310 prompt "Use 8kb for kernel stack instead of 16kb"
Heiko Carstens7f5a8ba2008-10-28 11:10:21 +0100311 depends on PACK_STACK && 64BIT && !LOCKDEP
Linus Torvalds1da177e2005-04-16 15:20:36 -0700312 help
313 If you say Y here and the compiler supports the -mkernel-backchain
Heiko Carstens7f5a8ba2008-10-28 11:10:21 +0100314 option the kernel will use a smaller kernel stack size. The reduced
315 size is 8kb instead of 16kb. This allows to run more threads on a
316 system and reduces the pressure on the memory management for higher
317 order page allocations.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700318
319 Say N if you are unsure.
320
Linus Torvalds1da177e2005-04-16 15:20:36 -0700321config CHECK_STACK
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100322 def_bool y
323 prompt "Detect kernel stack overflow"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700324 help
325 This option enables the compiler option -mstack-guard and
326 -mstack-size if they are available. If the compiler supports them
327 it will emit additional code to each function prolog to trigger
328 an illegal operation if the kernel stack is about to overflow.
329
330 Say N if you are unsure.
331
332config STACK_GUARD
333 int "Size of the guard area (128-1024)"
334 range 128 1024
335 depends on CHECK_STACK
336 default "256"
337 help
338 This allows you to specify the size of the guard area at the lower
339 end of the kernel stack. If the kernel stack points into the guard
340 area on function entry an illegal operation is triggered. The size
341 needs to be a power of 2. Please keep in mind that the size of an
342 interrupt frame is 184 bytes for 31 bit and 328 bytes on 64 bit.
343 The minimum size for the stack guard should be 256 for 31 bit and
344 512 for 64 bit.
345
Jan Glauber2c190da2011-03-15 17:08:19 +0100346config WARN_DYNAMIC_STACK
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100347 def_bool n
Jan Glauber2c190da2011-03-15 17:08:19 +0100348 prompt "Emit compiler warnings for function with dynamic stack usage"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700349 help
Jan Glauber2c190da2011-03-15 17:08:19 +0100350 This option enables the compiler option -mwarn-dynamicstack. If the
351 compiler supports this options generates warnings for functions
352 that dynamically allocate stack space using alloca.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700353
354 Say N if you are unsure.
355
Heiko Carstens39b742f2006-12-08 15:56:10 +0100356config ARCH_POPULATES_NODE_MAP
357 def_bool y
358
Martin Schwidefsky61d48c22007-05-10 15:46:00 +0200359comment "Kernel preemption"
360
361source "kernel/Kconfig.preempt"
362
Heiko Carstens17f34582008-04-30 13:38:47 +0200363config ARCH_SPARSEMEM_ENABLE
364 def_bool y
365 select SPARSEMEM_VMEMMAP_ENABLE
366 select SPARSEMEM_VMEMMAP
Heiko Carstens148f1672008-06-10 10:03:18 +0200367 select SPARSEMEM_STATIC if !64BIT
Heiko Carstens17f34582008-04-30 13:38:47 +0200368
369config ARCH_SPARSEMEM_DEFAULT
370 def_bool y
371
Hans-Joachim Picht97195d62008-05-30 10:03:24 +0200372config ARCH_SELECT_MEMORY_MODEL
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100373 def_bool y
Hans-Joachim Picht97195d62008-05-30 10:03:24 +0200374
Heiko Carstens421c1752008-07-14 09:59:18 +0200375config ARCH_ENABLE_MEMORY_HOTPLUG
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100376 def_bool y if SPARSEMEM
Heiko Carstens421c1752008-07-14 09:59:18 +0200377
Gerald Schaefer7e9238f2008-08-01 16:39:16 +0200378config ARCH_ENABLE_MEMORY_HOTREMOVE
379 def_bool y
380
Hans-Joachim Picht155af2f2009-06-16 10:30:52 +0200381config ARCH_HIBERNATION_POSSIBLE
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100382 def_bool y if 64BIT
Hans-Joachim Picht155af2f2009-06-16 10:30:52 +0200383
Dave Hansen3f22ab22005-06-23 00:07:43 -0700384source "mm/Kconfig"
385
Linus Torvalds1da177e2005-04-16 15:20:36 -0700386comment "I/O subsystem configuration"
387
Linus Torvalds1da177e2005-04-16 15:20:36 -0700388config QDIO
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100389 def_tristate y
390 prompt "QDIO support"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700391 ---help---
Frank Pavlic8129ee12006-01-06 00:19:20 -0800392 This driver provides the Queued Direct I/O base support for
Ursula Braunefca13b2008-04-17 07:46:19 +0200393 IBM System z.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700394
395 To compile this driver as a module, choose M here: the
396 module will be called qdio.
397
398 If unsure, say Y.
399
Cornelia Huck9d92a7e2008-07-14 09:59:05 +0200400config CHSC_SCH
Sebastian Ottd9c11b12011-01-31 11:30:09 +0100401 def_tristate m
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100402 prompt "Support for CHSC subchannels"
Cornelia Huck9d92a7e2008-07-14 09:59:05 +0200403 help
404 This driver allows usage of CHSC subchannels. A CHSC subchannel
405 is usually present on LPAR only.
406 The driver creates a device /dev/chsc, which may be used to
407 obtain I/O configuration information about the machine and
408 to issue asynchronous chsc commands (DANGEROUS).
409 You will usually only want to use this interface on a special
410 LPAR designated for system management.
411
412 To compile this driver as a module, choose M here: the
413 module will be called chsc_sch.
414
415 If unsure, say N.
416
Linus Torvalds1da177e2005-04-16 15:20:36 -0700417comment "Misc"
418
Linus Torvalds1da177e2005-04-16 15:20:36 -0700419config IPL
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100420 def_bool y
421 prompt "Builtin IPL record support"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700422 help
423 If you want to use the produced kernel to IPL directly from a
424 device, you have to merge a bootsector specific to the device
425 into the first bytes of the kernel. You will have to select the
426 IPL device.
427
428choice
429 prompt "IPL method generated into head.S"
430 depends on IPL
Heiko Carstens46e79512008-10-28 11:10:20 +0100431 default IPL_VM
Linus Torvalds1da177e2005-04-16 15:20:36 -0700432 help
433 Select "tape" if you want to IPL the image from a Tape.
434
435 Select "vm_reader" if you are running under VM/ESA and want
436 to IPL the image from the emulated card reader.
437
438config IPL_TAPE
439 bool "tape"
440
441config IPL_VM
442 bool "vm_reader"
443
444endchoice
445
446source "fs/Kconfig.binfmt"
447
Heiko Carstens684de392008-03-05 12:37:14 +0100448config FORCE_MAX_ZONEORDER
449 int
450 default "9"
451
Linus Torvalds1da177e2005-04-16 15:20:36 -0700452config PFAULT
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100453 def_bool y
454 prompt "Pseudo page fault support"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700455 help
456 Select this option, if you want to use PFAULT pseudo page fault
457 handling under VM. If running native or in LPAR, this option
458 has no effect. If your VM does not support PFAULT, PAGEEX
459 pseudo page fault handling will be used.
460 Note that VM 4.2 supports PFAULT but has a bug in its
461 implementation that causes some problems.
462 Everybody who wants to run Linux under VM != VM4.2 should select
463 this option.
464
465config SHARED_KERNEL
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100466 def_bool y
467 prompt "VM shared kernel support"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700468 help
469 Select this option, if you want to share the text segment of the
470 Linux kernel between different VM guests. This reduces memory
471 usage with lots of guests but greatly increases kernel size.
Heiko Carstens9c9c1762007-03-05 23:35:45 +0100472 Also if a kernel was IPL'ed from a shared segment the kexec system
473 call will not work.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700474 You should only select this option if you know what you are
475 doing and want to exploit this feature.
476
477config CMM
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100478 def_tristate n
479 prompt "Cooperative memory management"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700480 help
481 Select this option, if you want to enable the kernel interface
482 to reduce the memory size of the system. This is accomplished
483 by allocating pages of memory and put them "on hold". This only
484 makes sense for a system running under VM where the unused pages
485 will be reused by VM for other guest systems. The interface
486 allows an external monitor to balance memory of many systems.
487 Everybody who wants to run Linux under VM should select this
488 option.
489
Linus Torvalds1da177e2005-04-16 15:20:36 -0700490config CMM_IUCV
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100491 def_bool y
492 prompt "IUCV special message interface to cooperative memory management"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700493 depends on CMM && (SMSGIUCV=y || CMM=SMSGIUCV)
494 help
495 Select this option to enable the special message interface to
496 the cooperative memory management.
497
Linus Torvalds1da177e2005-04-16 15:20:36 -0700498config APPLDATA_BASE
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100499 def_bool n
500 prompt "Linux - VM Monitor Stream, base infrastructure"
Martin Schwidefskyc185b782008-12-25 13:39:25 +0100501 depends on PROC_FS
Linus Torvalds1da177e2005-04-16 15:20:36 -0700502 help
503 This provides a kernel interface for creating and updating z/VM APPLDATA
504 monitor records. The monitor records are updated at certain time
505 intervals, once the timer is started.
506 Writing 1 or 0 to /proc/appldata/timer starts(1) or stops(0) the timer,
507 i.e. enables or disables monitoring on the Linux side.
508 A custom interval value (in seconds) can be written to
509 /proc/appldata/interval.
510
511 Defaults are 60 seconds interval and timer off.
512 The /proc entries can also be read from, showing the current settings.
513
514config APPLDATA_MEM
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100515 def_tristate m
516 prompt "Monitor memory management statistics"
Al Viro62fb2ba2006-12-13 00:34:59 -0800517 depends on APPLDATA_BASE && VM_EVENT_COUNTERS
Linus Torvalds1da177e2005-04-16 15:20:36 -0700518 help
519 This provides memory management related data to the Linux - VM Monitor
520 Stream, like paging/swapping rate, memory utilisation, etc.
521 Writing 1 or 0 to /proc/appldata/memory creates(1) or removes(0) a z/VM
522 APPLDATA monitor record, i.e. enables or disables monitoring this record
523 on the z/VM side.
524
525 Default is disabled.
526 The /proc entry can also be read from, showing the current settings.
527
528 This can also be compiled as a module, which will be called
529 appldata_mem.o.
530
531config APPLDATA_OS
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100532 def_tristate m
533 prompt "Monitor OS statistics"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700534 depends on APPLDATA_BASE
535 help
536 This provides OS related data to the Linux - VM Monitor Stream, like
537 CPU utilisation, etc.
538 Writing 1 or 0 to /proc/appldata/os creates(1) or removes(0) a z/VM
539 APPLDATA monitor record, i.e. enables or disables monitoring this record
540 on the z/VM side.
541
542 Default is disabled.
543 This can also be compiled as a module, which will be called
544 appldata_os.o.
545
546config APPLDATA_NET_SUM
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100547 def_tristate m
548 prompt "Monitor overall network statistics"
Sachin Sant70193af2009-03-26 15:24:00 +0100549 depends on APPLDATA_BASE && NET
Linus Torvalds1da177e2005-04-16 15:20:36 -0700550 help
551 This provides network related data to the Linux - VM Monitor Stream,
552 currently there is only a total sum of network I/O statistics, no
553 per-interface data.
554 Writing 1 or 0 to /proc/appldata/net_sum creates(1) or removes(0) a z/VM
555 APPLDATA monitor record, i.e. enables or disables monitoring this record
556 on the z/VM side.
557
558 Default is disabled.
559 This can also be compiled as a module, which will be called
560 appldata_net_sum.o.
561
Martin Schwidefsky61d48c22007-05-10 15:46:00 +0200562source kernel/Kconfig.hz
563
Michael Holzheu24bbb1f2006-06-23 02:05:06 -0700564config S390_HYPFS_FS
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100565 def_bool y
566 prompt "s390 hypervisor file system support"
Michael Holzheu24bbb1f2006-06-23 02:05:06 -0700567 select SYS_HYPERVISOR
Michael Holzheu24bbb1f2006-06-23 02:05:06 -0700568 help
569 This is a virtual file system intended to provide accounting
570 information in an s390 hypervisor environment.
571
Heiko Carstenscf13f0e2005-06-25 14:58:11 -0700572config KEXEC
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100573 def_bool n
574 prompt "kexec system call"
Heiko Carstenscf13f0e2005-06-25 14:58:11 -0700575 help
576 kexec is a system call that implements the ability to shutdown your
577 current kernel, and to start another kernel. It is like a reboot
578 but is independent of hardware/microcode support.
579
Michael Holzheu411ed322007-04-27 16:01:49 +0200580config ZFCPDUMP
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100581 def_bool n
582 prompt "zfcpdump support"
Michael Holzheu411ed322007-04-27 16:01:49 +0200583 select SMP
Michael Holzheu411ed322007-04-27 16:01:49 +0200584 help
585 Select this option if you want to build an zfcpdump enabled kernel.
Dirk Hohndele4031492007-10-30 13:37:19 -0700586 Refer to <file:Documentation/s390/zfcpdump.txt> for more details on this.
Michael Holzheu411ed322007-04-27 16:01:49 +0200587
Carsten Ottefa587742008-03-25 18:47:44 +0100588config S390_GUEST
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100589 def_bool y
590 prompt "s390 guest support for KVM (EXPERIMENTAL)"
Carsten Ottefa587742008-03-25 18:47:44 +0100591 depends on 64BIT && EXPERIMENTAL
592 select VIRTIO
593 select VIRTIO_RING
Christian Borntraegerfaeba832008-06-20 15:24:18 +0200594 select VIRTIO_CONSOLE
Carsten Ottefa587742008-03-25 18:47:44 +0100595 help
Christian Borntraeger20766c02008-08-29 13:30:56 +0200596 Select this option if you want to run the kernel as a guest under
597 the KVM hypervisor. This will add detection for KVM as well as a
598 virtio transport. If KVM is detected, the virtio console will be
599 the default console.
Heiko Carstensbcf5cef2009-06-12 10:26:26 +0200600
601config SECCOMP
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100602 def_bool y
603 prompt "Enable seccomp to safely compute untrusted bytecode"
Heiko Carstensbcf5cef2009-06-12 10:26:26 +0200604 depends on PROC_FS
Heiko Carstensbcf5cef2009-06-12 10:26:26 +0200605 help
606 This kernel feature is useful for number crunching applications
607 that may need to compute untrusted bytecode during their
608 execution. By using pipes or other transports made available to
609 the process as file descriptors supporting the read/write
610 syscalls, it's possible to isolate those applications in
611 their own address space using seccomp. Once seccomp is
612 enabled via /proc/<pid>/seccomp, it cannot be disabled
613 and the task is only allowed to execute a few safe syscalls
614 defined by each seccomp mode.
615
616 If unsure, say Y.
617
Linus Torvalds1da177e2005-04-16 15:20:36 -0700618endmenu
619
Hans-Joachim Picht155af2f2009-06-16 10:30:52 +0200620menu "Power Management"
621
622source "kernel/power/Kconfig"
623
624endmenu
625
Sam Ravnborgd5950b42005-07-11 21:03:49 -0700626source "net/Kconfig"
627
Linus Torvalds1da177e2005-04-16 15:20:36 -0700628config PCMCIA
Martin Schwidefsky61d48c22007-05-10 15:46:00 +0200629 def_bool n
Linus Torvalds1da177e2005-04-16 15:20:36 -0700630
Martin Schwidefsky61d48c22007-05-10 15:46:00 +0200631config CCW
632 def_bool y
Linus Torvalds1da177e2005-04-16 15:20:36 -0700633
Martin Schwidefsky61d48c22007-05-10 15:46:00 +0200634source "drivers/Kconfig"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700635
636source "fs/Kconfig"
637
Linus Torvalds1da177e2005-04-16 15:20:36 -0700638source "arch/s390/Kconfig.debug"
639
640source "security/Kconfig"
641
642source "crypto/Kconfig"
643
644source "lib/Kconfig"
Christian Borntraeger77b455f2008-03-25 18:47:36 +0100645
646source "arch/s390/kvm/Kconfig"