blob: edcf80eda566be3ee56075acba1a42f5abd9a5fc [file] [log] [blame]
Sam Ravnborgdaa93fa2007-11-12 20:54:30 +01001# Select 32 or 64 bit
2config 64BIT
Sam Ravnborg68409992007-11-17 15:37:31 +01003 bool "64-bit kernel" if ARCH = "x86"
David Woodhouseffee0de2012-12-20 21:51:55 +00004 default ARCH != "i386"
Ingo Molnar8f9ca472009-02-05 16:21:53 +01005 ---help---
Sam Ravnborgdaa93fa2007-11-12 20:54:30 +01006 Say yes to build a 64-bit kernel - formerly known as x86_64
7 Say no to build a 32-bit kernel - formerly known as i386
8
9config X86_32
Jan Beulich3120e252012-09-10 12:41:45 +010010 def_bool y
11 depends on !64BIT
Russell King82491452011-05-08 18:55:19 +010012 select CLKSRC_I8253
Catalin Marinasaf1839e2012-10-08 16:28:08 -070013 select HAVE_UID16
Sam Ravnborgdaa93fa2007-11-12 20:54:30 +010014
15config X86_64
Jan Beulich3120e252012-09-10 12:41:45 +010016 def_bool y
17 depends on 64BIT
Alessandro Rubini4692d772012-04-04 19:39:58 +020018 select X86_DEV_DMA_OPS
Linus Torvaldsbc08b442013-09-02 12:12:15 -070019 select ARCH_USE_CMPXCHG_LOCKREF
Sam Ravnborg1032c0b2007-11-06 21:35:08 +010020
21### Arch settings
Sam Ravnborg8d5fffb2007-11-06 23:30:30 +010022config X86
Harvey Harrison3c2362e2008-01-30 13:31:03 +010023 def_bool y
Stephen Boyd446f24d2013-04-30 15:28:42 -070024 select ARCH_HAS_DEBUG_STRICT_USER_COPY_CHECKS
Mark Salter77fbbc82013-10-07 22:18:07 -040025 select ARCH_MIGHT_HAVE_PC_PARPORT
David Woodhousee17c6d52008-06-17 12:19:34 +010026 select HAVE_AOUT if X86_32
Ingo Molnara5574cf2008-05-05 23:19:50 +020027 select HAVE_UNSTABLE_SCHED_CLOCK
Peter Zijlstracbee9f82012-10-25 14:16:43 +020028 select ARCH_SUPPORTS_NUMA_BALANCING
Peter Zijlstrabe5e6102013-11-18 18:27:06 +010029 select ARCH_SUPPORTS_INT128 if X86_64
Peter Zijlstracbee9f82012-10-25 14:16:43 +020030 select ARCH_WANTS_PROT_NUMA_PROT_NONE
Sam Ravnborgec7748b2008-02-09 10:46:40 +010031 select HAVE_IDE
Mathieu Desnoyers42d4b832008-02-02 15:10:34 -050032 select HAVE_OPROFILE
Ralf Baechle8761f1a2011-06-01 19:05:09 +010033 select HAVE_PCSPKR_PLATFORM
Peter Zijlstracc2067a2010-11-16 21:49:01 +010034 select HAVE_PERF_EVENTS
Rik van Riel28b2ee22008-07-23 21:27:05 -070035 select HAVE_IOREMAP_PROT
Mathieu Desnoyers3f550092008-02-02 15:10:35 -050036 select HAVE_KPROBES
Yinghai Lu72d7c3b2010-08-25 13:39:17 -070037 select HAVE_MEMBLOCK
Tejun Heo0608f702011-07-14 11:44:23 +020038 select HAVE_MEMBLOCK_NODE_MAP
Tejun Heoc378ddd2011-07-14 11:46:03 +020039 select ARCH_DISCARD_MEMBLOCK
Ingo Molnar1f972762008-07-26 13:52:50 +020040 select ARCH_WANT_OPTIONAL_GPIOLIB
Ingo Molnarda4276b2009-01-07 11:05:10 +010041 select ARCH_WANT_FRAME_POINTERS
FUJITA Tomonori7c095e42009-06-17 16:28:12 -070042 select HAVE_DMA_ATTRS
Marek Szyprowski0a2b9a62011-12-29 13:09:51 +010043 select HAVE_DMA_CONTIGUOUS if !SWIOTLB
Ananth N Mavinakayanahalli9edddaa2008-03-04 14:28:37 -080044 select HAVE_KRETPROBES
Masami Hiramatsuc0f7ac32010-02-25 08:34:46 -050045 select HAVE_OPTPROBES
Masami Hiramatsue7dbfe32012-09-28 17:15:20 +090046 select HAVE_KPROBES_ON_FTRACE
Steven Rostedte4b2b882008-08-14 15:45:11 -040047 select HAVE_FTRACE_MCOUNT_RECORD
Steven Rostedtd57c5d52011-02-09 13:32:18 -050048 select HAVE_FENTRY if X86_64
Steven Rostedtcf4db252010-10-14 23:32:44 -040049 select HAVE_C_RECORDMCOUNT
Steven Rostedt677aa9f2008-05-17 00:01:36 -040050 select HAVE_DYNAMIC_FTRACE
Masami Hiramatsu06aeaae2012-09-28 17:15:17 +090051 select HAVE_DYNAMIC_FTRACE_WITH_REGS
Steven Rostedt606576c2008-10-06 19:06:12 -040052 select HAVE_FUNCTION_TRACER
Frederic Weisbecker48d68b22008-12-02 00:20:39 +010053 select HAVE_FUNCTION_GRAPH_TRACER
Steven Rostedt71e308a2009-06-18 12:45:08 -040054 select HAVE_FUNCTION_GRAPH_FP_TEST
Steven Rostedt60a7ecf2008-11-05 16:05:44 -050055 select HAVE_FUNCTION_TRACE_MCOUNT_TEST
Josh Stone66700002009-08-24 14:43:11 -070056 select HAVE_SYSCALL_TRACEPOINTS
Catalin Marinas7ac57a82012-10-08 16:28:16 -070057 select SYSCTL_EXCEPTION_TRACE
Ingo Molnare0ec9482009-01-27 17:01:14 +010058 select HAVE_KVM
Ingo Molnar49793b02009-01-27 17:02:29 +010059 select HAVE_ARCH_KGDB
Roland McGrath99bbc4b2008-04-20 14:35:12 -070060 select HAVE_ARCH_TRACEHOOK
Dmitry Baryshkov323ec002008-06-29 14:19:31 +040061 select HAVE_GENERIC_DMA_COHERENT if X86_32
Johannes Berg58340a02008-07-25 01:45:33 -070062 select HAVE_EFFICIENT_UNALIGNED_ACCESS
Török Edwin8d264872008-11-23 12:39:08 +020063 select USER_STACKTRACE_SUPPORT
Heiko Carstensf850c302010-02-10 17:25:17 +010064 select HAVE_REGS_AND_STACK_ACCESS_API
Joerg Roedel2118d0c2009-01-09 15:13:15 +010065 select HAVE_DMA_API_DEBUG
H. Peter Anvin2e9f3bd2009-01-04 15:41:25 -080066 select HAVE_KERNEL_GZIP
67 select HAVE_KERNEL_BZIP2
68 select HAVE_KERNEL_LZMA
Lasse Collin30314802011-01-12 17:01:24 -080069 select HAVE_KERNEL_XZ
Albin Tonnerre13510992010-01-08 14:42:45 -080070 select HAVE_KERNEL_LZO
Kyungsik Leef9b493a2013-07-08 16:01:48 -070071 select HAVE_KERNEL_LZ4
K.Prasad0067f122009-06-01 23:43:57 +053072 select HAVE_HW_BREAKPOINT
Frederic Weisbecker01027522010-04-11 18:55:56 +020073 select HAVE_MIXED_BREAKPOINTS_REGS
Frederic Weisbecker99e8c5a2009-12-17 01:33:54 +010074 select PERF_EVENTS
Frederic Weisbeckerc01d4322010-05-15 22:57:48 +020075 select HAVE_PERF_EVENTS_NMI
Jiri Olsac5e63192012-08-07 15:20:36 +020076 select HAVE_PERF_REGS
Jiri Olsac5ebced2012-08-07 15:20:40 +020077 select HAVE_PERF_USER_STACK_DUMP
Catalin Marinasb69ec422012-10-08 16:28:11 -070078 select HAVE_DEBUG_KMEMLEAK
Frederic Weisbecker99e8c5a2009-12-17 01:33:54 +010079 select ANON_INODES
H. Peter Anvineb068e72012-11-28 11:50:23 -080080 select HAVE_ALIGNED_STRUCT_PAGE if SLUB
81 select HAVE_CMPXCHG_LOCAL
Heiko Carstens25654092012-01-12 17:17:33 -080082 select HAVE_CMPXCHG_DOUBLE
Pekka Enberg0a4af3b2009-02-26 21:38:56 +020083 select HAVE_ARCH_KMEMCHECK
Avi Kivity7c68af62009-09-19 09:40:22 +030084 select HAVE_USER_RETURN_NOTIFIER
David Daneye39f5602012-01-10 15:10:21 -080085 select ARCH_BINFMT_ELF_RANDOMIZE_PIE
Steven Rostedt46eb3b62010-09-22 23:10:23 -040086 select HAVE_ARCH_JUMP_LABEL
Catalin Marinas74634492012-07-30 14:41:09 -070087 select ARCH_HAS_ATOMIC64_DEC_IF_POSITIVE
Yinghai Lu141d55e2011-10-12 11:53:17 -070088 select SPARSE_IRQ
Jan Beulichc49aa5b2011-03-08 09:24:26 +000089 select GENERIC_FIND_FIRST_BIT
Thomas Gleixner3bb98082010-09-27 12:46:02 +000090 select GENERIC_IRQ_PROBE
91 select GENERIC_PENDING_IRQ if SMP
Thomas Gleixner517e4982010-12-16 17:59:57 +010092 select GENERIC_IRQ_SHOW
Martin Schwidefskyd1748302011-08-23 15:29:42 +020093 select GENERIC_CLOCKEVENTS_MIN_ADJUST
Thomas Gleixnerc01858082011-02-07 02:24:08 +010094 select IRQ_FORCED_THREADING
Sam Ravnborge47b65b2012-05-21 20:45:37 +020095 select HAVE_BPF_JIT if X86_64
Gerald Schaefer15626062012-10-08 16:30:04 -070096 select HAVE_ARCH_TRANSPARENT_HUGEPAGE
Thomas Gleixner0a779c52011-06-09 13:08:26 +000097 select CLKEVT_I8253
Huang Yingdf013ff2011-07-13 13:14:22 +080098 select ARCH_HAVE_NMI_SAFE_CMPXCHG
Michael S. Tsirkin4673ca82011-11-24 14:54:28 +020099 select GENERIC_IOMAP
Linus Torvaldse419b4c2012-05-03 10:16:43 -0700100 select DCACHE_WORD_ACCESS
Thomas Gleixner7eb43a62012-04-20 13:05:48 +0000101 select GENERIC_SMP_IDLE_THREAD
Will Deaconc1d7e012012-07-30 14:42:46 -0700102 select ARCH_WANT_IPC_PARSE_VERSION if X86_32
Will Drewryc6cfbeb2012-04-12 16:48:03 -0500103 select HAVE_ARCH_SECCOMP_FILTER
David Daney8b5ad472012-04-24 11:23:15 -0700104 select BUILDTIME_EXTABLE_SORT
Thomas Gleixnerbdebaf82012-05-18 16:45:44 +0000105 select GENERIC_CMOS_UPDATE
Pavel Emelyanov0f8975e2013-07-03 15:01:20 -0700106 select HAVE_ARCH_SOFT_DIRTY
Thomas Gleixnerbdebaf82012-05-18 16:45:44 +0000107 select CLOCKSOURCE_WATCHDOG
108 select GENERIC_CLOCKEVENTS
109 select ARCH_CLOCKSOURCE_DATA if X86_64
110 select GENERIC_CLOCKEVENTS_BROADCAST if X86_64 || (X86_32 && X86_LOCAL_APIC)
111 select GENERIC_TIME_VSYSCALL if X86_64
112 select KTIME_SCALAR if X86_32
Linus Torvalds4ae73f22012-05-26 10:14:39 -0700113 select GENERIC_STRNCPY_FROM_USER
Linus Torvalds5723aa92012-05-26 11:09:53 -0700114 select GENERIC_STRNLEN_USER
Frederic Weisbecker91d1aa432012-11-27 19:33:25 +0100115 select HAVE_CONTEXT_TRACKING if X86_64
Frederic Weisbeckerfdf9c352012-09-09 14:56:31 +0200116 select HAVE_IRQ_TIME_ACCOUNTING
Stephen Rothwell4febd952013-03-07 15:48:16 +1100117 select VIRT_TO_BUS
David Howells786d35d2012-09-28 14:31:03 +0930118 select MODULES_USE_ELF_REL if X86_32
119 select MODULES_USE_ELF_RELA if X86_64
Al Viro1d4b4b22012-10-22 22:34:11 -0400120 select CLONE_BACKWARDS if X86_32
David Woodhouse83a57a42012-12-20 01:16:20 +0000121 select ARCH_USE_BUILTIN_BSWAP
Al Viro15ce1f72012-12-25 16:09:20 -0500122 select OLD_SIGSUSPEND3 if X86_32 || IA32_EMULATION
Al Viro5b3eb3a2012-12-25 19:14:55 -0500123 select OLD_SIGACTION if X86_32
124 select COMPAT_OLD_SIGACTION if IA32_EMULATION
Prarit Bhargava3195ef52013-02-14 12:02:54 -0500125 select RTC_LIB
Dave Hansend1a1dc02013-07-01 13:04:42 -0700126 select HAVE_DEBUG_STACKOVERFLOW
Frederic Weisbeckera2cd11f2013-09-24 17:18:36 +0200127 select HAVE_IRQ_EXIT_ON_IRQ_STACK if X86_64
Balbir Singh7d8330a2008-02-10 12:46:28 +0530128
Ingo Molnarba7e4d12009-06-06 13:58:12 +0200129config INSTRUCTION_DECODER
Jan Beulich3120e252012-09-10 12:41:45 +0100130 def_bool y
131 depends on KPROBES || PERF_EVENTS || UPROBES
Ingo Molnarba7e4d12009-06-06 13:58:12 +0200132
Linus Torvalds51b26ad2009-04-26 10:12:47 -0700133config OUTPUT_FORMAT
134 string
135 default "elf32-i386" if X86_32
136 default "elf64-x86-64" if X86_64
137
Sam Ravnborg73531902008-05-25 23:03:18 +0200138config ARCH_DEFCONFIG
Sam Ravnborgb9b39bf2008-04-29 12:48:15 +0200139 string
Sam Ravnborg73531902008-05-25 23:03:18 +0200140 default "arch/x86/configs/i386_defconfig" if X86_32
141 default "arch/x86/configs/x86_64_defconfig" if X86_64
Sam Ravnborgb9b39bf2008-04-29 12:48:15 +0200142
Sam Ravnborg8d5fffb2007-11-06 23:30:30 +0100143config LOCKDEP_SUPPORT
Harvey Harrison3c2362e2008-01-30 13:31:03 +0100144 def_bool y
Sam Ravnborg8d5fffb2007-11-06 23:30:30 +0100145
146config STACKTRACE_SUPPORT
Harvey Harrison3c2362e2008-01-30 13:31:03 +0100147 def_bool y
Sam Ravnborg8d5fffb2007-11-06 23:30:30 +0100148
Heiko Carstensaa7d9352008-02-01 17:45:14 +0100149config HAVE_LATENCYTOP_SUPPORT
150 def_bool y
151
Sam Ravnborg8d5fffb2007-11-06 23:30:30 +0100152config MMU
Harvey Harrison3c2362e2008-01-30 13:31:03 +0100153 def_bool y
Sam Ravnborg8d5fffb2007-11-06 23:30:30 +0100154
Sam Ravnborg8d5fffb2007-11-06 23:30:30 +0100155config SBUS
156 bool
157
FUJITA Tomonori3bc4e452010-03-10 15:23:22 -0800158config NEED_DMA_MAP_STATE
Jan Beulich3120e252012-09-10 12:41:45 +0100159 def_bool y
160 depends on X86_64 || INTEL_IOMMU || DMA_API_DEBUG
FUJITA Tomonori3bc4e452010-03-10 15:23:22 -0800161
FUJITA Tomonori18e98302010-05-26 14:44:32 -0700162config NEED_SG_DMA_LENGTH
Andrew Morton4a14d842010-05-26 14:44:33 -0700163 def_bool y
FUJITA Tomonori18e98302010-05-26 14:44:32 -0700164
Sam Ravnborg8d5fffb2007-11-06 23:30:30 +0100165config GENERIC_ISA_DMA
Jan Beulich3120e252012-09-10 12:41:45 +0100166 def_bool y
167 depends on ISA_DMA_API
Sam Ravnborg8d5fffb2007-11-06 23:30:30 +0100168
Sam Ravnborg8d5fffb2007-11-06 23:30:30 +0100169config GENERIC_BUG
Harvey Harrison3c2362e2008-01-30 13:31:03 +0100170 def_bool y
Sam Ravnborg8d5fffb2007-11-06 23:30:30 +0100171 depends on BUG
Jan Beulichb93a5312008-12-16 11:40:27 +0000172 select GENERIC_BUG_RELATIVE_POINTERS if X86_64
173
174config GENERIC_BUG_RELATIVE_POINTERS
175 bool
Sam Ravnborg8d5fffb2007-11-06 23:30:30 +0100176
177config GENERIC_HWEIGHT
Harvey Harrison3c2362e2008-01-30 13:31:03 +0100178 def_bool y
Sam Ravnborg8d5fffb2007-11-06 23:30:30 +0100179
180config ARCH_MAY_HAVE_PC_FDC
Jan Beulich3120e252012-09-10 12:41:45 +0100181 def_bool y
182 depends on ISA_DMA_API
Sam Ravnborg8d5fffb2007-11-06 23:30:30 +0100183
Sam Ravnborg1032c0b2007-11-06 21:35:08 +0100184config RWSEM_XCHGADD_ALGORITHM
Jan Beulich3120e252012-09-10 12:41:45 +0100185 def_bool y
Sam Ravnborg1032c0b2007-11-06 21:35:08 +0100186
Sam Ravnborg1032c0b2007-11-06 21:35:08 +0100187config GENERIC_CALIBRATE_DELAY
188 def_bool y
189
venkatesh.pallipadi@intel.com9a0b8412008-01-31 17:35:06 -0800190config ARCH_HAS_CPU_RELAX
191 def_bool y
Sam Ravnborg8d5fffb2007-11-06 23:30:30 +0100192
Pekka Enberg1b27d052008-04-28 02:12:22 -0700193config ARCH_HAS_CACHE_LINE_SIZE
194 def_bool y
195
Thomas Renningerfad12ac2012-01-26 00:09:14 +0100196config ARCH_HAS_CPU_AUTOPROBE
197 def_bool y
198
Mike Travisdd5af902008-01-30 13:33:32 +0100199config HAVE_SETUP_PER_CPU_AREA
Brian Gerst89c9c4c2009-01-27 12:56:48 +0900200 def_bool y
travis@sgi.comb32ef632008-01-30 13:32:51 +0100201
Tejun Heo08fc4582009-08-14 15:00:49 +0900202config NEED_PER_CPU_EMBED_FIRST_CHUNK
203 def_bool y
204
205config NEED_PER_CPU_PAGE_FIRST_CHUNK
Tejun Heo11124412009-02-20 16:29:09 +0900206 def_bool y
207
Johannes Berg801e4062007-12-08 02:12:39 +0100208config ARCH_HIBERNATION_POSSIBLE
209 def_bool y
Johannes Berg801e4062007-12-08 02:12:39 +0100210
Johannes Bergf4cb5702007-12-08 02:14:00 +0100211config ARCH_SUSPEND_POSSIBLE
212 def_bool y
Johannes Bergf4cb5702007-12-08 02:14:00 +0100213
Steve Cappercfe28c52013-04-29 14:29:48 +0100214config ARCH_WANT_HUGE_PMD_SHARE
215 def_bool y
216
Steve Capper53313b22013-04-30 08:03:42 +0100217config ARCH_WANT_GENERAL_HUGETLB
218 def_bool y
219
Sam Ravnborg8d5fffb2007-11-06 23:30:30 +0100220config ZONE_DMA32
221 bool
222 default X86_64
223
Sam Ravnborg8d5fffb2007-11-06 23:30:30 +0100224config AUDIT_ARCH
225 bool
226 default X86_64
227
Ingo Molnar765c68b2008-04-09 11:03:37 +0200228config ARCH_SUPPORTS_OPTIMIZED_INLINING
229 def_bool y
230
Akinobu Mita6a11f752009-03-31 15:23:17 -0700231config ARCH_SUPPORTS_DEBUG_PAGEALLOC
232 def_bool y
233
Shane Wang69575d32009-09-01 18:25:07 -0700234config HAVE_INTEL_TXT
235 def_bool y
Kees Cook6ea30382012-10-02 11:16:47 -0700236 depends on INTEL_IOMMU && ACPI
Shane Wang69575d32009-09-01 18:25:07 -0700237
Sam Ravnborg6b0c3d42008-01-30 13:32:27 +0100238config X86_32_SMP
239 def_bool y
240 depends on X86_32 && SMP
241
242config X86_64_SMP
243 def_bool y
244 depends on X86_64 && SMP
245
Sam Ravnborg8d5fffb2007-11-06 23:30:30 +0100246config X86_HT
Jan Beulich6fc108a2010-04-21 15:23:44 +0100247 def_bool y
Adrian Bunkee0011a2007-12-04 17:19:07 +0100248 depends on SMP
Sam Ravnborg8d5fffb2007-11-06 23:30:30 +0100249
Tejun Heoccbeed32009-02-09 22:17:40 +0900250config X86_32_LAZY_GS
251 def_bool y
Tejun Heo60a53172009-02-09 22:17:40 +0900252 depends on X86_32 && !CC_STACKPROTECTOR
Tejun Heoccbeed32009-02-09 22:17:40 +0900253
Borislav Petkovd61931d2010-03-05 17:34:46 +0100254config ARCH_HWEIGHT_CFLAGS
255 string
256 default "-fcall-saved-ecx -fcall-saved-edx" if X86_32
257 default "-fcall-saved-rdi -fcall-saved-rsi -fcall-saved-rdx -fcall-saved-rcx -fcall-saved-r8 -fcall-saved-r9 -fcall-saved-r10 -fcall-saved-r11" if X86_64
258
Srikar Dronamraju2b144492012-02-09 14:56:42 +0530259config ARCH_SUPPORTS_UPROBES
260 def_bool y
261
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100262source "init/Kconfig"
Matt Helsleydc52ddc2008-10-18 20:27:21 -0700263source "kernel/Kconfig.freezer"
Sam Ravnborg8d5fffb2007-11-06 23:30:30 +0100264
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100265menu "Processor type and features"
266
Randy Dunlap5ee71532012-01-16 11:57:18 -0800267config ZONE_DMA
268 bool "DMA memory allocation support" if EXPERT
269 default y
270 help
271 DMA memory allocation support allows devices with less than 32-bit
272 addressing to allocate within the first 16MB of address space.
273 Disable if no such devices will be used.
274
275 If unsure, say Y.
276
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100277config SMP
278 bool "Symmetric multi-processing support"
279 ---help---
280 This enables support for systems with more than one CPU. If you have
281 a system with only one CPU, like most personal computers, say N. If
282 you have a system with more than one CPU, say Y.
283
284 If you say N here, the kernel will run on single and multiprocessor
285 machines, but will use only one CPU of a multiprocessor machine. If
286 you say Y here, the kernel will run on many, but not all,
287 singleprocessor machines. On a singleprocessor machine, the kernel
288 will run faster if you say N here.
289
290 Note that if you say Y here and choose architecture "586" or
291 "Pentium" under "Processor family", the kernel will not work on 486
292 architectures. Similarly, multiprocessor kernels for the "PPro"
293 architecture may not work on all Pentium based boards.
294
295 People using multiprocessor machines who say Y here should also say
296 Y to "Enhanced Real Time Clock Support", below. The "Advanced Power
297 Management" code will be disabled if you say Y here.
298
Paul Bolle395cf962011-08-15 02:02:26 +0200299 See also <file:Documentation/x86/i386/IO-APIC.txt>,
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100300 <file:Documentation/nmi_watchdog.txt> and the SMP-HOWTO available at
301 <http://www.tldp.org/docs.html#howto>.
302
303 If you don't know what to do here, say N.
304
Yinghai Lu06cd9a72009-02-16 17:29:58 -0800305config X86_X2APIC
306 bool "Support x2apic"
Suresh Siddhad3f13812011-08-23 17:05:25 -0700307 depends on X86_LOCAL_APIC && X86_64 && IRQ_REMAP
Yinghai Lu06cd9a72009-02-16 17:29:58 -0800308 ---help---
309 This enables x2apic support on CPUs that have this feature.
310
311 This allows 32-bit apic IDs (so it can support very large systems),
312 and accesses the local apic via MSRs not via mmio.
313
Yinghai Lu06cd9a72009-02-16 17:29:58 -0800314 If you don't know what to do here, say N.
315
Yinghai Lu6695c852008-06-19 12:13:09 -0700316config X86_MPPARSE
Bin Gao6e87f9b72012-10-25 09:35:44 -0700317 bool "Enable MPS table" if ACPI || SFI
Jan Beulich7a527682008-10-30 10:38:24 +0000318 default y
Ingo Molnar5ab74722008-07-10 14:42:03 +0200319 depends on X86_LOCAL_APIC
Ingo Molnar8f9ca472009-02-05 16:21:53 +0100320 ---help---
Yinghai Lu6695c852008-06-19 12:13:09 -0700321 For old smp systems that do not have proper acpi support. Newer systems
322 (esp with 64bit cpus) with acpi support, MADT and DSDT will override it
Yinghai Lu6695c852008-06-19 12:13:09 -0700323
Yinghai Lu26f7ef12009-01-29 14:19:22 -0800324config X86_BIGSMP
325 bool "Support for big SMP systems with more than 8 CPUs"
326 depends on X86_32 && SMP
Ingo Molnar8f9ca472009-02-05 16:21:53 +0100327 ---help---
Yinghai Lu26f7ef12009-01-29 14:19:22 -0800328 This option is needed for the systems that have more than 8 CPUs
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100329
Jun Nakajimaddd70cf2013-01-21 17:23:09 +0000330config GOLDFISH
331 def_bool y
332 depends on X86_GOLDFISH
333
Ravikiran G Thirumalai84250912009-02-20 16:59:11 -0800334if X86_32
Ravikiran G Thirumalaic5c606d2009-02-09 18:18:14 -0800335config X86_EXTENDED_PLATFORM
336 bool "Support for extended (non-PC) x86 platforms"
337 default y
Ingo Molnar8f9ca472009-02-05 16:21:53 +0100338 ---help---
Ingo Molnar06ac8342009-01-27 18:11:43 +0100339 If you disable this option then the kernel will only support
340 standard PC platforms. (which covers the vast majority of
341 systems out there.)
342
Ravikiran G Thirumalai84250912009-02-20 16:59:11 -0800343 If you enable this option then you'll be able to select support
344 for the following (non-PC) 32 bit x86 platforms:
Ben Hutchingscb7b8022013-06-24 01:05:25 +0100345 Goldfish (Android emulator)
Ravikiran G Thirumalai84250912009-02-20 16:59:11 -0800346 AMD Elan
347 NUMAQ (IBM/Sequent)
348 RDC R-321x SoC
349 SGI 320/540 (Visual Workstation)
Alessandro Rubini83125a32012-04-04 19:40:21 +0200350 STA2X11-based (e.g. Northville)
Ravikiran G Thirumalai84250912009-02-20 16:59:11 -0800351 Summit/EXA (IBM x440)
352 Unisys ES7000 IA32 series
Thomas Gleixner3f4110a2009-08-29 14:54:20 +0200353 Moorestown MID devices
Ingo Molnar06ac8342009-01-27 18:11:43 +0100354
355 If you have one of these systems, or if you want to build a
356 generic distribution kernel, say Y here - otherwise say N.
Ravikiran G Thirumalai84250912009-02-20 16:59:11 -0800357endif
Ingo Molnar06ac8342009-01-27 18:11:43 +0100358
Ravikiran G Thirumalai84250912009-02-20 16:59:11 -0800359if X86_64
360config X86_EXTENDED_PLATFORM
361 bool "Support for extended (non-PC) x86 platforms"
362 default y
363 ---help---
364 If you disable this option then the kernel will only support
365 standard PC platforms. (which covers the vast majority of
366 systems out there.)
367
368 If you enable this option then you'll be able to select support
369 for the following (non-PC) 64 bit x86 platforms:
Steffen Persvold44b111b2011-12-06 00:07:26 +0800370 Numascale NumaChip
Ravikiran G Thirumalai84250912009-02-20 16:59:11 -0800371 ScaleMP vSMP
372 SGI Ultraviolet
373
374 If you have one of these systems, or if you want to build a
375 generic distribution kernel, say Y here - otherwise say N.
376endif
Ravikiran G Thirumalaic5c606d2009-02-09 18:18:14 -0800377# This is an alphabetically sorted list of 64 bit extended platforms
378# Please maintain the alphabetic order if and when there are additions
Steffen Persvold44b111b2011-12-06 00:07:26 +0800379config X86_NUMACHIP
380 bool "Numascale NumaChip"
381 depends on X86_64
382 depends on X86_EXTENDED_PLATFORM
383 depends on NUMA
384 depends on SMP
385 depends on X86_X2APIC
Daniel J Bluemanf9726bf2012-12-07 14:24:32 -0700386 depends on PCI_MMCONFIG
Steffen Persvold44b111b2011-12-06 00:07:26 +0800387 ---help---
388 Adds support for Numascale NumaChip large-SMP systems. Needed to
389 enable more than ~168 cores.
390 If you don't have one of these, you should say N here.
Nick Piggin03b48632009-01-20 04:36:04 +0100391
Ingo Molnar6a485652009-01-27 18:29:13 +0100392config X86_VSMP
Ravikiran G Thirumalaic5c606d2009-02-09 18:18:14 -0800393 bool "ScaleMP vSMP"
Borislav Petkov6276a072013-03-04 21:20:21 +0100394 select HYPERVISOR_GUEST
Ingo Molnar6a485652009-01-27 18:29:13 +0100395 select PARAVIRT
396 depends on X86_64 && PCI
Ravikiran G Thirumalaic5c606d2009-02-09 18:18:14 -0800397 depends on X86_EXTENDED_PLATFORM
Shai Fultheimead91d42012-04-16 10:39:35 +0300398 depends on SMP
Ingo Molnar8f9ca472009-02-05 16:21:53 +0100399 ---help---
Ingo Molnar6a485652009-01-27 18:29:13 +0100400 Support for ScaleMP vSMP systems. Say 'Y' here if this kernel is
401 supposed to run on these EM64T-based machines. Only choose this option
402 if you have one of these machines.
403
Ravikiran G Thirumalaic5c606d2009-02-09 18:18:14 -0800404config X86_UV
405 bool "SGI Ultraviolet"
406 depends on X86_64
407 depends on X86_EXTENDED_PLATFORM
Jack Steiner54c28d22009-04-03 15:39:42 -0500408 depends on NUMA
Suresh Siddha9d6c26e2009-04-20 13:02:31 -0700409 depends on X86_X2APIC
Ravikiran G Thirumalaic5c606d2009-02-09 18:18:14 -0800410 ---help---
411 This option is needed in order to support SGI Ultraviolet systems.
412 If you don't have one of these, you should say N here.
413
414# Following is an alphabetically sorted list of 32 bit extended platforms
415# Please maintain the alphabetic order if and when there are additions
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100416
Jun Nakajimaddd70cf2013-01-21 17:23:09 +0000417config X86_GOLDFISH
418 bool "Goldfish (Virtual Platform)"
419 depends on X86_32
Ben Hutchingscb7b8022013-06-24 01:05:25 +0100420 depends on X86_EXTENDED_PLATFORM
Jun Nakajimaddd70cf2013-01-21 17:23:09 +0000421 ---help---
422 Enable support for the Goldfish virtual platform used primarily
423 for Android development. Unless you are building for the Android
424 Goldfish emulator say N here.
425
Thomas Gleixnerc751e172010-11-09 12:08:04 -0800426config X86_INTEL_CE
427 bool "CE4100 TV platform"
428 depends on PCI
429 depends on PCI_GODIRECT
430 depends on X86_32
431 depends on X86_EXTENDED_PLATFORM
Dirk Brandewie37bc9f52010-11-09 12:08:08 -0800432 select X86_REBOOTFIXUPS
Sebastian Andrzej Siewiorda6b7372011-02-22 21:07:37 +0100433 select OF
434 select OF_EARLY_FLATTREE
Grant Likelyb4e51852011-12-16 15:50:17 -0700435 select IRQ_DOMAIN
Thomas Gleixnerc751e172010-11-09 12:08:04 -0800436 ---help---
437 Select for the Intel CE media processor (CE4100) SOC.
438 This option compiles in support for the CE4100 SOC for settop
439 boxes and media devices.
440
David Cohen4cb9b002013-12-16 17:37:26 -0800441config X86_INTEL_MID
Alan Cox43605ef2011-07-12 17:49:29 +0100442 bool "Intel MID platform support"
443 depends on X86_32
444 depends on X86_EXTENDED_PLATFORM
Alan Cox1ea7c672011-11-10 13:29:14 +0000445 depends on PCI
446 depends on PCI_GOANY
447 depends on X86_IO_APIC
Alan Cox7c9c3a12011-12-29 14:43:16 +0000448 select SFI
David Cohen4cb9b002013-12-16 17:37:26 -0800449 select I2C
Alan Cox7c9c3a12011-12-29 14:43:16 +0000450 select DW_APB_TIMER
Alan Cox1ea7c672011-11-10 13:29:14 +0000451 select APB_TIMER
Alan Cox1ea7c672011-11-10 13:29:14 +0000452 select INTEL_SCU_IPC
Mika Westerberg15a713d2012-01-26 17:35:05 +0000453 select MFD_INTEL_MSIC
Alan Cox1ea7c672011-11-10 13:29:14 +0000454 ---help---
David Cohen4cb9b002013-12-16 17:37:26 -0800455 Select to build a kernel capable of supporting Intel MID (Mobile
456 Internet Device) platform systems which do not have the PCI legacy
457 interfaces. If you are building for a PC class system say N here.
Alan Cox1ea7c672011-11-10 13:29:14 +0000458
David Cohen4cb9b002013-12-16 17:37:26 -0800459 Intel MID platforms are based on an Intel processor and chipset which
460 consume less power than most of the x86 derivatives.
Alan Cox43605ef2011-07-12 17:49:29 +0100461
Mika Westerberg3d48aab2013-01-18 13:45:59 +0000462config X86_INTEL_LPSS
463 bool "Intel Low Power Subsystem Support"
464 depends on ACPI
465 select COMMON_CLK
Mathias Nyman0f531432013-09-13 17:02:29 +0300466 select PINCTRL
Mika Westerberg3d48aab2013-01-18 13:45:59 +0000467 ---help---
468 Select to build support for Intel Low Power Subsystem such as
469 found on Intel Lynxpoint PCH. Selecting this option enables
Mathias Nyman0f531432013-09-13 17:02:29 +0300470 things like clock tree (common clock framework) and pincontrol
471 which are needed by the LPSS peripheral drivers.
Mika Westerberg3d48aab2013-01-18 13:45:59 +0000472
Ravikiran G Thirumalaic5c606d2009-02-09 18:18:14 -0800473config X86_RDC321X
474 bool "RDC R-321x SoC"
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100475 depends on X86_32
Ravikiran G Thirumalaic5c606d2009-02-09 18:18:14 -0800476 depends on X86_EXTENDED_PLATFORM
477 select M486
478 select X86_REBOOTFIXUPS
479 ---help---
480 This option is needed for RDC R-321x system-on-chip, also known
481 as R-8610-(G).
482 If you don't have one of these chips, you should say N here.
483
Ingo Molnare0c7ae32009-01-27 18:43:09 +0100484config X86_32_NON_STANDARD
Ingo Molnar9c398012009-01-27 18:24:57 +0100485 bool "Support non-standard 32-bit SMP architectures"
486 depends on X86_32 && SMP
Ravikiran G Thirumalaic5c606d2009-02-09 18:18:14 -0800487 depends on X86_EXTENDED_PLATFORM
Ingo Molnar8f9ca472009-02-05 16:21:53 +0100488 ---help---
Alessandro Rubini83125a32012-04-04 19:40:21 +0200489 This option compiles in the NUMAQ, Summit, bigsmp, ES7000,
490 STA2X11, default subarchitectures. It is intended for a generic
491 binary kernel. If you select them all, kernel will probe it
492 one by one and will fallback to default.
Yinghai Lud49c4282008-06-08 18:31:54 -0700493
Ravikiran G Thirumalaic5c606d2009-02-09 18:18:14 -0800494# Alphabetically sorted list of Non standard 32 bit platforms
Yinghai Lud49c4282008-06-08 18:31:54 -0700495
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100496config X86_NUMAQ
497 bool "NUMAQ (IBM/Sequent)"
Ingo Molnare0c7ae32009-01-27 18:43:09 +0100498 depends on X86_32_NON_STANDARD
Pan, Jacob juna92d1522010-02-24 16:59:55 -0800499 depends on PCI
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100500 select NUMA
Ingo Molnar9c398012009-01-27 18:24:57 +0100501 select X86_MPPARSE
Ingo Molnar8f9ca472009-02-05 16:21:53 +0100502 ---help---
Yinghai Lud49c4282008-06-08 18:31:54 -0700503 This option is used for getting Linux to run on a NUMAQ (IBM/Sequent)
504 NUMA multiquad box. This changes the way that processors are
505 bootstrapped, and uses Clustered Logical APIC addressing mode instead
506 of Flat Logical. You will need a new lynxer.elf file to flash your
507 firmware with - send email to <Martin.Bligh@us.ibm.com>.
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100508
Linus Torvaldsd949f362009-09-26 09:35:07 -0700509config X86_SUPPORTS_MEMORY_FAILURE
Jan Beulich6fc108a2010-04-21 15:23:44 +0100510 def_bool y
Linus Torvaldsd949f362009-09-26 09:35:07 -0700511 # MCE code calls memory_failure():
512 depends on X86_MCE
513 # On 32-bit this adds too big of NODES_SHIFT and we run out of page flags:
514 depends on !X86_NUMAQ
515 # On 32-bit SPARSEMEM adds too big of SECTIONS_WIDTH:
516 depends on X86_64 || !SPARSEMEM
517 select ARCH_SUPPORTS_MEMORY_FAILURE
Linus Torvaldsd949f362009-09-26 09:35:07 -0700518
Ingo Molnar1b84e1c2008-07-10 15:55:27 +0200519config X86_VISWS
520 bool "SGI 320/540 (Visual Workstation)"
Ravikiran G Thirumalaic5c606d2009-02-09 18:18:14 -0800521 depends on X86_32 && PCI && X86_MPPARSE && PCI_GODIRECT
522 depends on X86_32_NON_STANDARD
523 ---help---
Ingo Molnar1b84e1c2008-07-10 15:55:27 +0200524 The SGI Visual Workstation series is an IA32-based workstation
525 based on SGI systems chips with some legacy PC hardware attached.
526
527 Say Y here to create a kernel to run on the SGI 320 or 540.
528
529 A kernel compiled for the Visual Workstation will run on general
530 PCs as well. See <file:Documentation/sgi-visws.txt> for details.
531
Alessandro Rubini83125a32012-04-04 19:40:21 +0200532config STA2X11
533 bool "STA2X11 Companion Chip Support"
534 depends on X86_32_NON_STANDARD && PCI
535 select X86_DEV_DMA_OPS
536 select X86_DMA_REMAP
537 select SWIOTLB
538 select MFD_STA2X11
539 select ARCH_REQUIRE_GPIOLIB
540 default n
541 ---help---
542 This adds support for boards based on the STA2X11 IO-Hub,
543 a.k.a. "ConneXt". The chip is used in place of the standard
544 PC chipset, so all "standard" peripherals are missing. If this
545 option is selected the kernel will still be able to boot on
546 standard PC machines.
547
Ingo Molnar9c398012009-01-27 18:24:57 +0100548config X86_SUMMIT
549 bool "Summit/EXA (IBM x440)"
Ingo Molnare0c7ae32009-01-27 18:43:09 +0100550 depends on X86_32_NON_STANDARD
Ingo Molnar8f9ca472009-02-05 16:21:53 +0100551 ---help---
Ingo Molnar9c398012009-01-27 18:24:57 +0100552 This option is needed for IBM systems that use the Summit/EXA chipset.
553 In particular, it is needed for the x440.
Ingo Molnar1f972762008-07-26 13:52:50 +0200554
Ingo Molnar9c398012009-01-27 18:24:57 +0100555config X86_ES7000
Ravikiran G Thirumalaic5c606d2009-02-09 18:18:14 -0800556 bool "Unisys ES7000 IA32 series"
Yinghai Lu26f7ef12009-01-29 14:19:22 -0800557 depends on X86_32_NON_STANDARD && X86_BIGSMP
Ingo Molnar8f9ca472009-02-05 16:21:53 +0100558 ---help---
Ingo Molnar9c398012009-01-27 18:24:57 +0100559 Support for Unisys ES7000 systems. Say 'Y' here if this kernel is
560 supposed to run on an IA32-based Unisys ES7000 system.
561
Shérab82148d12010-09-25 06:06:57 +0200562config X86_32_IRIS
563 tristate "Eurobraille/Iris poweroff module"
564 depends on X86_32
565 ---help---
566 The Iris machines from EuroBraille do not have APM or ACPI support
567 to shut themselves down properly. A special I/O sequence is
568 needed to do so, which is what this module does at
569 kernel shutdown.
570
571 This is only for Iris machines from EuroBraille.
572
573 If unused, say N.
574
Ingo Molnarae1e9132008-11-11 09:05:16 +0100575config SCHED_OMIT_FRAME_POINTER
Harvey Harrison3c2362e2008-01-30 13:31:03 +0100576 def_bool y
577 prompt "Single-depth WCHAN output"
Ken Chena87d0912008-11-06 11:10:49 -0800578 depends on X86
Ingo Molnar8f9ca472009-02-05 16:21:53 +0100579 ---help---
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100580 Calculate simpler /proc/<PID>/wchan values. If this option
581 is disabled then wchan values will recurse back to the
582 caller function. This provides more accurate wchan values,
583 at the expense of slightly more scheduling overhead.
584
585 If in doubt, say "Y".
586
Borislav Petkov6276a072013-03-04 21:20:21 +0100587menuconfig HYPERVISOR_GUEST
588 bool "Linux guest support"
Ingo Molnar8f9ca472009-02-05 16:21:53 +0100589 ---help---
Borislav Petkov6276a072013-03-04 21:20:21 +0100590 Say Y here to enable options for running Linux under various hyper-
591 visors. This option enables basic hypervisor detection and platform
592 setup.
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100593
Borislav Petkov6276a072013-03-04 21:20:21 +0100594 If you say N, all options in this submenu will be skipped and
595 disabled, and Linux guest support won't be built in.
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100596
Borislav Petkov6276a072013-03-04 21:20:21 +0100597if HYPERVISOR_GUEST
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100598
Eduardo Pereira Habkoste61bd942008-01-30 13:33:32 +0100599config PARAVIRT
600 bool "Enable paravirtualization code"
Ingo Molnar8f9ca472009-02-05 16:21:53 +0100601 ---help---
Eduardo Pereira Habkoste61bd942008-01-30 13:33:32 +0100602 This changes the kernel so it can modify itself when it is run
603 under a hypervisor, potentially improving performance significantly
604 over full virtualization. However, when run without a hypervisor
605 the kernel is theoretically slower and slightly larger.
606
Borislav Petkov6276a072013-03-04 21:20:21 +0100607config PARAVIRT_DEBUG
608 bool "paravirt-ops debugging"
609 depends on PARAVIRT && DEBUG_KERNEL
610 ---help---
611 Enable to debug paravirt_ops internals. Specifically, BUG if
612 a paravirt_op is missing when it is called.
613
Jeremy Fitzhardingeb4ecc122009-05-13 17:16:55 -0700614config PARAVIRT_SPINLOCKS
615 bool "Paravirtualization layer for spinlocks"
Kees Cook6ea30382012-10-02 11:16:47 -0700616 depends on PARAVIRT && SMP
Raghavendra K T8db73262013-08-09 19:51:50 +0530617 select UNINLINE_SPIN_UNLOCK
Jeremy Fitzhardingeb4ecc122009-05-13 17:16:55 -0700618 ---help---
619 Paravirtualized spinlocks allow a pvops backend to replace the
620 spinlock implementation with something virtualization-friendly
621 (for example, block the virtual CPU rather than spinning).
622
Raghavendra K T4c4e4f62013-10-21 21:35:08 +0530623 It has a minimal impact on native kernels and gives a nice performance
624 benefit on paravirtualized KVM / Xen kernels.
Jeremy Fitzhardingeb4ecc122009-05-13 17:16:55 -0700625
Raghavendra K T4c4e4f62013-10-21 21:35:08 +0530626 If you are unsure how to answer this question, answer Y.
Jeremy Fitzhardingeb4ecc122009-05-13 17:16:55 -0700627
Borislav Petkov6276a072013-03-04 21:20:21 +0100628source "arch/x86/xen/Kconfig"
629
630config KVM_GUEST
631 bool "KVM Guest support (including kvmclock)"
632 depends on PARAVIRT
633 select PARAVIRT_CLOCK
634 default y
635 ---help---
636 This option enables various optimizations for running under the KVM
637 hypervisor. It includes a paravirtualized clock, so that instead
638 of relying on a PIT (or probably other) emulation by the
639 underlying device model, the host provides the guest with
640 timing infrastructure such as time of day, and system time
641
Srivatsa Vaddagiri1e20eb82013-08-09 19:52:01 +0530642config KVM_DEBUG_FS
643 bool "Enable debug information for KVM Guests in debugfs"
644 depends on KVM_GUEST && DEBUG_FS
645 default n
646 ---help---
647 This option enables collection of various statistics for KVM guest.
648 Statistics are displayed in debugfs filesystem. Enabling this option
649 may incur significant overhead.
650
Borislav Petkov6276a072013-03-04 21:20:21 +0100651source "arch/x86/lguest/Kconfig"
652
653config PARAVIRT_TIME_ACCOUNTING
654 bool "Paravirtual steal time accounting"
655 depends on PARAVIRT
656 default n
657 ---help---
658 Select this option to enable fine granularity task steal time
659 accounting. Time spent executing other tasks in parallel with
660 the current vCPU is discounted from the vCPU power. To account for
661 that, there can be a small performance impact.
662
663 If in doubt, say N here.
664
Gerd Hoffmann7af192c2008-06-03 16:17:29 +0200665config PARAVIRT_CLOCK
666 bool
Gerd Hoffmann7af192c2008-06-03 16:17:29 +0200667
Borislav Petkov6276a072013-03-04 21:20:21 +0100668endif #HYPERVISOR_GUEST
Jeremy Fitzhardinge97349132008-06-25 00:19:14 -0400669
Yinghai Lu08677212010-02-10 01:20:20 -0800670config NO_BOOTMEM
Yinghai Lu774ea0b2010-08-25 13:39:18 -0700671 def_bool y
Yinghai Lu08677212010-02-10 01:20:20 -0800672
Yinghai Lu03273182008-04-18 17:49:15 -0700673config MEMTEST
674 bool "Memtest"
Ingo Molnar8f9ca472009-02-05 16:21:53 +0100675 ---help---
Yinghai Luc64df702008-03-21 18:56:19 -0700676 This option adds a kernel parameter 'memtest', which allows memtest
Yinghai Lu03273182008-04-18 17:49:15 -0700677 to be set.
Ingo Molnar8f9ca472009-02-05 16:21:53 +0100678 memtest=0, mean disabled; -- default
679 memtest=1, mean do 1 test pattern;
680 ...
681 memtest=4, mean do 4 test patterns.
Thomas Gleixneraba37282008-07-15 14:48:48 +0200682 If you are unsure how to answer this question, answer N.
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100683
684config X86_SUMMIT_NUMA
Harvey Harrison3c2362e2008-01-30 13:31:03 +0100685 def_bool y
Ingo Molnare0c7ae32009-01-27 18:43:09 +0100686 depends on X86_32 && NUMA && X86_32_NON_STANDARD
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100687
688config X86_CYCLONE_TIMER
Harvey Harrison3c2362e2008-01-30 13:31:03 +0100689 def_bool y
Alessandro Rubinif9b15df2011-10-29 00:48:42 +0200690 depends on X86_SUMMIT
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100691
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100692source "arch/x86/Kconfig.cpu"
693
694config HPET_TIMER
Harvey Harrison3c2362e2008-01-30 13:31:03 +0100695 def_bool X86_64
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100696 prompt "HPET Timer Support" if X86_32
Ingo Molnar8f9ca472009-02-05 16:21:53 +0100697 ---help---
698 Use the IA-PC HPET (High Precision Event Timer) to manage
699 time in preference to the PIT and RTC, if a HPET is
700 present.
701 HPET is the next generation timer replacing legacy 8254s.
702 The HPET provides a stable time base on SMP
703 systems, unlike the TSC, but it is more expensive to access,
704 as it is off-chip. You can find the HPET spec at
705 <http://www.intel.com/hardwaredesign/hpetspec_1.pdf>.
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100706
Ingo Molnar8f9ca472009-02-05 16:21:53 +0100707 You can safely choose Y here. However, HPET will only be
708 activated if the platform and the BIOS support this feature.
709 Otherwise the 8254 will be used for timing services.
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100710
Ingo Molnar8f9ca472009-02-05 16:21:53 +0100711 Choose N to continue using the legacy 8254 timer.
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100712
713config HPET_EMULATE_RTC
Harvey Harrison3c2362e2008-01-30 13:31:03 +0100714 def_bool y
Bernhard Walle9d8af782008-02-06 01:38:52 -0800715 depends on HPET_TIMER && (RTC=y || RTC=m || RTC_DRV_CMOS=m || RTC_DRV_CMOS=y)
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100716
Jacob Panbb24c472009-09-02 07:37:17 -0700717config APB_TIMER
Alan Cox933b9462011-12-17 17:43:40 +0000718 def_bool y if X86_INTEL_MID
719 prompt "Intel MID APB Timer Support" if X86_INTEL_MID
Jamie Iles06c3df42011-06-06 12:43:07 +0100720 select DW_APB_TIMER
Alan Coxa0c38322011-12-17 21:57:25 +0000721 depends on X86_INTEL_MID && SFI
Jacob Panbb24c472009-09-02 07:37:17 -0700722 help
723 APB timer is the replacement for 8254, HPET on X86 MID platforms.
724 The APBT provides a stable time base on SMP
725 systems, unlike the TSC, but it is more expensive to access,
726 as it is off-chip. APB timers are always running regardless of CPU
727 C states, they are used as per CPU clockevent device when possible.
728
David Rientjes6a108a12011-01-20 14:44:16 -0800729# Mark as expert because too many people got it wrong.
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100730# The code disables itself when not needed.
Thomas Petazzoni7ae93922008-04-28 02:14:14 -0700731config DMI
732 default y
David Rientjes6a108a12011-01-20 14:44:16 -0800733 bool "Enable DMI scanning" if EXPERT
Ingo Molnar8f9ca472009-02-05 16:21:53 +0100734 ---help---
Thomas Petazzoni7ae93922008-04-28 02:14:14 -0700735 Enabled scanning of DMI to identify machine quirks. Say Y
736 here unless you have verified that your setup is not
737 affected by entries in the DMI blacklist. Required by PNP
738 BIOS code.
739
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100740config GART_IOMMU
Andi Kleen38901f12013-10-04 14:37:56 -0700741 bool "Old AMD GART IOMMU support"
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100742 select SWIOTLB
Andreas Herrmann23ac4ae2010-09-17 18:03:43 +0200743 depends on X86_64 && PCI && AMD_NB
Ingo Molnar8f9ca472009-02-05 16:21:53 +0100744 ---help---
Ingo Molnarced3c422013-10-06 11:45:20 +0200745 Provides a driver for older AMD Athlon64/Opteron/Turion/Sempron
746 GART based hardware IOMMUs.
747
748 The GART supports full DMA access for devices with 32-bit access
749 limitations, on systems with more than 3 GB. This is usually needed
750 for USB, sound, many IDE/SATA chipsets and some other devices.
751
752 Newer systems typically have a modern AMD IOMMU, supported via
753 the CONFIG_AMD_IOMMU=y config option.
754
755 In normal configurations this driver is only active when needed:
756 there's more than 3 GB of memory and the system contains a
757 32-bit limited device.
758
759 If unsure, say Y.
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100760
761config CALGARY_IOMMU
762 bool "IBM Calgary IOMMU support"
763 select SWIOTLB
Kees Cook6ea30382012-10-02 11:16:47 -0700764 depends on X86_64 && PCI
Ingo Molnar8f9ca472009-02-05 16:21:53 +0100765 ---help---
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100766 Support for hardware IOMMUs in IBM's xSeries x366 and x460
767 systems. Needed to run systems with more than 3GB of memory
768 properly with 32-bit PCI devices that do not support DAC
769 (Double Address Cycle). Calgary also supports bus level
770 isolation, where all DMAs pass through the IOMMU. This
771 prevents them from going anywhere except their intended
772 destination. This catches hard-to-find kernel bugs and
773 mis-behaving drivers and devices that do not use the DMA-API
774 properly to set up their DMA buffers. The IOMMU can be
775 turned off at boot time with the iommu=off parameter.
776 Normally the kernel will make the right choice by itself.
777 If unsure, say Y.
778
779config CALGARY_IOMMU_ENABLED_BY_DEFAULT
Harvey Harrison3c2362e2008-01-30 13:31:03 +0100780 def_bool y
781 prompt "Should Calgary be enabled by default?"
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100782 depends on CALGARY_IOMMU
Ingo Molnar8f9ca472009-02-05 16:21:53 +0100783 ---help---
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100784 Should Calgary be enabled by default? if you choose 'y', Calgary
785 will be used (if it exists). If you choose 'n', Calgary will not be
786 used even if it exists. If you choose 'n' and would like to use
787 Calgary anyway, pass 'iommu=calgary' on the kernel command line.
788 If unsure, say Y.
789
790# need this always selected by IOMMU for the VIA workaround
791config SWIOTLB
Joerg Roedela1afd012008-11-18 12:44:21 +0100792 def_bool y if X86_64
Ingo Molnar8f9ca472009-02-05 16:21:53 +0100793 ---help---
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100794 Support for software bounce buffers used on x86-64 systems
Joe Millenbach4454d322012-09-02 17:38:20 -0700795 which don't have a hardware IOMMU. Using this PCI devices
796 which can only access 32-bits of memory can be used on systems
797 with more than 3 GB of memory.
798 If unsure, say Y.
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100799
FUJITA Tomonoria8522502008-04-29 00:59:36 -0700800config IOMMU_HELPER
Jan Beulich3120e252012-09-10 12:41:45 +0100801 def_bool y
802 depends on CALGARY_IOMMU || GART_IOMMU || SWIOTLB || AMD_IOMMU
Linus Torvaldsd25e26b2008-08-25 14:15:38 -0700803
Mike Travis1184dc22008-05-12 21:21:12 +0200804config MAXSMP
Samuel Thibaultddb0c5a2010-08-21 21:32:41 +0200805 bool "Enable Maximum number of SMP Processors and NUMA Nodes"
Kees Cook6ea30382012-10-02 11:16:47 -0700806 depends on X86_64 && SMP && DEBUG_KERNEL
Mike Travis36f51012008-12-16 17:33:51 -0800807 select CPUMASK_OFFSTACK
Ingo Molnar8f9ca472009-02-05 16:21:53 +0100808 ---help---
Samuel Thibaultddb0c5a2010-08-21 21:32:41 +0200809 Enable maximum number of CPUS and NUMA Nodes for this architecture.
Mike Travis1184dc22008-05-12 21:21:12 +0200810 If unsure, say N.
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100811
812config NR_CPUS
Mike Travis36f51012008-12-16 17:33:51 -0800813 int "Maximum number of CPUs" if SMP && !MAXSMP
Michael K. Johnson2a3313f2009-04-21 21:44:48 -0400814 range 2 8 if SMP && X86_32 && !X86_BIGSMP
Josh Boyerbb61ccc2013-11-05 09:37:29 -0500815 range 2 512 if SMP && !MAXSMP && !CPUMASK_OFFSTACK
Josh Boyerb53b5ed2013-11-05 09:38:16 -0500816 range 2 8192 if SMP && !MAXSMP && CPUMASK_OFFSTACK && X86_64
Mike Travis78637a972008-12-16 17:34:00 -0800817 default "1" if !SMP
Josh Boyerb53b5ed2013-11-05 09:38:16 -0500818 default "8192" if MAXSMP
Mike Travis78637a972008-12-16 17:34:00 -0800819 default "32" if SMP && (X86_NUMAQ || X86_SUMMIT || X86_BIGSMP || X86_ES7000)
820 default "8" if SMP
Ingo Molnar8f9ca472009-02-05 16:21:53 +0100821 ---help---
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100822 This allows you to specify the maximum number of CPUs which this
Josh Boyerbb61ccc2013-11-05 09:37:29 -0500823 kernel will support. If CPUMASK_OFFSTACK is enabled, the maximum
824 supported value is 4096, otherwise the maximum value is 512. The
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100825 minimum value which makes sense is 2.
826
827 This is purely to save memory - each supported CPU adds
828 approximately eight kilobytes to the kernel image.
829
830config SCHED_SMT
831 bool "SMT (Hyperthreading) scheduler support"
Hiroshi Shimamotob089c122008-02-27 13:16:30 -0800832 depends on X86_HT
Ingo Molnar8f9ca472009-02-05 16:21:53 +0100833 ---help---
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100834 SMT scheduler support improves the CPU scheduler's decision making
835 when dealing with Intel Pentium 4 chips with HyperThreading at a
836 cost of slightly increased overhead in some places. If unsure say
837 N here.
838
839config SCHED_MC
Harvey Harrison3c2362e2008-01-30 13:31:03 +0100840 def_bool y
841 prompt "Multi-core scheduler support"
Hiroshi Shimamotob089c122008-02-27 13:16:30 -0800842 depends on X86_HT
Ingo Molnar8f9ca472009-02-05 16:21:53 +0100843 ---help---
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100844 Multi-core scheduler support improves the CPU scheduler's decision
845 making when dealing with multi-core CPU chips at a cost of slightly
846 increased overhead in some places. If unsure say N here.
847
848source "kernel/Kconfig.preempt"
849
850config X86_UP_APIC
851 bool "Local APIC support on uniprocessors"
Thomas Petazzoni0dbc6072013-10-03 11:59:14 +0200852 depends on X86_32 && !SMP && !X86_32_NON_STANDARD && !PCI_MSI
Ingo Molnar8f9ca472009-02-05 16:21:53 +0100853 ---help---
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100854 A local APIC (Advanced Programmable Interrupt Controller) is an
855 integrated interrupt controller in the CPU. If you have a single-CPU
856 system which has a processor with a local APIC, you can say Y here to
857 enable and use it. If you say Y here even though your machine doesn't
858 have a local APIC, then the kernel will still run with no slowdown at
859 all. The local APIC supports CPU-generated self-interrupts (timer,
860 performance counters), and the NMI watchdog which detects hard
861 lockups.
862
863config X86_UP_IOAPIC
864 bool "IO-APIC support on uniprocessors"
865 depends on X86_UP_APIC
Ingo Molnar8f9ca472009-02-05 16:21:53 +0100866 ---help---
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100867 An IO-APIC (I/O Advanced Programmable Interrupt Controller) is an
868 SMP-capable replacement for PC-style interrupt controllers. Most
869 SMP systems and many recent uniprocessor systems have one.
870
871 If you have a single-CPU system with an IO-APIC, you can say Y here
872 to use it. If you say Y here even though your machine doesn't have
873 an IO-APIC, then the kernel will still run with no slowdown at all.
874
875config X86_LOCAL_APIC
Harvey Harrison3c2362e2008-01-30 13:31:03 +0100876 def_bool y
Thomas Petazzoni0dbc6072013-10-03 11:59:14 +0200877 depends on X86_64 || SMP || X86_32_NON_STANDARD || X86_UP_APIC || PCI_MSI
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100878
879config X86_IO_APIC
Harvey Harrison3c2362e2008-01-30 13:31:03 +0100880 def_bool y
Thomas Petazzoni0dbc6072013-10-03 11:59:14 +0200881 depends on X86_64 || SMP || X86_32_NON_STANDARD || X86_UP_IOAPIC || PCI_MSI
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100882
883config X86_VISWS_APIC
Harvey Harrison3c2362e2008-01-30 13:31:03 +0100884 def_bool y
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100885 depends on X86_32 && X86_VISWS
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100886
Stefan Assmann41b9eb22008-07-15 13:48:55 +0200887config X86_REROUTE_FOR_BROKEN_BOOT_IRQS
888 bool "Reroute for broken boot IRQs"
Stefan Assmann41b9eb22008-07-15 13:48:55 +0200889 depends on X86_IO_APIC
Ingo Molnar8f9ca472009-02-05 16:21:53 +0100890 ---help---
Stefan Assmann41b9eb22008-07-15 13:48:55 +0200891 This option enables a workaround that fixes a source of
892 spurious interrupts. This is recommended when threaded
893 interrupt handling is used on systems where the generation of
894 superfluous "boot interrupts" cannot be disabled.
895
896 Some chipsets generate a legacy INTx "boot IRQ" when the IRQ
897 entry in the chipset's IO-APIC is masked (as, e.g. the RT
898 kernel does during interrupt handling). On chipsets where this
899 boot IRQ generation cannot be disabled, this workaround keeps
900 the original IRQ line masked so that only the equivalent "boot
901 IRQ" is delivered to the CPUs. The workaround also tells the
902 kernel to set up the IRQ handler on the boot IRQ line. In this
903 way only one interrupt is delivered to the kernel. Otherwise
904 the spurious second interrupt may cause the kernel to bring
905 down (vital) interrupt lines.
906
907 Only affects "broken" chipsets. Interrupt sharing may be
908 increased on these systems.
909
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100910config X86_MCE
Andi Kleenbab9bc62009-07-09 00:31:38 +0200911 bool "Machine Check / overheating reporting"
Borislav Petkove57dbaf2011-09-13 15:23:21 +0200912 default y
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100913 ---help---
Andi Kleenbab9bc62009-07-09 00:31:38 +0200914 Machine Check support allows the processor to notify the
915 kernel if it detects a problem (e.g. overheating, data corruption).
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100916 The action the kernel takes depends on the severity of the problem,
Andi Kleenbab9bc62009-07-09 00:31:38 +0200917 ranging from warning messages to halting the machine.
Andi Kleen4efc0672009-04-28 19:07:31 +0200918
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100919config X86_MCE_INTEL
Harvey Harrison3c2362e2008-01-30 13:31:03 +0100920 def_bool y
921 prompt "Intel MCE features"
Andi Kleenc1ebf832009-07-09 00:31:41 +0200922 depends on X86_MCE && X86_LOCAL_APIC
Ingo Molnar8f9ca472009-02-05 16:21:53 +0100923 ---help---
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100924 Additional support for intel specific MCE features such as
925 the thermal monitor.
926
927config X86_MCE_AMD
Harvey Harrison3c2362e2008-01-30 13:31:03 +0100928 def_bool y
929 prompt "AMD MCE features"
Andi Kleenc1ebf832009-07-09 00:31:41 +0200930 depends on X86_MCE && X86_LOCAL_APIC
Ingo Molnar8f9ca472009-02-05 16:21:53 +0100931 ---help---
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100932 Additional support for AMD specific MCE features such as
933 the DRAM Error Threshold.
934
Andi Kleen4efc0672009-04-28 19:07:31 +0200935config X86_ANCIENT_MCE
Jan Beulich6fc108a2010-04-21 15:23:44 +0100936 bool "Support for old Pentium 5 / WinChip machine checks"
Andi Kleenc31d9632009-07-09 00:31:37 +0200937 depends on X86_32 && X86_MCE
Hidetoshi Setocd13adcc2009-05-27 16:57:31 +0900938 ---help---
939 Include support for machine check handling on old Pentium 5 or WinChip
940 systems. These typically need to be enabled explicitely on the command
941 line.
Andi Kleen4efc0672009-04-28 19:07:31 +0200942
Andi Kleenb2762682009-02-12 13:49:31 +0100943config X86_MCE_THRESHOLD
944 depends on X86_MCE_AMD || X86_MCE_INTEL
Jan Beulich6fc108a2010-04-21 15:23:44 +0100945 def_bool y
Andi Kleenb2762682009-02-12 13:49:31 +0100946
Andi Kleenea149b32009-04-29 19:31:00 +0200947config X86_MCE_INJECT
Andi Kleenc1ebf832009-07-09 00:31:41 +0200948 depends on X86_MCE
Andi Kleenea149b32009-04-29 19:31:00 +0200949 tristate "Machine check injector support"
950 ---help---
951 Provide support for injecting machine checks for testing purposes.
952 If you don't know what a machine check is and you don't do kernel
953 QA it is safe to say n.
954
Andi Kleen4efc0672009-04-28 19:07:31 +0200955config X86_THERMAL_VECTOR
956 def_bool y
Andi Kleen5bb38ad2009-07-09 00:31:39 +0200957 depends on X86_MCE_INTEL
Andi Kleen4efc0672009-04-28 19:07:31 +0200958
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100959config VM86
David Rientjes6a108a12011-01-20 14:44:16 -0800960 bool "Enable VM86 support" if EXPERT
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100961 default y
962 depends on X86_32
Ingo Molnar8f9ca472009-02-05 16:21:53 +0100963 ---help---
964 This option is required by programs like DOSEMU to run 16-bit legacy
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100965 code on X86 processors. It also may be needed by software like
Ingo Molnar8f9ca472009-02-05 16:21:53 +0100966 XFree86 to initialize some video cards via BIOS. Disabling this
967 option saves about 6k.
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100968
969config TOSHIBA
970 tristate "Toshiba Laptop support"
971 depends on X86_32
972 ---help---
973 This adds a driver to safely access the System Management Mode of
974 the CPU on Toshiba portables with a genuine Toshiba BIOS. It does
975 not work on models with a Phoenix BIOS. The System Management Mode
976 is used to set the BIOS and power saving options on Toshiba portables.
977
978 For information on utilities to make use of this driver see the
979 Toshiba Linux utilities web site at:
980 <http://www.buzzard.org.uk/toshiba/>.
981
982 Say Y if you intend to run this kernel on a Toshiba portable.
983 Say N otherwise.
984
985config I8K
986 tristate "Dell laptop support"
Jean Delvare949a9d72011-05-25 20:43:33 +0200987 select HWMON
Sam Ravnborg506f1d02007-11-09 21:56:54 +0100988 ---help---
989 This adds a driver to safely access the System Management Mode
990 of the CPU on the Dell Inspiron 8000. The System Management Mode
991 is used to read cpu temperature and cooling fan status and to
992 control the fans on the I8K portables.
993
994 This driver has been tested only on the Inspiron 8000 but it may
995 also work with other Dell laptops. You can force loading on other
996 models by passing the parameter `force=1' to the module. Use at
997 your own risk.
998
999 For information on utilities to make use of this driver see the
1000 I8K Linux utilities web site at:
1001 <http://people.debian.org/~dz/i8k/>
1002
1003 Say Y if you intend to run this kernel on a Dell Inspiron 8000.
1004 Say N otherwise.
1005
1006config X86_REBOOTFIXUPS
Jan Beulich9ba16082008-10-15 22:01:38 -07001007 bool "Enable X86 board specific fixups for reboot"
1008 depends on X86_32
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001009 ---help---
1010 This enables chipset and/or board specific fixups to be done
1011 in order to get reboot to work correctly. This is only needed on
1012 some combinations of hardware and BIOS. The symptom, for which
1013 this config is intended, is when reboot ends with a stalled/hung
1014 system.
1015
1016 Currently, the only fixup is for the Geode machines using
Florian Fainelli5e3a77e2008-01-30 13:33:36 +01001017 CS5530A and CS5536 chipsets and the RDC R-321x SoC.
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001018
1019 Say Y if you want to enable the fixup. Currently, it's safe to
1020 enable this option even if you don't need it.
1021 Say N otherwise.
1022
1023config MICROCODE
Borislav Petkove43f6e62012-08-01 19:17:01 +02001024 tristate "CPU microcode loading support"
Borislav Petkov80030e32013-10-13 18:36:29 +02001025 depends on CPU_SUP_AMD || CPU_SUP_INTEL
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001026 select FW_LOADER
1027 ---help---
Borislav Petkove43f6e62012-08-01 19:17:01 +02001028
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001029 If you say Y here, you will be able to update the microcode on
Peter Oruba80cc9f12008-07-28 18:44:22 +02001030 certain Intel and AMD processors. The Intel support is for the
Borislav Petkove43f6e62012-08-01 19:17:01 +02001031 IA32 family, e.g. Pentium Pro, Pentium II, Pentium III, Pentium 4,
1032 Xeon etc. The AMD support is for families 0x10 and later. You will
1033 obviously need the actual microcode binary data itself which is not
1034 shipped with the Linux kernel.
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001035
Peter Oruba8d86f392008-07-28 18:44:21 +02001036 This option selects the general module only, you need to select
1037 at least one vendor specific module as well.
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001038
Borislav Petkove43f6e62012-08-01 19:17:01 +02001039 To compile this driver as a module, choose M here: the module
1040 will be called microcode.
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001041
Peter Oruba8d86f392008-07-28 18:44:21 +02001042config MICROCODE_INTEL
Borislav Petkove43f6e62012-08-01 19:17:01 +02001043 bool "Intel microcode loading support"
Ingo Molnar8f9ca472009-02-05 16:21:53 +01001044 depends on MICROCODE
1045 default MICROCODE
1046 select FW_LOADER
1047 ---help---
1048 This options enables microcode patch loading support for Intel
1049 processors.
Peter Oruba8d86f392008-07-28 18:44:21 +02001050
Ingo Molnar8f9ca472009-02-05 16:21:53 +01001051 For latest news and information on obtaining all the required
1052 Intel ingredients for this driver, check:
1053 <http://www.urbanmyth.org/microcode/>.
Peter Oruba8d86f392008-07-28 18:44:21 +02001054
Peter Oruba80cc9f12008-07-28 18:44:22 +02001055config MICROCODE_AMD
Borislav Petkove43f6e62012-08-01 19:17:01 +02001056 bool "AMD microcode loading support"
Ingo Molnar8f9ca472009-02-05 16:21:53 +01001057 depends on MICROCODE
1058 select FW_LOADER
1059 ---help---
1060 If you select this option, microcode patch loading support for AMD
1061 processors will be enabled.
Peter Oruba80cc9f12008-07-28 18:44:22 +02001062
Ingo Molnar8f9ca472009-02-05 16:21:53 +01001063config MICROCODE_OLD_INTERFACE
Harvey Harrison3c2362e2008-01-30 13:31:03 +01001064 def_bool y
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001065 depends on MICROCODE
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001066
Fenghua Yuda76f642012-12-20 23:44:32 -08001067config MICROCODE_INTEL_LIB
1068 def_bool y
1069 depends on MICROCODE_INTEL
1070
1071config MICROCODE_INTEL_EARLY
Jacob Shin757885e2013-05-30 14:09:19 -05001072 def_bool n
1073
1074config MICROCODE_AMD_EARLY
1075 def_bool n
1076
1077config MICROCODE_EARLY
Fenghua Yuda76f642012-12-20 23:44:32 -08001078 bool "Early load microcode"
Jacob Shin6b3389a2013-05-31 01:53:24 -05001079 depends on MICROCODE=y && BLK_DEV_INITRD
Jacob Shin757885e2013-05-30 14:09:19 -05001080 select MICROCODE_INTEL_EARLY if MICROCODE_INTEL
1081 select MICROCODE_AMD_EARLY if MICROCODE_AMD
Fenghua Yuda76f642012-12-20 23:44:32 -08001082 default y
1083 help
1084 This option provides functionality to read additional microcode data
1085 at the beginning of initrd image. The data tells kernel to load
1086 microcode to CPU's as early as possible. No functional change if no
1087 microcode data is glued to the initrd, therefore it's safe to say Y.
1088
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001089config X86_MSR
1090 tristate "/dev/cpu/*/msr - Model-specific register support"
Ingo Molnar8f9ca472009-02-05 16:21:53 +01001091 ---help---
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001092 This device gives privileged processes access to the x86
1093 Model-Specific Registers (MSRs). It is a character device with
1094 major 202 and minors 0 to 31 for /dev/cpu/0/msr to /dev/cpu/31/msr.
1095 MSR accesses are directed to a specific CPU on multi-processor
1096 systems.
1097
1098config X86_CPUID
1099 tristate "/dev/cpu/*/cpuid - CPU information support"
Ingo Molnar8f9ca472009-02-05 16:21:53 +01001100 ---help---
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001101 This device gives processes access to the x86 CPUID instruction to
1102 be executed on a specific processor. It is a character device
1103 with major 203 and minors 0 to 31 for /dev/cpu/0/cpuid to
1104 /dev/cpu/31/cpuid.
1105
1106choice
1107 prompt "High Memory Support"
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001108 default HIGHMEM64G if X86_NUMAQ
Jan Beulich6fc108a2010-04-21 15:23:44 +01001109 default HIGHMEM4G
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001110 depends on X86_32
1111
1112config NOHIGHMEM
1113 bool "off"
1114 depends on !X86_NUMAQ
1115 ---help---
1116 Linux can use up to 64 Gigabytes of physical memory on x86 systems.
1117 However, the address space of 32-bit x86 processors is only 4
1118 Gigabytes large. That means that, if you have a large amount of
1119 physical memory, not all of it can be "permanently mapped" by the
1120 kernel. The physical memory that's not permanently mapped is called
1121 "high memory".
1122
1123 If you are compiling a kernel which will never run on a machine with
1124 more than 1 Gigabyte total physical RAM, answer "off" here (default
1125 choice and suitable for most users). This will result in a "3GB/1GB"
1126 split: 3GB are mapped so that each process sees a 3GB virtual memory
1127 space and the remaining part of the 4GB virtual memory space is used
1128 by the kernel to permanently map as much physical memory as
1129 possible.
1130
1131 If the machine has between 1 and 4 Gigabytes physical RAM, then
1132 answer "4GB" here.
1133
1134 If more than 4 Gigabytes is used then answer "64GB" here. This
1135 selection turns Intel PAE (Physical Address Extension) mode on.
1136 PAE implements 3-level paging on IA32 processors. PAE is fully
1137 supported by Linux, PAE mode is implemented on all recent Intel
1138 processors (Pentium Pro and better). NOTE: If you say "64GB" here,
1139 then the kernel will not boot on CPUs that don't support PAE!
1140
1141 The actual amount of total physical memory will either be
1142 auto detected or can be forced by using a kernel command line option
1143 such as "mem=256M". (Try "man bootparam" or see the documentation of
1144 your boot loader (lilo or loadlin) about how to pass options to the
1145 kernel at boot time.)
1146
1147 If unsure, say "off".
1148
1149config HIGHMEM4G
1150 bool "4GB"
1151 depends on !X86_NUMAQ
Ingo Molnar8f9ca472009-02-05 16:21:53 +01001152 ---help---
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001153 Select this if you have a 32-bit processor and between 1 and 4
1154 gigabytes of physical RAM.
1155
1156config HIGHMEM64G
1157 bool "64GB"
H. Peter Anvineb068e72012-11-28 11:50:23 -08001158 depends on !M486
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001159 select X86_PAE
Ingo Molnar8f9ca472009-02-05 16:21:53 +01001160 ---help---
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001161 Select this if you have a 32-bit processor and more than 4
1162 gigabytes of physical RAM.
1163
1164endchoice
1165
1166choice
David Rientjes6a108a12011-01-20 14:44:16 -08001167 prompt "Memory split" if EXPERT
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001168 default VMSPLIT_3G
1169 depends on X86_32
Ingo Molnar8f9ca472009-02-05 16:21:53 +01001170 ---help---
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001171 Select the desired split between kernel and user memory.
1172
1173 If the address range available to the kernel is less than the
1174 physical memory installed, the remaining memory will be available
1175 as "high memory". Accessing high memory is a little more costly
1176 than low memory, as it needs to be mapped into the kernel first.
1177 Note that increasing the kernel address space limits the range
1178 available to user programs, making the address space there
1179 tighter. Selecting anything other than the default 3G/1G split
1180 will also likely make your kernel incompatible with binary-only
1181 kernel modules.
1182
1183 If you are not absolutely sure what you are doing, leave this
1184 option alone!
1185
1186 config VMSPLIT_3G
1187 bool "3G/1G user/kernel split"
1188 config VMSPLIT_3G_OPT
1189 depends on !X86_PAE
1190 bool "3G/1G user/kernel split (for full 1G low memory)"
1191 config VMSPLIT_2G
1192 bool "2G/2G user/kernel split"
1193 config VMSPLIT_2G_OPT
1194 depends on !X86_PAE
1195 bool "2G/2G user/kernel split (for full 2G low memory)"
1196 config VMSPLIT_1G
1197 bool "1G/3G user/kernel split"
1198endchoice
1199
1200config PAGE_OFFSET
1201 hex
1202 default 0xB0000000 if VMSPLIT_3G_OPT
1203 default 0x80000000 if VMSPLIT_2G
1204 default 0x78000000 if VMSPLIT_2G_OPT
1205 default 0x40000000 if VMSPLIT_1G
1206 default 0xC0000000
1207 depends on X86_32
1208
1209config HIGHMEM
Harvey Harrison3c2362e2008-01-30 13:31:03 +01001210 def_bool y
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001211 depends on X86_32 && (HIGHMEM64G || HIGHMEM4G)
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001212
1213config X86_PAE
Jan Beulich9ba16082008-10-15 22:01:38 -07001214 bool "PAE (Physical Address Extension) Support"
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001215 depends on X86_32 && !HIGHMEM4G
Ingo Molnar8f9ca472009-02-05 16:21:53 +01001216 ---help---
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001217 PAE is required for NX support, and furthermore enables
1218 larger swapspace support for non-overcommit purposes. It
1219 has the cost of more pagetable lookup overhead, and also
1220 consumes more pagetable space per process.
1221
Jeremy Fitzhardinge600715d2008-09-11 01:31:45 -07001222config ARCH_PHYS_ADDR_T_64BIT
Jan Beulich3120e252012-09-10 12:41:45 +01001223 def_bool y
1224 depends on X86_64 || X86_PAE
Jeremy Fitzhardinge600715d2008-09-11 01:31:45 -07001225
FUJITA Tomonori66f2b062010-10-20 15:55:35 -07001226config ARCH_DMA_ADDR_T_64BIT
Jan Beulich3120e252012-09-10 12:41:45 +01001227 def_bool y
1228 depends on X86_64 || HIGHMEM64G
FUJITA Tomonori66f2b062010-10-20 15:55:35 -07001229
Nick Piggin9e899812008-10-22 12:33:16 +02001230config DIRECT_GBPAGES
David Rientjes6a108a12011-01-20 14:44:16 -08001231 bool "Enable 1GB pages for kernel pagetables" if EXPERT
Nick Piggin9e899812008-10-22 12:33:16 +02001232 default y
1233 depends on X86_64
Ingo Molnar8f9ca472009-02-05 16:21:53 +01001234 ---help---
Nick Piggin9e899812008-10-22 12:33:16 +02001235 Allow the kernel linear mapping to use 1GB pages on CPUs that
1236 support it. This can improve the kernel's performance a tiny bit by
1237 reducing TLB pressure. If in doubt, say "Y".
1238
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001239# Common NUMA Features
1240config NUMA
KOSAKI Motohirofd51b2d2008-11-05 02:27:19 +09001241 bool "Numa Memory Allocation and Scheduler Support"
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001242 depends on SMP
Kees Cook6ea30382012-10-02 11:16:47 -07001243 depends on X86_64 || (X86_32 && HIGHMEM64G && (X86_NUMAQ || X86_BIGSMP || X86_SUMMIT && ACPI))
Yinghai Lu0699eae2008-06-17 15:39:01 -07001244 default y if (X86_NUMAQ || X86_SUMMIT || X86_BIGSMP)
Ingo Molnar8f9ca472009-02-05 16:21:53 +01001245 ---help---
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001246 Enable NUMA (Non Uniform Memory Access) support.
KOSAKI Motohirofd51b2d2008-11-05 02:27:19 +09001247
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001248 The kernel will try to allocate memory used by a CPU on the
1249 local memory controller of the CPU and add some more
1250 NUMA awareness to the kernel.
1251
Ingo Molnarc280ea52008-11-08 13:29:45 +01001252 For 64-bit this is recommended if the system is Intel Core i7
KOSAKI Motohirofd51b2d2008-11-05 02:27:19 +09001253 (or later), AMD Opteron, or EM64T NUMA.
1254
1255 For 32-bit this is only needed on (rare) 32-bit-only platforms
1256 that support NUMA topologies, such as NUMAQ / Summit, or if you
1257 boot a 32-bit kernel on a 64-bit NUMA platform.
1258
1259 Otherwise, you should say N.
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001260
1261comment "NUMA (Summit) requires SMP, 64GB highmem support, ACPI"
1262 depends on X86_32 && X86_SUMMIT && (!HIGHMEM64G || !ACPI)
1263
Hans Rosenfeldeec1d4f2010-10-29 17:14:30 +02001264config AMD_NUMA
Harvey Harrison3c2362e2008-01-30 13:31:03 +01001265 def_bool y
1266 prompt "Old style AMD Opteron NUMA detection"
Tejun Heo5da0ef92011-07-11 10:34:32 +02001267 depends on X86_64 && NUMA && PCI
Ingo Molnar8f9ca472009-02-05 16:21:53 +01001268 ---help---
Hans Rosenfeldeec1d4f2010-10-29 17:14:30 +02001269 Enable AMD NUMA node topology detection. You should say Y here if
1270 you have a multi processor AMD system. This uses an old method to
1271 read the NUMA configuration directly from the builtin Northbridge
1272 of Opteron. It is recommended to use X86_64_ACPI_NUMA instead,
1273 which also takes priority if both are compiled in.
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001274
1275config X86_64_ACPI_NUMA
Harvey Harrison3c2362e2008-01-30 13:31:03 +01001276 def_bool y
1277 prompt "ACPI NUMA detection"
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001278 depends on X86_64 && NUMA && ACPI && PCI
1279 select ACPI_NUMA
Ingo Molnar8f9ca472009-02-05 16:21:53 +01001280 ---help---
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001281 Enable ACPI SRAT based node topology detection.
1282
Suresh Siddha6ec6e0d2008-03-25 10:14:35 -07001283# Some NUMA nodes have memory ranges that span
1284# other nodes. Even though a pfn is valid and
1285# between a node's start and end pfns, it may not
1286# reside on that node. See memmap_init_zone()
1287# for details.
1288config NODES_SPAN_OTHER_NODES
1289 def_bool y
1290 depends on X86_64_ACPI_NUMA
1291
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001292config NUMA_EMU
1293 bool "NUMA emulation"
Tejun Heo1b7e03e2011-05-02 17:24:48 +02001294 depends on NUMA
Ingo Molnar8f9ca472009-02-05 16:21:53 +01001295 ---help---
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001296 Enable NUMA emulation. A flat machine will be split
1297 into virtual nodes when booted with "numa=fake=N", where N is the
1298 number of nodes. This is only useful for debugging.
1299
1300config NODES_SHIFT
Linus Torvaldsd25e26b2008-08-25 14:15:38 -07001301 int "Maximum NUMA Nodes (as a power of 2)" if !MAXSMP
David Rientjes51591e32010-03-25 15:39:27 -07001302 range 1 10
1303 default "10" if MAXSMP
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001304 default "6" if X86_64
1305 default "4" if X86_NUMAQ
1306 default "3"
1307 depends on NEED_MULTIPLE_NODES
Ingo Molnar8f9ca472009-02-05 16:21:53 +01001308 ---help---
Mike Travis1184dc22008-05-12 21:21:12 +02001309 Specify the maximum number of NUMA Nodes available on the target
Matt LaPlante692105b2009-01-26 11:12:25 +01001310 system. Increases memory reserved to accommodate various tables.
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001311
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001312config ARCH_HAVE_MEMORY_PRESENT
Harvey Harrison3c2362e2008-01-30 13:31:03 +01001313 def_bool y
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001314 depends on X86_32 && DISCONTIGMEM
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001315
1316config NEED_NODE_MEMMAP_SIZE
Harvey Harrison3c2362e2008-01-30 13:31:03 +01001317 def_bool y
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001318 depends on X86_32 && (DISCONTIGMEM || SPARSEMEM)
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001319
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001320config ARCH_FLATMEM_ENABLE
1321 def_bool y
Tejun Heo3b166512011-04-01 11:15:12 +02001322 depends on X86_32 && !NUMA
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001323
1324config ARCH_DISCONTIGMEM_ENABLE
1325 def_bool y
Christoph Lameterb2632952008-01-30 13:30:47 +01001326 depends on NUMA && X86_32
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001327
1328config ARCH_DISCONTIGMEM_DEFAULT
1329 def_bool y
Christoph Lameterb2632952008-01-30 13:30:47 +01001330 depends on NUMA && X86_32
1331
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001332config ARCH_SPARSEMEM_ENABLE
1333 def_bool y
Kees Cook6ea30382012-10-02 11:16:47 -07001334 depends on X86_64 || NUMA || X86_32 || X86_32_NON_STANDARD
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001335 select SPARSEMEM_STATIC if X86_32
1336 select SPARSEMEM_VMEMMAP_ENABLE if X86_64
1337
Tejun Heo3b166512011-04-01 11:15:12 +02001338config ARCH_SPARSEMEM_DEFAULT
1339 def_bool y
1340 depends on X86_64
1341
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001342config ARCH_SELECT_MEMORY_MODEL
1343 def_bool y
Christoph Lameterb2632952008-01-30 13:30:47 +01001344 depends on ARCH_SPARSEMEM_ENABLE
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001345
1346config ARCH_MEMORY_PROBE
Toshi Kania0842b72013-07-19 11:47:48 -06001347 bool "Enable sysfs memory/probe interface"
Jan Beulich3120e252012-09-10 12:41:45 +01001348 depends on X86_64 && MEMORY_HOTPLUG
Toshi Kania0842b72013-07-19 11:47:48 -06001349 help
1350 This option enables a sysfs memory/probe interface for testing.
1351 See Documentation/memory-hotplug.txt for more information.
1352 If you are unsure how to answer this question, answer N.
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001353
Tejun Heo3b166512011-04-01 11:15:12 +02001354config ARCH_PROC_KCORE_TEXT
1355 def_bool y
1356 depends on X86_64 && PROC_KCORE
1357
Avi Kivitya29815a2010-01-10 16:28:09 +02001358config ILLEGAL_POINTER_VALUE
1359 hex
1360 default 0 if X86_32
1361 default 0xdead000000000000 if X86_64
1362
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001363source "mm/Kconfig"
1364
1365config HIGHPTE
1366 bool "Allocate 3rd-level pagetables from highmem"
Jan Beulich6fc108a2010-04-21 15:23:44 +01001367 depends on HIGHMEM
Ingo Molnar8f9ca472009-02-05 16:21:53 +01001368 ---help---
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001369 The VM uses one page table entry for each page of physical memory.
1370 For systems with a lot of RAM, this can be wasteful of precious
1371 low memory. Setting this option will put user-space page table
1372 entries in high memory.
1373
Jeremy Fitzhardinge9f077872008-09-07 01:51:34 -07001374config X86_CHECK_BIOS_CORRUPTION
Ingo Molnar8f9ca472009-02-05 16:21:53 +01001375 bool "Check for low memory corruption"
1376 ---help---
1377 Periodically check for memory corruption in low memory, which
1378 is suspected to be caused by BIOS. Even when enabled in the
1379 configuration, it is disabled at runtime. Enable it by
1380 setting "memory_corruption_check=1" on the kernel command
1381 line. By default it scans the low 64k of memory every 60
1382 seconds; see the memory_corruption_check_size and
1383 memory_corruption_check_period parameters in
1384 Documentation/kernel-parameters.txt to adjust this.
Jeremy Fitzhardinge9f077872008-09-07 01:51:34 -07001385
Ingo Molnar8f9ca472009-02-05 16:21:53 +01001386 When enabled with the default parameters, this option has
1387 almost no overhead, as it reserves a relatively small amount
1388 of memory and scans it infrequently. It both detects corruption
1389 and prevents it from affecting the running system.
Jeremy Fitzhardinge9f077872008-09-07 01:51:34 -07001390
Ingo Molnar8f9ca472009-02-05 16:21:53 +01001391 It is, however, intended as a diagnostic tool; if repeatable
1392 BIOS-originated corruption always affects the same memory,
1393 you can use memmap= to prevent the kernel from using that
1394 memory.
Jeremy Fitzhardinge9f077872008-09-07 01:51:34 -07001395
Jeremy Fitzhardingec885df52008-09-07 02:37:32 -07001396config X86_BOOTPARAM_MEMORY_CORRUPTION_CHECK
Ingo Molnar8f9ca472009-02-05 16:21:53 +01001397 bool "Set the default setting of memory_corruption_check"
Jeremy Fitzhardingec885df52008-09-07 02:37:32 -07001398 depends on X86_CHECK_BIOS_CORRUPTION
1399 default y
Ingo Molnar8f9ca472009-02-05 16:21:53 +01001400 ---help---
1401 Set whether the default state of memory_corruption_check is
1402 on or off.
Jeremy Fitzhardingec885df52008-09-07 02:37:32 -07001403
H. Peter Anvin9ea77bd2010-08-25 16:38:20 -07001404config X86_RESERVE_LOW
H. Peter Anvind0cd7422010-08-24 17:32:04 -07001405 int "Amount of low memory, in kilobytes, to reserve for the BIOS"
1406 default 64
1407 range 4 640
Ingo Molnar8f9ca472009-02-05 16:21:53 +01001408 ---help---
H. Peter Anvind0cd7422010-08-24 17:32:04 -07001409 Specify the amount of low memory to reserve for the BIOS.
Ingo Molnarfc381512008-09-16 10:07:34 +02001410
H. Peter Anvind0cd7422010-08-24 17:32:04 -07001411 The first page contains BIOS data structures that the kernel
1412 must not use, so that page must always be reserved.
Ingo Molnarfc381512008-09-16 10:07:34 +02001413
H. Peter Anvind0cd7422010-08-24 17:32:04 -07001414 By default we reserve the first 64K of physical RAM, as a
1415 number of BIOSes are known to corrupt that memory range
1416 during events such as suspend/resume or monitor cable
1417 insertion, so it must not be used by the kernel.
Ingo Molnarfc381512008-09-16 10:07:34 +02001418
H. Peter Anvind0cd7422010-08-24 17:32:04 -07001419 You can set this to 4 if you are absolutely sure that you
1420 trust the BIOS to get all its memory reservations and usages
1421 right. If you know your BIOS have problems beyond the
1422 default 64K area, you can set this to 640 to avoid using the
1423 entire low memory range.
1424
1425 If you have doubts about the BIOS (e.g. suspend/resume does
1426 not work or there's kernel crashes after certain hardware
1427 hotplug events) then you might want to enable
1428 X86_CHECK_BIOS_CORRUPTION=y to allow the kernel to check
1429 typical corruption patterns.
1430
1431 Leave this to the default value of 64 if you are unsure.
Ingo Molnarfc381512008-09-16 10:07:34 +02001432
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001433config MATH_EMULATION
1434 bool
1435 prompt "Math emulation" if X86_32
1436 ---help---
1437 Linux can emulate a math coprocessor (used for floating point
1438 operations) if you don't have one. 486DX and Pentium processors have
1439 a math coprocessor built in, 486SX and 386 do not, unless you added
1440 a 487DX or 387, respectively. (The messages during boot time can
1441 give you some hints here ["man dmesg"].) Everyone needs either a
1442 coprocessor or this emulation.
1443
1444 If you don't have a math coprocessor, you need to say Y here; if you
1445 say Y here even though you have a coprocessor, the coprocessor will
1446 be used nevertheless. (This behavior can be changed with the kernel
1447 command line option "no387", which comes handy if your coprocessor
1448 is broken. Try "man bootparam" or see the documentation of your boot
1449 loader (lilo or loadlin) about how to pass options to the kernel at
1450 boot time.) This means that it is a good idea to say Y here if you
1451 intend to use this kernel on different machines.
1452
1453 More information about the internals of the Linux math coprocessor
1454 emulation can be found in <file:arch/x86/math-emu/README>.
1455
1456 If you are not sure, say Y; apart from resulting in a 66 KB bigger
1457 kernel, it won't hurt.
1458
1459config MTRR
Jan Beulich6fc108a2010-04-21 15:23:44 +01001460 def_bool y
David Rientjes6a108a12011-01-20 14:44:16 -08001461 prompt "MTRR (Memory Type Range Register) support" if EXPERT
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001462 ---help---
1463 On Intel P6 family processors (Pentium Pro, Pentium II and later)
1464 the Memory Type Range Registers (MTRRs) may be used to control
1465 processor access to memory ranges. This is most useful if you have
1466 a video (VGA) card on a PCI or AGP bus. Enabling write-combining
1467 allows bus write transfers to be combined into a larger transfer
1468 before bursting over the PCI/AGP bus. This can increase performance
1469 of image write operations 2.5 times or more. Saying Y here creates a
1470 /proc/mtrr file which may be used to manipulate your processor's
1471 MTRRs. Typically the X server should use this.
1472
1473 This code has a reasonably generic interface so that similar
1474 control registers on other processors can be easily supported
1475 as well:
1476
1477 The Cyrix 6x86, 6x86MX and M II processors have Address Range
1478 Registers (ARRs) which provide a similar functionality to MTRRs. For
1479 these, the ARRs are used to emulate the MTRRs.
1480 The AMD K6-2 (stepping 8 and above) and K6-3 processors have two
1481 MTRRs. The Centaur C6 (WinChip) has 8 MCRs, allowing
1482 write-combining. All of these processors are supported by this code
1483 and it makes sense to say Y here if you have one of them.
1484
1485 Saying Y here also fixes a problem with buggy SMP BIOSes which only
1486 set the MTRRs for the boot CPU and not for the secondary CPUs. This
1487 can lead to all sorts of problems, so it's good to say Y here.
1488
1489 You can safely say Y even if your machine doesn't have MTRRs, you'll
1490 just add about 9 KB to your kernel.
1491
Randy Dunlap7225e752008-07-26 17:54:22 -07001492 See <file:Documentation/x86/mtrr.txt> for more information.
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001493
Yinghai Lu95ffa242008-04-29 03:52:33 -07001494config MTRR_SANITIZER
Yinghai Lu2ffb3502008-09-30 16:29:40 -07001495 def_bool y
Yinghai Lu95ffa242008-04-29 03:52:33 -07001496 prompt "MTRR cleanup support"
1497 depends on MTRR
Ingo Molnar8f9ca472009-02-05 16:21:53 +01001498 ---help---
Thomas Gleixneraba37282008-07-15 14:48:48 +02001499 Convert MTRR layout from continuous to discrete, so X drivers can
1500 add writeback entries.
Yinghai Lu95ffa242008-04-29 03:52:33 -07001501
Thomas Gleixneraba37282008-07-15 14:48:48 +02001502 Can be disabled with disable_mtrr_cleanup on the kernel command line.
Matt LaPlante692105b2009-01-26 11:12:25 +01001503 The largest mtrr entry size for a continuous block can be set with
Thomas Gleixneraba37282008-07-15 14:48:48 +02001504 mtrr_chunk_size.
Yinghai Lu95ffa242008-04-29 03:52:33 -07001505
Yinghai Lu2ffb3502008-09-30 16:29:40 -07001506 If unsure, say Y.
Yinghai Lu95ffa242008-04-29 03:52:33 -07001507
1508config MTRR_SANITIZER_ENABLE_DEFAULT
Yinghai Luf5098d62008-04-29 20:25:58 -07001509 int "MTRR cleanup enable value (0-1)"
1510 range 0 1
1511 default "0"
Yinghai Lu95ffa242008-04-29 03:52:33 -07001512 depends on MTRR_SANITIZER
Ingo Molnar8f9ca472009-02-05 16:21:53 +01001513 ---help---
Yinghai Luf5098d62008-04-29 20:25:58 -07001514 Enable mtrr cleanup default value
Yinghai Lu95ffa242008-04-29 03:52:33 -07001515
Yinghai Lu12031a62008-05-02 02:40:22 -07001516config MTRR_SANITIZER_SPARE_REG_NR_DEFAULT
1517 int "MTRR cleanup spare reg num (0-7)"
1518 range 0 7
1519 default "1"
1520 depends on MTRR_SANITIZER
Ingo Molnar8f9ca472009-02-05 16:21:53 +01001521 ---help---
Yinghai Lu12031a62008-05-02 02:40:22 -07001522 mtrr cleanup spare entries default, it can be changed via
Thomas Gleixneraba37282008-07-15 14:48:48 +02001523 mtrr_spare_reg_nr=N on the kernel command line.
Yinghai Lu12031a62008-05-02 02:40:22 -07001524
venkatesh.pallipadi@intel.com2e5d9c82008-03-18 17:00:14 -07001525config X86_PAT
Jan Beulich6fc108a2010-04-21 15:23:44 +01001526 def_bool y
David Rientjes6a108a12011-01-20 14:44:16 -08001527 prompt "x86 PAT support" if EXPERT
Ingo Molnar2a8a2712008-04-26 10:26:52 +02001528 depends on MTRR
Ingo Molnar8f9ca472009-02-05 16:21:53 +01001529 ---help---
venkatesh.pallipadi@intel.com2e5d9c82008-03-18 17:00:14 -07001530 Use PAT attributes to setup page level cache control.
Venki Pallipadi042b78e2008-03-24 14:22:35 -07001531
venkatesh.pallipadi@intel.com2e5d9c82008-03-18 17:00:14 -07001532 PATs are the modern equivalents of MTRRs and are much more
1533 flexible than MTRRs.
1534
1535 Say N here if you see bootup problems (boot crash, boot hang,
Venki Pallipadi042b78e2008-03-24 14:22:35 -07001536 spontaneous reboots) or a non-working video driver.
venkatesh.pallipadi@intel.com2e5d9c82008-03-18 17:00:14 -07001537
1538 If unsure, say Y.
1539
Venkatesh Pallipadi46cf98c2009-07-10 09:57:37 -07001540config ARCH_USES_PG_UNCACHED
1541 def_bool y
1542 depends on X86_PAT
1543
H. Peter Anvin628c6242011-07-31 13:59:29 -07001544config ARCH_RANDOM
1545 def_bool y
1546 prompt "x86 architectural random number generator" if EXPERT
1547 ---help---
1548 Enable the x86 architectural RDRAND instruction
1549 (Intel Bull Mountain technology) to generate random numbers.
1550 If supported, this is a high bandwidth, cryptographically
1551 secure hardware random number generator.
1552
H. Peter Anvin51ae4a22012-09-21 12:43:10 -07001553config X86_SMAP
1554 def_bool y
1555 prompt "Supervisor Mode Access Prevention" if EXPERT
1556 ---help---
1557 Supervisor Mode Access Prevention (SMAP) is a security
1558 feature in newer Intel processors. There is a small
1559 performance cost if this enabled and turned on; there is
1560 also a small increase in the kernel size if this is enabled.
1561
1562 If unsure, say Y.
1563
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001564config EFI
Jan Beulich9ba16082008-10-15 22:01:38 -07001565 bool "EFI runtime service support"
Huang, Ying5b836832008-01-30 13:31:19 +01001566 depends on ACPI
Sergey Vlasovf6ce5002013-04-16 18:31:08 +04001567 select UCS2_STRING
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001568 ---help---
Ingo Molnar8f9ca472009-02-05 16:21:53 +01001569 This enables the kernel to use EFI runtime services that are
1570 available (such as the EFI variable services).
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001571
Ingo Molnar8f9ca472009-02-05 16:21:53 +01001572 This option is only useful on systems that have EFI firmware.
1573 In addition, you should use the latest ELILO loader available
1574 at <http://elilo.sourceforge.net> in order to take advantage
1575 of EFI runtime services. However, even with this option, the
1576 resultant kernel should continue to boot on existing non-EFI
1577 platforms.
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001578
Matt Fleming291f3632011-12-12 21:27:52 +00001579config EFI_STUB
1580 bool "EFI stub support"
1581 depends on EFI
1582 ---help---
1583 This kernel feature allows a bzImage to be loaded directly
1584 by EFI firmware without the use of a bootloader.
1585
Roy Franz4172fe22013-09-22 15:45:25 -07001586 See Documentation/efi-stub.txt for more information.
Matt Fleming0c759662012-03-16 12:03:13 +00001587
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001588config SECCOMP
Harvey Harrison3c2362e2008-01-30 13:31:03 +01001589 def_bool y
1590 prompt "Enable seccomp to safely compute untrusted bytecode"
Ingo Molnar8f9ca472009-02-05 16:21:53 +01001591 ---help---
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001592 This kernel feature is useful for number crunching applications
1593 that may need to compute untrusted bytecode during their
1594 execution. By using pipes or other transports made available to
1595 the process as file descriptors supporting the read/write
1596 syscalls, it's possible to isolate those applications in
1597 their own address space using seccomp. Once seccomp is
Alexey Dobriyan9c0bbee2008-09-09 11:01:31 +04001598 enabled via prctl(PR_SET_SECCOMP), it cannot be disabled
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001599 and the task is only allowed to execute a few safe syscalls
1600 defined by each seccomp mode.
1601
1602 If unsure, say Y. Only embedded should say N here.
1603
1604config CC_STACKPROTECTOR
Jean Delvare2a8ac742012-07-06 16:08:25 +02001605 bool "Enable -fstack-protector buffer overflow detection"
Ingo Molnar8f9ca472009-02-05 16:21:53 +01001606 ---help---
1607 This option turns on the -fstack-protector GCC feature. This
Ingo Molnar113c5412008-02-14 10:36:03 +01001608 feature puts, at the beginning of functions, a canary value on
1609 the stack just before the return address, and validates
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001610 the value just before actually returning. Stack based buffer
1611 overflows (that need to overwrite this return address) now also
1612 overwrite the canary, which gets detected and the attack is then
1613 neutralized via a kernel panic.
1614
1615 This feature requires gcc version 4.2 or above, or a distribution
1616 gcc with the feature backported. Older versions are automatically
Ingo Molnar113c5412008-02-14 10:36:03 +01001617 detected and for those versions, this configuration option is
1618 ignored. (and a warning is printed during bootup)
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001619
1620source kernel/Kconfig.hz
1621
1622config KEXEC
1623 bool "kexec system call"
Ingo Molnar8f9ca472009-02-05 16:21:53 +01001624 ---help---
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001625 kexec is a system call that implements the ability to shutdown your
1626 current kernel, and to start another kernel. It is like a reboot
1627 but it is independent of the system firmware. And like a reboot
1628 you can start any kernel with it, not just Linux.
1629
1630 The name comes from the similarity to the exec system call.
1631
1632 It is an ongoing process to be certain the hardware in a machine
1633 is properly shutdown, so do not be surprised if this code does not
Geert Uytterhoevenbf220692013-08-20 21:38:03 +02001634 initially work for you. As of this writing the exact hardware
1635 interface is strongly in flux, so no good recommendation can be
1636 made.
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001637
1638config CRASH_DUMP
Pavel Machek04b69442008-08-14 17:16:50 +02001639 bool "kernel crash dumps"
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001640 depends on X86_64 || (X86_32 && HIGHMEM)
Ingo Molnar8f9ca472009-02-05 16:21:53 +01001641 ---help---
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001642 Generate crash dump after being started by kexec.
1643 This should be normally only set in special crash dump kernels
1644 which are loaded in the main kernel with kexec-tools into
1645 a specially reserved region and then later executed after
1646 a crash by kdump/kexec. The crash dump kernel must be compiled
1647 to a memory address not used by the main kernel or BIOS using
1648 PHYSICAL_START, or it must be built as a relocatable image
1649 (CONFIG_RELOCATABLE=y).
1650 For more details see Documentation/kdump/kdump.txt
1651
Huang Ying3ab83522008-07-25 19:45:07 -07001652config KEXEC_JUMP
Kees Cook6ea30382012-10-02 11:16:47 -07001653 bool "kexec jump"
Huang Yingfee7b0d2009-03-10 10:57:16 +08001654 depends on KEXEC && HIBERNATION
Ingo Molnar8f9ca472009-02-05 16:21:53 +01001655 ---help---
Huang Ying89081d12008-07-25 19:45:10 -07001656 Jump between original kernel and kexeced kernel and invoke
1657 code in physical address mode via KEXEC
Huang Ying3ab83522008-07-25 19:45:07 -07001658
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001659config PHYSICAL_START
David Rientjes6a108a12011-01-20 14:44:16 -08001660 hex "Physical address where the kernel is loaded" if (EXPERT || CRASH_DUMP)
H. Peter Anvinceefccc2009-05-11 16:12:16 -07001661 default "0x1000000"
Ingo Molnar8f9ca472009-02-05 16:21:53 +01001662 ---help---
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001663 This gives the physical address where the kernel is loaded.
1664
1665 If kernel is a not relocatable (CONFIG_RELOCATABLE=n) then
1666 bzImage will decompress itself to above physical address and
1667 run from there. Otherwise, bzImage will run from the address where
1668 it has been loaded by the boot loader and will ignore above physical
1669 address.
1670
1671 In normal kdump cases one does not have to set/change this option
1672 as now bzImage can be compiled as a completely relocatable image
1673 (CONFIG_RELOCATABLE=y) and be used to load and run from a different
1674 address. This option is mainly useful for the folks who don't want
1675 to use a bzImage for capturing the crash dump and want to use a
1676 vmlinux instead. vmlinux is not relocatable hence a kernel needs
1677 to be specifically compiled to run from a specific memory area
1678 (normally a reserved region) and this option comes handy.
1679
H. Peter Anvinceefccc2009-05-11 16:12:16 -07001680 So if you are using bzImage for capturing the crash dump,
1681 leave the value here unchanged to 0x1000000 and set
1682 CONFIG_RELOCATABLE=y. Otherwise if you plan to use vmlinux
1683 for capturing the crash dump change this value to start of
1684 the reserved region. In other words, it can be set based on
1685 the "X" value as specified in the "crashkernel=YM@XM"
1686 command line boot parameter passed to the panic-ed
1687 kernel. Please take a look at Documentation/kdump/kdump.txt
1688 for more details about crash dumps.
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001689
1690 Usage of bzImage for capturing the crash dump is recommended as
1691 one does not have to build two kernels. Same kernel can be used
1692 as production kernel and capture kernel. Above option should have
1693 gone away after relocatable bzImage support is introduced. But it
1694 is present because there are users out there who continue to use
1695 vmlinux for dump capture. This option should go away down the
1696 line.
1697
1698 Don't change this unless you know what you are doing.
1699
1700config RELOCATABLE
H. Peter Anvin26717802009-05-07 14:19:34 -07001701 bool "Build a relocatable kernel"
1702 default y
Ingo Molnar8f9ca472009-02-05 16:21:53 +01001703 ---help---
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001704 This builds a kernel image that retains relocation information
1705 so it can be loaded someplace besides the default 1MB.
1706 The relocations tend to make the kernel binary about 10% larger,
1707 but are discarded at runtime.
1708
1709 One use is for the kexec on panic case where the recovery kernel
1710 must live at a different physical address than the primary
1711 kernel.
1712
1713 Note: If CONFIG_RELOCATABLE=y, then the kernel runs from the address
1714 it has been loaded at and the compile time physical address
1715 (CONFIG_PHYSICAL_START) is ignored.
1716
H. Peter Anvin845adf72009-05-05 21:20:51 -07001717# Relocation on x86-32 needs some additional build support
1718config X86_NEED_RELOCS
1719 def_bool y
1720 depends on X86_32 && RELOCATABLE
1721
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001722config PHYSICAL_ALIGN
Kees Cooka0215062013-07-08 09:15:17 -07001723 hex "Alignment value to which kernel should be aligned"
H. Peter Anvinceefccc2009-05-11 16:12:16 -07001724 default "0x1000000"
Kees Cooka0215062013-07-08 09:15:17 -07001725 range 0x2000 0x1000000 if X86_32
1726 range 0x200000 0x1000000 if X86_64
Ingo Molnar8f9ca472009-02-05 16:21:53 +01001727 ---help---
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001728 This value puts the alignment restrictions on physical address
1729 where kernel is loaded and run from. Kernel is compiled for an
1730 address which meets above alignment restriction.
1731
1732 If bootloader loads the kernel at a non-aligned address and
1733 CONFIG_RELOCATABLE is set, kernel will move itself to nearest
1734 address aligned to above value and run from there.
1735
1736 If bootloader loads the kernel at a non-aligned address and
1737 CONFIG_RELOCATABLE is not set, kernel will ignore the run time
1738 load address and decompress itself to the address it has been
1739 compiled for and run from there. The address for which kernel is
1740 compiled already meets above alignment restrictions. Hence the
1741 end result is that kernel runs from a physical address meeting
1742 above alignment restrictions.
1743
Kees Cooka0215062013-07-08 09:15:17 -07001744 On 32-bit this value must be a multiple of 0x2000. On 64-bit
1745 this value must be a multiple of 0x200000.
1746
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001747 Don't change this unless you know what you are doing.
1748
1749config HOTPLUG_CPU
Dimitri Sivanich7c13e6a2008-08-11 10:46:46 -05001750 bool "Support for hot-pluggable CPUs"
Stephen Rothwell40b31362013-05-21 13:49:35 +10001751 depends on SMP
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001752 ---help---
Dimitri Sivanich7c13e6a2008-08-11 10:46:46 -05001753 Say Y here to allow turning CPUs off and on. CPUs can be
1754 controlled through /sys/devices/system/cpu.
1755 ( Note: power management support will enable this option
1756 automatically on SMP systems. )
1757 Say N if you want to disable CPU hotplug.
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001758
Fenghua Yu80aa1df2012-11-13 11:32:39 -08001759config BOOTPARAM_HOTPLUG_CPU0
1760 bool "Set default setting of cpu0_hotpluggable"
1761 default n
Kees Cook2c922cd2013-01-22 13:01:19 -08001762 depends on HOTPLUG_CPU
Fenghua Yu80aa1df2012-11-13 11:32:39 -08001763 ---help---
1764 Set whether default state of cpu0_hotpluggable is on or off.
1765
1766 Say Y here to enable CPU0 hotplug by default. If this switch
1767 is turned on, there is no need to give cpu0_hotplug kernel
1768 parameter and the CPU0 hotplug feature is enabled by default.
1769
1770 Please note: there are two known CPU0 dependencies if you want
1771 to enable the CPU0 hotplug feature either by this switch or by
1772 cpu0_hotplug kernel parameter.
1773
1774 First, resume from hibernate or suspend always starts from CPU0.
1775 So hibernate and suspend are prevented if CPU0 is offline.
1776
1777 Second dependency is PIC interrupts always go to CPU0. CPU0 can not
1778 offline if any interrupt can not migrate out of CPU0. There may
1779 be other CPU0 dependencies.
1780
1781 Please make sure the dependencies are under your control before
1782 you enable this feature.
1783
1784 Say N if you don't want to enable CPU0 hotplug feature by default.
1785 You still can enable the CPU0 hotplug feature at boot by kernel
1786 parameter cpu0_hotplug.
1787
Fenghua Yua71c8bc2012-11-13 11:32:51 -08001788config DEBUG_HOTPLUG_CPU0
1789 def_bool n
1790 prompt "Debug CPU0 hotplug"
Kees Cook2c922cd2013-01-22 13:01:19 -08001791 depends on HOTPLUG_CPU
Fenghua Yua71c8bc2012-11-13 11:32:51 -08001792 ---help---
1793 Enabling this option offlines CPU0 (if CPU0 can be offlined) as
1794 soon as possible and boots up userspace with CPU0 offlined. User
1795 can online CPU0 back after boot time.
1796
1797 To debug CPU0 hotplug, you need to enable CPU0 offline/online
1798 feature by either turning on CONFIG_BOOTPARAM_HOTPLUG_CPU0 during
1799 compilation or giving cpu0_hotplug kernel parameter at boot.
1800
1801 If unsure, say N.
1802
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001803config COMPAT_VDSO
Harvey Harrison3c2362e2008-01-30 13:31:03 +01001804 def_bool y
1805 prompt "Compat VDSO support"
Roland McGrathaf65d642008-01-30 13:30:43 +01001806 depends on X86_32 || IA32_EMULATION
Ingo Molnar8f9ca472009-02-05 16:21:53 +01001807 ---help---
Roland McGrathaf65d642008-01-30 13:30:43 +01001808 Map the 32-bit VDSO to the predictable old-style address too.
Randy Dunlape84446d2009-11-10 15:46:52 -08001809
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001810 Say N here if you are running a sufficiently recent glibc
1811 version (2.3.3 or later), to remove the high-mapped
1812 VDSO mapping and to exclusively use the randomized VDSO.
1813
1814 If unsure, say Y.
1815
Tim Bird516cbf32008-08-12 12:52:36 -07001816config CMDLINE_BOOL
1817 bool "Built-in kernel command line"
Ingo Molnar8f9ca472009-02-05 16:21:53 +01001818 ---help---
Tim Bird516cbf32008-08-12 12:52:36 -07001819 Allow for specifying boot arguments to the kernel at
1820 build time. On some systems (e.g. embedded ones), it is
1821 necessary or convenient to provide some or all of the
1822 kernel boot arguments with the kernel itself (that is,
1823 to not rely on the boot loader to provide them.)
1824
1825 To compile command line arguments into the kernel,
1826 set this option to 'Y', then fill in the
1827 the boot arguments in CONFIG_CMDLINE.
1828
1829 Systems with fully functional boot loaders (i.e. non-embedded)
1830 should leave this option set to 'N'.
1831
1832config CMDLINE
1833 string "Built-in kernel command string"
1834 depends on CMDLINE_BOOL
1835 default ""
Ingo Molnar8f9ca472009-02-05 16:21:53 +01001836 ---help---
Tim Bird516cbf32008-08-12 12:52:36 -07001837 Enter arguments here that should be compiled into the kernel
1838 image and used at boot time. If the boot loader provides a
1839 command line at boot time, it is appended to this string to
1840 form the full kernel command line, when the system boots.
1841
1842 However, you can use the CONFIG_CMDLINE_OVERRIDE option to
1843 change this behavior.
1844
1845 In most cases, the command line (whether built-in or provided
1846 by the boot loader) should specify the device for the root
1847 file system.
1848
1849config CMDLINE_OVERRIDE
1850 bool "Built-in command line overrides boot loader arguments"
Tim Bird516cbf32008-08-12 12:52:36 -07001851 depends on CMDLINE_BOOL
Ingo Molnar8f9ca472009-02-05 16:21:53 +01001852 ---help---
Tim Bird516cbf32008-08-12 12:52:36 -07001853 Set this option to 'Y' to have the kernel ignore the boot loader
1854 command line, and use ONLY the built-in command line.
1855
1856 This is used to work around broken boot loaders. This should
1857 be set to 'N' under normal conditions.
1858
Sam Ravnborg506f1d02007-11-09 21:56:54 +01001859endmenu
1860
1861config ARCH_ENABLE_MEMORY_HOTPLUG
1862 def_bool y
1863 depends on X86_64 || (X86_32 && HIGHMEM)
1864
Gary Hade35551052008-10-31 10:52:03 -07001865config ARCH_ENABLE_MEMORY_HOTREMOVE
1866 def_bool y
1867 depends on MEMORY_HOTPLUG
1868
Lee Schermerhorne534c7c2010-05-26 14:44:58 -07001869config USE_PERCPU_NUMA_NODE_ID
Tejun Heo645a7912011-01-23 14:37:40 +01001870 def_bool y
Lee Schermerhorne534c7c2010-05-26 14:44:58 -07001871 depends on NUMA
1872
Kirill A. Shutemov94918462013-11-14 14:31:10 -08001873config ARCH_ENABLE_SPLIT_PMD_PTLOCK
1874 def_bool y
1875 depends on X86_64 || X86_PAE
1876
Bjorn Helgaasda85f862008-11-05 13:37:27 -06001877menu "Power management and ACPI options"
Sam Ravnborge279b6c2007-11-06 20:41:05 +01001878
1879config ARCH_HIBERNATION_HEADER
Harvey Harrison3c2362e2008-01-30 13:31:03 +01001880 def_bool y
Sam Ravnborge279b6c2007-11-06 20:41:05 +01001881 depends on X86_64 && HIBERNATION
Sam Ravnborge279b6c2007-11-06 20:41:05 +01001882
1883source "kernel/power/Kconfig"
1884
1885source "drivers/acpi/Kconfig"
1886
Feng Tangefafc8b2009-08-14 15:23:29 -04001887source "drivers/sfi/Kconfig"
1888
Andi Kleena6b68072008-01-30 13:32:49 +01001889config X86_APM_BOOT
Jan Beulich6fc108a2010-04-21 15:23:44 +01001890 def_bool y
Paul Bolle282e5aa2011-11-17 11:41:31 +01001891 depends on APM
Andi Kleena6b68072008-01-30 13:32:49 +01001892
Sam Ravnborge279b6c2007-11-06 20:41:05 +01001893menuconfig APM
1894 tristate "APM (Advanced Power Management) BIOS support"
Ingo Molnarefefa6f2008-07-10 16:09:50 +02001895 depends on X86_32 && PM_SLEEP
Sam Ravnborge279b6c2007-11-06 20:41:05 +01001896 ---help---
1897 APM is a BIOS specification for saving power using several different
1898 techniques. This is mostly useful for battery powered laptops with
1899 APM compliant BIOSes. If you say Y here, the system time will be
1900 reset after a RESUME operation, the /proc/apm device will provide
1901 battery status information, and user-space programs will receive
1902 notification of APM "events" (e.g. battery status change).
1903
1904 If you select "Y" here, you can disable actual use of the APM
1905 BIOS by passing the "apm=off" option to the kernel at boot time.
1906
1907 Note that the APM support is almost completely disabled for
1908 machines with more than one CPU.
1909
1910 In order to use APM, you will need supporting software. For location
Michael Witten2dc98fd2011-07-08 21:11:16 +00001911 and more information, read <file:Documentation/power/apm-acpi.txt>
1912 and the Battery Powered Linux mini-HOWTO, available from
Sam Ravnborge279b6c2007-11-06 20:41:05 +01001913 <http://www.tldp.org/docs.html#howto>.
1914
1915 This driver does not spin down disk drives (see the hdparm(8)
1916 manpage ("man 8 hdparm") for that), and it doesn't turn off
1917 VESA-compliant "green" monitors.
1918
1919 This driver does not support the TI 4000M TravelMate and the ACER
1920 486/DX4/75 because they don't have compliant BIOSes. Many "green"
1921 desktop machines also don't have compliant BIOSes, and this driver
1922 may cause those machines to panic during the boot phase.
1923
1924 Generally, if you don't have a battery in your machine, there isn't
1925 much point in using this driver and you should say N. If you get
1926 random kernel OOPSes or reboots that don't seem to be related to
1927 anything, try disabling/enabling this option (or disabling/enabling
1928 APM in your BIOS).
1929
1930 Some other things you should try when experiencing seemingly random,
1931 "weird" problems:
1932
1933 1) make sure that you have enough swap space and that it is
1934 enabled.
1935 2) pass the "no-hlt" option to the kernel
1936 3) switch on floating point emulation in the kernel and pass
1937 the "no387" option to the kernel
1938 4) pass the "floppy=nodma" option to the kernel
1939 5) pass the "mem=4M" option to the kernel (thereby disabling
1940 all but the first 4 MB of RAM)
1941 6) make sure that the CPU is not over clocked.
1942 7) read the sig11 FAQ at <http://www.bitwizard.nl/sig11/>
1943 8) disable the cache from your BIOS settings
1944 9) install a fan for the video card or exchange video RAM
1945 10) install a better fan for the CPU
1946 11) exchange RAM chips
1947 12) exchange the motherboard.
1948
1949 To compile this driver as a module, choose M here: the
1950 module will be called apm.
1951
1952if APM
1953
1954config APM_IGNORE_USER_SUSPEND
1955 bool "Ignore USER SUSPEND"
Ingo Molnar8f9ca472009-02-05 16:21:53 +01001956 ---help---
Sam Ravnborge279b6c2007-11-06 20:41:05 +01001957 This option will ignore USER SUSPEND requests. On machines with a
1958 compliant APM BIOS, you want to say N. However, on the NEC Versa M
1959 series notebooks, it is necessary to say Y because of a BIOS bug.
1960
1961config APM_DO_ENABLE
1962 bool "Enable PM at boot time"
1963 ---help---
1964 Enable APM features at boot time. From page 36 of the APM BIOS
1965 specification: "When disabled, the APM BIOS does not automatically
1966 power manage devices, enter the Standby State, enter the Suspend
1967 State, or take power saving steps in response to CPU Idle calls."
1968 This driver will make CPU Idle calls when Linux is idle (unless this
1969 feature is turned off -- see "Do CPU IDLE calls", below). This
1970 should always save battery power, but more complicated APM features
1971 will be dependent on your BIOS implementation. You may need to turn
1972 this option off if your computer hangs at boot time when using APM
1973 support, or if it beeps continuously instead of suspending. Turn
1974 this off if you have a NEC UltraLite Versa 33/C or a Toshiba
1975 T400CDT. This is off by default since most machines do fine without
1976 this feature.
1977
1978config APM_CPU_IDLE
Len Browndd8af072013-02-09 21:10:04 -05001979 depends on CPU_IDLE
Sam Ravnborge279b6c2007-11-06 20:41:05 +01001980 bool "Make CPU Idle calls when idle"
Ingo Molnar8f9ca472009-02-05 16:21:53 +01001981 ---help---
Sam Ravnborge279b6c2007-11-06 20:41:05 +01001982 Enable calls to APM CPU Idle/CPU Busy inside the kernel's idle loop.
1983 On some machines, this can activate improved power savings, such as
1984 a slowed CPU clock rate, when the machine is idle. These idle calls
1985 are made after the idle loop has run for some length of time (e.g.,
1986 333 mS). On some machines, this will cause a hang at boot time or
1987 whenever the CPU becomes idle. (On machines with more than one CPU,
1988 this option does nothing.)
1989
1990config APM_DISPLAY_BLANK
1991 bool "Enable console blanking using APM"
Ingo Molnar8f9ca472009-02-05 16:21:53 +01001992 ---help---
Sam Ravnborge279b6c2007-11-06 20:41:05 +01001993 Enable console blanking using the APM. Some laptops can use this to
1994 turn off the LCD backlight when the screen blanker of the Linux
1995 virtual console blanks the screen. Note that this is only used by
1996 the virtual console screen blanker, and won't turn off the backlight
1997 when using the X Window system. This also doesn't have anything to
1998 do with your VESA-compliant power-saving monitor. Further, this
1999 option doesn't work for all laptops -- it might not turn off your
2000 backlight at all, or it might print a lot of errors to the console,
2001 especially if you are using gpm.
2002
2003config APM_ALLOW_INTS
2004 bool "Allow interrupts during APM BIOS calls"
Ingo Molnar8f9ca472009-02-05 16:21:53 +01002005 ---help---
Sam Ravnborge279b6c2007-11-06 20:41:05 +01002006 Normally we disable external interrupts while we are making calls to
2007 the APM BIOS as a measure to lessen the effects of a badly behaving
2008 BIOS implementation. The BIOS should reenable interrupts if it
2009 needs to. Unfortunately, some BIOSes do not -- especially those in
2010 many of the newer IBM Thinkpads. If you experience hangs when you
2011 suspend, try setting this to Y. Otherwise, say N.
2012
Sam Ravnborge279b6c2007-11-06 20:41:05 +01002013endif # APM
2014
Dave Jonesbb0a56e2011-05-19 18:51:07 -04002015source "drivers/cpufreq/Kconfig"
Sam Ravnborge279b6c2007-11-06 20:41:05 +01002016
2017source "drivers/cpuidle/Kconfig"
2018
Andy Henroid27471fd2008-10-09 11:45:22 -07002019source "drivers/idle/Kconfig"
2020
Sam Ravnborge279b6c2007-11-06 20:41:05 +01002021endmenu
2022
2023
2024menu "Bus options (PCI etc.)"
2025
2026config PCI
Ingo Molnar1ac97012008-05-19 14:10:14 +02002027 bool "PCI support"
Adrian Bunk1c858082008-01-30 13:32:32 +01002028 default y
Ingo Molnar8f9ca472009-02-05 16:21:53 +01002029 ---help---
Sam Ravnborge279b6c2007-11-06 20:41:05 +01002030 Find out whether you have a PCI motherboard. PCI is the name of a
2031 bus system, i.e. the way the CPU talks to the other stuff inside
2032 your box. Other bus systems are ISA, EISA, MicroChannel (MCA) or
2033 VESA. If you have PCI, say Y, otherwise N.
2034
Sam Ravnborge279b6c2007-11-06 20:41:05 +01002035choice
2036 prompt "PCI access mode"
Ingo Molnarefefa6f2008-07-10 16:09:50 +02002037 depends on X86_32 && PCI
Sam Ravnborge279b6c2007-11-06 20:41:05 +01002038 default PCI_GOANY
2039 ---help---
2040 On PCI systems, the BIOS can be used to detect the PCI devices and
2041 determine their configuration. However, some old PCI motherboards
2042 have BIOS bugs and may crash if this is done. Also, some embedded
2043 PCI-based systems don't have any BIOS at all. Linux can also try to
2044 detect the PCI hardware directly without using the BIOS.
2045
2046 With this option, you can specify how Linux should detect the
2047 PCI devices. If you choose "BIOS", the BIOS will be used,
2048 if you choose "Direct", the BIOS won't be used, and if you
2049 choose "MMConfig", then PCI Express MMCONFIG will be used.
2050 If you choose "Any", the kernel will try MMCONFIG, then the
2051 direct access method and falls back to the BIOS if that doesn't
2052 work. If unsure, go with the default, which is "Any".
2053
2054config PCI_GOBIOS
2055 bool "BIOS"
2056
2057config PCI_GOMMCONFIG
2058 bool "MMConfig"
2059
2060config PCI_GODIRECT
2061 bool "Direct"
2062
Andres Salomon3ef0e1f2008-04-29 00:59:53 -07002063config PCI_GOOLPC
Daniel Drake76fb6572010-09-23 17:28:04 +01002064 bool "OLPC XO-1"
Andres Salomon3ef0e1f2008-04-29 00:59:53 -07002065 depends on OLPC
2066
Andres Salomon2bdd1b02008-06-05 14:14:41 -07002067config PCI_GOANY
2068 bool "Any"
2069
Sam Ravnborge279b6c2007-11-06 20:41:05 +01002070endchoice
2071
2072config PCI_BIOS
Harvey Harrison3c2362e2008-01-30 13:31:03 +01002073 def_bool y
Ingo Molnarefefa6f2008-07-10 16:09:50 +02002074 depends on X86_32 && PCI && (PCI_GOBIOS || PCI_GOANY)
Sam Ravnborge279b6c2007-11-06 20:41:05 +01002075
2076# x86-64 doesn't support PCI BIOS access from long mode so always go direct.
2077config PCI_DIRECT
Harvey Harrison3c2362e2008-01-30 13:31:03 +01002078 def_bool y
Shaohua Li0aba4962011-05-27 14:59:39 +08002079 depends on PCI && (X86_64 || (PCI_GODIRECT || PCI_GOANY || PCI_GOOLPC || PCI_GOMMCONFIG))
Sam Ravnborge279b6c2007-11-06 20:41:05 +01002080
2081config PCI_MMCONFIG
Harvey Harrison3c2362e2008-01-30 13:31:03 +01002082 def_bool y
Feng Tang5f0db7a2009-08-14 15:37:50 -04002083 depends on X86_32 && PCI && (ACPI || SFI) && (PCI_GOMMCONFIG || PCI_GOANY)
Sam Ravnborge279b6c2007-11-06 20:41:05 +01002084
Andres Salomon3ef0e1f2008-04-29 00:59:53 -07002085config PCI_OLPC
Andres Salomon2bdd1b02008-06-05 14:14:41 -07002086 def_bool y
2087 depends on PCI && OLPC && (PCI_GOOLPC || PCI_GOANY)
Andres Salomon3ef0e1f2008-04-29 00:59:53 -07002088
Alex Nixonb5401a92010-03-18 16:31:34 -04002089config PCI_XEN
2090 def_bool y
2091 depends on PCI && XEN
2092 select SWIOTLB_XEN
2093
Sam Ravnborge279b6c2007-11-06 20:41:05 +01002094config PCI_DOMAINS
Harvey Harrison3c2362e2008-01-30 13:31:03 +01002095 def_bool y
Sam Ravnborge279b6c2007-11-06 20:41:05 +01002096 depends on PCI
Sam Ravnborge279b6c2007-11-06 20:41:05 +01002097
2098config PCI_MMCONFIG
2099 bool "Support mmconfig PCI config space access"
2100 depends on X86_64 && PCI && ACPI
2101
Ira W. Snyder3f6ea842010-04-01 11:43:30 -07002102config PCI_CNB20LE_QUIRK
David Rientjes6a108a12011-01-20 14:44:16 -08002103 bool "Read CNB20LE Host Bridge Windows" if EXPERT
Kees Cook6ea30382012-10-02 11:16:47 -07002104 depends on PCI
Ira W. Snyder3f6ea842010-04-01 11:43:30 -07002105 help
2106 Read the PCI windows out of the CNB20LE host bridge. This allows
2107 PCI hotplug to work on systems with the CNB20LE chipset which do
2108 not have ACPI.
2109
Bjorn Helgaas64a5fed2011-01-06 10:12:30 -07002110 There's no public spec for this chipset, and this functionality
2111 is known to be incomplete.
2112
2113 You should say N unless you know you need this.
2114
Sam Ravnborge279b6c2007-11-06 20:41:05 +01002115source "drivers/pci/pcie/Kconfig"
2116
2117source "drivers/pci/Kconfig"
2118
David Rientjes1c00f012011-03-22 16:34:59 -07002119# x86_64 have no ISA slots, but can have ISA-style DMA.
Sam Ravnborge279b6c2007-11-06 20:41:05 +01002120config ISA_DMA_API
David Rientjes1c00f012011-03-22 16:34:59 -07002121 bool "ISA-style DMA support" if (X86_64 && EXPERT)
2122 default y
2123 help
2124 Enables ISA-style DMA support for devices requiring such controllers.
2125 If unsure, say Y.
Sam Ravnborge279b6c2007-11-06 20:41:05 +01002126
2127if X86_32
2128
2129config ISA
2130 bool "ISA support"
Ingo Molnar8f9ca472009-02-05 16:21:53 +01002131 ---help---
Sam Ravnborge279b6c2007-11-06 20:41:05 +01002132 Find out whether you have ISA slots on your motherboard. ISA is the
2133 name of a bus system, i.e. the way the CPU talks to the other stuff
2134 inside your box. Other bus systems are PCI, EISA, MicroChannel
2135 (MCA) or VESA. ISA is an older system, now being displaced by PCI;
2136 newer boards don't support it. If you have ISA, say Y, otherwise N.
2137
2138config EISA
2139 bool "EISA support"
2140 depends on ISA
2141 ---help---
2142 The Extended Industry Standard Architecture (EISA) bus was
2143 developed as an open alternative to the IBM MicroChannel bus.
2144
2145 The EISA bus provided some of the features of the IBM MicroChannel
2146 bus while maintaining backward compatibility with cards made for
2147 the older ISA bus. The EISA bus saw limited use between 1988 and
2148 1995 when it was made obsolete by the PCI bus.
2149
2150 Say Y here if you are building a kernel for an EISA-based machine.
2151
2152 Otherwise, say N.
2153
2154source "drivers/eisa/Kconfig"
2155
Sam Ravnborge279b6c2007-11-06 20:41:05 +01002156config SCx200
2157 tristate "NatSemi SCx200 support"
Ingo Molnar8f9ca472009-02-05 16:21:53 +01002158 ---help---
Sam Ravnborge279b6c2007-11-06 20:41:05 +01002159 This provides basic support for National Semiconductor's
2160 (now AMD's) Geode processors. The driver probes for the
2161 PCI-IDs of several on-chip devices, so its a good dependency
2162 for other scx200_* drivers.
2163
2164 If compiled as a module, the driver is named scx200.
2165
2166config SCx200HR_TIMER
2167 tristate "NatSemi SCx200 27MHz High-Resolution Timer Support"
John Stultz592913e2010-07-13 17:56:20 -07002168 depends on SCx200
Sam Ravnborge279b6c2007-11-06 20:41:05 +01002169 default y
Ingo Molnar8f9ca472009-02-05 16:21:53 +01002170 ---help---
Sam Ravnborge279b6c2007-11-06 20:41:05 +01002171 This driver provides a clocksource built upon the on-chip
2172 27MHz high-resolution timer. Its also a workaround for
2173 NSC Geode SC-1100's buggy TSC, which loses time when the
2174 processor goes idle (as is done by the scheduler). The
2175 other workaround is idle=poll boot option.
2176
Andres Salomon3ef0e1f2008-04-29 00:59:53 -07002177config OLPC
2178 bool "One Laptop Per Child support"
Thomas Gleixner54008972011-02-23 09:50:15 +01002179 depends on !X86_PAE
Andres Salomon3c554942009-12-14 18:00:36 -08002180 select GPIOLIB
Thomas Gleixnerdc3119e72011-02-23 10:08:31 +01002181 select OF
Daniel Drake45bb1672011-03-13 15:10:17 +00002182 select OF_PROMTREE
Grant Likelyb4e51852011-12-16 15:50:17 -07002183 select IRQ_DOMAIN
Ingo Molnar8f9ca472009-02-05 16:21:53 +01002184 ---help---
Andres Salomon3ef0e1f2008-04-29 00:59:53 -07002185 Add support for detecting the unique features of the OLPC
2186 XO hardware.
2187
Daniel Drakea3128582011-06-25 17:34:10 +01002188config OLPC_XO1_PM
2189 bool "OLPC XO-1 Power Management"
Daniel Drake97c4cb72011-06-25 17:34:11 +01002190 depends on OLPC && MFD_CS5535 && PM_SLEEP
Daniel Drakea3128582011-06-25 17:34:10 +01002191 select MFD_CORE
Daniel Drakebf1ebf02010-10-10 10:40:32 +01002192 ---help---
Daniel Drake97c4cb72011-06-25 17:34:11 +01002193 Add support for poweroff and suspend of the OLPC XO-1 laptop.
Daniel Drakebf1ebf02010-10-10 10:40:32 +01002194
Daniel Drakecfee9592011-06-25 17:34:17 +01002195config OLPC_XO1_RTC
2196 bool "OLPC XO-1 Real Time Clock"
2197 depends on OLPC_XO1_PM && RTC_DRV_CMOS
2198 ---help---
2199 Add support for the XO-1 real time clock, which can be used as a
2200 programmable wakeup source.
2201
Daniel Drake7feda8e2011-06-25 17:34:12 +01002202config OLPC_XO1_SCI
2203 bool "OLPC XO-1 SCI extras"
Daniel Draked8d01a62011-07-24 18:33:21 +01002204 depends on OLPC && OLPC_XO1_PM
Randy Dunlaped8e47f2012-12-18 12:22:17 -08002205 depends on INPUT=y
Daniel Draked8d01a62011-07-24 18:33:21 +01002206 select POWER_SUPPLY
Daniel Drake7feda8e2011-06-25 17:34:12 +01002207 select GPIO_CS5535
2208 select MFD_CORE
2209 ---help---
2210 Add support for SCI-based features of the OLPC XO-1 laptop:
Daniel Drake7bc74b32011-06-25 17:34:14 +01002211 - EC-driven system wakeups
Daniel Drake7feda8e2011-06-25 17:34:12 +01002212 - Power button
Daniel Drake7bc74b32011-06-25 17:34:14 +01002213 - Ebook switch
Daniel Drake2cf2bae2011-06-25 17:34:15 +01002214 - Lid switch
Daniel Drakee1040ac2011-06-25 17:34:16 +01002215 - AC adapter status updates
2216 - Battery status updates
Daniel Drake7feda8e2011-06-25 17:34:12 +01002217
Daniel Drakea0f30f52011-06-25 17:34:18 +01002218config OLPC_XO15_SCI
2219 bool "OLPC XO-1.5 SCI extras"
Daniel Draked8d01a62011-07-24 18:33:21 +01002220 depends on OLPC && ACPI
2221 select POWER_SUPPLY
Daniel Drakea0f30f52011-06-25 17:34:18 +01002222 ---help---
2223 Add support for SCI-based features of the OLPC XO-1.5 laptop:
2224 - EC-driven system wakeups
2225 - AC adapter status updates
2226 - Battery status updates
Sam Ravnborge279b6c2007-11-06 20:41:05 +01002227
Ed Wildgoosed4f3e352011-09-20 14:00:12 -07002228config ALIX
2229 bool "PCEngines ALIX System Support (LED setup)"
2230 select GPIOLIB
2231 ---help---
2232 This option enables system support for the PCEngines ALIX.
2233 At present this just sets up LEDs for GPIO control on
2234 ALIX2/3/6 boards. However, other system specific setup should
2235 get added here.
2236
2237 Note: You must still enable the drivers for GPIO and LED support
2238 (GPIO_CS5535 & LEDS_GPIO) to actually use the LEDs
2239
2240 Note: You have to set alix.force=1 for boards with Award BIOS.
2241
Philip Prindevilleda4e3302012-03-05 15:05:15 -08002242config NET5501
2243 bool "Soekris Engineering net5501 System Support (LEDS, GPIO, etc)"
2244 select GPIOLIB
2245 ---help---
2246 This option enables system support for the Soekris Engineering net5501.
2247
Philip A. Prindeville31970592012-01-14 01:45:39 -07002248config GEOS
2249 bool "Traverse Technologies GEOS System Support (LEDS, GPIO, etc)"
2250 select GPIOLIB
2251 depends on DMI
2252 ---help---
2253 This option enables system support for the Traverse Technologies GEOS.
2254
Vivien Didelot7d029122013-01-04 16:18:14 -05002255config TS5500
2256 bool "Technologic Systems TS-5500 platform support"
2257 depends on MELAN
2258 select CHECK_SIGNATURE
2259 select NEW_LEDS
2260 select LEDS_CLASS
2261 ---help---
2262 This option enables system support for the Technologic Systems TS-5500.
2263
Sam Ravnborge279b6c2007-11-06 20:41:05 +01002264endif # X86_32
2265
Andreas Herrmann23ac4ae2010-09-17 18:03:43 +02002266config AMD_NB
Sam Ravnborge279b6c2007-11-06 20:41:05 +01002267 def_bool y
Borislav Petkov0e152cd2010-03-12 15:43:03 +01002268 depends on CPU_SUP_AMD && PCI
Sam Ravnborge279b6c2007-11-06 20:41:05 +01002269
2270source "drivers/pcmcia/Kconfig"
2271
2272source "drivers/pci/hotplug/Kconfig"
2273
Alexandre Bounine388b78a2011-03-23 16:43:03 -07002274config RAPIDIO
Alexandre Bouninefdf90ab2013-07-03 15:08:56 -07002275 tristate "RapidIO support"
Alexandre Bounine388b78a2011-03-23 16:43:03 -07002276 depends on PCI
2277 default n
2278 help
Alexandre Bouninefdf90ab2013-07-03 15:08:56 -07002279 If enabled this option will include drivers and the core
Alexandre Bounine388b78a2011-03-23 16:43:03 -07002280 infrastructure code to support RapidIO interconnect devices.
2281
2282source "drivers/rapidio/Kconfig"
2283
David Herrmanne3263ab2013-08-02 14:05:22 +02002284config X86_SYSFB
2285 bool "Mark VGA/VBE/EFI FB as generic system framebuffer"
2286 help
2287 Firmwares often provide initial graphics framebuffers so the BIOS,
2288 bootloader or kernel can show basic video-output during boot for
2289 user-guidance and debugging. Historically, x86 used the VESA BIOS
2290 Extensions and EFI-framebuffers for this, which are mostly limited
2291 to x86.
2292 This option, if enabled, marks VGA/VBE/EFI framebuffers as generic
2293 framebuffers so the new generic system-framebuffer drivers can be
2294 used on x86. If the framebuffer is not compatible with the generic
2295 modes, it is adverticed as fallback platform framebuffer so legacy
2296 drivers like efifb, vesafb and uvesafb can pick it up.
2297 If this option is not selected, all system framebuffers are always
2298 marked as fallback platform framebuffers as usual.
2299
2300 Note: Legacy fbdev drivers, including vesafb, efifb, uvesafb, will
2301 not be able to pick up generic system framebuffers if this option
2302 is selected. You are highly encouraged to enable simplefb as
2303 replacement if you select this option. simplefb can correctly deal
2304 with generic system framebuffers. But you should still keep vesafb
2305 and others enabled as fallback if a system framebuffer is
2306 incompatible with simplefb.
2307
2308 If unsure, say Y.
2309
Sam Ravnborge279b6c2007-11-06 20:41:05 +01002310endmenu
2311
2312
2313menu "Executable file formats / Emulations"
2314
2315source "fs/Kconfig.binfmt"
2316
2317config IA32_EMULATION
2318 bool "IA32 Emulation"
2319 depends on X86_64
Randy Dunlapd1603992013-06-18 12:33:40 -07002320 select BINFMT_ELF
Roland McGratha97f52e2008-01-30 13:31:55 +01002321 select COMPAT_BINFMT_ELF
Catalin Marinasaf1839e2012-10-08 16:28:08 -07002322 select HAVE_UID16
Ingo Molnar8f9ca472009-02-05 16:21:53 +01002323 ---help---
H. J. Lu5fd92e62012-02-19 10:40:03 -08002324 Include code to run legacy 32-bit programs under a
2325 64-bit kernel. You should likely turn this on, unless you're
2326 100% sure that you don't have any 32-bit programs left.
Sam Ravnborge279b6c2007-11-06 20:41:05 +01002327
2328config IA32_AOUT
Ingo Molnar8f9ca472009-02-05 16:21:53 +01002329 tristate "IA32 a.out support"
2330 depends on IA32_EMULATION
2331 ---help---
2332 Support old a.out binaries in the 32bit emulation.
Sam Ravnborge279b6c2007-11-06 20:41:05 +01002333
H. Peter Anvin0bf62762012-02-27 14:09:10 -08002334config X86_X32
Kees Cook6ea30382012-10-02 11:16:47 -07002335 bool "x32 ABI for 64-bit mode"
2336 depends on X86_64 && IA32_EMULATION
H. J. Lu5fd92e62012-02-19 10:40:03 -08002337 ---help---
2338 Include code to run binaries for the x32 native 32-bit ABI
2339 for 64-bit processors. An x32 process gets access to the
2340 full 64-bit register file and wide data path while leaving
2341 pointers at 32 bits for smaller memory footprint.
2342
2343 You will need a recent binutils (2.22 or later) with
2344 elf32_x86_64 support enabled to compile a kernel with this
2345 option set.
2346
Sam Ravnborge279b6c2007-11-06 20:41:05 +01002347config COMPAT
Harvey Harrison3c2362e2008-01-30 13:31:03 +01002348 def_bool y
H. Peter Anvin0bf62762012-02-27 14:09:10 -08002349 depends on IA32_EMULATION || X86_X32
Chris Metcalf48b25c42012-03-15 13:13:38 -04002350 select ARCH_WANT_OLD_COMPAT_IPC
Sam Ravnborge279b6c2007-11-06 20:41:05 +01002351
Jan Beulich3120e252012-09-10 12:41:45 +01002352if COMPAT
Sam Ravnborge279b6c2007-11-06 20:41:05 +01002353config COMPAT_FOR_U64_ALIGNMENT
Jan Beulich3120e252012-09-10 12:41:45 +01002354 def_bool y
Sam Ravnborge279b6c2007-11-06 20:41:05 +01002355
2356config SYSVIPC_COMPAT
Harvey Harrison3c2362e2008-01-30 13:31:03 +01002357 def_bool y
Jan Beulich3120e252012-09-10 12:41:45 +01002358 depends on SYSVIPC
Sam Ravnborge279b6c2007-11-06 20:41:05 +01002359
David Howellsee009e4a02011-03-07 15:06:20 +00002360config KEYS_COMPAT
Jan Beulich3120e252012-09-10 12:41:45 +01002361 def_bool y
2362 depends on KEYS
2363endif
David Howellsee009e4a02011-03-07 15:06:20 +00002364
Sam Ravnborge279b6c2007-11-06 20:41:05 +01002365endmenu
2366
2367
Keith Packarde5beae12008-11-03 18:21:45 +01002368config HAVE_ATOMIC_IOMAP
2369 def_bool y
2370 depends on X86_32
2371
Alessandro Rubini4692d772012-04-04 19:39:58 +02002372config X86_DEV_DMA_OPS
2373 bool
Alessandro Rubini83125a32012-04-04 19:40:21 +02002374 depends on X86_64 || STA2X11
Alessandro Rubini4692d772012-04-04 19:39:58 +02002375
Alessandro Rubinif7219a52012-04-04 19:40:10 +02002376config X86_DMA_REMAP
2377 bool
Alessandro Rubini83125a32012-04-04 19:40:21 +02002378 depends on STA2X11
Alessandro Rubinif7219a52012-04-04 19:40:10 +02002379
Sam Ravnborge279b6c2007-11-06 20:41:05 +01002380source "net/Kconfig"
2381
2382source "drivers/Kconfig"
2383
2384source "drivers/firmware/Kconfig"
2385
2386source "fs/Kconfig"
2387
Sam Ravnborge279b6c2007-11-06 20:41:05 +01002388source "arch/x86/Kconfig.debug"
2389
2390source "security/Kconfig"
2391
2392source "crypto/Kconfig"
2393
Avi Kivityedf88412007-12-16 11:02:48 +02002394source "arch/x86/kvm/Kconfig"
2395
Sam Ravnborge279b6c2007-11-06 20:41:05 +01002396source "lib/Kconfig"