blob: baba37cfcf84180beb61e034e622999779f0e53a [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
Heiko Carstens69dbb2f2011-05-26 09:48:31 +02005 def_bool y
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
Heiko Carstensc0007f12007-04-27 16:01:42 +020031config GENERIC_BUG
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +010032 def_bool y if BUG
Heiko Carstensc0007f12007-04-27 16:01:42 +020033
Heiko Carstens52499f42010-02-26 22:37:44 +010034config GENERIC_BUG_RELATIVE_POINTERS
35 def_bool y
36
Al Viro23db7642007-02-11 18:15:29 +000037config NO_IOMEM
Al Viro5ea81762007-02-11 15:41:31 +000038 def_bool y
39
Heiko Carstens411f0f32007-05-06 14:49:09 -070040config NO_DMA
41 def_bool y
42
FUJITA Tomonorieca577e2010-10-25 16:10:50 +020043config ARCH_DMA_ADDR_T_64BIT
44 def_bool 64BIT
45
Martin Schwidefskyb6b40c52008-02-05 16:50:42 +010046config GENERIC_LOCKBREAK
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +010047 def_bool y if SMP && PREEMPT
Martin Schwidefskyb6b40c52008-02-05 16:50:42 +010048
Carsten Otte402b0862008-03-25 18:47:10 +010049config PGSTE
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +010050 def_bool y if KVM
Carsten Otte402b0862008-03-25 18:47:10 +010051
Akinobu Mita6a11f752009-03-31 15:23:17 -070052config ARCH_SUPPORTS_DEBUG_PAGEALLOC
53 def_bool y
54
Jan Glauber843c48f2012-08-27 10:55:18 +020055config KEXEC
56 def_bool y
57
58config AUDIT_ARCH
59 def_bool y
60
Martin Schwidefsky347a8dc2006-01-06 00:19:28 -080061config S390
Martin Schwidefsky61d48c22007-05-10 15:46:00 +020062 def_bool y
Heiko Carstensca9fc752008-12-25 13:38:39 +010063 select USE_GENERIC_SMP_HELPERS if SMP
Martin Schwidefsky5d3b56f2012-03-23 11:13:07 +010064 select GENERIC_CPU_DEVICES if !SMP
Heiko Carstensed6bb612009-01-14 14:14:01 +010065 select HAVE_SYSCALL_WRAPPERS
Heiko Carstens5d360a72008-12-25 13:38:56 +010066 select HAVE_FUNCTION_TRACER
Heiko Carstens8b4488f2009-06-12 10:26:45 +020067 select HAVE_FUNCTION_TRACE_MCOUNT_TEST
Heiko Carstensdfd9f7a2009-06-12 10:26:44 +020068 select HAVE_FTRACE_MCOUNT_RECORD
Heiko Carstensb25c4772010-10-29 16:50:42 +020069 select HAVE_C_RECORDMCOUNT
Josh Stone66700002009-08-24 14:43:11 -070070 select HAVE_SYSCALL_TRACEPOINTS
Heiko Carstensdfd9f7a2009-06-12 10:26:44 +020071 select HAVE_DYNAMIC_FTRACE
Heiko Carstens88dbd202009-06-12 10:26:46 +020072 select HAVE_FUNCTION_GRAPH_TRACER
Heiko Carstens952974ac62010-02-12 13:38:40 +010073 select HAVE_REGS_AND_STACK_ACCESS_API
Mathieu Desnoyers42d4b832008-02-02 15:10:34 -050074 select HAVE_OPROFILE
Mathieu Desnoyers3f550092008-02-02 15:10:35 -050075 select HAVE_KPROBES
Ananth N Mavinakayanahalli9edddaa2008-03-04 14:28:37 -080076 select HAVE_KRETPROBES
Christian Borntraeger77b455f2008-03-25 18:47:36 +010077 select HAVE_KVM if 64BIT
Martin Schwidefsky753c4dd2008-10-10 21:33:20 +020078 select HAVE_ARCH_TRACEHOOK
Rusty Russell98a79d62008-12-13 21:19:41 +103079 select INIT_ALL_POSSIBLE
Peter Zijlstrae360adb2010-10-14 14:01:34 +080080 select HAVE_IRQ_WORK
Ingo Molnarcdd6c482009-09-21 12:02:48 +020081 select HAVE_PERF_EVENTS
Huang Yingdf013ff2011-07-13 13:14:22 +080082 select ARCH_HAVE_NMI_SAFE_CMPXCHG
Martin Schwidefsky1844c9b2010-02-26 22:37:53 +010083 select HAVE_KERNEL_GZIP
84 select HAVE_KERNEL_BZIP2
85 select HAVE_KERNEL_LZMA
Heiko Carstenscdf56642010-05-26 23:27:12 +020086 select HAVE_KERNEL_LZO
Heiko Carstensd7b081a2011-03-15 17:08:32 +010087 select HAVE_KERNEL_XZ
Gerald Schaefer34b133f2011-01-05 12:48:14 +010088 select HAVE_ARCH_MUTEX_CPU_RELAX
Jan Glauber5373db82011-03-16 15:58:30 -040089 select HAVE_ARCH_JUMP_LABEL if !MARCH_G5
Martin Schwidefskyc10302e2012-07-31 16:23:59 +020090 select HAVE_BPF_JIT if 64BIT && PACK_STACK
Martin Schwidefsky85055dd2011-08-17 20:42:24 +020091 select ARCH_SAVE_PAGE_KEYS if HIBERNATION
Catalin Marinas74634492012-07-30 14:41:09 -070092 select ARCH_HAS_ATOMIC64_DEC_IF_POSITIVE
Tejun Heoff38df32011-12-08 10:22:09 -080093 select HAVE_MEMBLOCK
94 select HAVE_MEMBLOCK_NODE_MAP
Heiko Carstens2e30db952012-05-29 11:21:27 +020095 select HAVE_CMPXCHG_LOCAL
Heiko Carstensb1d6b402012-09-17 07:37:13 +020096 select HAVE_CMPXCHG_DOUBLE
Frederic Weisbeckerb9527412012-06-16 15:39:34 +020097 select HAVE_VIRT_CPU_ACCOUNTING
98 select VIRT_CPU_ACCOUNTING
Tejun Heoff38df32011-12-08 10:22:09 -080099 select ARCH_DISCARD_MEMBLOCK
Heiko Carstens3193a982012-07-24 14:51:34 +0200100 select BUILDTIME_EXTABLE_SORT
Thomas Gleixner6beb0002009-11-09 15:21:34 +0000101 select ARCH_INLINE_SPIN_TRYLOCK
102 select ARCH_INLINE_SPIN_TRYLOCK_BH
103 select ARCH_INLINE_SPIN_LOCK
104 select ARCH_INLINE_SPIN_LOCK_BH
105 select ARCH_INLINE_SPIN_LOCK_IRQ
106 select ARCH_INLINE_SPIN_LOCK_IRQSAVE
107 select ARCH_INLINE_SPIN_UNLOCK
108 select ARCH_INLINE_SPIN_UNLOCK_BH
109 select ARCH_INLINE_SPIN_UNLOCK_IRQ
110 select ARCH_INLINE_SPIN_UNLOCK_IRQRESTORE
111 select ARCH_INLINE_READ_TRYLOCK
112 select ARCH_INLINE_READ_LOCK
113 select ARCH_INLINE_READ_LOCK_BH
114 select ARCH_INLINE_READ_LOCK_IRQ
115 select ARCH_INLINE_READ_LOCK_IRQSAVE
116 select ARCH_INLINE_READ_UNLOCK
117 select ARCH_INLINE_READ_UNLOCK_BH
118 select ARCH_INLINE_READ_UNLOCK_IRQ
119 select ARCH_INLINE_READ_UNLOCK_IRQRESTORE
120 select ARCH_INLINE_WRITE_TRYLOCK
121 select ARCH_INLINE_WRITE_LOCK
122 select ARCH_INLINE_WRITE_LOCK_BH
123 select ARCH_INLINE_WRITE_LOCK_IRQ
124 select ARCH_INLINE_WRITE_LOCK_IRQSAVE
125 select ARCH_INLINE_WRITE_UNLOCK
126 select ARCH_INLINE_WRITE_UNLOCK_BH
127 select ARCH_INLINE_WRITE_UNLOCK_IRQ
128 select ARCH_INLINE_WRITE_UNLOCK_IRQRESTORE
Catalin Marinasaf1839e2012-10-08 16:28:08 -0700129 select HAVE_UID16 if 32BIT
Will Deaconc1d7e012012-07-30 14:42:46 -0700130 select ARCH_WANT_IPC_PARSE_VERSION
Thomas Gleixnere80e7812012-04-20 13:05:52 +0000131 select GENERIC_SMP_IDLE_THREAD
Anna-Maria Gleixnera6527b92012-05-18 16:45:52 +0000132 select GENERIC_TIME_VSYSCALL
133 select GENERIC_CLOCKEVENTS
134 select KTIME_SCALAR if 32BIT
Heiko Carstensc63cb462012-07-31 15:37:13 +0200135 select HAVE_ARCH_SECCOMP_FILTER
Linus Torvalds1da177e2005-04-16 15:20:36 -0700136
Martin Schwidefskyfca3e352009-07-07 16:37:10 +0200137config SCHED_OMIT_FRAME_POINTER
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100138 def_bool y
Martin Schwidefskyfca3e352009-07-07 16:37:10 +0200139
Linus Torvalds1da177e2005-04-16 15:20:36 -0700140source "init/Kconfig"
141
Matt Helsleydc52ddc2008-10-18 20:27:21 -0700142source "kernel/Kconfig.freezer"
143
Jan Glauber843c48f2012-08-27 10:55:18 +0200144menu "Processor type and features"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700145
Jan Glauber843c48f2012-08-27 10:55:18 +0200146config HAVE_MARCH_Z900_FEATURES
147 def_bool n
148
149config HAVE_MARCH_Z990_FEATURES
150 def_bool n
151 select HAVE_MARCH_Z900_FEATURES
152
153config HAVE_MARCH_Z9_109_FEATURES
154 def_bool n
155 select HAVE_MARCH_Z990_FEATURES
156
157config HAVE_MARCH_Z10_FEATURES
158 def_bool n
159 select HAVE_MARCH_Z9_109_FEATURES
160
161config HAVE_MARCH_Z196_FEATURES
162 def_bool n
163 select HAVE_MARCH_Z10_FEATURES
164
165choice
166 prompt "Processor type"
167 default MARCH_G5
168
169config MARCH_G5
170 bool "System/390 model G5 and G6"
171 depends on !64BIT
172 help
173 Select this to build a 31 bit kernel that works
174 on all ESA/390 and z/Architecture machines.
175
176config MARCH_Z900
177 bool "IBM zSeries model z800 and z900"
178 select HAVE_MARCH_Z900_FEATURES if 64BIT
179 help
180 Select this to enable optimizations for model z800/z900 (2064 and
181 2066 series). This will enable some optimizations that are not
182 available on older ESA/390 (31 Bit) only CPUs.
183
184config MARCH_Z990
185 bool "IBM zSeries model z890 and z990"
186 select HAVE_MARCH_Z990_FEATURES if 64BIT
187 help
188 Select this to enable optimizations for model z890/z990 (2084 and
189 2086 series). The kernel will be slightly faster but will not work
190 on older machines.
191
192config MARCH_Z9_109
193 bool "IBM System z9"
194 select HAVE_MARCH_Z9_109_FEATURES if 64BIT
195 help
196 Select this to enable optimizations for IBM System z9 (2094 and
197 2096 series). The kernel will be slightly faster but will not work
198 on older machines.
199
200config MARCH_Z10
201 bool "IBM System z10"
202 select HAVE_MARCH_Z10_FEATURES if 64BIT
203 help
204 Select this to enable optimizations for IBM System z10 (2097 and
205 2098 series). The kernel will be slightly faster but will not work
206 on older machines.
207
208config MARCH_Z196
209 bool "IBM zEnterprise 114 and 196"
210 select HAVE_MARCH_Z196_FEATURES if 64BIT
211 help
212 Select this to enable optimizations for IBM zEnterprise 114 and 196
213 (2818 and 2817 series). The kernel will be slightly faster but will
214 not work on older machines.
215
216endchoice
Linus Torvalds1da177e2005-04-16 15:20:36 -0700217
Martin Schwidefsky347a8dc2006-01-06 00:19:28 -0800218config 64BIT
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100219 def_bool y
220 prompt "64 bit kernel"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700221 help
Heiko Carstensdb81a232010-10-29 16:50:36 +0200222 Select this option if you have an IBM z/Architecture machine
Linus Torvalds1da177e2005-04-16 15:20:36 -0700223 and want to use the 64 bit addressing mode.
224
Martin Schwidefskyd9f7a742006-09-28 16:55:39 +0200225config 32BIT
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100226 def_bool y if !64BIT
Martin Schwidefskyd9f7a742006-09-28 16:55:39 +0200227
Jan Glauber843c48f2012-08-27 10:55:18 +0200228config COMPAT
229 def_bool y
230 prompt "Kernel support for 31 bit emulation"
231 depends on 64BIT
232 select COMPAT_BINFMT_ELF if BINFMT_ELF
233 select ARCH_WANT_OLD_COMPAT_IPC
234 help
235 Select this option if you want to enable your system kernel to
236 handle system-calls from ELF binaries for 31 bit ESA. This option
237 (and some other stuff like libraries and such) is needed for
238 executing 31 bit applications. It is safe to say "Y".
239
240config SYSVIPC_COMPAT
241 def_bool y if COMPAT && SYSVIPC
242
243config KEYS_COMPAT
244 def_bool y if COMPAT && KEYS
245
Linus Torvalds1da177e2005-04-16 15:20:36 -0700246config SMP
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100247 def_bool y
248 prompt "Symmetric multi-processing support"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700249 ---help---
250 This enables support for systems with more than one CPU. If you have
251 a system with only one CPU, like most personal computers, say N. If
252 you have a system with more than one CPU, say Y.
253
254 If you say N here, the kernel will run on single and multiprocessor
255 machines, but will use only one CPU of a multiprocessor machine. If
256 you say Y here, the kernel will run on many, but not all,
257 singleprocessor machines. On a singleprocessor machine, the kernel
258 will run faster if you say N here.
259
Adrian Bunk03502fa2008-02-03 15:50:21 +0200260 See also the SMP-HOWTO available at
261 <http://www.tldp.org/docs.html#howto>.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700262
263 Even if you don't know what to do here, say Y.
264
265config NR_CPUS
266 int "Maximum number of CPUs (2-64)"
267 range 2 64
268 depends on SMP
Heiko Carstens057c5cb2008-02-19 15:29:25 +0100269 default "32" if !64BIT
270 default "64" if 64BIT
Linus Torvalds1da177e2005-04-16 15:20:36 -0700271 help
272 This allows you to specify the maximum number of CPUs which this
273 kernel will support. The maximum supported value is 64 and the
274 minimum value which makes sense is 2.
275
276 This is purely to save memory - each supported CPU adds
277 approximately sixteen kilobytes to the kernel image.
278
279config HOTPLUG_CPU
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100280 def_bool y
281 prompt "Support for hot-pluggable CPUs"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700282 depends on SMP
283 select HOTPLUG
Linus Torvalds1da177e2005-04-16 15:20:36 -0700284 help
285 Say Y here to be able to turn CPUs off and on. CPUs
286 can be controlled through /sys/devices/system/cpu/cpu#.
287 Say N if you want to disable CPU hotplug.
288
Heiko Carstens8d11e022010-10-29 16:50:37 +0200289config SCHED_MC
Heiko Carstens83a24e32011-12-27 11:27:09 +0100290 def_bool n
Heiko Carstens8d11e022010-10-29 16:50:37 +0200291
Heiko Carstens4cb14bc2010-08-31 10:28:18 +0200292config SCHED_BOOK
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100293 def_bool y
294 prompt "Book scheduler support"
Heiko Carstens83a24e32011-12-27 11:27:09 +0100295 depends on SMP
296 select SCHED_MC
Heiko Carstens4cb14bc2010-08-31 10:28:18 +0200297 help
298 Book scheduler support improves the CPU scheduler's decision making
299 when dealing with machines that have several books.
300
Jan Glauber843c48f2012-08-27 10:55:18 +0200301source kernel/Kconfig.preempt
302
Linus Torvalds1da177e2005-04-16 15:20:36 -0700303config MATHEMU
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100304 def_bool y
305 prompt "IEEE FPU emulation"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700306 depends on MARCH_G5
307 help
308 This option is required for IEEE compliant floating point arithmetic
Heiko Carstensdb81a232010-10-29 16:50:36 +0200309 on older ESA/390 machines. Say Y unless you know your machine doesn't
Linus Torvalds1da177e2005-04-16 15:20:36 -0700310 need this.
311
Jan Glauber843c48f2012-08-27 10:55:18 +0200312source kernel/Kconfig.hz
313
314endmenu
315
316menu "Memory setup"
317
318config ARCH_SPARSEMEM_ENABLE
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100319 def_bool y
Jan Glauber843c48f2012-08-27 10:55:18 +0200320 select SPARSEMEM_VMEMMAP_ENABLE
321 select SPARSEMEM_VMEMMAP
322 select SPARSEMEM_STATIC if !64BIT
Linus Torvalds1da177e2005-04-16 15:20:36 -0700323
Jan Glauber843c48f2012-08-27 10:55:18 +0200324config ARCH_SPARSEMEM_DEFAULT
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100325 def_bool y
Al Viroe65e1fc2006-09-12 03:04:40 -0400326
Jan Glauber843c48f2012-08-27 10:55:18 +0200327config ARCH_SELECT_MEMORY_MODEL
328 def_bool y
Heiko Carstens05445162012-05-14 10:12:41 +0200329
Jan Glauber843c48f2012-08-27 10:55:18 +0200330config ARCH_ENABLE_MEMORY_HOTPLUG
331 def_bool y if SPARSEMEM
Heiko Carstens05445162012-05-14 10:12:41 +0200332
Jan Glauber843c48f2012-08-27 10:55:18 +0200333config ARCH_ENABLE_MEMORY_HOTREMOVE
334 def_bool y
Heiko Carstens05445162012-05-14 10:12:41 +0200335
Jan Glauber843c48f2012-08-27 10:55:18 +0200336config FORCE_MAX_ZONEORDER
337 int
338 default "9"
Heiko Carstens05445162012-05-14 10:12:41 +0200339
Jan Glauber843c48f2012-08-27 10:55:18 +0200340source "mm/Kconfig"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700341
342config PACK_STACK
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100343 def_bool y
344 prompt "Pack kernel stack"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700345 help
346 This option enables the compiler option -mkernel-backchain if it
347 is available. If the option is available the compiler supports
348 the new stack layout which dramatically reduces the minimum stack
349 frame size. With an old compiler a non-leaf function needs a
350 minimum of 96 bytes on 31 bit and 160 bytes on 64 bit. With
351 -mkernel-backchain the minimum size drops to 16 byte on 31 bit
352 and 24 byte on 64 bit.
353
354 Say Y if you are unsure.
355
356config SMALL_STACK
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100357 def_bool n
358 prompt "Use 8kb for kernel stack instead of 16kb"
Heiko Carstens7f5a8ba2008-10-28 11:10:21 +0100359 depends on PACK_STACK && 64BIT && !LOCKDEP
Linus Torvalds1da177e2005-04-16 15:20:36 -0700360 help
361 If you say Y here and the compiler supports the -mkernel-backchain
Heiko Carstens7f5a8ba2008-10-28 11:10:21 +0100362 option the kernel will use a smaller kernel stack size. The reduced
363 size is 8kb instead of 16kb. This allows to run more threads on a
364 system and reduces the pressure on the memory management for higher
365 order page allocations.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700366
367 Say N if you are unsure.
368
Linus Torvalds1da177e2005-04-16 15:20:36 -0700369config CHECK_STACK
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100370 def_bool y
371 prompt "Detect kernel stack overflow"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700372 help
373 This option enables the compiler option -mstack-guard and
374 -mstack-size if they are available. If the compiler supports them
375 it will emit additional code to each function prolog to trigger
376 an illegal operation if the kernel stack is about to overflow.
377
378 Say N if you are unsure.
379
380config STACK_GUARD
381 int "Size of the guard area (128-1024)"
382 range 128 1024
383 depends on CHECK_STACK
384 default "256"
385 help
386 This allows you to specify the size of the guard area at the lower
387 end of the kernel stack. If the kernel stack points into the guard
388 area on function entry an illegal operation is triggered. The size
389 needs to be a power of 2. Please keep in mind that the size of an
390 interrupt frame is 184 bytes for 31 bit and 328 bytes on 64 bit.
391 The minimum size for the stack guard should be 256 for 31 bit and
392 512 for 64 bit.
393
Jan Glauber2c190da2011-03-15 17:08:19 +0100394config WARN_DYNAMIC_STACK
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100395 def_bool n
Jan Glauber2c190da2011-03-15 17:08:19 +0100396 prompt "Emit compiler warnings for function with dynamic stack usage"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700397 help
Jan Glauber2c190da2011-03-15 17:08:19 +0100398 This option enables the compiler option -mwarn-dynamicstack. If the
399 compiler supports this options generates warnings for functions
400 that dynamically allocate stack space using alloca.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700401
402 Say N if you are unsure.
403
Jan Glauber843c48f2012-08-27 10:55:18 +0200404endmenu
Martin Schwidefsky61d48c22007-05-10 15:46:00 +0200405
Jan Glauber843c48f2012-08-27 10:55:18 +0200406menu "I/O subsystem"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700407
Linus Torvalds1da177e2005-04-16 15:20:36 -0700408config QDIO
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100409 def_tristate y
410 prompt "QDIO support"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700411 ---help---
Frank Pavlic8129ee12006-01-06 00:19:20 -0800412 This driver provides the Queued Direct I/O base support for
Ursula Braunefca13b2008-04-17 07:46:19 +0200413 IBM System z.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700414
415 To compile this driver as a module, choose M here: the
416 module will be called qdio.
417
418 If unsure, say Y.
419
Cornelia Huck9d92a7e2008-07-14 09:59:05 +0200420config CHSC_SCH
Sebastian Ottd9c11b12011-01-31 11:30:09 +0100421 def_tristate m
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100422 prompt "Support for CHSC subchannels"
Cornelia Huck9d92a7e2008-07-14 09:59:05 +0200423 help
424 This driver allows usage of CHSC subchannels. A CHSC subchannel
425 is usually present on LPAR only.
426 The driver creates a device /dev/chsc, which may be used to
427 obtain I/O configuration information about the machine and
428 to issue asynchronous chsc commands (DANGEROUS).
429 You will usually only want to use this interface on a special
430 LPAR designated for system management.
431
432 To compile this driver as a module, choose M here: the
433 module will be called chsc_sch.
434
435 If unsure, say N.
436
Sebastian Ott1d1c8f72012-08-28 16:46:26 +0200437config SCM_BUS
438 def_bool y
439 depends on 64BIT
440 prompt "SCM bus driver"
441 help
442 Bus driver for Storage Class Memory.
443
Sebastian Otteadb86a2012-08-28 16:48:16 +0200444config EADM_SCH
445 def_tristate m
446 prompt "Support for EADM subchannels"
447 depends on SCM_BUS
448 help
449 This driver allows usage of EADM subchannels. EADM subchannels act
450 as a communication vehicle for SCM increments.
451
452 To compile this driver as a module, choose M here: the
453 module will be called eadm_sch.
454
Jan Glauber843c48f2012-08-27 10:55:18 +0200455endmenu
456
457menu "Dump support"
458
459config CRASH_DUMP
460 bool "kernel crash dumps"
461 depends on 64BIT && SMP
462 select KEXEC
463 help
464 Generate crash dump after being started by kexec.
465 Crash dump kernels are loaded in the main kernel with kexec-tools
466 into a specially reserved region and then later executed after
467 a crash by kdump/kexec.
468 For more details see Documentation/kdump/kdump.txt
469
470config ZFCPDUMP
471 def_bool n
472 prompt "zfcpdump support"
473 select SMP
474 help
475 Select this option if you want to build an zfcpdump enabled kernel.
476 Refer to <file:Documentation/s390/zfcpdump.txt> for more details on this.
477
478endmenu
479
480menu "Executable file formats / Emulations"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700481
Linus Torvalds1da177e2005-04-16 15:20:36 -0700482source "fs/Kconfig.binfmt"
483
Jan Glauber843c48f2012-08-27 10:55:18 +0200484config SECCOMP
485 def_bool y
486 prompt "Enable seccomp to safely compute untrusted bytecode"
487 depends on PROC_FS
488 help
489 This kernel feature is useful for number crunching applications
490 that may need to compute untrusted bytecode during their
491 execution. By using pipes or other transports made available to
492 the process as file descriptors supporting the read/write
493 syscalls, it's possible to isolate those applications in
494 their own address space using seccomp. Once seccomp is
495 enabled via /proc/<pid>/seccomp, it cannot be disabled
496 and the task is only allowed to execute a few safe syscalls
497 defined by each seccomp mode.
498
499 If unsure, say Y.
500
501endmenu
502
503menu "Power Management"
504
505config ARCH_HIBERNATION_POSSIBLE
506 def_bool y if 64BIT
507
508source "kernel/power/Kconfig"
509
510endmenu
511
512source "net/Kconfig"
513
514config PCMCIA
515 def_bool n
516
517config CCW
518 def_bool y
519
520source "drivers/Kconfig"
521
522source "fs/Kconfig"
523
524source "arch/s390/Kconfig.debug"
525
526source "security/Kconfig"
527
528source "crypto/Kconfig"
529
530source "lib/Kconfig"
531
532menu "Virtualization"
Heiko Carstens684de392008-03-05 12:37:14 +0100533
Linus Torvalds1da177e2005-04-16 15:20:36 -0700534config PFAULT
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100535 def_bool y
536 prompt "Pseudo page fault support"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700537 help
538 Select this option, if you want to use PFAULT pseudo page fault
539 handling under VM. If running native or in LPAR, this option
540 has no effect. If your VM does not support PFAULT, PAGEEX
541 pseudo page fault handling will be used.
542 Note that VM 4.2 supports PFAULT but has a bug in its
543 implementation that causes some problems.
544 Everybody who wants to run Linux under VM != VM4.2 should select
545 this option.
546
547config SHARED_KERNEL
Heiko Carstens0eccc782012-09-25 14:53:15 +0200548 bool "VM shared kernel support"
549 depends on !JUMP_LABEL
Linus Torvalds1da177e2005-04-16 15:20:36 -0700550 help
551 Select this option, if you want to share the text segment of the
552 Linux kernel between different VM guests. This reduces memory
553 usage with lots of guests but greatly increases kernel size.
Heiko Carstens9c9c1762007-03-05 23:35:45 +0100554 Also if a kernel was IPL'ed from a shared segment the kexec system
555 call will not work.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700556 You should only select this option if you know what you are
557 doing and want to exploit this feature.
558
559config CMM
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100560 def_tristate n
561 prompt "Cooperative memory management"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700562 help
563 Select this option, if you want to enable the kernel interface
564 to reduce the memory size of the system. This is accomplished
565 by allocating pages of memory and put them "on hold". This only
566 makes sense for a system running under VM where the unused pages
567 will be reused by VM for other guest systems. The interface
568 allows an external monitor to balance memory of many systems.
569 Everybody who wants to run Linux under VM should select this
570 option.
571
Linus Torvalds1da177e2005-04-16 15:20:36 -0700572config CMM_IUCV
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100573 def_bool y
574 prompt "IUCV special message interface to cooperative memory management"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700575 depends on CMM && (SMSGIUCV=y || CMM=SMSGIUCV)
576 help
577 Select this option to enable the special message interface to
578 the cooperative memory management.
579
Linus Torvalds1da177e2005-04-16 15:20:36 -0700580config APPLDATA_BASE
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100581 def_bool n
582 prompt "Linux - VM Monitor Stream, base infrastructure"
Martin Schwidefskyc185b782008-12-25 13:39:25 +0100583 depends on PROC_FS
Linus Torvalds1da177e2005-04-16 15:20:36 -0700584 help
585 This provides a kernel interface for creating and updating z/VM APPLDATA
586 monitor records. The monitor records are updated at certain time
587 intervals, once the timer is started.
588 Writing 1 or 0 to /proc/appldata/timer starts(1) or stops(0) the timer,
589 i.e. enables or disables monitoring on the Linux side.
590 A custom interval value (in seconds) can be written to
591 /proc/appldata/interval.
592
593 Defaults are 60 seconds interval and timer off.
594 The /proc entries can also be read from, showing the current settings.
595
596config APPLDATA_MEM
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100597 def_tristate m
598 prompt "Monitor memory management statistics"
Al Viro62fb2ba2006-12-13 00:34:59 -0800599 depends on APPLDATA_BASE && VM_EVENT_COUNTERS
Linus Torvalds1da177e2005-04-16 15:20:36 -0700600 help
601 This provides memory management related data to the Linux - VM Monitor
602 Stream, like paging/swapping rate, memory utilisation, etc.
603 Writing 1 or 0 to /proc/appldata/memory creates(1) or removes(0) a z/VM
604 APPLDATA monitor record, i.e. enables or disables monitoring this record
605 on the z/VM side.
606
607 Default is disabled.
608 The /proc entry can also be read from, showing the current settings.
609
610 This can also be compiled as a module, which will be called
611 appldata_mem.o.
612
613config APPLDATA_OS
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100614 def_tristate m
615 prompt "Monitor OS statistics"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700616 depends on APPLDATA_BASE
617 help
618 This provides OS related data to the Linux - VM Monitor Stream, like
619 CPU utilisation, etc.
620 Writing 1 or 0 to /proc/appldata/os creates(1) or removes(0) a z/VM
621 APPLDATA monitor record, i.e. enables or disables monitoring this record
622 on the z/VM side.
623
624 Default is disabled.
625 This can also be compiled as a module, which will be called
626 appldata_os.o.
627
628config APPLDATA_NET_SUM
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100629 def_tristate m
630 prompt "Monitor overall network statistics"
Sachin Sant70193af2009-03-26 15:24:00 +0100631 depends on APPLDATA_BASE && NET
Linus Torvalds1da177e2005-04-16 15:20:36 -0700632 help
633 This provides network related data to the Linux - VM Monitor Stream,
634 currently there is only a total sum of network I/O statistics, no
635 per-interface data.
636 Writing 1 or 0 to /proc/appldata/net_sum creates(1) or removes(0) a z/VM
637 APPLDATA monitor record, i.e. enables or disables monitoring this record
638 on the z/VM side.
639
640 Default is disabled.
641 This can also be compiled as a module, which will be called
642 appldata_net_sum.o.
643
Michael Holzheu24bbb1f2006-06-23 02:05:06 -0700644config S390_HYPFS_FS
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100645 def_bool y
646 prompt "s390 hypervisor file system support"
Michael Holzheu24bbb1f2006-06-23 02:05:06 -0700647 select SYS_HYPERVISOR
Michael Holzheu24bbb1f2006-06-23 02:05:06 -0700648 help
649 This is a virtual file system intended to provide accounting
650 information in an s390 hypervisor environment.
651
Jan Glauber843c48f2012-08-27 10:55:18 +0200652source "arch/s390/kvm/Kconfig"
Michael Holzheu411ed322007-04-27 16:01:49 +0200653
Carsten Ottefa587742008-03-25 18:47:44 +0100654config S390_GUEST
Martin Schwidefsky6f9a3c32011-01-05 12:47:15 +0100655 def_bool y
Cornelia Huckbdd1fc22012-08-27 12:56:48 +0200656 prompt "s390 support for virtio devices (EXPERIMENTAL)"
Carsten Ottefa587742008-03-25 18:47:44 +0100657 depends on 64BIT && EXPERIMENTAL
Christian Borntraeger80629b02011-06-22 16:24:07 +0200658 select VIRTUALIZATION
Carsten Ottefa587742008-03-25 18:47:44 +0100659 select VIRTIO
Christian Borntraegerfaeba8302008-06-20 15:24:18 +0200660 select VIRTIO_CONSOLE
Carsten Ottefa587742008-03-25 18:47:44 +0100661 help
Cornelia Huckbdd1fc22012-08-27 12:56:48 +0200662 Enabling this option adds support for virtio based paravirtual device
663 drivers on s390.
664
Christian Borntraeger20766c02008-08-29 13:30:56 +0200665 Select this option if you want to run the kernel as a guest under
Cornelia Huckbdd1fc22012-08-27 12:56:48 +0200666 the KVM hypervisor.
Heiko Carstensbcf5cef2009-06-12 10:26:26 +0200667
Linus Torvalds1da177e2005-04-16 15:20:36 -0700668endmenu